Create convenience overloads based on wrappers, not entry points

It makes sense to generate convenience overloads for each relevant
wrapper function, instead of each entry point. This way, we generate
convenience overloads for every wrapper in overrides.xml (even wrappers
for background compatibility), which would otherwise be ignored.
This commit is contained in:
Stefanos A 2013-12-08 16:19:46 +01:00
parent 94c405b6aa
commit cc25916f14

View file

@ -85,7 +85,6 @@ namespace Bind
foreach (var d in signatures) foreach (var d in signatures)
{ {
var replace = GetFuncOverride(nav, d, apiname, apiversion); var replace = GetFuncOverride(nav, d, apiname, apiversion);
TranslateExtension(d); TranslateExtension(d);
TranslateReturnType(d, replace, nav, enum_processor, enums, apiname, version); TranslateReturnType(d, replace, nav, enum_processor, enums, apiname, version);
TranslateParameters(d, replace, nav, enum_processor, enums, apiname, version); TranslateParameters(d, replace, nav, enum_processor, enums, apiname, version);
@ -114,12 +113,12 @@ namespace Bind
} }
} }
Console.WriteLine("Generating convenience overloads.");
delegates.AddRange(CreateConvenienceOverloads(delegates));
Console.WriteLine("Generating wrappers."); Console.WriteLine("Generating wrappers.");
var wrappers = CreateWrappers(delegates, enums); var wrappers = CreateWrappers(delegates, enums);
Console.WriteLine("Generating convenience overloads.");
wrappers.AddRange(CreateConvenienceOverloads(wrappers));
Console.WriteLine("Generating CLS compliant overloads."); Console.WriteLine("Generating CLS compliant overloads.");
wrappers = CreateCLSCompliantWrappers(wrappers, enums); wrappers = CreateCLSCompliantWrappers(wrappers, enums);
@ -387,16 +386,6 @@ namespace Bind
} }
} }
// If we have a convenience overload, we should turn the name from
// plural into singular
if (d.ReturnType.WrapperType == WrapperTypes.ConvenienceReturnType ||
d.ReturnType.WrapperType == WrapperTypes.ConvenienceArrayReturnType ||
d.Parameters.Any(p => p.WrapperType == WrapperTypes.ConvenienceArrayType))
{
trimmed_name = trimmed_name.Replace("Queries", "Query");
trimmed_name = trimmed_name.TrimEnd('s');
}
return trimmed_name; return trimmed_name;
} }
@ -851,17 +840,17 @@ namespace Bind
} }
} }
IEnumerable<Delegate> CreateConvenienceOverloads(DelegateCollection delegates) IEnumerable<Function> CreateConvenienceOverloads(FunctionCollection wrappers)
{ {
foreach (var list in delegates.Values) var convenience_wrappers = new List<Function>();
foreach (var d in wrappers.Values.SelectMany(w => w))
{ {
var d = list.First();
if (d.Parameters.Count > 0 && d.Parameters.Count <= 2) if (d.Parameters.Count > 0 && d.Parameters.Count <= 2)
{ {
var p = d.Parameters.Last(); var p = d.Parameters.Last();
var r = d.ReturnType; var r = d.ReturnType;
var name = GetTrimmedName(d); var name = d.Name;
bool is_candidate = true; bool is_candidate = true;
is_candidate &= is_candidate &=
@ -874,28 +863,41 @@ namespace Bind
is_candidate &= p.ElementCount == 0 || p.ElementCount == 1; is_candidate &= p.ElementCount == 0 || p.ElementCount == 1;
is_candidate &= r.CurrentType == "void" && r.Pointer == 0; is_candidate &= r.CurrentType == "void" && r.Pointer == 0;
Function f = null;
if (is_candidate && p.Flow == FlowDirection.Out) if (is_candidate && p.Flow == FlowDirection.Out)
{ {
// Match Gen*|Get*|New*([Out] int[] names) methods // Match Gen*|Get*|New*([Out] int[] names) methods
var f = CreateReturnTypeConvenienceWrapper(d); f = CreateReturnTypeConvenienceWrapper(d);
yield return f;
} }
else if (is_candidate && p.Flow != FlowDirection.Out) else if (is_candidate && p.Flow != FlowDirection.Out)
{ {
// Match *Delete(int count, int[] names) methods // Match *Delete(int count, int[] names) methods
if (d.Parameters.Count == 2) if (d.Parameters.Count == 2)
{ {
var f = CreateArrayReturnTypeConvencienceWrapper(d); f = CreateArrayReturnTypeConvenienceWrapper(d);
yield return f;
} }
} }
if (f != null)
{
// If we have a convenience overload, we should turn its name from
// plural into singular
if (f.ReturnType.WrapperType == WrapperTypes.ConvenienceReturnType ||
f.ReturnType.WrapperType == WrapperTypes.ConvenienceArrayReturnType ||
f.Parameters.Any(t => t.WrapperType == WrapperTypes.ConvenienceArrayType))
{
f.TrimmedName = f.TrimmedName.Replace("Queries", "Query").TrimEnd('s');
}
convenience_wrappers.Add(f);
}
} }
} }
return convenience_wrappers;
} }
static Delegate CreateReturnTypeConvenienceWrapper(Delegate d) static Function CreateReturnTypeConvenienceWrapper(Function d)
{ {
var f = new Delegate(d); var f = new Function(d);
f.ReturnType = new Type(f.Parameters.Last()); f.ReturnType = new Type(f.Parameters.Last());
f.ReturnType.Pointer = 0; f.ReturnType.Pointer = 0;
f.Parameters.RemoveAt(f.Parameters.Count - 1); f.Parameters.RemoveAt(f.Parameters.Count - 1);
@ -913,9 +915,9 @@ namespace Bind
return f; return f;
} }
static Delegate CreateArrayReturnTypeConvencienceWrapper(Delegate d) static Function CreateArrayReturnTypeConvenienceWrapper(Function d)
{ {
var f = new Delegate(d); var f = new Function(d);
var p_array = f.Parameters.Last(); var p_array = f.Parameters.Last();
var p_size = f.Parameters[f.Parameters.Count - 2]; var p_size = f.Parameters[f.Parameters.Count - 2];
f.Parameters.RemoveAt(f.Parameters.Count - 2); f.Parameters.RemoveAt(f.Parameters.Count - 2);