Type, Parameter, ParameterCollection and Function classes now implement IComparable directly (rather than casting to strings and comparing those).

Modified comparison order to place pointer overloads after reference or array overloads. Fixes issue [#1098]: "[Bind] Work around VS bug by ensuring pointer parameters are generated last".
This commit is contained in:
the_fiddler 2009-11-17 09:26:05 +00:00
parent 3aa67b84a3
commit 97b3cd2e93
5 changed files with 28105 additions and 28044 deletions

View file

@ -608,9 +608,9 @@ namespace Bind.Structures
{ {
int ret = Name.CompareTo(other.Name); int ret = Name.CompareTo(other.Name);
if (ret == 0) if (ret == 0)
ret = Parameters.ToString().CompareTo(other.Parameters.ToString()); ret = Parameters.CompareTo(other.Parameters);
if (ret == 0) if (ret == 0)
ret = ReturnType.ToString().CompareTo(other.ReturnType.ToString()); ret = ReturnType.CompareTo(other.ReturnType);
return ret; return ret;
} }

View file

@ -15,7 +15,7 @@ namespace Bind.Structures
/// <summary> /// <summary>
/// Represents a single parameter of an opengl function. /// Represents a single parameter of an opengl function.
/// </summary> /// </summary>
public class Parameter : Type public class Parameter : Type, IComparable<Parameter>
{ {
string cache; string cache;
bool rebuild; bool rebuild;
@ -350,12 +350,24 @@ namespace Bind.Structures
} }
#endregion #endregion
#region IComparable<Parameter> Members
public int CompareTo(Parameter other)
{
int result = base.CompareTo(other);
if (result == 0)
result = Name.CompareTo(other.Name);
return result;
}
#endregion
} }
/// <summary> /// <summary>
/// Holds the parameter list of an opengl function. /// Holds the parameter list of an opengl function.
/// </summary> /// </summary>
public class ParameterCollection : List<Parameter> public class ParameterCollection : List<Parameter>, IComparable<ParameterCollection>
{ {
string cache = String.Empty; string cache = String.Empty;
string callStringCache = String.Empty; string callStringCache = String.Empty;
@ -642,5 +654,31 @@ namespace Bind.Structures
return true; return true;
return false; return false;
} }
#region IComparable<ParameterCollection> Members
public int CompareTo(ParameterCollection other)
{
if (Count < other.Count)
{
return -1;
}
else if (Count > other.Count)
{
return 1;
}
else
{
for (int i = 0; i < Count; i++)
{
int result = this[i].CompareTo(other[i]);
if (result != 0)
return result;
}
return 0;
}
}
#endregion
} }
} }

View file

@ -11,7 +11,7 @@ using System.Xml.XPath;
namespace Bind.Structures namespace Bind.Structures
{ {
public class Type public class Type : IComparable<Type>
{ {
internal static Dictionary<string, string> GLTypes; internal static Dictionary<string, string> GLTypes;
internal static Dictionary<string, string> CSTypes; internal static Dictionary<string, string> CSTypes;
@ -461,5 +461,28 @@ namespace Bind.Structures
} }
#endregion #endregion
#region IComparable<Type> Members
public int CompareTo(Type other)
{
// Make sure that Pointer parameters are sorted last to avoid bug [#1098].
// The rest of the comparisons are not important, but they are there to
// guarantee a stable order between program executions.
int result = this.CurrentType.CompareTo(other.CurrentType);
if (result == 0)
result = Pointer.CompareTo(other.Pointer);
if (result == 0)
result = Reference.CompareTo(other.Reference);
if (result == 0)
result = Array.CompareTo(other.Array);
if (result == 0)
result = CLSCompliant.CompareTo(other.CLSCompliant);
if (result == 0)
result = ElementCount.CompareTo(other.ElementCount);
return result;
}
#endregion
} }
} }

File diff suppressed because it is too large Load diff

File diff suppressed because it is too large Load diff