mirror of
https://github.com/Ryujinx/Opentk.git
synced 2025-01-25 23:01:01 +00:00
Applied Jonathan's patch for output directories.
This commit is contained in:
parent
fba220efae
commit
beac0d41d1
|
@ -11,19 +11,21 @@ namespace Bind.ES
|
||||||
{
|
{
|
||||||
class ESGenerator : Generator
|
class ESGenerator : Generator
|
||||||
{
|
{
|
||||||
public ESGenerator(string name)
|
public ESGenerator(string nsName, string dirName)
|
||||||
{
|
{
|
||||||
if (String.IsNullOrEmpty(name))
|
if (String.IsNullOrEmpty(nsName))
|
||||||
throw new ArgumentNullException("name");
|
throw new ArgumentNullException("nsName");
|
||||||
|
if (dirName == null)
|
||||||
|
dirName = nsName;
|
||||||
|
|
||||||
glTypemap = "GL2/gl.tm";
|
glTypemap = "GL2/gl.tm";
|
||||||
csTypemap = "csharp.tm";
|
csTypemap = "csharp.tm";
|
||||||
|
|
||||||
enumSpec = name + "/signatures.xml";
|
enumSpec = dirName + "/signatures.xml";
|
||||||
enumSpecExt = String.Empty;
|
enumSpecExt = String.Empty;
|
||||||
glSpec = name + "/signatures.xml";
|
glSpec = dirName + "/signatures.xml";
|
||||||
glSpecExt = String.Empty;
|
glSpecExt = String.Empty;
|
||||||
functionOverridesFile = name + "/overrides.xml";
|
functionOverridesFile = dirName + "/overrides.xml";
|
||||||
|
|
||||||
importsFile = "Core.cs";
|
importsFile = "Core.cs";
|
||||||
delegatesFile = "Delegates.cs";
|
delegatesFile = "Delegates.cs";
|
||||||
|
@ -33,8 +35,8 @@ namespace Bind.ES
|
||||||
Settings.DelegatesClass = "Delegates";
|
Settings.DelegatesClass = "Delegates";
|
||||||
|
|
||||||
Settings.OutputClass = "ES";
|
Settings.OutputClass = "ES";
|
||||||
Settings.OutputNamespace = "OpenTK.Graphics." + name;
|
Settings.OutputNamespace = "OpenTK.Graphics." + nsName;
|
||||||
Settings.OutputPath = Path.Combine(Directory.GetParent(Settings.OutputPath).FullName, name);
|
Settings.OutputPath = Path.Combine(Settings.OutputPath, dirName);
|
||||||
}
|
}
|
||||||
|
|
||||||
public override DelegateCollection ReadDelegates(StreamReader specFile)
|
public override DelegateCollection ReadDelegates(StreamReader specFile)
|
||||||
|
@ -42,7 +44,7 @@ namespace Bind.ES
|
||||||
DelegateCollection delegates = new DelegateCollection();
|
DelegateCollection delegates = new DelegateCollection();
|
||||||
|
|
||||||
XPathDocument overrides = new XPathDocument(new StreamReader(Path.Combine(Settings.InputPath, functionOverridesFile)));
|
XPathDocument overrides = new XPathDocument(new StreamReader(Path.Combine(Settings.InputPath, functionOverridesFile)));
|
||||||
|
|
||||||
XPathNavigator nav = new XPathDocument(specFile).CreateNavigator().SelectSingleNode("/signatures");
|
XPathNavigator nav = new XPathDocument(specFile).CreateNavigator().SelectSingleNode("/signatures");
|
||||||
|
|
||||||
foreach (XPathNavigator node in nav.SelectChildren("function", String.Empty))
|
foreach (XPathNavigator node in nav.SelectChildren("function", String.Empty))
|
||||||
|
|
|
@ -6,6 +6,8 @@
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using System.Security;
|
using System.Security;
|
||||||
using Bind.CL;
|
using Bind.CL;
|
||||||
|
@ -49,6 +51,8 @@ namespace Bind
|
||||||
//Console.WriteLine(" - the OpenTK team ;-)");
|
//Console.WriteLine(" - the OpenTK team ;-)");
|
||||||
Console.WriteLine();
|
Console.WriteLine();
|
||||||
|
|
||||||
|
string dirName = null;
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
foreach (string a in arguments)
|
foreach (string a in arguments)
|
||||||
|
@ -64,11 +68,11 @@ namespace Bind
|
||||||
return;
|
return;
|
||||||
case "in":
|
case "in":
|
||||||
case "input":
|
case "input":
|
||||||
Settings.InputPath = b[1];
|
Settings.InputPath = string.Join(Path.DirectorySeparatorChar.ToString(), b.Skip(1).ToArray());
|
||||||
break;
|
break;
|
||||||
case "out":
|
case "out":
|
||||||
case "output":
|
case "output":
|
||||||
Settings.OutputPath = b[1];
|
Settings.OutputPath = string.Join(Path.DirectorySeparatorChar.ToString(), b.Skip(1).ToArray());
|
||||||
break;
|
break;
|
||||||
case "mode":
|
case "mode":
|
||||||
string arg = b[1].ToLower();
|
string arg = b[1].ToLower();
|
||||||
|
@ -84,6 +88,8 @@ namespace Bind
|
||||||
mode = GeneratorMode.CL10;
|
mode = GeneratorMode.CL10;
|
||||||
else
|
else
|
||||||
throw new NotImplementedException();
|
throw new NotImplementedException();
|
||||||
|
if (b.Length > 1)
|
||||||
|
dirName = b[2];
|
||||||
break;
|
break;
|
||||||
case "namespace":
|
case "namespace":
|
||||||
case "ns":
|
case "ns":
|
||||||
|
@ -104,6 +110,7 @@ namespace Bind
|
||||||
//Settings.Compatibility |= b[1].ToLower().Contains("novoid") ? Settings.Legacy.TurnVoidPointersToIntPtr : Settings.Legacy.None;
|
//Settings.Compatibility |= b[1].ToLower().Contains("novoid") ? Settings.Legacy.TurnVoidPointersToIntPtr : Settings.Legacy.None;
|
||||||
Settings.Compatibility |= b[1].ToLower().Contains("permutations") ? Settings.Legacy.GenerateAllPermutations : Settings.Legacy.None;
|
Settings.Compatibility |= b[1].ToLower().Contains("permutations") ? Settings.Legacy.GenerateAllPermutations : Settings.Legacy.None;
|
||||||
Settings.Compatibility |= b[1].ToLower().Contains("enums_in_class") ? Settings.Legacy.NestedEnums : Settings.Legacy.None;
|
Settings.Compatibility |= b[1].ToLower().Contains("enums_in_class") ? Settings.Legacy.NestedEnums : Settings.Legacy.None;
|
||||||
|
Settings.Compatibility |= b[1].ToLower().Contains("nodocs") ? Settings.Legacy.NoDocumentation : Settings.Legacy.None;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
throw new ArgumentException(
|
throw new ArgumentException(
|
||||||
|
@ -135,15 +142,15 @@ namespace Bind
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case GeneratorMode.ES10:
|
case GeneratorMode.ES10:
|
||||||
Generator = new ESGenerator("ES10");
|
Generator = new ESGenerator("ES10", dirName);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case GeneratorMode.ES11:
|
case GeneratorMode.ES11:
|
||||||
Generator = new ESGenerator("ES11");
|
Generator = new ESGenerator("ES11", dirName);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case GeneratorMode.ES20:
|
case GeneratorMode.ES20:
|
||||||
Generator = new ESGenerator("ES20");
|
Generator = new ESGenerator("ES20", dirName);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case GeneratorMode.CL10:
|
case GeneratorMode.CL10:
|
||||||
|
@ -164,12 +171,12 @@ namespace Bind
|
||||||
|
|
||||||
case GeneratorMode.GL3:
|
case GeneratorMode.GL3:
|
||||||
throw new NotImplementedException(String.Format("Mode {0} not implemented.", mode));
|
throw new NotImplementedException(String.Format("Mode {0} not implemented.", mode));
|
||||||
|
|
||||||
case GeneratorMode.Unknown:
|
case GeneratorMode.Unknown:
|
||||||
default:
|
default:
|
||||||
Console.WriteLine("Please specify a generator mode (use '-mode:gl2/gl3/glu/wgl/glx])'");
|
Console.WriteLine("Please specify a generator mode (use '-mode:gl2/gl3/glu/wgl/glx])'");
|
||||||
return;
|
return;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Generator.Process();
|
Generator.Process();
|
||||||
|
@ -190,11 +197,6 @@ namespace Bind
|
||||||
Console.WriteLine(e.Message);
|
Console.WriteLine(e.Message);
|
||||||
Console.WriteLine("The requested functionality is not implemented yet.");
|
Console.WriteLine("The requested functionality is not implemented yet.");
|
||||||
}
|
}
|
||||||
finally
|
|
||||||
{
|
|
||||||
Console.WriteLine("Press any key to continue...");
|
|
||||||
Console.ReadKey(true);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void ShowHelp()
|
private static void ShowHelp()
|
||||||
|
|
Loading…
Reference in a new issue