2004-12-27 Mike Kestner <mkestner@novell.com>

* generator/EnumGen.cs : rework for a single pass thru ChildNodes.
	* generator/Parameters.cs : simplify PassAs logic.
	* generator/SimpleBase.cs : mark abstract.

svn path=/trunk/gtk-sharp/; revision=38111
This commit is contained in:
Mike Kestner 2004-12-27 20:00:55 +00:00
parent 5562bf645f
commit bf9ed95944
4 changed files with 35 additions and 51 deletions

View File

@ -1,3 +1,9 @@
2004-12-27 Mike Kestner <mkestner@novell.com>
* generator/EnumGen.cs : rework for a single pass thru ChildNodes.
* generator/Parameters.cs : simplify PassAs logic.
* generator/SimpleBase.cs : mark abstract.
2004-12-27 Mike Kestner <mkestner@novell.com>
* generator/AliasGen.cs : derive from SimpleBase.

View File

@ -22,12 +22,34 @@
namespace GtkSharp.Generation {
using System;
using System.Collections;
using System.IO;
using System.Xml;
public class EnumGen : GenBase {
public EnumGen (XmlElement ns, XmlElement elem) : base (ns, elem) {}
string enum_type = String.Empty;
ArrayList members = new ArrayList ();
public EnumGen (XmlElement ns, XmlElement elem) : base (ns, elem)
{
foreach (XmlElement member in elem.ChildNodes) {
if (member.Name != "member")
continue;
string result = "\t\t" + member.GetAttribute("name");
if (member.HasAttribute("value")) {
string value = member.GetAttribute("value");
if (value.EndsWith("U")) {
enum_type = " : uint";
value = value.TrimEnd('U');
}
result += " = " + value;
}
members.Add (result + ",");
}
}
public override string MarshalType {
get {
@ -59,51 +81,13 @@ namespace GtkSharp.Generation {
sw.WriteLine ("\t[Flags]");
}
// Ok, this is obscene. We need to go through the enums first
// to find "large" values. If we find some, we need to change
// the base type of the enum.
string enum_type = null;
foreach (XmlNode node in Elem.ChildNodes) {
if (!(node is XmlElement) || node.Name != "member") {
continue;
}
XmlElement member = (XmlElement) node;
if (member.HasAttribute("value")) {
string value = member.GetAttribute("value");
if (value.EndsWith("U")) {
enum_type = "uint";
member.SetAttribute("value", value.TrimEnd('U'));
}
}
}
sw.WriteLine ("#region Autogenerated code");
if (enum_type != null)
sw.WriteLine ("\tpublic enum " + Name + " : " + enum_type + " {");
else
sw.WriteLine ("\tpublic enum " + Name + " {");
sw.WriteLine ("\tpublic enum " + Name + enum_type + " {");
sw.WriteLine ();
foreach (XmlNode node in Elem.ChildNodes) {
if (!(node is XmlElement) || node.Name != "member") {
continue;
}
XmlElement member = (XmlElement) node;
sw.Write ("\t\t" + member.GetAttribute("name"));
if (member.HasAttribute("value")) {
sw.WriteLine (" = " + member.GetAttribute("value") + ",");
} else {
sw.WriteLine (",");
}
}
foreach (string member in members)
sw.WriteLine (member);
sw.WriteLine ("\t}");
sw.WriteLine ("#endregion");

View File

@ -172,16 +172,10 @@ namespace GtkSharp.Generation {
if (elem.HasAttribute ("pass_as"))
return elem.GetAttribute ("pass_as");
if (IsArray)
if (IsArray || CSType.EndsWith ("IntPtr"))
return "";
if (Generatable is SimpleGen && !(Generatable is ConstStringGen) && CType.EndsWith ("*") && !CSType.EndsWith ("IntPtr"))
return "out";
if ((Generatable is LPGen || Generatable is LPUGen) && CType.EndsWith ("*"))
return "out";
if (Generatable is EnumGen && CType.EndsWith ("*"))
if (CType.EndsWith ("*") && (Generatable is SimpleGen || Generatable is EnumGen))
return "out";
return "";

View File

@ -23,7 +23,7 @@ namespace GtkSharp.Generation {
using System;
public class SimpleBase : IGeneratable {
public abstract class SimpleBase : IGeneratable {
string type;
string ctype;