2002-02-14 Mike Kestner <mkestner@speakeasy.net>

* generator/ObjectGen.cs : suppress generation of get/set methods when
	  properties exist. Mangle method names on signal name clashes.  Gen
	  the signals.
	* generator/SymbolTable.cs : Add GetName. Add some more calls to Trim.
	* generator/gtkapi.xml : adding binary file as an experiment.  If the
	  diff's show this file, I'll be removing it with apologies and going
	  back to the separate package idea.
	* parser/gapi2xml.pl : some signal related fixes.
	* sample/HelloWorld.cs : uncomment the event hook.

svn path=/trunk/gtk-sharp/; revision=2419
This commit is contained in:
Mike Kestner 2002-02-15 01:08:57 +00:00
parent 123557fb68
commit 61b1d1de13
6 changed files with 93 additions and 24 deletions

View file

@ -1,3 +1,15 @@
2002-02-14 Mike Kestner <mkestner@speakeasy.net>
* generator/ObjectGen.cs : suppress generation of get/set methods when
properties exist. Mangle method names on signal name clashes. Gen
the signals.
* generator/SymbolTable.cs : Add GetName. Add some more calls to Trim.
* generator/gtkapi.xml : adding binary file as an experiment. If the
diff's show this file, I'll be removing it with apologies and going
back to the separate package idea.
* parser/gapi2xml.pl : some signal related fixes.
* sample/HelloWorld.cs : uncomment the event hook.
2002-02-10 Mike Kestner <mkestner@speakeasy.net>
* generator/BoxedGen.cs (FromNative): Add explicit cast.

View file

