2003-10-04 Mike Kestner <mkestner@ximian.com>

* generator/AliasGen.cs : stub new Generate overload.
	* generator/BoxedGen.cs : implement new Generate overload.
	* generator/CallbackGen.cs (Generate):implement new overload.
	* generator/ClassBase.cs : implement new Generate overload and
	pass around the gen_info.
	* generator/ClassGen.cs : implement new Generate overload.
	* generator/Ctor.cs (Generate): s/sw/gen_info.
	* generator/EnumGen.cs : implement new Generate overload.
	* generator/GenBase.cs : expose NSElem, add gen_info param to
	AppendCustom. kill CreateWriter.
	(GenWrapper): add gen_info param and use it to open stream.
	* generator/GenerationInfo.cs : new class to pass around generation
	related information and perform tasks like opening streams.
	* generator/IGeneratable.cs : add Generate(gen_info) overload.
	* generator/InterfaceGen.cs : implement new Generate overload.
	* generator/ManualGen.cs : stub new Generate overload.
	* generator/Method.cs (Generate): accept gen_info. kill GenerateComments.
	* generator/ObjectGen.cs : implement new Generate overload.
	* generator/OpaqueGen.cs : implement new Generate overload.
	* generator/Parameters.cs (Initialize): s/sw/gen_info.
	* generator/Property.cs (Generate): accept gen_info.
	* generator/Signal.cs (Generate): accept gen_info.
	* generator/SimpleGen.cs : stub new Generate overload.
	* generator/StructBase.cs : s/sw/gen_info
	* generator/StructGen.cs : implement new Generate overload.

svn path=/trunk/gtk-sharp/; revision=18615
This commit is contained in:
Mike Kestner 2003-10-05 00:20:17 +00:00
parent e7f84c070d
commit 460b3e5623
22 changed files with 323 additions and 148 deletions

View file

@ -1,3 +1,31 @@
2003-10-04 Mike Kestner <mkestner@ximian.com>
* generator/AliasGen.cs : stub new Generate overload.
* generator/BoxedGen.cs : implement new Generate overload.
* generator/CallbackGen.cs (Generate):implement new overload.
* generator/ClassBase.cs : implement new Generate overload and
pass around the gen_info.
* generator/ClassGen.cs : implement new Generate overload.
* generator/Ctor.cs (Generate): s/sw/gen_info.
* generator/EnumGen.cs : implement new Generate overload.
* generator/GenBase.cs : expose NSElem, add gen_info param to
AppendCustom. kill CreateWriter.
(GenWrapper): add gen_info param and use it to open stream.
* generator/GenerationInfo.cs : new class to pass around generation
related information and perform tasks like opening streams.
* generator/IGeneratable.cs : add Generate(gen_info) overload.
* generator/InterfaceGen.cs : implement new Generate overload.
* generator/ManualGen.cs : stub new Generate overload.
* generator/Method.cs (Generate): accept gen_info. kill GenerateComments.
* generator/ObjectGen.cs : implement new Generate overload.
* generator/OpaqueGen.cs : implement new Generate overload.
* generator/Parameters.cs (Initialize): s/sw/gen_info.
* generator/Property.cs (Generate): accept gen_info.
* generator/Signal.cs (Generate): accept gen_info.
* generator/SimpleGen.cs : stub new Generate overload.
* generator/StructBase.cs : s/sw/gen_info
* generator/StructGen.cs : implement new Generate overload.
2003-10-03 Mike Kestner <mkestner@ximian.com> 2003-10-03 Mike Kestner <mkestner@ximian.com>
* generator/GenBase.cs : remove unused do_generate private member. * generator/GenBase.cs : remove unused do_generate private member.

View file

@ -77,6 +77,10 @@ namespace GtkSharp.Generation {
{ {
} }
public void Generate (GenerationInfo gen_info)
{
}
} }
} }

View file

@ -14,9 +14,15 @@ namespace GtkSharp.Generation {
public BoxedGen (XmlElement ns, XmlElement elem) : base (ns, elem) {} public BoxedGen (XmlElement ns, XmlElement elem) : base (ns, elem) {}
public override void Generate () public void Generate ()
{ {
base.Generate (); GenerationInfo gen_info = new GenerationInfo (NSElem);
Generate (gen_info);
}
public override void Generate (GenerationInfo gen_info)
{
base.Generate (gen_info);
Statistics.BoxedCount++; Statistics.BoxedCount++;
} }
} }

View file

