2002-07-30 Rachel Hestilow <hestilow@ximian.com>
* generator/ClassBase.cs: Change hasDefaultConstructor to protected, adjust now that it is an attr and not a subnode. Also add virtual property AssignToName (for ctors). * generator/Ctor.cs: Add property ForceStatic. (Generate): Optimize return code a bit for the static case. * generator/Method.cs: Assign to a "raw_ret" pointer before calling FromNativeReturn. * generator/Parameters.cs: Change "out ref" to "out", not "ref". * generator/Property.cs: Fix to work correctly with all object and struct types (mostly just some if-cases added). * generator/SignalHandler.cs: Remove args_type and argfields (unused). (Generate): Initialize struct if necessary. * generator/StructBase.cs: Massive reworking to support methods, ctors, etc. * generator/SymbolTable.cs: Add GdkAtom and gconstpointer simple types. * glib/Boxed.cs: Accept both IntPtr and object ctors. Add access for both. * glib/Opaque.cs: Fix copy/pasted copyright notice, remove data and event fields. Fix docs. * glib/Value.cs: Work correctly with boxed properties. * gnome/Modules.cs: Use new struct ctors. * gnome/Program.custom: Remove Get, this is being generated now. * parser/Gdk.metadata: Fix the drawable classes to inherit correctly. * parser/Metadata.pm: Change per-class attributes to actually be attributes. * parser/Gtk.metadata: Add a dummy attribute value for disabledefaultctor. * parser/gapi2xml.pl: Add hacks for the (broken) Drawable and Bitmap typedefs. * sample/test/TestColorSelection.cs: Display color string in hex format, update to use IsNull instead of == null, and size dialog to look pretty. * sample/Size.cs: Added. svn path=/trunk/gtk-sharp/; revision=6264
This commit is contained in:
parent
9823d2d8ea
commit
967e3e9c5a
24 changed files with 376 additions and 111 deletions
51
ChangeLog
51
ChangeLog
|
@ -1,3 +1,54 @@
|
||||||
|
2002-07-30 Rachel Hestilow <hestilow@ximian.com>
|
||||||
|
|
||||||
|
* generator/ClassBase.cs: Change hasDefaultConstructor to protected,
|
||||||
|
adjust now that it is an attr and not a subnode. Also add virtual
|
||||||
|
property AssignToName (for ctors).
|
||||||
|
|
||||||
|
* generator/Ctor.cs: Add property ForceStatic.
|
||||||
|
(Generate): Optimize return code a bit for the static case.
|
||||||
|
|
||||||
|
* generator/Method.cs: Assign to a "raw_ret" pointer before calling
|
||||||
|
FromNativeReturn.
|
||||||
|
|
||||||
|
* generator/Parameters.cs: Change "out ref" to "out", not "ref".
|
||||||
|
|
||||||
|
* generator/Property.cs: Fix to work correctly with all object and
|
||||||
|
struct types (mostly just some if-cases added).
|
||||||
|
|
||||||
|
* generator/SignalHandler.cs: Remove args_type and argfields (unused).
|
||||||
|
(Generate): Initialize struct if necessary.
|
||||||
|
|
||||||
|
* generator/StructBase.cs: Massive reworking to support methods, ctors,
|
||||||
|
etc.
|
||||||
|
|
||||||
|
* generator/SymbolTable.cs: Add GdkAtom and gconstpointer simple types.
|
||||||
|
|
||||||
|
* glib/Boxed.cs: Accept both IntPtr and object ctors. Add access for both.
|
||||||
|
|
||||||
|
* glib/Opaque.cs: Fix copy/pasted copyright notice, remove data and event
|
||||||
|
fields. Fix docs.
|
||||||
|
|
||||||
|
* glib/Value.cs: Work correctly with boxed properties.
|
||||||
|
|
||||||
|
* gnome/Modules.cs: Use new struct ctors.
|
||||||
|
|
||||||
|
* gnome/Program.custom: Remove Get, this is being generated now.
|
||||||
|
|
||||||
|
* parser/Gdk.metadata: Fix the drawable classes to inherit correctly.
|
||||||
|
|
||||||
|
* parser/Metadata.pm: Change per-class attributes to actually be
|
||||||
|
attributes.
|
||||||
|
|
||||||
|
* parser/Gtk.metadata: Add a dummy attribute value for disabledefaultctor.
|
||||||
|
|
||||||
|
* parser/gapi2xml.pl: Add hacks for the (broken) Drawable and Bitmap
|
||||||
|
typedefs.
|
||||||
|
|
||||||
|
* sample/test/TestColorSelection.cs: Display color string in hex format,
|
||||||
|
update to use IsNull instead of == null, and size dialog to look pretty.
|
||||||
|
|
||||||
|
* sample/Size.cs: Added.
|
||||||
|
|
||||||
2002-07-25 Rachel Hestilow <hestilow@ximian.com>
|
2002-07-25 Rachel Hestilow <hestilow@ximian.com>
|
||||||
|
|
||||||
[about 60% of the marshalling patch that I lost.
|
[about 60% of the marshalling patch that I lost.
|
||||||
|
|
|
@ -19,7 +19,7 @@ namespace GtkSharp.Generation {
|
||||||
protected ArrayList interfaces = null;
|
protected ArrayList interfaces = null;
|
||||||
protected ArrayList ctors = new ArrayList();
|
protected ArrayList ctors = new ArrayList();
|
||||||
|
|
||||||
private bool hasDefaultConstructor = true;
|
protected bool hasDefaultConstructor = true;
|
||||||
private bool ctors_initted = false;
|
private bool ctors_initted = false;
|
||||||
private Hashtable clash_map;
|
private Hashtable clash_map;
|
||||||
|
|
||||||
|
@ -43,6 +43,8 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
|
|
||||||
protected ClassBase (XmlElement ns, XmlElement elem) : base (ns, elem) {
|
protected ClassBase (XmlElement ns, XmlElement elem) : base (ns, elem) {
|
||||||
|
hasDefaultConstructor = !elem.HasAttribute ("disabledefaultconstructor");
|
||||||
|
|
||||||
foreach (XmlNode node in elem.ChildNodes) {
|
foreach (XmlNode node in elem.ChildNodes) {
|
||||||
if (!(node is XmlElement)) continue;
|
if (!(node is XmlElement)) continue;
|
||||||
XmlElement member = (XmlElement) node;
|
XmlElement member = (XmlElement) node;
|
||||||
|
@ -73,10 +75,6 @@ namespace GtkSharp.Generation {
|
||||||
ctors.Add (new Ctor (LibraryName, member, this));
|
ctors.Add (new Ctor (LibraryName, member, this));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "disabledefaultconstructor":
|
|
||||||
hasDefaultConstructor = false;
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -123,6 +121,10 @@ namespace GtkSharp.Generation {
|
||||||
return "Handle";
|
return "Handle";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public virtual String AssignToName {
|
||||||
|
get { return "Raw"; }
|
||||||
|
}
|
||||||
|
|
||||||
public virtual String FromNative(String var)
|
public virtual String FromNative(String var)
|
||||||
{
|
{
|
||||||
return "(" + QualifiedName + ") GLib.Object.GetObject(" + var + ")";
|
return "(" + QualifiedName + ") GLib.Object.GetObject(" + var + ")";
|
||||||
|
|
|
@ -19,12 +19,18 @@ namespace GtkSharp.Generation {
|
||||||
private bool preferred;
|
private bool preferred;
|
||||||
private String clashName = null;
|
private String clashName = null;
|
||||||
private ClassBase container_type;
|
private ClassBase container_type;
|
||||||
|
private bool force_static;
|
||||||
|
|
||||||
public bool Preferred {
|
public bool Preferred {
|
||||||
get { return preferred; }
|
get { return preferred; }
|
||||||
set { preferred = value; }
|
set { preferred = value; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public bool ForceStatic {
|
||||||
|
get { return force_static; }
|
||||||
|
set { force_static = value; }
|
||||||
|
}
|
||||||
|
|
||||||
public Ctor (string libname, XmlElement elem, ClassBase container_type) {
|
public Ctor (string libname, XmlElement elem, ClassBase container_type) {
|
||||||
this.libname = libname;
|
this.libname = libname;
|
||||||
this.elem = elem;
|
this.elem = elem;
|
||||||
|
@ -71,7 +77,7 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
int clashes = (int) clash_map[sigtypes];
|
int clashes = (int) clash_map[sigtypes];
|
||||||
string cname = elem.GetAttribute("cname");
|
string cname = elem.GetAttribute("cname");
|
||||||
if (clashes > 0 && !Preferred) {
|
if (force_static || (clashes > 0 && !Preferred)) {
|
||||||
String mname = cname.Substring(cname.IndexOf("new"));
|
String mname = cname.Substring(cname.IndexOf("new"));
|
||||||
mname = mname.Substring(0,1).ToUpper() + mname.Substring(1);
|
mname = mname.Substring(0,1).ToUpper() + mname.Substring(1);
|
||||||
int idx;
|
int idx;
|
||||||
|
@ -126,20 +132,26 @@ namespace GtkSharp.Generation {
|
||||||
|
|
||||||
sw.WriteLine("\t\tpublic static " + safety + modifiers + name + " " + clashName);
|
sw.WriteLine("\t\tpublic static " + safety + modifiers + name + " " + clashName);
|
||||||
sw.WriteLine("\t\t{");
|
sw.WriteLine("\t\t{");
|
||||||
if (parms != null)
|
|
||||||
parms.Initialize(sw, false, "");
|
|
||||||
sw.WriteLine("\t\t\tIntPtr ret = " + cname + call + ";");
|
|
||||||
if (parms != null)
|
if (parms != null)
|
||||||
parms.HandleException (sw, "");
|
parms.HandleException (sw, "");
|
||||||
sw.WriteLine("\t\t\treturn new " + name + "(ret);");
|
|
||||||
|
sw.Write("\t\t\treturn ");
|
||||||
|
if (container_type is StructBase)
|
||||||
|
sw.Write ("{0}.New (", name);
|
||||||
|
else
|
||||||
|
sw.Write ("new {0} (", name);
|
||||||
|
sw.WriteLine (cname + call + ");");
|
||||||
} else {
|
} else {
|
||||||
sw.WriteLine("\t\tpublic " + safety + name + sig);
|
sw.WriteLine("\t\tpublic " + safety + name + sig);
|
||||||
sw.WriteLine("\t\t{");
|
sw.WriteLine("\t\t{");
|
||||||
|
|
||||||
if (parms != null)
|
if (parms != null)
|
||||||
parms.Initialize(sw, false, "");
|
parms.Initialize(sw, false, "");
|
||||||
sw.WriteLine("\t\t\tRaw = " + cname + call + ";");
|
sw.WriteLine("\t\t\t{0} = {1}{2};", container_type.AssignToName, cname, call);
|
||||||
if (parms != null)
|
if (parms != null)
|
||||||
parms.HandleException (sw, "");
|
parms.HandleException (sw, "");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sw.WriteLine("\t\t}");
|
sw.WriteLine("\t\t}");
|
||||||
|
|
|
@ -349,8 +349,11 @@ namespace GtkSharp.Generation {
|
||||||
sw.WriteLine(indent +"\t\t\t" + s_ret + " ret = " + SymbolTable.FromNativeReturn(rettype, "raw_ret") + ";");
|
sw.WriteLine(indent +"\t\t\t" + s_ret + " ret = " + SymbolTable.FromNativeReturn(rettype, "raw_ret") + ";");
|
||||||
sw.WriteLine(indent + "\t\t\tif (ret == null) ret = new " + s_ret + "(raw_ret);");
|
sw.WriteLine(indent + "\t\t\tif (ret == null) ret = new " + s_ret + "(raw_ret);");
|
||||||
}
|
}
|
||||||
else
|
else {
|
||||||
sw.WriteLine(s_ret + " ret = " + SymbolTable.FromNativeReturn(rettype, cname + call) + ";");
|
sw.WriteLine(m_ret + " raw_ret = " + cname + call + ";");
|
||||||
|
sw.Write(indent + "\t\t\t");
|
||||||
|
sw.WriteLine(s_ret + " ret = " + SymbolTable.FromNativeReturn(rettype, "raw_ret") + ";");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (parms != null)
|
if (parms != null)
|
||||||
|
|
|
@ -226,8 +226,8 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
import_sig += (m_type + " " + name);
|
import_sig += (m_type + " " + name);
|
||||||
// FIXME: lame
|
// FIXME: lame
|
||||||
call_string = call_string.Replace ("out ref", "ref");
|
call_string = call_string.Replace ("out ref", "out");
|
||||||
import_sig = import_sig.Replace ("out ref", "ref");
|
import_sig = import_sig.Replace ("out ref", "out");
|
||||||
|
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
|
|
@ -74,7 +74,7 @@ namespace GtkSharp.Generation {
|
||||||
Statistics.ThrottledCount++;
|
Statistics.ThrottledCount++;
|
||||||
return;
|
return;
|
||||||
} else if (SymbolTable.IsObject(c_type)) {
|
} else if (SymbolTable.IsObject(c_type)) {
|
||||||
v_type = "(GLib.Object)";
|
v_type = "(GLib.UnwrappedObject)";
|
||||||
} else if (SymbolTable.IsBoxed (c_type)) {
|
} else if (SymbolTable.IsBoxed (c_type)) {
|
||||||
v_type = "(GLib.Boxed)";
|
v_type = "(GLib.Boxed)";
|
||||||
} else if (SymbolTable.IsOpaque (c_type)) {
|
} else if (SymbolTable.IsOpaque (c_type)) {
|
||||||
|
@ -95,22 +95,19 @@ namespace GtkSharp.Generation {
|
||||||
sw.WriteLine("\t\t\tget {");
|
sw.WriteLine("\t\t\tget {");
|
||||||
sw.WriteLine("\t\t\t\tGLib.Value val = new GLib.Value (Handle, " + cname + ");");
|
sw.WriteLine("\t\t\t\tGLib.Value val = new GLib.Value (Handle, " + cname + ");");
|
||||||
sw.WriteLine("\t\t\t\tGetProperty(" + cname + ", val);");
|
sw.WriteLine("\t\t\t\tGetProperty(" + cname + ", val);");
|
||||||
if (SymbolTable.IsObject (c_type) || SymbolTable.IsOpaque (c_type)) {
|
if (SymbolTable.IsObject (c_type) || SymbolTable.IsOpaque (c_type) || SymbolTable.IsBoxed (c_type)) {
|
||||||
sw.WriteLine("\t\t\t\tSystem.IntPtr raw_ret = (System.IntPtr) (GLib.UnwrappedObject) val;");
|
sw.WriteLine("\t\t\t\tSystem.IntPtr raw_ret = (System.IntPtr) {0} val;", v_type);
|
||||||
sw.WriteLine("\t\t\t\t" + cs_type + " ret = " + SymbolTable.FromNativeReturn(c_type, "raw_ret") + ";");
|
sw.WriteLine("\t\t\t\t" + cs_type + " ret = " + SymbolTable.FromNativeReturn(c_type, "raw_ret") + ";");
|
||||||
|
if (!SymbolTable.IsBoxed (c_type))
|
||||||
sw.WriteLine("\t\t\t\tif (ret == null) ret = new " + cs_type + "(raw_ret);");
|
sw.WriteLine("\t\t\t\tif (ret == null) ret = new " + cs_type + "(raw_ret);");
|
||||||
} else {
|
} else {
|
||||||
sw.Write("\t\t\t\t" + cs_type + " ret = ");
|
sw.Write("\t\t\t\t" + cs_type + " ret = ");
|
||||||
if (SymbolTable.IsBoxed (c_type)) {
|
|
||||||
sw.WriteLine ("({0}) (({1} val).Obj);", cs_type, v_type);
|
|
||||||
} else {
|
|
||||||
sw.Write ("(" + cs_type + ") ");
|
sw.Write ("(" + cs_type + ") ");
|
||||||
if (v_type != "") {
|
if (v_type != "") {
|
||||||
sw.Write(v_type + " ");
|
sw.Write(v_type + " ");
|
||||||
}
|
}
|
||||||
sw.WriteLine("val;");
|
sw.WriteLine("val;");
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
sw.WriteLine("\t\t\t\treturn ret;");
|
sw.WriteLine("\t\t\t\treturn ret;");
|
||||||
sw.WriteLine("\t\t\t}");
|
sw.WriteLine("\t\t\t}");
|
||||||
|
@ -124,7 +121,7 @@ namespace GtkSharp.Generation {
|
||||||
} else if (SymbolTable.IsBoxed (c_type)) {
|
} else if (SymbolTable.IsBoxed (c_type)) {
|
||||||
sw.WriteLine("Handle, " + cname + ", new GLib.Boxed (value)));");
|
sw.WriteLine("Handle, " + cname + ", new GLib.Boxed (value)));");
|
||||||
} else {
|
} else {
|
||||||
if (v_type != "") {
|
if (v_type != "" && !(SymbolTable.IsObject (c_type) || SymbolTable.IsOpaque (c_type))) {
|
||||||
sw.Write(v_type + " ");
|
sw.Write(v_type + " ");
|
||||||
}
|
}
|
||||||
sw.WriteLine("value));");
|
sw.WriteLine("value));");
|
||||||
|
|
|
@ -14,7 +14,6 @@ namespace GtkSharp.Generation {
|
||||||
public class SignalHandler {
|
public class SignalHandler {
|
||||||
|
|
||||||
private static Hashtable handlers = new Hashtable ();
|
private static Hashtable handlers = new Hashtable ();
|
||||||
private string args_type;
|
|
||||||
|
|
||||||
public static String GetName(XmlElement sig)
|
public static String GetName(XmlElement sig)
|
||||||
{
|
{
|
||||||
|
@ -40,7 +39,6 @@ namespace GtkSharp.Generation {
|
||||||
string key = retval;
|
string key = retval;
|
||||||
string pinv = "";
|
string pinv = "";
|
||||||
string name = SymbolTable.GetName(retval);
|
string name = SymbolTable.GetName(retval);
|
||||||
string argfields = "";
|
|
||||||
int pcnt = 0;
|
int pcnt = 0;
|
||||||
|
|
||||||
ArrayList parms = new ArrayList();
|
ArrayList parms = new ArrayList();
|
||||||
|
@ -152,8 +150,11 @@ namespace GtkSharp.Generation {
|
||||||
sw.WriteLine("= GLib.Object.GetObject(arg" + idx + ");");
|
sw.WriteLine("= GLib.Object.GetObject(arg" + idx + ");");
|
||||||
} else {
|
} else {
|
||||||
string ctype = (string) parms[idx];
|
string ctype = (string) parms[idx];
|
||||||
sw.WriteLine("\t\t\targs.Args[" + (idx-1) + "] = " + SymbolTable.FromNative (ctype, "arg" + idx) + ";");
|
|
||||||
ClassBase wrapper = SymbolTable.GetClassGen (ctype);
|
ClassBase wrapper = SymbolTable.GetClassGen (ctype);
|
||||||
|
if (wrapper != null && (wrapper is StructBase)) {
|
||||||
|
sw.WriteLine("\t\t\targ{0}._Initialize ();", idx);
|
||||||
|
}
|
||||||
|
sw.WriteLine("\t\t\targs.Args[" + (idx-1) + "] = " + SymbolTable.FromNative (ctype, "arg" + idx) + ";");
|
||||||
if ((wrapper != null && ((wrapper is ObjectGen) || (wrapper is OpaqueGen))) || SymbolTable.IsManuallyWrapped (ctype)) {
|
if ((wrapper != null && ((wrapper is ObjectGen) || (wrapper is OpaqueGen))) || SymbolTable.IsManuallyWrapped (ctype)) {
|
||||||
sw.WriteLine("\t\t\tif (args.Args[" + (idx-1) + "] == null)");
|
sw.WriteLine("\t\t\tif (args.Args[" + (idx-1) + "] == null)");
|
||||||
sw.WriteLine("\t\t\t\targs.Args[{0}] = new {1}(arg{2});", idx-1, SymbolTable.GetCSType (ctype), idx);
|
sw.WriteLine("\t\t\t\targs.Args[{0}] = new {1}(arg{2});", idx-1, SymbolTable.GetCSType (ctype), idx);
|
||||||
|
|
|
@ -14,7 +14,34 @@ namespace GtkSharp.Generation {
|
||||||
|
|
||||||
public class StructBase : ClassBase {
|
public class StructBase : ClassBase {
|
||||||
|
|
||||||
public StructBase (XmlElement ns, XmlElement elem) : base (ns, elem) {}
|
ArrayList fields = new ArrayList ();
|
||||||
|
uint bitfields;
|
||||||
|
|
||||||
|
public StructBase (XmlElement ns, XmlElement elem) : base (ns, elem)
|
||||||
|
{
|
||||||
|
hasDefaultConstructor = false;
|
||||||
|
|
||||||
|
foreach (XmlNode node in elem.ChildNodes) {
|
||||||
|
|
||||||
|
if (!(node is XmlElement)) continue;
|
||||||
|
XmlElement member = (XmlElement) node;
|
||||||
|
|
||||||
|
switch (node.Name) {
|
||||||
|
case "field":
|
||||||
|
fields.Add (member);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case "callback":
|
||||||
|
Statistics.IgnoreCount++;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
if (!IsNodeNameHandled (node.Name))
|
||||||
|
Console.WriteLine ("Unexpected node " + node.Name + " in " + CName);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public override String MarshalType {
|
public override String MarshalType {
|
||||||
get
|
get
|
||||||
|
@ -40,6 +67,10 @@ namespace GtkSharp.Generation {
|
||||||
return "ref this";
|
return "ref this";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public override String AssignToName {
|
||||||
|
get { return "raw"; }
|
||||||
|
}
|
||||||
|
|
||||||
public override String FromNative(String var)
|
public override String FromNative(String var)
|
||||||
{
|
{
|
||||||
return var;
|
return var;
|
||||||
|
@ -47,33 +78,71 @@ namespace GtkSharp.Generation {
|
||||||
|
|
||||||
public override String FromNativeReturn(String var)
|
public override String FromNativeReturn(String var)
|
||||||
{
|
{
|
||||||
return "new " + QualifiedName + " (" + var + ")";
|
return QualifiedName + ".New (" + var + ")";
|
||||||
}
|
}
|
||||||
|
|
||||||
protected bool GenField (XmlElement field, StreamWriter sw)
|
bool IsBit (XmlElement field)
|
||||||
{
|
{
|
||||||
String c_type;
|
return (field.HasAttribute("bits") && (field.GetAttribute("bits") == "1"));
|
||||||
|
|
||||||
if (field.HasAttribute("bits") && (field.GetAttribute("bits") == "1")) {
|
|
||||||
c_type = "gboolean";
|
|
||||||
} else {
|
|
||||||
c_type = field.GetAttribute("type");
|
|
||||||
}
|
}
|
||||||
char[] ast = {'*'};
|
|
||||||
c_type = c_type.TrimEnd(ast);
|
|
||||||
String m_type = SymbolTable.GetMarshalType(c_type);
|
|
||||||
|
|
||||||
if (m_type == "") {
|
bool IsPointer (XmlElement field)
|
||||||
|
{
|
||||||
|
string c_type = field.GetAttribute("type");
|
||||||
|
return (c_type[c_type.Length - 1] == '*');
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void GenFields (StreamWriter sw)
|
||||||
|
{
|
||||||
|
bitfields = 0;
|
||||||
|
bool need_field = true;
|
||||||
|
foreach (XmlElement field in fields) {
|
||||||
|
if (IsBit (field)) {
|
||||||
|
if (need_field)
|
||||||
|
need_field = false;
|
||||||
|
else
|
||||||
|
continue;
|
||||||
|
} else
|
||||||
|
need_field = true;
|
||||||
|
GenField (field, sw);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected bool GetFieldInfo (XmlElement field, out string type, out string name)
|
||||||
|
{
|
||||||
|
name = "";
|
||||||
|
if (IsBit (field))
|
||||||
|
type = "uint";
|
||||||
|
else if (IsPointer (field)) {
|
||||||
|
type = "IntPtr";
|
||||||
|
name = "_";
|
||||||
|
} else {
|
||||||
|
string c_type = field.GetAttribute ("type");
|
||||||
|
type = SymbolTable.GetCSType (c_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;
|
||||||
}
|
}
|
||||||
|
|
||||||
sw.Write ("\t\t public " + m_type);
|
|
||||||
if (field.HasAttribute("array_len")) {
|
|
||||||
sw.Write ("[]");
|
|
||||||
}
|
}
|
||||||
sw.WriteLine (" " + MangleName(field.GetAttribute("cname")) + ";");
|
|
||||||
|
if (field.HasAttribute("array_len"))
|
||||||
|
type += "[]";
|
||||||
|
|
||||||
|
if (IsBit (field))
|
||||||
|
name = String.Format ("_bitfield{0}", bitfields++);
|
||||||
|
else
|
||||||
|
name += MangleName (field.GetAttribute ("cname"));
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected bool GenField (XmlElement field, StreamWriter sw)
|
||||||
|
{
|
||||||
|
string type, name;
|
||||||
|
if (!GetFieldInfo (field, out type, out name))
|
||||||
|
return false;
|
||||||
|
sw.WriteLine ("\t\tpublic {0} {1};", type, name);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -109,7 +178,10 @@ namespace GtkSharp.Generation {
|
||||||
sw.WriteLine ("\tpublic struct " + Name + " {");
|
sw.WriteLine ("\tpublic struct " + Name + " {");
|
||||||
sw.WriteLine ();
|
sw.WriteLine ();
|
||||||
|
|
||||||
|
GenFields (sw);
|
||||||
|
sw.WriteLine ();
|
||||||
GenCtors (sw);
|
GenCtors (sw);
|
||||||
|
GenMethods (sw, null, null, true);
|
||||||
AppendCustom(sw);
|
AppendCustom(sw);
|
||||||
|
|
||||||
sw.WriteLine ("\t}");
|
sw.WriteLine ("\t}");
|
||||||
|
@ -118,9 +190,30 @@ namespace GtkSharp.Generation {
|
||||||
|
|
||||||
protected override void GenCtors (StreamWriter sw)
|
protected override void GenCtors (StreamWriter sw)
|
||||||
{
|
{
|
||||||
sw.WriteLine("\t\tpublic " + Name + "(IntPtr raw) {}");
|
sw.WriteLine ("\t\tbool _is_null;");
|
||||||
|
sw.WriteLine ("\t\tpublic bool IsNull {");
|
||||||
|
sw.WriteLine ("\t\t\tget { return _is_null; }");
|
||||||
|
sw.WriteLine ("\t\t}");
|
||||||
|
sw.WriteLine ("\t\tpublic void _Initialize () {");
|
||||||
|
sw.WriteLine ("\t\t\t_is_null = false;");
|
||||||
|
sw.WriteLine ("\t\t}");
|
||||||
sw.WriteLine();
|
sw.WriteLine();
|
||||||
//base.GenCtors (sw);
|
sw.WriteLine ("\t\tpublic static " + QualifiedName + " New(IntPtr raw) {");
|
||||||
|
sw.WriteLine ("\t\t\t{0} self = new {0}();", QualifiedName);
|
||||||
|
sw.WriteLine ("\t\t\tif (raw == IntPtr.Zero) {");
|
||||||
|
sw.WriteLine ("\t\t\t\tself._is_null = true;");
|
||||||
|
sw.WriteLine ("\t\t\t} else {");
|
||||||
|
sw.WriteLine ("\t\t\t\tself = ({0}) Marshal.PtrToStructure (raw, self.GetType ());", QualifiedName);
|
||||||
|
sw.WriteLine ("\t\t\t\tself._is_null = false;");
|
||||||
|
sw.WriteLine ("\t\t\t}");
|
||||||
|
sw.WriteLine ("\t\t\treturn self;");
|
||||||
|
sw.WriteLine ("\t\t}");
|
||||||
|
sw.WriteLine();
|
||||||
|
|
||||||
|
foreach (Ctor ctor in Ctors) {
|
||||||
|
ctor.ForceStatic = true;
|
||||||
|
}
|
||||||
|
base.GenCtors (sw);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,6 +26,7 @@ namespace GtkSharp.Generation {
|
||||||
simple_types.Add ("guint", "uint");
|
simple_types.Add ("guint", "uint");
|
||||||
simple_types.Add ("glong", "long");
|
simple_types.Add ("glong", "long");
|
||||||
simple_types.Add ("gshort", "short");
|
simple_types.Add ("gshort", "short");
|
||||||
|
simple_types.Add ("gushort", "ushort");
|
||||||
simple_types.Add ("guint32", "uint");
|
simple_types.Add ("guint32", "uint");
|
||||||
simple_types.Add ("const-gchar", "string");
|
simple_types.Add ("const-gchar", "string");
|
||||||
simple_types.Add ("const-char", "string");
|
simple_types.Add ("const-char", "string");
|
||||||
|
@ -71,6 +72,8 @@ namespace GtkSharp.Generation {
|
||||||
simple_types.Add ("GHashTable", "System.IntPtr");
|
simple_types.Add ("GHashTable", "System.IntPtr");
|
||||||
simple_types.Add ("va_list", "System.IntPtr");
|
simple_types.Add ("va_list", "System.IntPtr");
|
||||||
simple_types.Add ("GParamSpec", "System.IntPtr");
|
simple_types.Add ("GParamSpec", "System.IntPtr");
|
||||||
|
simple_types.Add ("GdkAtom", "System.IntPtr");
|
||||||
|
simple_types.Add ("gconstpointer", "System.IntPtr");
|
||||||
|
|
||||||
manually_wrapped_types = new Hashtable ();
|
manually_wrapped_types = new Hashtable ();
|
||||||
manually_wrapped_types.Add ("GdkEvent", "Gdk.Event");
|
manually_wrapped_types.Add ("GdkEvent", "Gdk.Event");
|
||||||
|
|
|
@ -2624,7 +2624,7 @@
|
||||||
</parameters>
|
</parameters>
|
||||||
</method>
|
</method>
|
||||||
</object>
|
</object>
|
||||||
<object name="Pixmap" cname="GdkPixmap" parent="GObject">
|
<object name="Pixmap" cname="GdkPixmap" parent="GdkDrawable">
|
||||||
<method name="ColormapCreateFromXpm" cname="gdk_pixmap_colormap_create_from_xpm" shared="true">
|
<method name="ColormapCreateFromXpm" cname="gdk_pixmap_colormap_create_from_xpm" shared="true">
|
||||||
<return-type type="GdkPixmap*"/>
|
<return-type type="GdkPixmap*"/>
|
||||||
<parameters>
|
<parameters>
|
||||||
|
@ -2752,7 +2752,7 @@
|
||||||
<return-type type="GType"/>
|
<return-type type="GType"/>
|
||||||
</method>
|
</method>
|
||||||
</object>
|
</object>
|
||||||
<object name="Window" cname="GdkWindow" parent="GObject">
|
<object name="Window" cname="GdkWindow" parent="GdkDrawable">
|
||||||
<method name="AddFilter" cname="gdk_window_add_filter">
|
<method name="AddFilter" cname="gdk_window_add_filter">
|
||||||
<return-type type="void"/>
|
<return-type type="void"/>
|
||||||
<parameters>
|
<parameters>
|
||||||
|
@ -3254,7 +3254,7 @@
|
||||||
<return-type type="void"/>
|
<return-type type="void"/>
|
||||||
</method>
|
</method>
|
||||||
</object>
|
</object>
|
||||||
<struct name="Bitmap" cname="GdkBitmap">
|
<object name="Bitmap" cname="GdkBitmap" parent="GdkDrawable">
|
||||||
<field cname="parent_instance" type="GObject"/>
|
<field cname="parent_instance" type="GObject"/>
|
||||||
<method name="CreateFromData" cname="gdk_bitmap_create_from_data" shared="true">
|
<method name="CreateFromData" cname="gdk_bitmap_create_from_data" shared="true">
|
||||||
<return-type type="GdkBitmap*"/>
|
<return-type type="GdkBitmap*"/>
|
||||||
|
@ -3265,7 +3265,7 @@
|
||||||
<parameter type="gint" name="height"/>
|
<parameter type="gint" name="height"/>
|
||||||
</parameters>
|
</parameters>
|
||||||
</method>
|
</method>
|
||||||
</struct>
|
</object>
|
||||||
<boxed name="Color" cname="GdkColor">
|
<boxed name="Color" cname="GdkColor">
|
||||||
<field cname="pixel" type="guint32"/>
|
<field cname="pixel" type="guint32"/>
|
||||||
<field cname="red" type="guint16"/>
|
<field cname="red" type="guint16"/>
|
||||||
|
@ -9051,7 +9051,7 @@
|
||||||
<return-type type="GtkType"/>
|
<return-type type="GtkType"/>
|
||||||
</method>
|
</method>
|
||||||
</object>
|
</object>
|
||||||
<object name="ScrolledWindow" cname="GtkScrolledWindow" parent="GtkBin">
|
<object name="ScrolledWindow" cname="GtkScrolledWindow" parent="GtkBin" disabledefaultconstructor="1">
|
||||||
<field cname="hscrollbar" type="GtkWidget*"/>
|
<field cname="hscrollbar" type="GtkWidget*"/>
|
||||||
<field cname="vscrollbar" type="GtkWidget*"/>
|
<field cname="vscrollbar" type="GtkWidget*"/>
|
||||||
<field cname="hscrollbar_policy" bits="2" type="guint"/>
|
<field cname="hscrollbar_policy" bits="2" type="guint"/>
|
||||||
|
@ -9147,7 +9147,6 @@
|
||||||
<parameter type="GtkAdjustment*" name="hadjustment"/>
|
<parameter type="GtkAdjustment*" name="hadjustment"/>
|
||||||
</parameters>
|
</parameters>
|
||||||
</method>
|
</method>
|
||||||
<disabledefaultconstructor/>
|
|
||||||
</object>
|
</object>
|
||||||
<object name="Separator" cname="GtkSeparator" parent="GtkWidget">
|
<object name="Separator" cname="GtkSeparator" parent="GtkWidget">
|
||||||
<method name="GetType" cname="gtk_separator_get_type" shared="true">
|
<method name="GetType" cname="gtk_separator_get_type" shared="true">
|
||||||
|
|
|
@ -17,7 +17,8 @@ namespace GLib {
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
|
|
||||||
public class Boxed {
|
public class Boxed {
|
||||||
object raw;
|
object obj;
|
||||||
|
IntPtr raw;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Boxed Constructor
|
/// Boxed Constructor
|
||||||
|
@ -29,7 +30,12 @@ namespace GLib {
|
||||||
|
|
||||||
public Boxed (object o)
|
public Boxed (object o)
|
||||||
{
|
{
|
||||||
this.raw = raw;
|
this.obj = obj;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Boxed (IntPtr ptr)
|
||||||
|
{
|
||||||
|
this.raw = ptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -39,8 +45,7 @@ namespace GLib {
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
/// Gets a marshallable IntPtr.
|
/// Gets a marshallable IntPtr.
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
|
public virtual IntPtr Handle {
|
||||||
public virtual object Obj {
|
|
||||||
get {
|
get {
|
||||||
return raw;
|
return raw;
|
||||||
}
|
}
|
||||||
|
@ -48,5 +53,18 @@ namespace GLib {
|
||||||
raw = value;
|
raw = value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static explicit operator System.IntPtr (Boxed boxed) {
|
||||||
|
return boxed.Handle;
|
||||||
|
}
|
||||||
|
|
||||||
|
public virtual object Obj {
|
||||||
|
get {
|
||||||
|
return obj;
|
||||||
|
}
|
||||||
|
set {
|
||||||
|
obj = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,10 @@
|
||||||
// Object.cs - GObject class wrapper implementation
|
// Opaque .cs - Opaque struct wrapper implementation
|
||||||
//
|
//
|
||||||
// Authors: Bob Smith <bob@thestuff.net>
|
// Authors: Bob Smith <bob@thestuff.net>
|
||||||
// Mike Kestner <mkestner@speakeasy.net>
|
// Mike Kestner <mkestner@speakeasy.net>
|
||||||
|
// Rachel Hestilow <hestilow@ximian.com>
|
||||||
//
|
//
|
||||||
// (c) 2001 Bob Smith and Mike Kestner
|
// (c) 2001 Bob Smith and Mike Kestner, 2002 Rachel Hestilow
|
||||||
|
|
||||||
namespace GLib {
|
namespace GLib {
|
||||||
|
|
||||||
|
@ -24,8 +25,6 @@ namespace GLib {
|
||||||
|
|
||||||
// Private class and instance members
|
// Private class and instance members
|
||||||
IntPtr _obj;
|
IntPtr _obj;
|
||||||
EventHandlerList _events;
|
|
||||||
Hashtable Data;
|
|
||||||
static Hashtable Opaques = new Hashtable();
|
static Hashtable Opaques = new Hashtable();
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -37,7 +36,7 @@ namespace GLib {
|
||||||
/// given raw object pointer. This method is primarily
|
/// given raw object pointer. This method is primarily
|
||||||
/// used to wrap object references that are returned
|
/// used to wrap object references that are returned
|
||||||
/// by either the signal system or raw class methods that
|
/// by either the signal system or raw class methods that
|
||||||
/// return GObject references.
|
/// return opaque struct references.
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
///
|
///
|
||||||
/// <returns>
|
/// <returns>
|
||||||
|
@ -52,7 +51,7 @@ namespace GLib {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Object Constructor
|
/// Opaque Constructor
|
||||||
/// </summary>
|
/// </summary>
|
||||||
///
|
///
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
|
@ -62,11 +61,11 @@ namespace GLib {
|
||||||
public Opaque () {}
|
public Opaque () {}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Object Constructor
|
/// Opaque Constructor
|
||||||
/// </summary>
|
/// </summary>
|
||||||
///
|
///
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
/// Creates an object from a raw object reference.
|
/// Creates an opaque wrapper from a raw object reference.
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
|
|
||||||
public Opaque (IntPtr raw)
|
public Opaque (IntPtr raw)
|
||||||
|
@ -79,8 +78,8 @@ namespace GLib {
|
||||||
/// </summary>
|
/// </summary>
|
||||||
///
|
///
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
/// The raw GObject reference associated with this wrapper.
|
/// The raw Opaque reference associated with this wrapper.
|
||||||
/// Only subclasses of Object can access this read/write
|
/// Only subclasses of Opaque can access this read/write
|
||||||
/// property. For public read-only access, use the
|
/// property. For public read-only access, use the
|
||||||
/// Handle property.
|
/// Handle property.
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
|
@ -100,7 +99,7 @@ namespace GLib {
|
||||||
/// </summary>
|
/// </summary>
|
||||||
///
|
///
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
/// The raw GObject reference associated with this object.
|
/// The raw Opaque reference associated with this object.
|
||||||
/// Subclasses can use Raw property for read/write
|
/// Subclasses can use Raw property for read/write
|
||||||
/// access.
|
/// access.
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
|
@ -134,5 +133,9 @@ namespace GLib {
|
||||||
{
|
{
|
||||||
return Handle.GetHashCode ();
|
return Handle.GetHashCode ();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static explicit operator System.IntPtr (Opaque opaque) {
|
||||||
|
return opaque.Handle;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -288,10 +288,7 @@ namespace GLib {
|
||||||
|
|
||||||
public static explicit operator GLib.Boxed (Value val)
|
public static explicit operator GLib.Boxed (Value val)
|
||||||
{
|
{
|
||||||
// FIXME: Insert an appropriate exception here if
|
return new GLib.Boxed (g_value_get_boxed (val._val));
|
||||||
// _val.type indicates an error.
|
|
||||||
// FIXME: Figure out how to wrap this boxed type
|
|
||||||
return null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
[DllImport("gobject-2.0")]
|
[DllImport("gobject-2.0")]
|
||||||
|
|
|
@ -11,11 +11,15 @@ namespace Gnome
|
||||||
static extern System.IntPtr libgnomeui_module_info_get ();
|
static extern System.IntPtr libgnomeui_module_info_get ();
|
||||||
|
|
||||||
public static ModuleInfo LibGnome {
|
public static ModuleInfo LibGnome {
|
||||||
get { return new ModuleInfo (libgnome_module_info_get ()); }
|
get {
|
||||||
|
return ModuleInfo.New (libgnome_module_info_get ());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ModuleInfo UI {
|
public static ModuleInfo UI {
|
||||||
get { return new ModuleInfo (libgnomeui_module_info_get ()); }
|
get {
|
||||||
|
return ModuleInfo.New (libgnomeui_module_info_get ());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -64,17 +64,4 @@ public void Quit ()
|
||||||
Gtk.Application.Quit ();
|
Gtk.Application.Quit ();
|
||||||
}
|
}
|
||||||
|
|
||||||
[DllImport("libgnome-2.so.0")]
|
|
||||||
static extern System.IntPtr gnome_program_get ();
|
|
||||||
|
|
||||||
public static Program Get ()
|
|
||||||
{
|
|
||||||
IntPtr raw = gnome_program_get ();
|
|
||||||
if (raw == IntPtr.Zero)
|
|
||||||
return null;
|
|
||||||
Program program = (Program) GLib.Object.GetObject (raw);
|
|
||||||
if (program == null)
|
|
||||||
program = new Program (raw);
|
|
||||||
return program;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
|
@ -150,8 +150,7 @@ sub addClassData {
|
||||||
|
|
||||||
if (0 == scalar @nodes) {
|
if (0 == scalar @nodes) {
|
||||||
print STDERR "DEBUG> $class $$data[0] $$data[1] $$data[2] $$data[3] $$data[4] $$data[5] $$data[6]\n";
|
print STDERR "DEBUG> $class $$data[0] $$data[1] $$data[2] $$data[3] $$data[4] $$data[5] $$data[6]\n";
|
||||||
my $new_node = $doc->createElement ($$data[5]);
|
$node->setAttribute ($$data[5], $$data[6]);
|
||||||
$node->appendChild ($new_node);
|
|
||||||
}
|
}
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,4 +41,18 @@
|
||||||
</attribute>
|
</attribute>
|
||||||
</data>
|
</data>
|
||||||
</rule>
|
</rule>
|
||||||
|
|
||||||
|
<!-- drawable hacks-->
|
||||||
|
<rule>
|
||||||
|
<class name="GdkBitmap"/>
|
||||||
|
<class name="GdkPixmap"/>
|
||||||
|
<class name="GdkWindow"/>
|
||||||
|
<data>
|
||||||
|
<attribute target="class">
|
||||||
|
<name>parent</name>
|
||||||
|
<value>GdkDrawable</value>
|
||||||
|
</attribute>
|
||||||
|
</data>
|
||||||
|
</rule>
|
||||||
|
|
||||||
</metadata>
|
</metadata>
|
||||||
|
|
|
@ -1205,6 +1205,7 @@
|
||||||
<data>
|
<data>
|
||||||
<attribute target="class">
|
<attribute target="class">
|
||||||
<name>disabledefaultconstructor</name>
|
<name>disabledefaultconstructor</name>
|
||||||
|
<value>1</value>
|
||||||
</attribute>
|
</attribute>
|
||||||
</data>
|
</data>
|
||||||
</rule>
|
</rule>
|
||||||
|
|
|
@ -150,8 +150,7 @@ sub addClassData {
|
||||||
|
|
||||||
if (0 == scalar @nodes) {
|
if (0 == scalar @nodes) {
|
||||||
print STDERR "DEBUG> $class $$data[0] $$data[1] $$data[2] $$data[3] $$data[4] $$data[5] $$data[6]\n";
|
print STDERR "DEBUG> $class $$data[0] $$data[1] $$data[2] $$data[3] $$data[4] $$data[5] $$data[6]\n";
|
||||||
my $new_node = $doc->createElement ($$data[5]);
|
$node->setAttribute ($$data[5], $$data[6]);
|
||||||
$node->appendChild ($new_node);
|
|
||||||
}
|
}
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
|
@ -50,6 +50,8 @@ while ($line = <STDIN>) {
|
||||||
$ptrs{$2} = $1;
|
$ptrs{$2} = $1;
|
||||||
} elsif ($line =~ /typedef\s+(struct\s+\w+)\s+(\w+);/) {
|
} elsif ($line =~ /typedef\s+(struct\s+\w+)\s+(\w+);/) {
|
||||||
next if ($2 =~ /Private$/);
|
next if ($2 =~ /Private$/);
|
||||||
|
# fixme: siiigh
|
||||||
|
$2 = "GdkDrawable" if ($1 eq "_GdkDrawable");
|
||||||
$types{$2} = $1;
|
$types{$2} = $1;
|
||||||
} elsif ($line =~ /typedef\s+(\w+\s+\**)(\w+);/) {
|
} elsif ($line =~ /typedef\s+(\w+\s+\**)(\w+);/) {
|
||||||
$types{$2} = $1;
|
$types{$2} = $1;
|
||||||
|
@ -324,7 +326,11 @@ foreach $key (sort (keys (%types))) {
|
||||||
$def = "privatestruct";
|
$def = "privatestruct";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (exists($boxdefs{$key})) {
|
|
||||||
|
# fixme: hack
|
||||||
|
if ($key eq "GdkBitmap") {
|
||||||
|
$struct_el = addNameElem($ns_elem, 'object', $key, $ns);
|
||||||
|
} elsif (exists($boxdefs{$key})) {
|
||||||
$struct_el = addNameElem($ns_elem, 'boxed', $key, $ns);
|
$struct_el = addNameElem($ns_elem, 'boxed', $key, $ns);
|
||||||
} else {
|
} else {
|
||||||
$struct_el = addNameElem($ns_elem, 'struct', $key, $ns);
|
$struct_el = addNameElem($ns_elem, 'struct', $key, $ns);
|
||||||
|
|
42
sample/Size.cs
Normal file
42
sample/Size.cs
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
// Size.cs - struct marshalling test
|
||||||
|
//
|
||||||
|
// Author: Rachel Hestilow <hestilow@ximian.com>
|
||||||
|
//
|
||||||
|
// (c) 2002 Rachel Hestilow
|
||||||
|
|
||||||
|
namespace GtkSamples {
|
||||||
|
|
||||||
|
using Gtk;
|
||||||
|
using Gdk;
|
||||||
|
using GtkSharp;
|
||||||
|
using System;
|
||||||
|
|
||||||
|
public class SizeTest {
|
||||||
|
|
||||||
|
public static int Main (string[] args)
|
||||||
|
{
|
||||||
|
Application.Init ();
|
||||||
|
Gtk.Window win = new Gtk.Window ("Gtk# Hello World");
|
||||||
|
win.DeleteEvent += new DeleteEventHandler (Window_Delete);
|
||||||
|
win.SizeAllocated += new SizeAllocatedHandler (Size_Allocated);
|
||||||
|
win.ShowAll ();
|
||||||
|
Application.Run ();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void Window_Delete (object obj, DeleteEventArgs args)
|
||||||
|
{
|
||||||
|
SignalArgs sa = (SignalArgs) args;
|
||||||
|
Application.Quit ();
|
||||||
|
sa.RetVal = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void Size_Allocated (object obj, SizeAllocatedArgs args)
|
||||||
|
{
|
||||||
|
Gdk.Rectangle rect = args.Allocation;
|
||||||
|
if (rect.IsNull)
|
||||||
|
Console.WriteLine ("ERROR: Allocation is null!");
|
||||||
|
Console.WriteLine ("Size: ({0}, {1})", rect.width, rect.height);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -7,6 +7,7 @@
|
||||||
//
|
//
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
|
using System.Text;
|
||||||
|
|
||||||
using Gtk;
|
using Gtk;
|
||||||
using GtkSharp;
|
using GtkSharp;
|
||||||
|
@ -59,20 +60,38 @@ namespace WidgetViewer {
|
||||||
window.ColorSelection.HasPalette = ((ToggleButton )o).Active;
|
window.ColorSelection.HasPalette = ((ToggleButton )o).Active;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static string HexFormat (Gdk.Color color)
|
||||||
|
{
|
||||||
|
StringBuilder s = new StringBuilder ();
|
||||||
|
ushort[] vals = { color.red, color.green, color.blue };
|
||||||
|
char[] hexchars = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
|
||||||
|
'A', 'B', 'C', 'D', 'E', 'F'};
|
||||||
|
|
||||||
|
s.Append ('#');
|
||||||
|
foreach (ushort val in vals) {
|
||||||
|
/* Convert to a range of 0-255, then lookup the
|
||||||
|
* digit for each half-byte */
|
||||||
|
byte rounded = (byte) (val >> 8);
|
||||||
|
s.Append (hexchars[(rounded & 0xf0) >> 4]);
|
||||||
|
s.Append (hexchars[rounded & 0x0f]);
|
||||||
|
}
|
||||||
|
|
||||||
|
return s.ToString ();
|
||||||
|
}
|
||||||
|
|
||||||
static void Color_Changed (object o, EventArgs args)
|
static void Color_Changed (object o, EventArgs args)
|
||||||
{
|
{
|
||||||
Gdk.Color color = window.ColorSelection.CurrentColor;
|
Gdk.Color color = window.ColorSelection.CurrentColor;
|
||||||
|
Console.WriteLine (HexFormat (color));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Color_Selection_OK (object o, EventArgs args)
|
static void Color_Selection_OK (object o, EventArgs args)
|
||||||
{
|
{
|
||||||
Gdk.Color selected = window.ColorSelection.CurrentColor;
|
Gdk.Color selected = window.ColorSelection.CurrentColor;
|
||||||
/*
|
if (selected.IsNull) {
|
||||||
if (selected == null) {
|
|
||||||
Console.WriteLine ("Color selection failed.");
|
Console.WriteLine ("Color selection failed.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
Display_Result (selected);
|
Display_Result (selected);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -85,20 +104,20 @@ namespace WidgetViewer {
|
||||||
|
|
||||||
static void Display_Result (Gdk.Color color)
|
static void Display_Result (Gdk.Color color)
|
||||||
{
|
{
|
||||||
/*
|
if (color.IsNull)
|
||||||
if (color == null)
|
|
||||||
Console.WriteLine ("Null color");
|
Console.WriteLine ("Null color");
|
||||||
*/
|
|
||||||
dialog = new Dialog ();
|
dialog = new Dialog ();
|
||||||
dialog.Title = "Selected Color";
|
dialog.Title = "Selected Color";
|
||||||
|
|
||||||
|
dialog.VBox.PackStart (new Gtk.Label (HexFormat (color)),
|
||||||
|
false, false, 0);
|
||||||
|
|
||||||
DrawingArea da = new DrawingArea ();
|
DrawingArea da = new DrawingArea ();
|
||||||
|
|
||||||
da.ModifyBg (StateType.Normal, color);
|
da.ModifyBg (StateType.Normal, color);
|
||||||
|
|
||||||
Console.WriteLine (da);
|
|
||||||
|
|
||||||
dialog.VBox.PackStart (da, true, true, 0);
|
dialog.VBox.PackStart (da, true, true, 0);
|
||||||
|
dialog.SetDefaultSize (200, 200);
|
||||||
|
|
||||||
Button button = new Button ("OK");
|
Button button = new Button ("OK");
|
||||||
button.Clicked += new EventHandler (Close_Button);
|
button.Clicked += new EventHandler (Close_Button);
|
||||||
|
|
|
@ -41,4 +41,18 @@
|
||||||
</attribute>
|
</attribute>
|
||||||
</data>
|
</data>
|
||||||
</rule>
|
</rule>
|
||||||
|
|
||||||
|
<!-- drawable hacks-->
|
||||||
|
<rule>
|
||||||
|
<class name="GdkBitmap"/>
|
||||||
|
<class name="GdkPixmap"/>
|
||||||
|
<class name="GdkWindow"/>
|
||||||
|
<data>
|
||||||
|
<attribute target="class">
|
||||||
|
<name>parent</name>
|
||||||
|
<value>GdkDrawable</value>
|
||||||
|
</attribute>
|
||||||
|
</data>
|
||||||
|
</rule>
|
||||||
|
|
||||||
</metadata>
|
</metadata>
|
||||||
|
|
|
@ -1205,6 +1205,7 @@
|
||||||
<data>
|
<data>
|
||||||
<attribute target="class">
|
<attribute target="class">
|
||||||
<name>disabledefaultconstructor</name>
|
<name>disabledefaultconstructor</name>
|
||||||
|
<value>1</value>
|
||||||
</attribute>
|
</attribute>
|
||||||
</data>
|
</data>
|
||||||
</rule>
|
</rule>
|
||||||
|
|
Loading…
Add table
Reference in a new issue