@ -43,7 +43,7 @@ namespace GtkSharp.Generation {
StreamWriter sw = new StreamWriter (stream);
sw.WriteLine ("// Generated File. Do not modify.");
sw.WriteLine ("// <c> 2001 Mike Kestner");
sw.WriteLine ("// <c> 2001-2002 Mike Kestner");
sw.WriteLine ();
sw.WriteLine ("namespace " + ns + " {");
@ -69,6 +69,10 @@ namespace GtkSharp.Generation {
sw.WriteLine();
Hashtable clash_map = new Hashtable();
Hashtable props = new Hashtable();
Hashtable sigs = new Hashtable();
ArrayList methods = new ArrayList();
bool first_sig = true;
foreach (XmlNode node in elem.ChildNodes) {
@ -91,18 +95,27 @@ namespace GtkSharp.Generation {
break;
case "method":
if (!GenMethod(member, table, sw)) {
Console.WriteLine("in object " + CName);
}
methods.Add(member);
break;
case "property":
if (!GenProperty(member, table, sw)) {
String pname;
if (!GenProperty(member, table, sw, out pname)) {
Console.WriteLine("in object " + CName);
}
props.Add(pname, pname);
break;
case "signal":
if (first_sig) {
first_sig = false;
sw.WriteLine("\t\tprivate Hashtable Signals = new Hashtable();");
}
String sname;
if (!GenSignal(member, table, sw, out sname)) {
Console.WriteLine("in object " + CName);
}
sigs.Add(sname, sname);
break;
default:
@ -116,7 +129,21 @@ namespace GtkSharp.Generation {
sw.WriteLine("\t\tpublic " + Name + "() : base(){}");
sw.WriteLine();
}
foreach (XmlElement member in methods) {
String mname = member.GetAttribute("name");
if ((mname.StartsWith("Set") || mname.StartsWith("Get")) &&
props.ContainsKey(mname.Substring(3))) {
continue;
} else if (sigs.ContainsKey(mname)) {
member.SetAttribute("name", "Emit" + mname);
}
if (!GenMethod(member, table, sw)) {
Console.WriteLine("in object " + CName);
}
}
sw.WriteLine ("\t}");
sw.WriteLine ();
sw.WriteLine ("}");
@ -125,7 +152,7 @@ namespace GtkSharp.Generation {
sw.Close();
}
public bool GenProperty (XmlElement prop, SymbolTable table, StreamWriter sw)
public bool GenProperty (XmlElement prop, SymbolTable table, StreamWriter sw, out String name)
{
String c_type = prop.GetAttribute("type");
@ -134,6 +161,12 @@ namespace GtkSharp.Generation {
String cs_type = table.GetCSType(c_type);
String m_type;
XmlElement parent = (XmlElement) prop.ParentNode;
name = prop.GetAttribute("name");
if (name == parent.GetAttribute("name")) {
name += "Prop";
}
if (table.IsObject(c_type)) {
m_type = "GLib.Object";
} else if (table.IsBoxed(c_type)) {
@ -155,12 +188,6 @@ namespace GtkSharp.Generation {
return true;
}
XmlElement parent = (XmlElement) prop.ParentNode;
String name = prop.GetAttribute("name");
if (name == parent.GetAttribute("name")) {
name += "Prop";
}
sw.WriteLine("\t\tpublic " + cs_type + " " + name + " {");
if (prop.HasAttribute("readable")) {
sw.WriteLine("\t\t\tget {");
@ -186,30 +213,33 @@ namespace GtkSharp.Generation {
return true;
}
public bool GenSignal (XmlElement sig, SymbolTable table, StreamWriter sw)
public bool GenSignal (XmlElement sig, SymbolTable table, StreamWriter sw, out String name)
{
String cname = "\"" + sig.GetAttribute("cname") + "\"";
name = sig.GetAttribute("name");
String marsh = "blah"; // SignalHandler.GetName(sig);
String marsh = SignalHandler.GetName(sig, table);
if (marsh == "") {
return false;
}
marsh = "GtkSharp." + marsh;
sw.WriteLine("\t\t/// <summary> " + cname + " Event </summary>");
sw.WriteLine("\t\t/// <summary> " + name + " Event </summary>");
sw.WriteLine("\t\t/// <remarks>");
// FIXME: Generate some signal docs
sw.WriteLine("\t\t/// </remarks>");
sw.WriteLine();
sw.WriteLine("\t\tpublic event EventHandler " + cname + " {");
sw.WriteLine("\t\tpublic event EventHandler " + name + " {");
sw.WriteLine("\t\t\tadd {");
sw.WriteLine("\t\t\t\tif (Events [" + cname + "] == null)");
sw.WriteLine("\t\t\t\tif (EventList[" + cname + "] == null)");
sw.Write("\t\t\t\t\tSignals[" + cname + "] = new " + marsh);
sw.WriteLine("(this, Handle, " + cname + ", value);");
sw.WriteLine("\t\t\t\tEvents.AddHandler(" + cname + ", value);");
sw.WriteLine("\t\t\t\tEventList.AddHandler(" + cname + ", value);");
sw.WriteLine("\t\t\t}");
sw.WriteLine("\t\t\tremove {");
sw.WriteLine("\t\t\t\tEvents.RemoveHandler(" + cname + ", value);");
sw.WriteLine("\t\t\t\tif (Events[" + cname + "] == null)");
sw.WriteLine("\t\t\t\tEventList.RemoveHandler(" + cname + ", value);");
sw.WriteLine("\t\t\t\tif (EventList[" + cname + "] == null)");
sw.WriteLine("\t\t\t\t\tSignals.Remove(" + cname + ");");
sw.WriteLine("\t\t\t}");
sw.WriteLine("\t\t}");

View file

@ -122,6 +122,25 @@ namespace GtkSharp.Generation {
}
}
public String GetName(String c_type)
{
c_type = Trim(c_type);
if (simple_types.ContainsKey(c_type)) {
String stype = (String) simple_types[c_type];
int dotidx = stype.IndexOf(".");
if (dotidx == -1) {
return stype;
} else {
return stype.Substring(dotidx+1);
}
} else if (complex_types.ContainsKey(c_type)) {
IGeneratable gen = (IGeneratable) complex_types[c_type];
return gen.Name;
} else {
return "";
}
}
public String GetDllName(String ns)
{
return (String) dlls[ns];
@ -155,6 +174,7 @@ namespace GtkSharp.Generation {
public bool IsBoxed(String c_type)
{
c_type = Trim(c_type);
if (complex_types.ContainsKey(c_type)) {
IGeneratable gen = (IGeneratable) complex_types[c_type];
if (gen is BoxedGen) {
@ -166,6 +186,7 @@ namespace GtkSharp.Generation {
public bool IsInterface(String c_type)
{
c_type = Trim(c_type);
if (complex_types.ContainsKey(c_type)) {
IGeneratable gen = (IGeneratable) complex_types[c_type];
if (gen is InterfaceGen) {
@ -177,6 +198,7 @@ namespace GtkSharp.Generation {
public bool IsObject(String c_type)
{
c_type = Trim(c_type);
if (complex_types.ContainsKey(c_type)) {
IGeneratable gen = (IGeneratable) complex_types[c_type];
if (gen is ObjectGen) {

2
generator/gtkapi.xml Normal file

File diff suppressed because one or more lines are too long

View file

@ -496,7 +496,10 @@ sub addSignalElem
$sig_elem = $doc->createElement('signal');
$node->appendChild($sig_elem);
$sig_elem->setAttribute('name', $1) if ($spec =~ /\(\"(\w+)\"/);
if ($spec =~ /\(\"([\w\-]+)\"/) {
$sig_elem->setAttribute('name', StudlyCaps($1));
$sig_elem->setAttribute('cname', $1);
}
$sig_elem->setAttribute('when', $1) if ($spec =~ /_RUN_(\w+)/);
my $method = "";
@ -523,7 +526,7 @@ sub addSignalElem
return;
}
if ($class =~ /;\s*(\S+\s*\**)\s*\(\*\s*$method\)\s*\((.*)\);/) {
if ($class =~ /;\s*(\S+\s*\**)\s*\(\*\s*$method\)\s*\((.*?)\);/) {
$ret = $1; $parms = $2;
addReturnElem($sig_elem, $ret);
if ($parms && ($parms ne "void")) {

View file

@ -21,8 +21,8 @@ namespace GtkSamples {
Gtk.Window win = new Gtk.Window (Gtk.WindowType.Toplevel);
Console.WriteLine("Setting Title");
win.Title = "Gtk# Hello World";
// win.Deleted += new EventHandler (Window_Delete);
win.Show ();
win.DeleteEvent += new EventHandler (Window_Delete);
win.ShowAll ();
Console.WriteLine("Entering event loop");
Application.Run ();
return 0;