mirror of
https://github.com/Ryujinx/Opentk.git
synced 2025-01-26 07:11:15 +00:00
Added translation code to follow the .Net naming conventions.
This commit is contained in:
parent
4f21d69dc9
commit
9364a4af10
|
@ -18,7 +18,11 @@ namespace Bind.Structures
|
||||||
internal static EnumCollection GLEnums;
|
internal static EnumCollection GLEnums;
|
||||||
internal static EnumCollection AuxEnums;
|
internal static EnumCollection AuxEnums;
|
||||||
|
|
||||||
private static bool enumsLoaded;
|
static StringBuilder translator = new StringBuilder();
|
||||||
|
string _name;
|
||||||
|
static bool enumsLoaded;
|
||||||
|
|
||||||
|
#region Initialize
|
||||||
|
|
||||||
internal static void Initialize(string enumFile, string enumextFile, string auxFile)
|
internal static void Initialize(string enumFile, string enumextFile, string auxFile)
|
||||||
{
|
{
|
||||||
|
@ -57,6 +61,9 @@ namespace Bind.Structures
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region Constructors
|
||||||
|
|
||||||
public Enum()
|
public Enum()
|
||||||
{ }
|
{ }
|
||||||
|
@ -66,7 +73,7 @@ namespace Bind.Structures
|
||||||
Name = name;
|
Name = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
string _name;
|
#endregion
|
||||||
|
|
||||||
public string Name
|
public string Name
|
||||||
{
|
{
|
||||||
|
@ -79,7 +86,43 @@ namespace Bind.Structures
|
||||||
public System.Collections.Hashtable ConstantCollection
|
public System.Collections.Hashtable ConstantCollection
|
||||||
{
|
{
|
||||||
get { return _constant_collection; }
|
get { return _constant_collection; }
|
||||||
set { _constant_collection = value; }
|
//set { _constant_collection = value; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public static string TranslateName(string name)
|
||||||
|
{
|
||||||
|
translator.Remove(0, translator.Length); // Trick to avoid allocating a new StringBuilder.
|
||||||
|
|
||||||
|
// Translate the constant's name to match .Net naming conventions
|
||||||
|
if ((Settings.Compatibility & Settings.Legacy.NoAdvancedEnumProcessing) == Settings.Legacy.None)
|
||||||
|
{
|
||||||
|
bool is_after_underscore = true; // Detect if we just passed a '_' and make the next char
|
||||||
|
// uppercase.
|
||||||
|
bool is_previous_uppercase = false; // Detetc if previous character was uppercase, and turn
|
||||||
|
// the current one to lowercase.
|
||||||
|
|
||||||
|
foreach (char c in name)
|
||||||
|
{
|
||||||
|
char char_to_add;
|
||||||
|
if (c != '_')
|
||||||
|
{
|
||||||
|
char_to_add = is_after_underscore ? Char.ToUpper(c) :
|
||||||
|
is_previous_uppercase ? Char.ToLower(c) : c;
|
||||||
|
is_previous_uppercase = Char.IsUpper(c);
|
||||||
|
translator.Append(char_to_add);
|
||||||
|
is_after_underscore = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
is_after_underscore = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
translator[0] = Char.ToUpper(translator[0]);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
translator.Append(name);
|
||||||
|
|
||||||
|
translator.Replace("Pname", "PName");
|
||||||
|
return translator.ToString();
|
||||||
}
|
}
|
||||||
|
|
||||||
public override string ToString()
|
public override string ToString()
|
||||||
|
@ -116,6 +159,9 @@ namespace Bind.Structures
|
||||||
|
|
||||||
internal void Translate()
|
internal void Translate()
|
||||||
{
|
{
|
||||||
|
foreach (Enum e in this.Values)
|
||||||
|
e.Name = Enum.TranslateName(e.Name);
|
||||||
|
|
||||||
foreach (Enum e in this.Values)
|
foreach (Enum e in this.Values)
|
||||||
{
|
{
|
||||||
foreach (Constant c in e.ConstantCollection.Values)
|
foreach (Constant c in e.ConstantCollection.Values)
|
||||||
|
@ -139,12 +185,11 @@ namespace Bind.Structures
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Obey .Net naming rules:
|
new bool TryGetValue(string key, out Enum value)
|
||||||
if ((Settings.Compatibility & Settings.Legacy.NoAdvancedEnumProcessing) == Settings.Legacy.None)
|
{
|
||||||
{
|
return base.TryGetValue(key, out value);
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue