mirror of
https://github.com/Ryujinx/GtkSharp.git
synced 2025-01-11 13:55:40 +00:00
2003-09-17 Rachel Hestilow <rachel@nullenvoid.com>
* generator/StructBase.cs: Make pointer, wrapped, bitfield, and dummy fields private fields. svn path=/trunk/gtk-sharp/; revision=18162
This commit is contained in:
parent
f249abd390
commit
9ff3497076
|
@ -1,3 +1,8 @@
|
||||||
|
2003-09-17 Rachel Hestilow <rachel@nullenvoid.com>
|
||||||
|
|
||||||
|
* generator/StructBase.cs: Make pointer, wrapped,
|
||||||
|
bitfield, and dummy fields private fields.
|
||||||
|
|
||||||
2003-09-16 Martin Willemoes Hansen <mwh@sysrq.dk>
|
2003-09-16 Martin Willemoes Hansen <mwh@sysrq.dk>
|
||||||
|
|
||||||
* api/gda-api.xml: Updated to reflect new versions of the targeted
|
* api/gda-api.xml: Updated to reflect new versions of the targeted
|
||||||
|
|
|
@ -95,7 +95,13 @@ namespace GtkSharp.Generation {
|
||||||
bool IsPointer (XmlElement field)
|
bool IsPointer (XmlElement field)
|
||||||
{
|
{
|
||||||
string c_type = field.GetAttribute("type");
|
string c_type = field.GetAttribute("type");
|
||||||
return (c_type[c_type.Length - 1] == '*');
|
return (c_type.EndsWith ("*") || c_type.EndsWith ("pointer"));
|
||||||
|
}
|
||||||
|
|
||||||
|
bool IsPadding (XmlElement field)
|
||||||
|
{
|
||||||
|
string c_name = field.GetAttribute ("cname");
|
||||||
|
return (c_name.StartsWith ("dummy"));
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void GenFields (StreamWriter sw)
|
protected void GenFields (StreamWriter sw)
|
||||||
|
@ -114,29 +120,39 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected bool GetFieldInfo (XmlElement field, out string c_type, out string type, out string name)
|
protected bool GetFieldInfo (XmlElement field, out string c_type, out string type, out string name, out string protection)
|
||||||
{
|
{
|
||||||
name = "";
|
name = "";
|
||||||
|
protection = "";
|
||||||
c_type = field.GetAttribute ("type");
|
c_type = field.GetAttribute ("type");
|
||||||
type = SymbolTable.Table.GetCSType (c_type);
|
type = SymbolTable.Table.GetCSType (c_type);
|
||||||
if (IsBit (field)) {
|
if (IsBit (field)) {
|
||||||
type = "uint";
|
type = "uint";
|
||||||
|
protection = "private";
|
||||||
} else if ((IsPointer (field) || SymbolTable.Table.IsOpaque (c_type)) && type != "string") {
|
} else if ((IsPointer (field) || SymbolTable.Table.IsOpaque (c_type)) && type != "string") {
|
||||||
type = "IntPtr";
|
type = "IntPtr";
|
||||||
name = "_";
|
name = "_";
|
||||||
|
protection = "private";
|
||||||
} else if (SymbolTable.Table.IsCallback (c_type)) {
|
} else if (SymbolTable.Table.IsCallback (c_type)) {
|
||||||
type = "IntPtr";
|
type = "IntPtr";
|
||||||
|
protection = "private";
|
||||||
|
} else if (IsPadding (field)) {
|
||||||
|
protection = "private";
|
||||||
} else {
|
} else {
|
||||||
if (type == "") {
|
if (type == "") {
|
||||||
Console.WriteLine ("Field has unknown Type {0}", c_type);
|
Console.WriteLine ("Field has unknown Type {0}", c_type);
|
||||||
Statistics.ThrottledCount++;
|
Statistics.ThrottledCount++;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protection = "public";
|
||||||
}
|
}
|
||||||
|
|
||||||
// FIXME: marshalling not implemented here in mono
|
// FIXME: marshalling not implemented here in mono
|
||||||
if (field.HasAttribute("array_len"))
|
if (field.HasAttribute("array_len")) {
|
||||||
type = "IntPtr";
|
type = "IntPtr";
|
||||||
|
protection = "private";
|
||||||
|
}
|
||||||
|
|
||||||
if (IsBit (field))
|
if (IsBit (field))
|
||||||
name = String.Format ("_bitfield{0}", bitfields++);
|
name = String.Format ("_bitfield{0}", bitfields++);
|
||||||
|
@ -148,10 +164,10 @@ namespace GtkSharp.Generation {
|
||||||
|
|
||||||
protected bool GenField (XmlElement field, StreamWriter sw)
|
protected bool GenField (XmlElement field, StreamWriter sw)
|
||||||
{
|
{
|
||||||
string c_type, type, name;
|
string c_type, type, name, protection;
|
||||||
if (!GetFieldInfo (field, out c_type, out type, out name))
|
if (!GetFieldInfo (field, out c_type, out type, out name, out protection))
|
||||||
return false;
|
return false;
|
||||||
sw.WriteLine ("\t\tpublic {0} {1};", type, SymbolTable.Table.MangleName (name));
|
sw.WriteLine ("\t\t{0} {1} {2};", protection, type, SymbolTable.Table.MangleName (name));
|
||||||
|
|
||||||
if (field.HasAttribute("array_len"))
|
if (field.HasAttribute("array_len"))
|
||||||
Console.WriteLine ("warning: array field {0}.{1} probably incorrectly generated", QualifiedName, name);
|
Console.WriteLine ("warning: array field {0}.{1} probably incorrectly generated", QualifiedName, name);
|
||||||
|
|
Loading…
Reference in a new issue