mirror of
https://github.com/Ryujinx/Opentk.git
synced 2025-01-23 06:51:04 +00:00
Simplified the ISpecReader interface. Ensure 'delete' directives are followed in the xml specs.
This commit is contained in:
parent
772e987c2b
commit
85a774c902
|
@ -58,6 +58,10 @@ namespace Bind.GL2
|
||||||
Settings.DelegatesFile = "GLDelegates.cs";
|
Settings.DelegatesFile = "GLDelegates.cs";
|
||||||
Settings.EnumsFile = "GLEnums.cs";
|
Settings.EnumsFile = "GLEnums.cs";
|
||||||
Settings.WrappersFile = "GL.cs";
|
Settings.WrappersFile = "GL.cs";
|
||||||
|
|
||||||
|
Delegates = new DelegateCollection();
|
||||||
|
Enums = new EnumCollection();
|
||||||
|
Wrappers = new FunctionCollection();
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
@ -73,10 +77,10 @@ namespace Bind.GL2
|
||||||
string overrides = Path.Combine(Settings.InputPath, Settings.OverridesFile);
|
string overrides = Path.Combine(Settings.InputPath, Settings.OverridesFile);
|
||||||
Type.GLTypes = SpecReader.ReadTypeMap(Path.Combine(Settings.InputPath, glTypemap));
|
Type.GLTypes = SpecReader.ReadTypeMap(Path.Combine(Settings.InputPath, glTypemap));
|
||||||
Type.CSTypes = SpecReader.ReadCSTypeMap(Path.Combine(Settings.InputPath, csTypemap));
|
Type.CSTypes = SpecReader.ReadCSTypeMap(Path.Combine(Settings.InputPath, csTypemap));
|
||||||
Enums = SpecReader.ReadEnums(Path.Combine(Settings.InputPath, enumSpec));
|
SpecReader.ReadEnums(Path.Combine(Settings.InputPath, enumSpec), Enums);
|
||||||
Utilities.Merge(Enums, SpecReader.ReadEnums(overrides));
|
SpecReader.ReadEnums(overrides, Enums);
|
||||||
Delegates = SpecReader.ReadDelegates(Path.Combine(Settings.InputPath, glSpec));
|
SpecReader.ReadDelegates(Path.Combine(Settings.InputPath, glSpec), Delegates);
|
||||||
Utilities.Merge(Delegates, SpecReader.ReadDelegates(overrides));
|
SpecReader.ReadDelegates(overrides, Delegates);
|
||||||
|
|
||||||
Enums = new EnumProcessor(overrides).Process(Enums);
|
Enums = new EnumProcessor(overrides).Process(Enums);
|
||||||
Wrappers = new FuncProcessor(overrides).Process(Delegates, Enums);
|
Wrappers = new FuncProcessor(overrides).Process(Delegates, Enums);
|
||||||
|
|
|
@ -12,8 +12,8 @@ namespace Bind
|
||||||
{
|
{
|
||||||
interface ISpecReader
|
interface ISpecReader
|
||||||
{
|
{
|
||||||
DelegateCollection ReadDelegates(string file);
|
void ReadDelegates(string file, DelegateCollection delegates);
|
||||||
EnumCollection ReadEnums(string file);
|
void ReadEnums(string file, EnumCollection enums);
|
||||||
Dictionary<string, string> ReadTypeMap(string file);
|
Dictionary<string, string> ReadTypeMap(string file);
|
||||||
Dictionary<string, string> ReadCSTypeMap(string file);
|
Dictionary<string, string> ReadCSTypeMap(string file);
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,9 +40,23 @@ namespace Bind
|
||||||
|
|
||||||
class XmlSpecReader : ISpecReader
|
class XmlSpecReader : ISpecReader
|
||||||
{
|
{
|
||||||
#region Public Members
|
#region ISpecReader Members
|
||||||
|
|
||||||
public DelegateCollection ReadDelegates(XPathNavigator specs)
|
public void ReadDelegates(string file, DelegateCollection delegates)
|
||||||
|
{
|
||||||
|
var specs = new XPathDocument(file);
|
||||||
|
foreach (XPathNavigator nav in specs.CreateNavigator().Select("/signatures/delete"))
|
||||||
|
{
|
||||||
|
foreach (XPathNavigator node in nav.SelectChildren("function", String.Empty))
|
||||||
|
delegates.Remove(node.GetAttribute("name", String.Empty));
|
||||||
|
}
|
||||||
|
foreach (XPathNavigator nav in specs.CreateNavigator().Select("/signatures/add"))
|
||||||
|
{
|
||||||
|
Utilities.Merge(delegates, ReadDelegates(nav));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private DelegateCollection ReadDelegates(XPathNavigator specs)
|
||||||
{
|
{
|
||||||
DelegateCollection delegates = new DelegateCollection();
|
DelegateCollection delegates = new DelegateCollection();
|
||||||
|
|
||||||
|
@ -98,15 +112,101 @@ namespace Bind
|
||||||
return delegates;
|
return delegates;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
public void ReadEnums(string file, EnumCollection enums)
|
||||||
|
|
||||||
#region ISpecReader Members
|
|
||||||
|
|
||||||
public DelegateCollection ReadDelegates(string file)
|
|
||||||
{
|
{
|
||||||
|
// First, read all enum definitions from spec and override file.
|
||||||
|
// Afterwards, read all token/enum overrides from overrides file.
|
||||||
|
// Every single enum is merged into
|
||||||
|
|
||||||
var specs = new XPathDocument(file);
|
var specs = new XPathDocument(file);
|
||||||
var delegates = ReadDelegates(specs.CreateNavigator().SelectSingleNode("/signatures/add"));
|
foreach (XPathNavigator nav in specs.CreateNavigator().Select("/signatures/delete"))
|
||||||
return delegates;
|
{
|
||||||
|
foreach (XPathNavigator node in nav.SelectChildren("enum", String.Empty))
|
||||||
|
enums.Remove(node.GetAttribute("name", String.Empty));
|
||||||
|
}
|
||||||
|
foreach (XPathNavigator nav in specs.CreateNavigator().Select("/signatures/add"))
|
||||||
|
{
|
||||||
|
Utilities.Merge(enums, ReadEnums(nav));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private EnumCollection ReadEnums(XPathNavigator nav)
|
||||||
|
{
|
||||||
|
EnumCollection enums = new EnumCollection();
|
||||||
|
Enum all = new Enum() { Name = Settings.CompleteEnumName };
|
||||||
|
|
||||||
|
if (nav != null)
|
||||||
|
{
|
||||||
|
foreach (XPathNavigator node in nav.SelectChildren("enum", String.Empty))
|
||||||
|
{
|
||||||
|
Enum e = new Enum()
|
||||||
|
{
|
||||||
|
Name = node.GetAttribute("name", String.Empty),
|
||||||
|
Type = node.GetAttribute("type", String.Empty)
|
||||||
|
};
|
||||||
|
if (String.IsNullOrEmpty(e.Name))
|
||||||
|
throw new InvalidOperationException(String.Format("Empty name for enum element {0}", node.ToString()));
|
||||||
|
|
||||||
|
foreach (XPathNavigator param in node.SelectChildren(XPathNodeType.Element))
|
||||||
|
{
|
||||||
|
Constant c = null;
|
||||||
|
switch (param.Name)
|
||||||
|
{
|
||||||
|
case "token":
|
||||||
|
c = new Constant
|
||||||
|
{
|
||||||
|
Name = param.GetAttribute("name", String.Empty),
|
||||||
|
Value = param.GetAttribute("value", String.Empty)
|
||||||
|
};
|
||||||
|
break;
|
||||||
|
|
||||||
|
case "use":
|
||||||
|
c = new Constant
|
||||||
|
{
|
||||||
|
Name = param.GetAttribute("token", String.Empty),
|
||||||
|
Reference = param.GetAttribute("enum", String.Empty),
|
||||||
|
Value = param.GetAttribute("token", String.Empty),
|
||||||
|
};
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
throw new NotSupportedException();
|
||||||
|
}
|
||||||
|
Utilities.Merge(all, c);
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if (!e.ConstantCollection.ContainsKey(c.Name))
|
||||||
|
{
|
||||||
|
e.ConstantCollection.Add(c.Name, c);
|
||||||
|
}
|
||||||
|
else if (e.ConstantCollection[c.Name].Value != c.Value)
|
||||||
|
{
|
||||||
|
var existing = e.ConstantCollection[c.Name];
|
||||||
|
if (existing.Reference != null && c.Reference == null)
|
||||||
|
{
|
||||||
|
e.ConstantCollection[c.Name] = c;
|
||||||
|
}
|
||||||
|
else if (existing.Reference == null && c.Reference != null)
|
||||||
|
{ } // Keep existing
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Console.WriteLine("[Warning] Conflicting token {0}.{1} with value {2} != {3}",
|
||||||
|
e.Name, c.Name, e.ConstantCollection[c.Name].Value, c.Value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (ArgumentException ex)
|
||||||
|
{
|
||||||
|
Console.WriteLine("[Warning] Failed to add constant {0} to enum {1}: {2}", c.Name, e.Name, ex.Message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Utilities.Merge(enums, e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Utilities.Merge(enums, all);
|
||||||
|
return enums;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Dictionary<string, string> ReadTypeMap(string file)
|
public Dictionary<string, string> ReadTypeMap(string file)
|
||||||
|
@ -200,102 +300,6 @@ namespace Bind
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public EnumCollection ReadEnums(string file)
|
|
||||||
{
|
|
||||||
// First, read all enum definitions from spec and override file.
|
|
||||||
// Afterwards, read all token/enum overrides from overrides file.
|
|
||||||
// Every single enum is merged into
|
|
||||||
|
|
||||||
EnumCollection enums = new EnumCollection();
|
|
||||||
var specs = new XPathDocument(file);
|
|
||||||
foreach (XPathNavigator nav in specs.CreateNavigator().Select("/signatures/add"))
|
|
||||||
{
|
|
||||||
var new_enums = ReadEnums(nav);
|
|
||||||
Utilities.Merge(enums, new_enums);
|
|
||||||
}
|
|
||||||
|
|
||||||
return enums;
|
|
||||||
}
|
|
||||||
|
|
||||||
public EnumCollection ReadEnums(XPathNavigator nav)
|
|
||||||
{
|
|
||||||
EnumCollection enums = new EnumCollection();
|
|
||||||
Enum all = new Enum() { Name = Settings.CompleteEnumName };
|
|
||||||
|
|
||||||
if (nav != null)
|
|
||||||
{
|
|
||||||
foreach (XPathNavigator node in nav.SelectChildren("enum", String.Empty))
|
|
||||||
{
|
|
||||||
Enum e = new Enum()
|
|
||||||
{
|
|
||||||
Name = node.GetAttribute("name", String.Empty),
|
|
||||||
Type = node.GetAttribute("type", String.Empty)
|
|
||||||
};
|
|
||||||
if (String.IsNullOrEmpty(e.Name))
|
|
||||||
throw new InvalidOperationException(String.Format("Empty name for enum element {0}", node.ToString()));
|
|
||||||
|
|
||||||
foreach (XPathNavigator param in node.SelectChildren(XPathNodeType.Element))
|
|
||||||
{
|
|
||||||
Constant c = null;
|
|
||||||
switch (param.Name)
|
|
||||||
{
|
|
||||||
case "token":
|
|
||||||
c = new Constant
|
|
||||||
{
|
|
||||||
Name = param.GetAttribute("name", String.Empty),
|
|
||||||
Value = param.GetAttribute("value", String.Empty)
|
|
||||||
};
|
|
||||||
break;
|
|
||||||
|
|
||||||
case "use":
|
|
||||||
c = new Constant
|
|
||||||
{
|
|
||||||
Name = param.GetAttribute("token", String.Empty),
|
|
||||||
Reference = param.GetAttribute("enum", String.Empty),
|
|
||||||
Value = param.GetAttribute("token", String.Empty),
|
|
||||||
};
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
throw new NotSupportedException();
|
|
||||||
}
|
|
||||||
Utilities.Merge(all, c);
|
|
||||||
try
|
|
||||||
{
|
|
||||||
if (!e.ConstantCollection.ContainsKey(c.Name))
|
|
||||||
{
|
|
||||||
e.ConstantCollection.Add(c.Name, c);
|
|
||||||
}
|
|
||||||
else if (e.ConstantCollection[c.Name].Value != c.Value)
|
|
||||||
{
|
|
||||||
var existing = e.ConstantCollection[c.Name];
|
|
||||||
if (existing.Reference != null && c.Reference == null)
|
|
||||||
{
|
|
||||||
e.ConstantCollection[c.Name] = c;
|
|
||||||
}
|
|
||||||
else if (existing.Reference == null && c.Reference != null)
|
|
||||||
{ } // Keep existing
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Console.WriteLine("[Warning] Conflicting token {0}.{1} with value {2} != {3}",
|
|
||||||
e.Name, c.Name, e.ConstantCollection[c.Name].Value, c.Value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (ArgumentException ex)
|
|
||||||
{
|
|
||||||
Console.WriteLine("[Warning] Failed to add constant {0} to enum {1}: {2}", c.Name, e.Name, ex.Message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Utilities.Merge(enums, e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Utilities.Merge(enums, all);
|
|
||||||
return enums;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue