parent
							
								
									0b9c9ea07d
								
							
						
					
					
						commit
						4ec0c37abc
					
				
				 4 changed files with 676 additions and 585 deletions
			
			
		| @ -0,0 +1,506 @@ | |||||||
|  | using System; | ||||||
|  | using System.Linq; | ||||||
|  | using System.Threading.Tasks; | ||||||
|  | using System.Collections.Generic; | ||||||
|  | using Microsoft.CodeAnalysis.CSharp.Scripting; | ||||||
|  | using System.IO; | ||||||
|  | using Newtonsoft.Json; | ||||||
|  | using Newtonsoft.Json.Linq; | ||||||
|  | 
 | ||||||
|  | namespace CodeGenerator | ||||||
|  | { | ||||||
|  |     class ImguiDefinitions | ||||||
|  |     { | ||||||
|  |         public EnumDefinition[] Enums; | ||||||
|  |         public TypeDefinition[] Types; | ||||||
|  |         public FunctionDefinition[] Functions; | ||||||
|  |         public Dictionary<string, MethodVariant> Variants; | ||||||
|  |         public void LoadFrom(string directory) | ||||||
|  |         { | ||||||
|  |              | ||||||
|  |             JObject typesJson; | ||||||
|  |             using (StreamReader fs = File.OpenText(Path.Combine(directory, "structs_and_enums.json"))) | ||||||
|  |             using (JsonTextReader jr = new JsonTextReader(fs)) | ||||||
|  |             { | ||||||
|  |                 typesJson = JObject.Load(jr); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             JObject functionsJson; | ||||||
|  |             using (StreamReader fs = File.OpenText(Path.Combine(directory, "definitions.json"))) | ||||||
|  |             using (JsonTextReader jr = new JsonTextReader(fs)) | ||||||
|  |             { | ||||||
|  |                 functionsJson = JObject.Load(jr); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             JObject variantsJson = null; | ||||||
|  |             if (File.Exists(Path.Combine(directory, "variants.json"))) | ||||||
|  |             { | ||||||
|  |                 using (StreamReader fs = File.OpenText(Path.Combine(AppContext.BaseDirectory, "variants.json"))) | ||||||
|  |                 using (JsonTextReader jr = new JsonTextReader(fs)) | ||||||
|  |                 { | ||||||
|  |                     variantsJson = JObject.Load(jr); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             Variants = new Dictionary<string, MethodVariant>(); | ||||||
|  |             foreach (var jt in variantsJson.Children()) | ||||||
|  |             { | ||||||
|  |                 JProperty jp = (JProperty)jt; | ||||||
|  |                 ParameterVariant[] methodVariants = jp.Values().Select(jv => | ||||||
|  |                 { | ||||||
|  |                     return new ParameterVariant(jv["name"].ToString(), jv["type"].ToString(), jv["variants"].Select(s => s.ToString()).ToArray()); | ||||||
|  |                 }).ToArray(); | ||||||
|  |                 Variants.Add(jp.Name, new MethodVariant(jp.Name, methodVariants)); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             var typeLocations = typesJson["locations"]; | ||||||
|  | 
 | ||||||
|  |             Enums = typesJson["enums"].Select(jt => | ||||||
|  |             { | ||||||
|  |                 JProperty jp = (JProperty)jt; | ||||||
|  |                 string name = jp.Name; | ||||||
|  |                 if (typeLocations[jp.Name].Value<string>() == "internal") { | ||||||
|  |                     return null; | ||||||
|  |                 } | ||||||
|  |                 EnumMember[] elements = jp.Values().Select(v => | ||||||
|  |                 { | ||||||
|  |                     return new EnumMember(v["name"].ToString(), v["value"].ToString()); | ||||||
|  |                 }).ToArray(); | ||||||
|  |                 return new EnumDefinition(name, elements); | ||||||
|  |             }).Where(x => x != null).ToArray(); | ||||||
|  | 
 | ||||||
|  |             Types = typesJson["structs"].Select(jt => | ||||||
|  |             { | ||||||
|  |                 JProperty jp = (JProperty)jt; | ||||||
|  |                 string name = jp.Name; | ||||||
|  |                 if (typeLocations[jp.Name].Value<string>() == "internal") { | ||||||
|  |                     return null; | ||||||
|  |                 } | ||||||
|  |                 TypeReference[] fields = jp.Values().Select(v => | ||||||
|  |                 { | ||||||
|  |                     if (v["type"].ToString().Contains("static")) { return null; } | ||||||
|  | 
 | ||||||
|  |                     return new TypeReference( | ||||||
|  |                         v["name"].ToString(), | ||||||
|  |                         v["type"].ToString(), | ||||||
|  |                         v["template_type"]?.ToString(), | ||||||
|  |                         Enums); | ||||||
|  |                 }).Where(tr => tr != null).ToArray(); | ||||||
|  |                 return new TypeDefinition(name, fields); | ||||||
|  |             }).Where(x => x != null).ToArray(); | ||||||
|  | 
 | ||||||
|  |             Functions = functionsJson.Children().Select(jt => | ||||||
|  |             { | ||||||
|  |                 JProperty jp = (JProperty)jt; | ||||||
|  |                 string name = jp.Name; | ||||||
|  |                 bool hasNonUdtVariants = jp.Values().Any(val => val["ov_cimguiname"]?.ToString().EndsWith("nonUDT") ?? false); | ||||||
|  |                 OverloadDefinition[] overloads = jp.Values().Select(val => | ||||||
|  |                 { | ||||||
|  |                     string ov_cimguiname = val["ov_cimguiname"]?.ToString(); | ||||||
|  |                     string cimguiname = val["cimguiname"].ToString(); | ||||||
|  |                     string friendlyName = val["funcname"]?.ToString(); | ||||||
|  |                     if (cimguiname.EndsWith("_destroy")) | ||||||
|  |                     { | ||||||
|  |                         friendlyName = "Destroy"; | ||||||
|  |                     } | ||||||
|  |                     //skip internal functions | ||||||
|  |                     var typename = val["stname"]?.ToString(); | ||||||
|  |                     if (!string.IsNullOrEmpty(typename)) | ||||||
|  |                     { | ||||||
|  |                         if (!Types.Any(x => x.Name == val["stname"]?.ToString())) { | ||||||
|  |                             return null; | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                     if (friendlyName == null) { return null; } | ||||||
|  |                     if (val["location"]?.ToString() == "internal") return null; | ||||||
|  | 
 | ||||||
|  |                     string exportedName = ov_cimguiname; | ||||||
|  |                     if (exportedName == null) | ||||||
|  |                     { | ||||||
|  |                         exportedName = cimguiname; | ||||||
|  |                     } | ||||||
|  | 
 | ||||||
|  |                     if (hasNonUdtVariants && !exportedName.EndsWith("nonUDT2")) | ||||||
|  |                     { | ||||||
|  |                         return null; | ||||||
|  |                     } | ||||||
|  | 
 | ||||||
|  |                     string selfTypeName = null; | ||||||
|  |                     int underscoreIndex = exportedName.IndexOf('_'); | ||||||
|  |                     if (underscoreIndex > 0 && !exportedName.StartsWith("ig")) // Hack to exclude some weirdly-named non-instance functions. | ||||||
|  |                     { | ||||||
|  |                         selfTypeName = exportedName.Substring(0, underscoreIndex); | ||||||
|  |                     } | ||||||
|  | 
 | ||||||
|  |                     List<TypeReference> parameters = new List<TypeReference>(); | ||||||
|  | 
 | ||||||
|  |                     // find any variants that can be applied to the parameters of this method based on the method name | ||||||
|  |                     MethodVariant methodVariants = null; | ||||||
|  |                     Variants.TryGetValue(jp.Name, out methodVariants); | ||||||
|  | 
 | ||||||
|  |                     foreach (JToken p in val["argsT"]) | ||||||
|  |                     { | ||||||
|  |                         string pType = p["type"].ToString(); | ||||||
|  |                         string pName = p["name"].ToString(); | ||||||
|  | 
 | ||||||
|  |                         // if there are possible variants for this method then try to match them based on the parameter name and expected type | ||||||
|  |                         ParameterVariant matchingVariant = methodVariants?.Parameters.Where(pv => pv.Name == pName && pv.OriginalType == pType).FirstOrDefault() ?? null; | ||||||
|  |                         if (matchingVariant != null) matchingVariant.Used = true; | ||||||
|  | 
 | ||||||
|  |                         parameters.Add(new TypeReference(pName, pType, Enums, matchingVariant?.VariantTypes)); | ||||||
|  |                     } | ||||||
|  | 
 | ||||||
|  |                     Dictionary<string, string> defaultValues = new Dictionary<string, string>(); | ||||||
|  |                     foreach (JToken dv in val["defaults"]) | ||||||
|  |                     { | ||||||
|  |                         JProperty dvProp = (JProperty)dv; | ||||||
|  |                         defaultValues.Add(dvProp.Name, dvProp.Value.ToString()); | ||||||
|  |                     } | ||||||
|  |                     string returnType = val["ret"]?.ToString() ?? "void"; | ||||||
|  |                     string comment = null; | ||||||
|  | 
 | ||||||
|  |                     string structName = val["stname"].ToString(); | ||||||
|  |                     bool isConstructor = val.Value<bool>("constructor"); | ||||||
|  |                     bool isDestructor = val.Value<bool>("destructor"); | ||||||
|  |                     if (isConstructor) | ||||||
|  |                     { | ||||||
|  |                         returnType = structName + "*"; | ||||||
|  |                     } | ||||||
|  | 
 | ||||||
|  |                     return new OverloadDefinition( | ||||||
|  |                         exportedName, | ||||||
|  |                         friendlyName, | ||||||
|  |                         parameters.ToArray(), | ||||||
|  |                         defaultValues, | ||||||
|  |                         returnType, | ||||||
|  |                         structName, | ||||||
|  |                         comment, | ||||||
|  |                         isConstructor, | ||||||
|  |                         isDestructor); | ||||||
|  |                 }).Where(od => od != null).ToArray(); | ||||||
|  |                 if(overloads.Length == 0) return null; | ||||||
|  |                 return new FunctionDefinition(name, overloads, Enums); | ||||||
|  |             }).Where(x => x != null).OrderBy(fd => fd.Name).ToArray(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     class MethodVariant | ||||||
|  |     { | ||||||
|  |         public string Name { get; } | ||||||
|  | 
 | ||||||
|  |         public ParameterVariant[] Parameters { get; } | ||||||
|  | 
 | ||||||
|  |         public MethodVariant(string name, ParameterVariant[] parameters) | ||||||
|  |         { | ||||||
|  |             Name = name; | ||||||
|  |             Parameters = parameters; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     class ParameterVariant | ||||||
|  |     { | ||||||
|  |         public string Name { get; } | ||||||
|  | 
 | ||||||
|  |         public string OriginalType { get; } | ||||||
|  | 
 | ||||||
|  |         public string[] VariantTypes { get; } | ||||||
|  | 
 | ||||||
|  |         public bool Used { get; set; } | ||||||
|  | 
 | ||||||
|  |         public ParameterVariant(string name, string originalType, string[] variantTypes) | ||||||
|  |         { | ||||||
|  |             Name = name; | ||||||
|  |             OriginalType = originalType; | ||||||
|  |             VariantTypes = variantTypes; | ||||||
|  |             Used = false; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     class EnumDefinition | ||||||
|  |     { | ||||||
|  |         private readonly Dictionary<string, string> _sanitizedNames; | ||||||
|  | 
 | ||||||
|  |         public string Name { get; } | ||||||
|  |         public string FriendlyName { get; } | ||||||
|  |         public EnumMember[] Members { get; } | ||||||
|  | 
 | ||||||
|  |         public EnumDefinition(string name, EnumMember[] elements) | ||||||
|  |         { | ||||||
|  |             Name = name; | ||||||
|  |             if (Name.EndsWith('_')) | ||||||
|  |             { | ||||||
|  |                 FriendlyName = Name.Substring(0, Name.Length - 1); | ||||||
|  |             } | ||||||
|  |             else | ||||||
|  |             { | ||||||
|  |                 FriendlyName = Name; | ||||||
|  |             } | ||||||
|  |             Members = elements; | ||||||
|  | 
 | ||||||
|  |             _sanitizedNames = new Dictionary<string, string>(); | ||||||
|  |             foreach (EnumMember el in elements) | ||||||
|  |             { | ||||||
|  |                 _sanitizedNames.Add(el.Name, SanitizeMemberName(el.Name)); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public string SanitizeNames(string text) | ||||||
|  |         { | ||||||
|  |             foreach (KeyValuePair<string, string> kvp in _sanitizedNames) | ||||||
|  |             { | ||||||
|  |                 text = text.Replace(kvp.Key, kvp.Value); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return text; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         private string SanitizeMemberName(string memberName) | ||||||
|  |         { | ||||||
|  |             string ret = memberName; | ||||||
|  |             if (memberName.StartsWith(Name)) | ||||||
|  |             { | ||||||
|  |                 ret = memberName.Substring(Name.Length); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (ret.EndsWith('_')) | ||||||
|  |             { | ||||||
|  |                 ret = ret.Substring(0, ret.Length - 1); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return ret; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     class EnumMember | ||||||
|  |     { | ||||||
|  |         public EnumMember(string name, string value) | ||||||
|  |         { | ||||||
|  |             Name = name; | ||||||
|  |             Value = value; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public string Name { get; } | ||||||
|  |         public string Value { get; } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     class TypeDefinition | ||||||
|  |     { | ||||||
|  |         public string Name { get; } | ||||||
|  |         public TypeReference[] Fields { get; } | ||||||
|  | 
 | ||||||
|  |         public TypeDefinition(string name, TypeReference[] fields) | ||||||
|  |         { | ||||||
|  |             Name = name; | ||||||
|  |             Fields = fields; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     class TypeReference | ||||||
|  |     { | ||||||
|  |         public string Name { get; } | ||||||
|  |         public string Type { get; } | ||||||
|  |         public string TemplateType { get; } | ||||||
|  |         public int ArraySize { get; } | ||||||
|  |         public bool IsFunctionPointer { get; } | ||||||
|  |         public string[] TypeVariants { get; } | ||||||
|  |         public bool IsEnum { get; } | ||||||
|  | 
 | ||||||
|  |         public TypeReference(string name, string type, EnumDefinition[] enums) | ||||||
|  |             : this(name, type, null, enums, null) { } | ||||||
|  | 
 | ||||||
|  |         public TypeReference(string name, string type, EnumDefinition[] enums, string[] typeVariants) | ||||||
|  |             : this(name, type, null, enums, typeVariants) { } | ||||||
|  | 
 | ||||||
|  |         public TypeReference(string name, string type, string templateType, EnumDefinition[] enums) | ||||||
|  |             : this(name, type, templateType, enums, null) { } | ||||||
|  | 
 | ||||||
|  |         public TypeReference(string name, string type, string templateType, EnumDefinition[] enums, string[] typeVariants) | ||||||
|  |         { | ||||||
|  |             Name = name; | ||||||
|  |             Type = type.Replace("const", string.Empty).Trim(); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |             if (Type.StartsWith("ImVector_")) | ||||||
|  |             { | ||||||
|  |                 if (Type.EndsWith("*")) | ||||||
|  |                 { | ||||||
|  |                     Type = "ImVector*"; | ||||||
|  |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     Type = "ImVector"; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (Type.StartsWith("ImChunkStream_")) | ||||||
|  |             { | ||||||
|  |                 if (Type.EndsWith("*")) | ||||||
|  |                 { | ||||||
|  |                     Type = "ImChunkStream*"; | ||||||
|  |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     Type = "ImChunkStream"; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             TemplateType = templateType; | ||||||
|  |             int startBracket = name.IndexOf('['); | ||||||
|  |             if (startBracket != -1) | ||||||
|  |             { | ||||||
|  |                 int endBracket = name.IndexOf(']'); | ||||||
|  |                 string sizePart = name.Substring(startBracket + 1, endBracket - startBracket - 1); | ||||||
|  |                 ArraySize = ParseSizeString(sizePart, enums); | ||||||
|  |                 Name = Name.Substring(0, startBracket); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             IsFunctionPointer = Type.IndexOf('(') != -1; | ||||||
|  | 
 | ||||||
|  |             TypeVariants = typeVariants; | ||||||
|  | 
 | ||||||
|  |             IsEnum = enums.Any(t => t.Name == type || t.FriendlyName == type); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |          private int ParseSizeString(string sizePart, EnumDefinition[] enums) | ||||||
|  |          { | ||||||
|  |             if (sizePart.Contains("(") || sizePart.Contains("+") || sizePart.Contains("/") || | ||||||
|  |                 sizePart.Contains("*")) | ||||||
|  |             { | ||||||
|  |                 return Task.WaitAny(CSharpScript.EvaluateAsync<int>($"(int)({sizePart})")); | ||||||
|  |             } | ||||||
|  |             if (!int.TryParse(sizePart, out int ret)) | ||||||
|  |             { | ||||||
|  |                 foreach (EnumDefinition ed in enums) | ||||||
|  |                 { | ||||||
|  |                     if (sizePart.StartsWith(ed.Name)) | ||||||
|  |                     { | ||||||
|  |                         foreach (EnumMember member in ed.Members) | ||||||
|  |                         { | ||||||
|  |                             if (member.Name == sizePart) | ||||||
|  |                             { | ||||||
|  |                                 return int.Parse(member.Value); | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 ret = -1; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return ret; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public TypeReference WithVariant(int variantIndex, EnumDefinition[] enums) | ||||||
|  |         { | ||||||
|  |             if (variantIndex == 0) return this; | ||||||
|  |             else return new TypeReference(Name, TypeVariants[variantIndex - 1], TemplateType, enums); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     class FunctionDefinition | ||||||
|  |     { | ||||||
|  |         public string Name { get; } | ||||||
|  |         public OverloadDefinition[] Overloads { get; } | ||||||
|  | 
 | ||||||
|  |         public FunctionDefinition(string name, OverloadDefinition[] overloads, EnumDefinition[] enums) | ||||||
|  |         { | ||||||
|  |             Name = name; | ||||||
|  |             Overloads = ExpandOverloadVariants(overloads, enums); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         private OverloadDefinition[] ExpandOverloadVariants(OverloadDefinition[] overloads, EnumDefinition[] enums) | ||||||
|  |         { | ||||||
|  |             List<OverloadDefinition> newDefinitions = new List<OverloadDefinition>(); | ||||||
|  | 
 | ||||||
|  |             foreach (OverloadDefinition overload in overloads) | ||||||
|  |             { | ||||||
|  |                 bool hasVariants = false; | ||||||
|  |                 int[] variantCounts = new int[overload.Parameters.Length]; | ||||||
|  | 
 | ||||||
|  |                 for (int i = 0; i < overload.Parameters.Length; i++) | ||||||
|  |                 { | ||||||
|  |                     if (overload.Parameters[i].TypeVariants != null) | ||||||
|  |                     { | ||||||
|  |                         hasVariants = true; | ||||||
|  |                         variantCounts[i] = overload.Parameters[i].TypeVariants.Length + 1; | ||||||
|  |                     } | ||||||
|  |                     else | ||||||
|  |                     { | ||||||
|  |                         variantCounts[i] = 1; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 if (hasVariants) | ||||||
|  |                 { | ||||||
|  |                     int totalVariants = variantCounts[0]; | ||||||
|  |                     for (int i = 1; i < variantCounts.Length; i++) totalVariants *= variantCounts[i]; | ||||||
|  | 
 | ||||||
|  |                     for (int i = 0; i < totalVariants; i++) | ||||||
|  |                     { | ||||||
|  |                         TypeReference[] parameters = new TypeReference[overload.Parameters.Length]; | ||||||
|  |                         int div = 1; | ||||||
|  | 
 | ||||||
|  |                         for (int j = 0; j < parameters.Length; j++) | ||||||
|  |                         { | ||||||
|  |                             int k = (i / div) % variantCounts[j]; | ||||||
|  | 
 | ||||||
|  |                             parameters[j] = overload.Parameters[j].WithVariant(k, enums); | ||||||
|  | 
 | ||||||
|  |                             if (j > 0) div *= variantCounts[j]; | ||||||
|  |                         } | ||||||
|  | 
 | ||||||
|  |                         newDefinitions.Add(overload.WithParameters(parameters)); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     newDefinitions.Add(overload); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return newDefinitions.ToArray(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     class OverloadDefinition | ||||||
|  |     { | ||||||
|  |         public string ExportedName { get; } | ||||||
|  |         public string FriendlyName { get; } | ||||||
|  |         public TypeReference[] Parameters { get; } | ||||||
|  |         public Dictionary<string, string> DefaultValues { get; } | ||||||
|  |         public string ReturnType { get; } | ||||||
|  |         public string StructName { get; } | ||||||
|  |         public bool IsMemberFunction { get; } | ||||||
|  |         public string Comment { get; } | ||||||
|  |         public bool IsConstructor { get; } | ||||||
|  |         public bool IsDestructor { get; } | ||||||
|  | 
 | ||||||
|  |         public OverloadDefinition( | ||||||
|  |             string exportedName, | ||||||
|  |             string friendlyName, | ||||||
|  |             TypeReference[] parameters, | ||||||
|  |             Dictionary<string, string> defaultValues, | ||||||
|  |             string returnType, | ||||||
|  |             string structName, | ||||||
|  |             string comment, | ||||||
|  |             bool isConstructor, | ||||||
|  |             bool isDestructor) | ||||||
|  |         { | ||||||
|  |             ExportedName = exportedName; | ||||||
|  |             FriendlyName = friendlyName; | ||||||
|  |             Parameters = parameters; | ||||||
|  |             DefaultValues = defaultValues; | ||||||
|  |             ReturnType = returnType.Replace("const", string.Empty).Replace("inline", string.Empty).Trim(); | ||||||
|  |             StructName = structName; | ||||||
|  |             IsMemberFunction = !string.IsNullOrEmpty(structName); | ||||||
|  |             Comment = comment; | ||||||
|  |             IsConstructor = isConstructor; | ||||||
|  |             IsDestructor = isDestructor; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public OverloadDefinition WithParameters(TypeReference[] parameters) | ||||||
|  |         { | ||||||
|  |             return new OverloadDefinition(ExportedName, FriendlyName, parameters, DefaultValues, ReturnType, StructName, Comment, IsConstructor, IsDestructor); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,105 @@ | |||||||
|  | using System.Collections.Generic; | ||||||
|  | 
 | ||||||
|  | namespace CodeGenerator | ||||||
|  | { | ||||||
|  |     public class TypeInfo | ||||||
|  |     { | ||||||
|  |         public static readonly Dictionary<string, string> WellKnownTypes = new Dictionary<string, string>() | ||||||
|  |         { | ||||||
|  |             { "bool", "byte" }, | ||||||
|  |             { "unsigned char", "byte" }, | ||||||
|  |             { "signed char", "sbyte" }, | ||||||
|  |             { "char", "byte" }, | ||||||
|  |             { "ImWchar", "ushort" }, | ||||||
|  |             { "ImFileHandle", "IntPtr" }, | ||||||
|  |             { "ImU8", "byte" }, | ||||||
|  |             { "ImS8", "sbyte" }, | ||||||
|  |             { "ImU64", "ulong" }, | ||||||
|  |             { "unsigned short", "ushort" }, | ||||||
|  |             { "unsigned int", "uint" }, | ||||||
|  |             { "ImVec2", "Vector2" }, | ||||||
|  |             { "ImVec2_Simple", "Vector2" }, | ||||||
|  |             { "ImVec3", "Vector3" }, | ||||||
|  |             { "ImVec4", "Vector4" }, | ||||||
|  |             { "ImWchar16", "ushort" }, //char is not blittable | ||||||
|  |             { "ImVec4_Simple", "Vector4" }, | ||||||
|  |             { "ImColor_Simple", "ImColor" }, | ||||||
|  |             { "ImTextureID", "IntPtr" }, | ||||||
|  |             { "ImGuiID", "uint" }, | ||||||
|  |             { "ImDrawIdx", "ushort" }, | ||||||
|  |             { "ImDrawListSharedData", "IntPtr" }, | ||||||
|  |             { "ImDrawListSharedData*", "IntPtr" }, | ||||||
|  |             { "ImU32", "uint" }, | ||||||
|  |             { "ImDrawCallback", "IntPtr" }, | ||||||
|  |             { "size_t", "uint" }, | ||||||
|  |             { "ImGuiContext*", "IntPtr" }, | ||||||
|  |             { "float[2]", "Vector2*" }, | ||||||
|  |             { "float[3]", "Vector3*" }, | ||||||
|  |             { "float[4]", "Vector4*" }, | ||||||
|  |             { "int[2]", "int*" }, | ||||||
|  |             { "int[3]", "int*" }, | ||||||
|  |             { "int[4]", "int*" }, | ||||||
|  |             { "float&", "float*" }, | ||||||
|  |             { "ImVec2[2]", "Vector2*" }, | ||||||
|  |             { "char* []", "byte**" }, | ||||||
|  |             { "unsigned char[256]", "byte*"}, | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         public static readonly Dictionary<string, string> WellKnownFieldReplacements = new Dictionary<string, string>() | ||||||
|  |         { | ||||||
|  |             { "bool", "bool" }, // Force bool to remain as bool in type-safe wrappers. | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         public static readonly HashSet<string> CustomDefinedTypes = new HashSet<string>() | ||||||
|  |         { | ||||||
|  |             "ImVector", | ||||||
|  |             "ImVec2", | ||||||
|  |             "ImVec4", | ||||||
|  |             "ImGuiStoragePair", | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         public static readonly Dictionary<string, string> WellKnownDefaultValues = new Dictionary<string, string>() | ||||||
|  |         { | ||||||
|  |             { "((void *)0)", "null" }, | ||||||
|  |             { "((void*)0)", "null" }, | ||||||
|  |             { "ImVec2(0,0)", "new Vector2()" }, | ||||||
|  |             { "ImVec2(-1,0)", "new Vector2(-1, 0)" }, | ||||||
|  |             { "ImVec2(1,0)", "new Vector2(1, 0)" }, | ||||||
|  |             { "ImVec2(1,1)", "new Vector2(1, 1)" }, | ||||||
|  |             { "ImVec2(0,1)", "new Vector2(0, 1)" }, | ||||||
|  |             { "ImVec4(0,0,0,0)", "new Vector4()" }, | ||||||
|  |             { "ImVec4(1,1,1,1)", "new Vector4(1, 1, 1, 1)" }, | ||||||
|  |             { "ImDrawCornerFlags_All", "ImDrawCornerFlags.All" }, | ||||||
|  |             { "FLT_MAX", "float.MaxValue" }, | ||||||
|  |             { "(((ImU32)(255)<<24)|((ImU32)(255)<<16)|((ImU32)(255)<<8)|((ImU32)(255)<<0))", "0xFFFFFFFF" } | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         public static readonly Dictionary<string, string> IdentifierReplacements = new Dictionary<string, string>() | ||||||
|  |         { | ||||||
|  |             { "in", "@in" }, | ||||||
|  |             { "out", "@out" }, | ||||||
|  |             { "ref", "@ref" }, | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         public static readonly HashSet<string> LegalFixedTypes = new HashSet<string>() | ||||||
|  |         { | ||||||
|  |             "byte", | ||||||
|  |             "sbyte", | ||||||
|  |             "char", | ||||||
|  |             "ushort", | ||||||
|  |             "short", | ||||||
|  |             "uint", | ||||||
|  |             "int", | ||||||
|  |             "ulong", | ||||||
|  |             "long", | ||||||
|  |             "float", | ||||||
|  |             "double", | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         public static readonly HashSet<string> SkippedFunctions = new HashSet<string>() | ||||||
|  |         { | ||||||
|  |             "igInputText", | ||||||
|  |             "igInputTextMultiline" | ||||||
|  |         }; | ||||||
|  |     } | ||||||
|  | } | ||||||
					Loading…
					
					
				
		Reference in new issue