@ -2,7 +2,7 @@
// //
// Author: Mike Kestner <mkestner@speakeasy.net> // Author: Mike Kestner <mkestner@speakeasy.net>
// //
// (c) 2002 Mike Kestner // (c) 2002-2003 Mike Kestner
namespace GtkSharp.Generation { namespace GtkSharp.Generation {
@ -54,24 +54,13 @@ namespace GtkSharp.Generation {
return CallByName (var); return CallByName (var);
} }
public string GenWrapper (string ns) public string GenWrapper (string ns, GenerationInfo gen_info)
{ {
char sep = Path.DirectorySeparatorChar;
string dir = ".." + sep + ns.ToLower() + sep + "generated";
if (!Directory.Exists (dir))
Directory.CreateDirectory (dir);
string wrapper = Name + "Native"; string wrapper = Name + "Native";
string qualname = ns + "Sharp." + wrapper;
string filename = dir + sep + ns + "Sharp." + wrapper + ".cs"; StreamWriter sw = gen_info.OpenStream (qualname);
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 on regeneration.");
sw.WriteLine ();
sw.WriteLine ("namespace " + ns + "Sharp {"); sw.WriteLine ("namespace " + ns + "Sharp {");
sw.WriteLine (); sw.WriteLine ();
sw.WriteLine ("\tusing System;"); sw.WriteLine ("\tusing System;");
@ -111,7 +100,6 @@ namespace GtkSharp.Generation {
} }
sw.WriteLine (); sw.WriteLine ();
sw.WriteLine ("\t\tpublic " + m_ret + " NativeCallback (" + import_sig + ")"); sw.WriteLine ("\t\tpublic " + m_ret + " NativeCallback (" + import_sig + ")");
sw.WriteLine ("\t\t{"); sw.WriteLine ("\t\t{");
@ -191,6 +179,12 @@ namespace GtkSharp.Generation {
} }
public void Generate () public void Generate ()
{
GenerationInfo gen_info = new GenerationInfo (NSElem);
Generate (gen_info);
}
public void Generate (GenerationInfo gen_info)
{ {
XmlElement ret_elem = Elem["return-type"]; XmlElement ret_elem = Elem["return-type"];
if (ret_elem == null) { if (ret_elem == null) {
@ -215,7 +209,7 @@ namespace GtkSharp.Generation {
parms = null; parms = null;
} }
StreamWriter sw = CreateWriter (); StreamWriter sw = gen_info.OpenStream (Name);
string sig = ""; string sig = "";
if (parms != null) { if (parms != null) {
@ -224,11 +218,17 @@ namespace GtkSharp.Generation {
sig = parms.Signature; sig = parms.Signature;
} }
sw.WriteLine ("namespace " + NS + " {");
sw.WriteLine ();
sw.WriteLine ("\tusing System;");
sw.WriteLine ();
sw.WriteLine ("\tpublic delegate " + s_ret + " " + Name + "(" + sig + ");"); sw.WriteLine ("\tpublic delegate " + s_ret + " " + Name + "(" + sig + ");");
sw.WriteLine ();
sw.WriteLine ("}");
CloseWriter (sw); sw.Close ();
GenWrapper (NS); GenWrapper (NS, gen_info);
Statistics.CBCount++; Statistics.CBCount++;
} }

View file

@ -147,27 +147,27 @@ namespace GtkSharp.Generation {
return CallByName (var); return CallByName (var);
} }
protected void GenProperties (StreamWriter sw) protected void GenProperties (GenerationInfo gen_info)
{ {
if (props == null) if (props == null)
return; return;
foreach (Property prop in props.Values) { foreach (Property prop in props.Values) {
if (prop.Validate ()) if (prop.Validate ())
prop.Generate (sw); prop.Generate (gen_info);
else else
Console.WriteLine("in Object " + QualifiedName); Console.WriteLine("in Object " + QualifiedName);
} }
} }
public void GenSignals (StreamWriter sw, ClassBase implementor) public void GenSignals (GenerationInfo gen_info, ClassBase implementor)
{ {
if (sigs == null) if (sigs == null)
return; return;
foreach (Signal sig in sigs.Values) { foreach (Signal sig in sigs.Values) {
if (sig.Validate ()) if (sig.Validate ())
sig.Generate (sw, implementor); sig.Generate (gen_info, implementor);
else else
Console.WriteLine("in Object " + QualifiedName); Console.WriteLine("in Object " + QualifiedName);
} }
@ -194,7 +194,7 @@ namespace GtkSharp.Generation {
(props != null) && props.ContainsKey(mname.Substring(3))); (props != null) && props.ContainsKey(mname.Substring(3)));
} }
public void GenMethods (StreamWriter sw, Hashtable collisions, ClassBase implementor, bool gen_docs) public void GenMethods (GenerationInfo gen_info, Hashtable collisions, ClassBase implementor)
{ {
if (methods == null) if (methods == null)
return; return;
@ -205,7 +205,7 @@ namespace GtkSharp.Generation {
if (method.Validate ()) if (method.Validate ())
{ {
String oname = null, oprotection = null; string oname = null, oprotection = null;
if (collisions != null && collisions.Contains (method.Name)) if (collisions != null && collisions.Contains (method.Name))
{ {
oname = method.Name; oname = method.Name;
@ -213,7 +213,7 @@ namespace GtkSharp.Generation {
method.Name = Name + "." + method.Name; method.Name = Name + "." + method.Name;
method.Protection = ""; method.Protection = "";
} }
method.Generate (sw, implementor, gen_docs); method.Generate (gen_info, implementor);
if (oname != null) if (oname != null)
{ {
method.Name = oname; method.Name = oname;
@ -343,7 +343,7 @@ namespace GtkSharp.Generation {
ctors_initted = true; ctors_initted = true;
} }
protected virtual void GenCtors (StreamWriter sw) protected virtual void GenCtors (GenerationInfo gen_info)
{ {
ClassBase klass = this; ClassBase klass = this;
while (klass != null) { while (klass != null) {
@ -352,11 +352,11 @@ namespace GtkSharp.Generation {
} }
foreach (Ctor ctor in ctors) foreach (Ctor ctor in ctors)
ctor.Generate (sw); ctor.Generate (gen_info);
if (!clash_map.ContainsKey("") && hasDefaultConstructor) { if (!clash_map.ContainsKey("") && hasDefaultConstructor) {
sw.WriteLine("\t\tprotected " + Name + "() : base(){}"); gen_info.Writer.WriteLine("\t\tprotected " + Name + "() : base(){}");
sw.WriteLine(); gen_info.Writer.WriteLine();
} }
} }

View file

@ -1,4 +1,4 @@
// GtkSharp.Generation.ObjectGen.cs - The Object Generatable. // GtkSharp.Generation.ClassGen.cs - The Class Generatable.
// //
// Author: Mike Kestner <mkestner@speakeasy.net> // Author: Mike Kestner <mkestner@speakeasy.net>
// //
@ -21,27 +21,36 @@ namespace GtkSharp.Generation {
public void Generate () public void Generate ()
{ {
StreamWriter sw = CreateWriter (); GenerationInfo gen_info = new GenerationInfo (NSElem);
Generate (gen_info);
}
public void Generate (GenerationInfo gen_info)
{
StreamWriter sw = gen_info.Writer = gen_info.OpenStream(Name);
sw.WriteLine ("namespace " + NS + " {");
sw.WriteLine ();
sw.WriteLine ("\tusing System;");
sw.WriteLine ("\tusing System.Runtime.InteropServices;"); sw.WriteLine ("\tusing System.Runtime.InteropServices;");
sw.WriteLine (); sw.WriteLine ();
SymbolTable table = SymbolTable.Table;
sw.WriteLine ("#region Autogenerated code"); sw.WriteLine ("#region Autogenerated code");
sw.Write ("\tpublic class " + Name); sw.Write ("\tpublic class " + Name);
sw.WriteLine (" {"); sw.WriteLine (" {");
sw.WriteLine (); sw.WriteLine ();
GenProperties (sw); GenProperties (gen_info);
GenMethods (sw, null, null, false); GenMethods (gen_info, null, null);
sw.WriteLine ("#endregion"); sw.WriteLine ("#endregion");
AppendCustom(sw); AppendCustom(sw, gen_info.CustomDir);
sw.WriteLine ("\t}"); sw.WriteLine ("\t}");
sw.WriteLine ("}");
CloseWriter (sw); sw.Close ();
gen_info.Writer = null;
} }
} }
} }

View file

@ -92,8 +92,9 @@ namespace GtkSharp.Generation {
} }
} }
public void Generate (StreamWriter sw) public void Generate (GenerationInfo gen_info)
{ {
StreamWriter sw = gen_info.Writer;
string sigtypes = ""; string sigtypes = "";
string sig = "()"; string sig = "()";
string call = "()"; string call = "()";
@ -136,7 +137,7 @@ namespace GtkSharp.Generation {
sw.WriteLine("\t\t{"); sw.WriteLine("\t\t{");
if (parms != null) if (parms != null)
parms.Initialize(sw, false, false, ""); parms.Initialize(gen_info, false, false, "");
sw.Write("\t\t\treturn "); sw.Write("\t\t\treturn ");
if (container_type is StructBase) if (container_type is StructBase)
@ -149,7 +150,7 @@ namespace GtkSharp.Generation {
sw.WriteLine("\t\t{"); sw.WriteLine("\t\t{");
if (parms != null) if (parms != null)
parms.Initialize(sw, false, false, ""); parms.Initialize(gen_info, false, false, "");
sw.WriteLine("\t\t\t{0} = {1}{2};", container_type.AssignToName, 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, "");

View file

@ -49,7 +49,18 @@ namespace GtkSharp.Generation {
public void Generate () public void Generate ()
{ {
StreamWriter sw = CreateWriter (); GenerationInfo gen_info = new GenerationInfo (NSElem);
Generate (gen_info);
}
public void Generate (GenerationInfo gen_info)
{
StreamWriter sw = gen_info.OpenStream (Name);
sw.WriteLine ("namespace " + NS + " {");
sw.WriteLine ();
sw.WriteLine ("\tusing System;");
sw.WriteLine ();
if (Elem.GetAttribute("type") == "flags") { if (Elem.GetAttribute("type") == "flags") {
sw.WriteLine (); sw.WriteLine ();
@ -104,7 +115,8 @@ namespace GtkSharp.Generation {
sw.WriteLine ("\t}"); sw.WriteLine ("\t}");
sw.WriteLine ("#endregion"); sw.WriteLine ("#endregion");
CloseWriter (sw); sw.WriteLine ("}");
sw.Close ();
Statistics.EnumCount++; Statistics.EnumCount++;
} }

View file

@ -51,6 +51,12 @@ namespace GtkSharp.Generation {
} }
} }
public XmlElement NSElem {
get {
return ns;
}
}
public string QualifiedName { public string QualifiedName {
get { get {
return NS + "." + Name; return NS + "." + Name;
@ -90,10 +96,10 @@ namespace GtkSharp.Generation {
sw.Close(); sw.Close();
} }
public void AppendCustom (StreamWriter sw) public void AppendCustom (StreamWriter sw, string custom_dir)
{ {
char sep = Path.DirectorySeparatorChar; char sep = Path.DirectorySeparatorChar;
string custom = ".." + sep + NS.ToLower() + sep + Name + ".custom"; string custom = custom_dir + sep + Name + ".custom";
if (File.Exists(custom)) { if (File.Exists(custom)) {
sw.WriteLine ("#region Customized extensions"); sw.WriteLine ("#region Customized extensions");
sw.WriteLine ("#line 1 \"" + Name + ".custom\""); sw.WriteLine ("#line 1 \"" + Name + ".custom\"");

View file

@ -0,0 +1,75 @@
// GtkSharp.Generation.GenerationInfo.cs - Generation information class.
//
// Author: Mike Kestner <mkestner@ximian.com>
//
// (c) 2003 Ximian Inc.
namespace GtkSharp.Generation {
using System;
using System.Collections;
using System.IO;
using System.Xml;
public class GenerationInfo {
string dir;
string custom_dir;
string assembly_name;
StreamWriter sw;
public GenerationInfo (XmlElement ns)
{
string ns_name = ns.GetAttribute ("name");
char sep = Path.DirectorySeparatorChar;
dir = ".." + sep + ns_name.ToLower () + sep + "generated";
custom_dir = ".." + sep + ns_name.ToLower ();
assembly_name = ns_name.ToLower () + "-sharp";
}
public string AssemblyName {
get {
return assembly_name;
}
}
public string CustomDir {
get {
return custom_dir;
}
}
public string Dir {
get {
return dir;
}
}
public StreamWriter Writer {
get {
return sw;
}
set {
sw = value;
}
}
public StreamWriter OpenStream (string name)
{
char sep = Path.DirectorySeparatorChar;
if (!Directory.Exists(dir))
Directory.CreateDirectory(dir);
string filename = dir + sep + name + ".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 ();
return sw;
}
}
}

View file

@ -6,28 +6,28 @@
namespace GtkSharp.Generation { namespace GtkSharp.Generation {
using System;
public interface IGeneratable { public interface IGeneratable {
String CName {get;} string CName {get;}
String MarshalType {get;} string MarshalType {get;}
String MarshalReturnType {get;} string MarshalReturnType {get;}
String Name {get;} string Name {get;}
String QualifiedName {get;} string QualifiedName {get;}
String CallByName (String var_name); string CallByName (string var_name);
String FromNative (String var); string FromNative (string var);
String FromNativeReturn (String var); string FromNativeReturn (string var);
String ToNativeReturn (String var); string ToNativeReturn (string var);
void Generate (); void Generate ();
void Generate (GenerationInfo gen_info);
} }
} }

View file

@ -16,8 +16,18 @@ namespace GtkSharp.Generation {
public void Generate () public void Generate ()
{ {
StreamWriter sw = CreateWriter (); GenerationInfo gen_info = new GenerationInfo (NSElem);
Generate (gen_info);
}
public void Generate (GenerationInfo gen_info)
{
StreamWriter sw = gen_info.Writer = gen_info.OpenStream (Name);
sw.WriteLine ("namespace " + NS + " {");
sw.WriteLine ();
sw.WriteLine ("\tusing System;");
sw.WriteLine ();
sw.WriteLine ("#region Autogenerated code"); sw.WriteLine ("#region Autogenerated code");
sw.WriteLine ("\tpublic interface " + Name + " : GLib.IWrapper {"); sw.WriteLine ("\tpublic interface " + Name + " : GLib.IWrapper {");
sw.WriteLine (); sw.WriteLine ();
@ -35,11 +45,13 @@ namespace GtkSharp.Generation {
method.GenerateDecl (sw); method.GenerateDecl (sw);
} }
AppendCustom (sw); AppendCustom (sw, gen_info.CustomDir);
sw.WriteLine ("\t}"); sw.WriteLine ("\t}");
sw.WriteLine ("#endregion"); sw.WriteLine ("#endregion");
CloseWriter (sw); sw.WriteLine ("}");
sw.Close ();
gen_info.Writer = null;
Statistics.IFaceCount++; Statistics.IFaceCount++;
} }
} }

View file

@ -90,6 +90,9 @@ namespace GtkSharp.Generation {
{ {
} }
public void Generate (GenerationInfo gen_info)
{
}
} }
} }

View file

@ -248,8 +248,6 @@ namespace GtkSharp.Generation {
if (elem.HasAttribute("shared")) if (elem.HasAttribute("shared"))
return; return;
GenerateComments (sw);
if (is_get || is_set) if (is_get || is_set)
{ {
Method comp = GetComplement (); Method comp = GetComplement ();
@ -279,32 +277,14 @@ namespace GtkSharp.Generation {
Statistics.MethodCount++; Statistics.MethodCount++;
} }
void GenerateComments (StreamWriter sw)
{
string summary, sname;
sw.WriteLine();
if (is_get || is_set) {
summary = "Property";
sname = Name.Substring (3);
} else {
summary = "Method";
sname = Name;
}
}
public void GenerateImport (StreamWriter sw) public void GenerateImport (StreamWriter sw)
{ {
sw.WriteLine("\t\t[DllImport(\"" + libname + "\")]"); sw.WriteLine("\t\t[DllImport(\"" + libname + "\")]");
sw.Write("\t\tstatic extern " + safety + m_ret + " " + cname + isig); sw.WriteLine("\t\tstatic extern " + safety + m_ret + " " + cname + isig);
sw.WriteLine(); sw.WriteLine();
} }
public void Generate (StreamWriter sw, ClassBase implementor) public void Generate (GenerationInfo gen_info, ClassBase implementor)
{
Generate (sw, implementor, true);
}
public void Generate (StreamWriter sw, ClassBase implementor, bool gen_docs)
{ {
Method comp = null; Method comp = null;
@ -334,51 +314,49 @@ namespace GtkSharp.Generation {
comp = null; comp = null;
} }
GenerateImport (sw); GenerateImport (gen_info.Writer);
if (comp != null && s_ret == comp.parms.AccessorReturnType) if (comp != null && s_ret == comp.parms.AccessorReturnType)
comp.GenerateImport (sw); comp.GenerateImport (gen_info.Writer);
if (gen_docs) gen_info.Writer.Write("\t\t");
GenerateComments (sw);
sw.Write("\t\t");
if (protection != "") if (protection != "")
sw.Write("{0} ", protection); gen_info.Writer.Write("{0} ", protection);
GenerateDeclCommon (sw, implementor); GenerateDeclCommon (gen_info.Writer, implementor);
if (is_get || is_set) if (is_get || is_set)
{ {
sw.Write ("\t\t\t"); gen_info.Writer.Write ("\t\t\t");
sw.Write ((is_get) ? "get" : "set"); gen_info.Writer.Write ((is_get) ? "get" : "set");
GenerateBody (sw, "\t"); GenerateBody (gen_info, "\t");
} }
else else
GenerateBody (sw, ""); GenerateBody (gen_info, "");
if (is_get || is_set) if (is_get || is_set)
{ {
if (comp != null && s_ret == comp.parms.AccessorReturnType) if (comp != null && s_ret == comp.parms.AccessorReturnType)
{ {
sw.WriteLine (); gen_info.Writer.WriteLine ();
sw.Write ("\t\t\tset"); gen_info.Writer.Write ("\t\t\tset");
comp.GenerateBody (sw, "\t"); comp.GenerateBody (gen_info, "\t");
} }
sw.WriteLine (); gen_info.Writer.WriteLine ();
sw.WriteLine ("\t\t}"); gen_info.Writer.WriteLine ("\t\t}");
} }
else else
sw.WriteLine(); gen_info.Writer.WriteLine();
sw.WriteLine(); gen_info.Writer.WriteLine();
Statistics.MethodCount++; Statistics.MethodCount++;
} }
public void GenerateBody (StreamWriter sw, string indent) public void GenerateBody (GenerationInfo gen_info, string indent)
{ {
StreamWriter sw = gen_info.Writer;
sw.WriteLine(" {"); sw.WriteLine(" {");
if (parms != null) if (parms != null)
parms.Initialize(sw, is_get, is_set, indent); parms.Initialize(gen_info, is_get, is_set, indent);
SymbolTable table = SymbolTable.Table; SymbolTable table = SymbolTable.Table;

View file

@ -53,8 +53,17 @@ namespace GtkSharp.Generation {
public void Generate () public void Generate ()
{ {
StreamWriter sw = CreateWriter (); GenerationInfo gen_info = new GenerationInfo (NSElem);
Generate (gen_info);
}
public void Generate (GenerationInfo gen_info)
{
StreamWriter sw = gen_info.Writer = gen_info.OpenStream (Name);
sw.WriteLine ("namespace " + NS + " {");
sw.WriteLine ();
sw.WriteLine ("\tusing System;");
sw.WriteLine ("\tusing System.Collections;"); sw.WriteLine ("\tusing System.Collections;");
sw.WriteLine ("\tusing System.Runtime.InteropServices;"); sw.WriteLine ("\tusing System.Runtime.InteropServices;");
sw.WriteLine (); sw.WriteLine ();
@ -76,8 +85,8 @@ namespace GtkSharp.Generation {
sw.WriteLine (" {"); sw.WriteLine (" {");
sw.WriteLine (); sw.WriteLine ();
GenCtors (sw); GenCtors (gen_info);
GenProperties (sw); GenProperties (gen_info);
bool has_sigs = (sigs != null); bool has_sigs = (sigs != null);
if (!has_sigs) { if (!has_sigs) {
@ -93,10 +102,10 @@ namespace GtkSharp.Generation {
if (has_sigs && Elem.HasAttribute("parent")) if (has_sigs && Elem.HasAttribute("parent"))
{ {
sw.WriteLine("\t\tprivate Hashtable Signals = new Hashtable();"); sw.WriteLine("\t\tprivate Hashtable Signals = new Hashtable();");
GenSignals (sw, null); GenSignals (gen_info, null);
} }
GenMethods (sw, null, null, true); GenMethods (gen_info, null, null);
if (interfaces != null) { if (interfaces != null) {
Hashtable all_methods = new Hashtable (); Hashtable all_methods = new Hashtable ();
@ -115,8 +124,8 @@ namespace GtkSharp.Generation {
if (Parent != null && Parent.Implements (iface)) if (Parent != null && Parent.Implements (iface))
continue; continue;
ClassBase igen = table.GetClassGen (iface); ClassBase igen = table.GetClassGen (iface);
igen.GenMethods (sw, collisions, this, false); igen.GenMethods (gen_info, collisions, this);
igen.GenSignals (sw, this); igen.GenSignals (gen_info, this);
} }
} }
@ -126,29 +135,31 @@ namespace GtkSharp.Generation {
} }
sw.WriteLine ("#endregion"); sw.WriteLine ("#endregion");
AppendCustom(sw); AppendCustom (sw, gen_info.CustomDir);
sw.WriteLine ("\t}"); sw.WriteLine ("\t}");
sw.WriteLine ("}");
CloseWriter (sw); sw.Close ();
gen_info.Writer = null;
Statistics.ObjectCount++; Statistics.ObjectCount++;
} }
protected override void GenCtors (StreamWriter sw) protected override void GenCtors (GenerationInfo gen_info)
{ {
if (!Elem.HasAttribute("parent")) if (!Elem.HasAttribute("parent"))
return; return;
sw.WriteLine("\t\t~" + Name + "()"); gen_info.Writer.WriteLine("\t\t~" + Name + "()");
sw.WriteLine("\t\t{"); gen_info.Writer.WriteLine("\t\t{");
sw.WriteLine("\t\t\tDispose();"); gen_info.Writer.WriteLine("\t\t\tDispose();");
sw.WriteLine("\t\t}"); gen_info.Writer.WriteLine("\t\t}");
sw.WriteLine(); gen_info.Writer.WriteLine();
sw.WriteLine("\t\tprotected " + Name + "(GLib.Type gtype) : base(gtype) {}"); gen_info.Writer.WriteLine("\t\tprotected " + Name + "(GLib.Type gtype) : base(gtype) {}");
sw.WriteLine("\t\tpublic " + Name + "(IntPtr raw) : base(raw) {}"); gen_info.Writer.WriteLine("\t\tpublic " + Name + "(IntPtr raw) : base(raw) {}");
sw.WriteLine(); gen_info.Writer.WriteLine();
base.GenCtors (sw); base.GenCtors (gen_info);
} }
/* Keep this in sync with the one in glib/ObjectManager.cs */ /* Keep this in sync with the one in glib/ObjectManager.cs */

View file

@ -29,8 +29,17 @@ namespace GtkSharp.Generation {
public void Generate () public void Generate ()
{ {
StreamWriter sw = CreateWriter (); GenerationInfo gen_info = new GenerationInfo (NSElem);
Generate (gen_info);
}
public void Generate (GenerationInfo gen_info)
{
StreamWriter sw = gen_info.Writer = gen_info.OpenStream (Name);
sw.WriteLine ("namespace " + NS + " {");
sw.WriteLine ();
sw.WriteLine ("\tusing System;");
sw.WriteLine ("\tusing System.Collections;"); sw.WriteLine ("\tusing System.Collections;");
sw.WriteLine ("\tusing System.Runtime.InteropServices;"); sw.WriteLine ("\tusing System.Runtime.InteropServices;");
sw.WriteLine (); sw.WriteLine ();
@ -40,15 +49,17 @@ namespace GtkSharp.Generation {
sw.WriteLine (" {"); sw.WriteLine (" {");
sw.WriteLine (); sw.WriteLine ();
GenMethods (sw, null, null, true); GenMethods (gen_info, null, null);
GenCtors (sw); GenCtors (gen_info);
sw.WriteLine ("#endregion"); sw.WriteLine ("#endregion");
AppendCustom(sw); AppendCustom(sw, gen_info.CustomDir);
sw.WriteLine ("\t}"); sw.WriteLine ("\t}");
sw.WriteLine ("}");
CloseWriter (sw); sw.Close ();
gen_info.Writer = null;
Statistics.OpaqueCount++; Statistics.OpaqueCount++;
} }
@ -63,12 +74,12 @@ namespace GtkSharp.Generation {
return true; return true;
} }
protected override void GenCtors (StreamWriter sw) protected override void GenCtors (GenerationInfo gen_info)
{ {
sw.WriteLine("\t\tpublic " + Name + "(IntPtr raw) : base(raw) {}"); gen_info.Writer.WriteLine("\t\tpublic " + Name + "(IntPtr raw) : base(raw) {}");
sw.WriteLine(); gen_info.Writer.WriteLine();
base.GenCtors (sw); base.GenCtors (gen_info);
} }
} }

View file

@ -329,8 +329,9 @@ namespace GtkSharp.Generation {
signature = signature.Remove (signature.Length - 2, 2); signature = signature.Remove (signature.Length - 2, 2);
} }
public void Initialize (StreamWriter sw, bool is_get, bool is_set, string indent) public void Initialize (GenerationInfo gen_info, bool is_get, bool is_set, string indent)
{ {
StreamWriter sw = gen_info.Writer;
foreach (Parameter p in param_list) { foreach (Parameter p in param_list) {
IGeneratable gen = p.Generatable; IGeneratable gen = p.Generatable;
@ -349,7 +350,7 @@ namespace GtkSharp.Generation {
if (gen is CallbackGen) { if (gen is CallbackGen) {
CallbackGen cbgen = gen as CallbackGen; CallbackGen cbgen = gen as CallbackGen;
string wrapper = cbgen.GenWrapper(impl_ns); string wrapper = cbgen.GenWrapper(impl_ns, gen_info);
sw.WriteLine (indent + "\t\t\t{0} {1}_wrapper = null;", wrapper, name); sw.WriteLine (indent + "\t\t\t{0} {1}_wrapper = null;", wrapper, name);
sw.Write (indent + "\t\t\t"); sw.Write (indent + "\t\t\t");
if (p.NullOk) if (p.NullOk)

View file

@ -50,9 +50,10 @@ namespace GtkSharp.Generation {
return true; return true;
} }
public void Generate (StreamWriter sw) public void Generate (GenerationInfo gen_info)
{ {
SymbolTable table = SymbolTable.Table; SymbolTable table = SymbolTable.Table;
StreamWriter sw = gen_info.Writer;
string c_type = elem.GetAttribute("type"); string c_type = elem.GetAttribute("type");
string cs_type = table.GetCSType(c_type); string cs_type = table.GetCSType(c_type);
@ -112,7 +113,7 @@ namespace GtkSharp.Generation {
sw.WriteLine("\t\tpublic " + modifiers + cs_type + " " + name + " {"); sw.WriteLine("\t\tpublic " + modifiers + cs_type + " " + name + " {");
if (has_getter) { if (has_getter) {
sw.Write("\t\t\tget "); sw.Write("\t\t\tget ");
getter.GenerateBody(sw, "\t"); getter.GenerateBody(gen_info, "\t");
sw.WriteLine(); sw.WriteLine();
} else if (elem.HasAttribute("readable")) { } else if (elem.HasAttribute("readable")) {
sw.WriteLine("\t\t\tget {"); sw.WriteLine("\t\t\tget {");
@ -140,7 +141,7 @@ namespace GtkSharp.Generation {
if (has_setter) { if (has_setter) {
sw.Write("\t\t\tset "); sw.Write("\t\t\tset ");
setter.GenerateBody(sw, "\t"); setter.GenerateBody(gen_info, "\t");
sw.WriteLine(); sw.WriteLine();
} else if (elem.HasAttribute("writeable") && !elem.HasAttribute("construct-only")) { } else if (elem.HasAttribute("writeable") && !elem.HasAttribute("construct-only")) {
sw.WriteLine("\t\t\tset {"); sw.WriteLine("\t\t\tset {");

View file

@ -122,8 +122,9 @@ namespace GtkSharp.Generation {
return ns + "Sharp." + handler; return ns + "Sharp." + handler;
} }
public void Generate (StreamWriter sw, ClassBase implementor) public void Generate (GenerationInfo gen_info, ClassBase implementor)
{ {
StreamWriter sw = gen_info.Writer;
string cname = "\"" + elem.GetAttribute("cname") + "\""; string cname = "\"" + elem.GetAttribute("cname") + "\"";
string ns; string ns;
if (implementor == null) if (implementor == null)

View file

@ -77,6 +77,9 @@ namespace GtkSharp.Generation {
{ {
} }
public void Generate (GenerationInfo gen_info)
{
}
} }
} }

View file

@ -206,10 +206,13 @@ namespace GtkSharp.Generation {
return true; return true;
} }
public virtual void Generate () public virtual void Generate (GenerationInfo gen_info)
{ {
StreamWriter sw = CreateWriter (); StreamWriter sw = gen_info.Writer = gen_info.OpenStream (Name);
sw.WriteLine ("namespace " + NS + " {");
sw.WriteLine ();
sw.WriteLine ("\tusing System;");
sw.WriteLine ("\tusing System.Collections;"); sw.WriteLine ("\tusing System.Collections;");
sw.WriteLine ("\tusing System.Runtime.InteropServices;"); sw.WriteLine ("\tusing System.Runtime.InteropServices;");
sw.WriteLine (); sw.WriteLine ();
@ -221,18 +224,22 @@ namespace GtkSharp.Generation {
GenFields (sw); GenFields (sw);
sw.WriteLine (); sw.WriteLine ();
GenCtors (sw); GenCtors (gen_info);
GenMethods (sw, null, null, true); GenMethods (gen_info, null, null);
sw.WriteLine ("#endregion"); sw.WriteLine ("#endregion");
AppendCustom(sw); AppendCustom(sw, gen_info.CustomDir);
sw.WriteLine ("\t}"); sw.WriteLine ("\t}");
CloseWriter (sw); sw.WriteLine ("}");
sw.Close ();
gen_info.Writer = null;
} }
protected override void GenCtors (StreamWriter sw) protected override void GenCtors (GenerationInfo gen_info)
{ {
StreamWriter sw = gen_info.Writer;
sw.WriteLine ("\t\tpublic static {0} Zero = new {0} ();", QualifiedName); sw.WriteLine ("\t\tpublic static {0} Zero = new {0} ();", QualifiedName);
sw.WriteLine(); sw.WriteLine();
sw.WriteLine ("\t\tpublic static " + QualifiedName + " New(IntPtr raw) {"); sw.WriteLine ("\t\tpublic static " + QualifiedName + " New(IntPtr raw) {");
@ -261,7 +268,7 @@ namespace GtkSharp.Generation {
ctor.Params.Static = true; ctor.Params.Static = true;
} }
base.GenCtors (sw); base.GenCtors (gen_info);
} }
} }

View file

@ -14,9 +14,15 @@ namespace GtkSharp.Generation {
public StructGen (XmlElement ns, XmlElement elem) : base (ns, elem) {} public StructGen (XmlElement ns, XmlElement elem) : base (ns, elem) {}
public override void Generate () public void Generate ()
{ {
base.Generate (); GenerationInfo gen_info = new GenerationInfo (NSElem);
Generate (gen_info);
}
public override void Generate (GenerationInfo gen_info)
{
base.Generate (gen_info);
Statistics.StructCount++; Statistics.StructCount++;
} }
} }