bbf727c80e
* CallbackGen.cs : rework for internal callback helpers, pass NS to parms ctor * Ctor.cs : pass NS to parms ctor * Method.cs : pass NS to parms ctor * Parameters.cs : refactoring, plus rework for internal callback helpers. * Signal.cs : pass NS to parms ctor svn path=/trunk/gtk-sharp/; revision=15385
174 lines
5.5 KiB
C#
174 lines
5.5 KiB
C#
// GtkSharp.Generation.Signal.cs - The Signal Generatable.
|
|
//
|
|
// Author: Mike Kestner <mkestner@speakeasy.net>
|
|
//
|
|
// (c) 2001-2002 Mike Kestner
|
|
|
|
namespace GtkSharp.Generation {
|
|
|
|
using System;
|
|
using System.Collections;
|
|
using System.IO;
|
|
using System.Xml;
|
|
|
|
public class Signal {
|
|
|
|
private string marsh;
|
|
private string name;
|
|
private XmlElement elem;
|
|
private Parameters parms;
|
|
private ClassBase container_type;
|
|
|
|
public Signal (XmlElement elem, ClassBase container_type)
|
|
{
|
|
this.elem = elem;
|
|
this.name = elem.GetAttribute ("name");
|
|
if (elem["parameters"] != null)
|
|
parms = new Parameters (elem["parameters"], container_type.NS);
|
|
this.container_type = container_type;
|
|
}
|
|
|
|
public string Name {
|
|
get {
|
|
return name;
|
|
}
|
|
set {
|
|
name = value;
|
|
}
|
|
}
|
|
|
|
public bool Validate ()
|
|
{
|
|
marsh = SignalHandler.GetName(elem, container_type.NS, false);
|
|
if ((Name == "") || (marsh == "")) {
|
|
Console.Write ("bad signal " + Name);
|
|
Statistics.ThrottledCount++;
|
|
return false;
|
|
}
|
|
|
|
if (parms != null && !parms.Validate ())
|
|
return false;
|
|
|
|
return true;
|
|
}
|
|
|
|
public void GenerateDecl (StreamWriter sw)
|
|
{
|
|
string argsname;
|
|
string handler = GetHandlerName (out argsname);
|
|
if (handler != "EventHandler")
|
|
handler = container_type.NS + "Sharp." + handler;
|
|
|
|
if (elem.HasAttribute("new_flag") || (container_type != null && container_type.GetSignalRecursively (Name) != null))
|
|
sw.Write("new ");
|
|
|
|
sw.WriteLine ("\t\tevent " + handler + " " + Name + ";");
|
|
}
|
|
|
|
private string GetHandlerName (out string argsname)
|
|
{
|
|
if (marsh.EndsWith (".voidObjectSignal")) {
|
|
argsname = "System.EventArgs";
|
|
return "EventHandler";
|
|
}
|
|
|
|
argsname = Name + "Args";
|
|
return Name + "Handler";
|
|
}
|
|
|
|
private string GenHandler (out string argsname)
|
|
{
|
|
string handler = GetHandlerName (out argsname);
|
|
if (handler == "EventHandler" || !container_type.DoGenerate)
|
|
return handler;
|
|
|
|
string ns = container_type.NS;
|
|
char sep = Path.DirectorySeparatorChar;
|
|
string dir = ".." + sep + ns.ToLower() + sep + "generated";
|
|
|
|
if (!Directory.Exists (dir))
|
|
Directory.CreateDirectory (dir);
|
|
|
|
string filename = dir + sep + ns + "Sharp." + handler + ".cs";
|
|
|
|
FileStream stream = new FileStream (filename, FileMode.Create, FileAccess.Write);
|
|
StreamWriter sw = new StreamWriter (stream);
|
|
|
|
sw.WriteLine ("// This file was generated by the Gtk# Code generator.");
|
|
sw.WriteLine ("// Any changes made will be lost if regenerated.");
|
|
sw.WriteLine ();
|
|
sw.WriteLine ("namespace " + ns + "Sharp {");
|
|
sw.WriteLine ();
|
|
sw.WriteLine ("\tusing System;");
|
|
|
|
sw.WriteLine ();
|
|
sw.WriteLine ("\tpublic delegate void " + handler + "(object o, " + argsname + " args);");
|
|
sw.WriteLine ();
|
|
sw.WriteLine ("\tpublic class " + argsname + " : GtkSharp.SignalArgs {");
|
|
if (parms != null) {
|
|
for (int i = 1; i < parms.Count; i++) {
|
|
sw.WriteLine ("\t\tpublic " + parms[i].CSType + " " + parms[i].StudlyName + "{");
|
|
sw.WriteLine ("\t\t\tget {");
|
|
sw.WriteLine ("\t\t\t\treturn (" + parms[i].CSType + ") Args[" + (i - 1) + "];");
|
|
sw.WriteLine ("\t\t\t}");
|
|
sw.WriteLine ("\t\t}");
|
|
sw.WriteLine ();
|
|
}
|
|
}
|
|
sw.WriteLine ("\t}");
|
|
sw.WriteLine ("}");
|
|
sw.Close ();
|
|
argsname = ns + "Sharp." + argsname;
|
|
return ns + "Sharp." + handler;
|
|
}
|
|
|
|
public void Generate (StreamWriter sw, ClassBase implementor)
|
|
{
|
|
string cname = "\"" + elem.GetAttribute("cname") + "\"";
|
|
string ns;
|
|
if (implementor == null)
|
|
ns = container_type.NS;
|
|
else
|
|
ns = implementor.NS;
|
|
|
|
string qual_marsh = SignalHandler.GetName(elem, ns, container_type.DoGenerate);
|
|
|
|
string argsname;
|
|
string handler = GenHandler (out argsname);
|
|
|
|
sw.WriteLine("\t\t[GLib.Signal("+ cname + ")]");
|
|
sw.Write("\t\tpublic ");
|
|
if (elem.HasAttribute("new_flag") || (container_type != null && container_type.GetSignalRecursively (Name) != null) || (implementor != null && implementor.GetSignalRecursively (Name) != null))
|
|
sw.Write("new ");
|
|
sw.WriteLine("event " + handler + " " + Name + " {");
|
|
sw.WriteLine("\t\t\tadd {");
|
|
sw.WriteLine("\t\t\t\tif (EventList[" + cname + "] == null)");
|
|
sw.Write("\t\t\t\t\tSignals[" + cname + "] = new " + qual_marsh);
|
|
sw.Write("(this, Handle, " + cname + ", value, System.Type.GetType(\"" + argsname);
|
|
if (argsname != "System.EventArgs")
|
|
sw.Write("," + container_type.NS.ToLower() + "-sharp");
|
|
sw.WriteLine("\"));\n\t\t\t\telse");
|
|
sw.WriteLine("\t\t\t\t\t((GtkSharp.SignalCallback) Signals [{0}]).AddDelegate (value);", cname);
|
|
sw.WriteLine("\t\t\t\tEventList.AddHandler(" + cname + ", value);");
|
|
sw.WriteLine("\t\t\t}");
|
|
sw.WriteLine("\t\t\tremove {");
|
|
sw.WriteLine("\t\t\t\tEventList.RemoveHandler(" + cname + ", value);");
|
|
sw.WriteLine("\t\t\t\tGtkSharp.SignalCallback cb = Signals [{0}] as GtkSharp.SignalCallback;", cname);
|
|
sw.WriteLine("\t\t\t\tif (cb == null)");
|
|
sw.WriteLine("\t\t\t\t\treturn;");
|
|
sw.WriteLine();
|
|
sw.WriteLine("\t\t\t\tcb.RemoveDelegate (value);");
|
|
sw.WriteLine();
|
|
sw.WriteLine("\t\t\t\tif (EventList[" + cname + "] == null) {");
|
|
sw.WriteLine("\t\t\t\t\tSignals.Remove(" + cname + ");");
|
|
sw.WriteLine("\t\t\t\t\tcb.Dispose ();");
|
|
sw.WriteLine("\t\t\t\t}");
|
|
sw.WriteLine("\t\t\t}");
|
|
sw.WriteLine("\t\t}");
|
|
sw.WriteLine();
|
|
|
|
Statistics.SignalCount++;
|
|
}
|
|
}
|
|
}
|
|
|