mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-04 14:38:48 +00:00
1315 lines
60 KiB
Diff
1315 lines
60 KiB
Diff
diff -Naur generator-upstream/BoxedGen.cs generator/BoxedGen.cs
|
|
--- generator-upstream/BoxedGen.cs 2009-01-04 23:29:56.000000000 +0100
|
|
+++ generator/BoxedGen.cs 2009-11-25 08:07:47.000000000 +0100
|
|
@@ -40,16 +40,16 @@
|
|
|
|
StreamWriter sw = gen_info.Writer = gen_info.OpenStream (Name);
|
|
base.Generate (gen_info);
|
|
- sw.WriteLine ("\t\tpublic static explicit operator GLib.Value (" + QualifiedName + " boxed)");
|
|
+ sw.WriteLine ("\t\tpublic static explicit operator Gst.GLib.Value (" + QualifiedName + " boxed)");
|
|
sw.WriteLine ("\t\t{");
|
|
|
|
- sw.WriteLine ("\t\t\tGLib.Value val = GLib.Value.Empty;");
|
|
+ sw.WriteLine ("\t\t\tGst.GLib.Value val = Gst.GLib.Value.Empty;");
|
|
sw.WriteLine ("\t\t\tval.Init (" + QualifiedName + ".GType);");
|
|
sw.WriteLine ("\t\t\tval.Val = boxed;");
|
|
sw.WriteLine ("\t\t\treturn val;");
|
|
sw.WriteLine ("\t\t}");
|
|
sw.WriteLine ();
|
|
- sw.WriteLine ("\t\tpublic static explicit operator " + QualifiedName + " (GLib.Value val)");
|
|
+ sw.WriteLine ("\t\tpublic static explicit operator " + QualifiedName + " (Gst.GLib.Value val)");
|
|
sw.WriteLine ("\t\t{");
|
|
|
|
sw.WriteLine ("\t\t\treturn (" + QualifiedName + ") val.Val;");
|
|
diff -Naur generator-upstream/ByRefGen.cs generator/ByRefGen.cs
|
|
--- generator-upstream/ByRefGen.cs 2008-02-26 17:29:14.000000000 +0100
|
|
+++ generator/ByRefGen.cs 2009-11-25 08:07:47.000000000 +0100
|
|
@@ -46,7 +46,7 @@
|
|
|
|
public string AllocNative (string var_name)
|
|
{
|
|
- return "GLib.Marshaller.StructureToPtrAlloc (" + var_name + ")";
|
|
+ return "Gst.GLib.Marshaller.StructureToPtrAlloc (" + var_name + ")";
|
|
}
|
|
|
|
public override string FromNative (string var_name)
|
|
diff -Naur generator-upstream/CallbackGen.cs generator/CallbackGen.cs
|
|
--- generator-upstream/CallbackGen.cs 2009-09-03 21:50:53.000000000 +0200
|
|
+++ generator/CallbackGen.cs 2009-11-25 08:07:47.000000000 +0100
|
|
@@ -140,7 +140,7 @@
|
|
sw.WriteLine ();
|
|
sw.WriteLine ("\t\t" + Name + "Native native_cb;");
|
|
sw.WriteLine ("\t\tIntPtr __data;");
|
|
- sw.WriteLine ("\t\tGLib.DestroyNotify __notify;");
|
|
+ sw.WriteLine ("\t\tGst.GLib.DestroyNotify __notify;");
|
|
sw.WriteLine ();
|
|
sw.WriteLine ("\t\t~" + Name + "Invoker ()");
|
|
sw.WriteLine ("\t\t{");
|
|
@@ -153,7 +153,7 @@
|
|
sw.WriteLine ();
|
|
sw.WriteLine ("\t\tinternal " + Name + "Invoker (" + Name + "Native native_cb, IntPtr data) : this (native_cb, data, null) {}");
|
|
sw.WriteLine ();
|
|
- sw.WriteLine ("\t\tinternal " + Name + "Invoker (" + Name + "Native native_cb, IntPtr data, GLib.DestroyNotify notify)");
|
|
+ sw.WriteLine ("\t\tinternal " + Name + "Invoker (" + Name + "Native native_cb, IntPtr data, Gst.GLib.DestroyNotify notify)");
|
|
sw.WriteLine ("\t\t{");
|
|
sw.WriteLine ("\t\t\tthis.native_cb = native_cb;");
|
|
sw.WriteLine ("\t\t\t__data = data;");
|
|
@@ -233,7 +233,7 @@
|
|
*/
|
|
bool fatal = (retval.MarshalType != "void" && retval.MarshalType != "bool") || call.HasOutParam;
|
|
sw.WriteLine ("\t\t\t} catch (Exception e) {");
|
|
- sw.WriteLine ("\t\t\t\tGLib.ExceptionManager.RaiseUnhandledException (e, " + (fatal ? "true" : "false") + ");");
|
|
+ sw.WriteLine ("\t\t\t\tGst.GLib.ExceptionManager.RaiseUnhandledException (e, " + (fatal ? "true" : "false") + ");");
|
|
if (fatal) {
|
|
sw.WriteLine ("\t\t\t\t// NOTREACHED: Above call does not return.");
|
|
sw.WriteLine ("\t\t\t\tthrow e;");
|
|
diff -Naur generator-upstream/ConstFilenameGen.cs generator/ConstFilenameGen.cs
|
|
--- generator-upstream/ConstFilenameGen.cs 2007-09-21 18:37:04.000000000 +0200
|
|
+++ generator/ConstFilenameGen.cs 2009-11-25 08:07:47.000000000 +0100
|
|
@@ -35,17 +35,17 @@
|
|
|
|
public override string FromNative (string var)
|
|
{
|
|
- return "GLib.Marshaller.FilenamePtrToString (" + var + ")";
|
|
+ return "Gst.GLib.Marshaller.FilenamePtrToString (" + var + ")";
|
|
}
|
|
|
|
public string AllocNative (string managed_var)
|
|
{
|
|
- return "GLib.Marshaller.StringToFilenamePtr (" + managed_var + ")";
|
|
+ return "Gst.GLib.Marshaller.StringToFilenamePtr (" + managed_var + ")";
|
|
}
|
|
|
|
public string ReleaseNative (string native_var)
|
|
{
|
|
- return "GLib.Marshaller.Free (" + native_var + ")";
|
|
+ return "Gst.GLib.Marshaller.Free (" + native_var + ")";
|
|
}
|
|
}
|
|
}
|
|
diff -Naur generator-upstream/ConstStringGen.cs generator/ConstStringGen.cs
|
|
--- generator-upstream/ConstStringGen.cs 2009-08-13 16:46:33.000000000 +0200
|
|
+++ generator/ConstStringGen.cs 2009-11-25 08:07:47.000000000 +0100
|
|
@@ -37,17 +37,17 @@
|
|
|
|
public override string FromNative (string var)
|
|
{
|
|
- return "GLib.Marshaller.Utf8PtrToString (" + var + ")";
|
|
+ return "Gst.GLib.Marshaller.Utf8PtrToString (" + var + ")";
|
|
}
|
|
|
|
public string AllocNative (string managed_var)
|
|
{
|
|
- return "GLib.Marshaller.StringToPtrGStrdup (" + managed_var + ")";
|
|
+ return "Gst.GLib.Marshaller.StringToPtrGStrdup (" + managed_var + ")";
|
|
}
|
|
|
|
public string ReleaseNative (string native_var)
|
|
{
|
|
- return "GLib.Marshaller.Free (" + native_var + ")";
|
|
+ return "Gst.GLib.Marshaller.Free (" + native_var + ")";
|
|
}
|
|
}
|
|
}
|
|
diff -Naur generator-upstream/Ctor.cs generator/Ctor.cs
|
|
--- generator-upstream/Ctor.cs 2009-09-03 21:50:53.000000000 +0200
|
|
+++ generator/Ctor.cs 2009-11-25 08:07:47.000000000 +0100
|
|
@@ -32,14 +32,16 @@
|
|
private bool preferred;
|
|
private string name;
|
|
private bool needs_chaining = false;
|
|
+ private bool mini_object = false;
|
|
|
|
public Ctor (XmlElement elem, ClassBase implementor) : base (elem, implementor)
|
|
{
|
|
if (elem.HasAttribute ("preferred"))
|
|
preferred = true;
|
|
- if (implementor is ObjectGen)
|
|
+ if (implementor is ObjectGen || implementor is MiniObjectGen)
|
|
needs_chaining = true;
|
|
name = implementor.Name;
|
|
+ mini_object = implementor is MiniObjectGen;
|
|
}
|
|
|
|
public bool Preferred {
|
|
@@ -110,9 +112,14 @@
|
|
sw.WriteLine ("\t\t\tif (GetType () != typeof (" + name + ")) {");
|
|
|
|
if (Parameters.Count == 0) {
|
|
- sw.WriteLine ("\t\t\t\tCreateNativeObject (new string [0], new GLib.Value[0]);");
|
|
+ if (mini_object)
|
|
+ sw.WriteLine ("\t\t\t\tCreateNativeObject ();");
|
|
+ else
|
|
+ sw.WriteLine ("\t\t\t\tCreateNativeObject (new string [0], new Gst.GLib.Value[0]);");
|
|
sw.WriteLine ("\t\t\t\treturn;");
|
|
} else {
|
|
+ if (mini_object)
|
|
+ throw new Exception ("MiniObject subclasses can't have ctors with parameters");
|
|
ArrayList names = new ArrayList ();
|
|
ArrayList values = new ArrayList ();
|
|
for (int i = 0; i < Parameters.Count; i++) {
|
|
@@ -137,13 +144,13 @@
|
|
indent += "\t";
|
|
}
|
|
sw.WriteLine (indent + "names.Add (\"" + names [i] + "\");");
|
|
- sw.WriteLine (indent + "vals.Add (new GLib.Value (" + values[i] + "));");
|
|
+ sw.WriteLine (indent + "vals.Add (new Gst.GLib.Value (" + values[i] + "));");
|
|
|
|
if (p.Generatable is ClassBase && !(p.Generatable is StructBase))
|
|
sw.WriteLine ("\t\t\t\t}");
|
|
}
|
|
|
|
- sw.WriteLine ("\t\t\t\tCreateNativeObject ((string[])names.ToArray (typeof (string)), (GLib.Value[])vals.ToArray (typeof (GLib.Value)));");
|
|
+ sw.WriteLine ("\t\t\t\tCreateNativeObject ((string[])names.ToArray (typeof (string)), (Gst.GLib.Value[])vals.ToArray (typeof (Gst.GLib.Value)));");
|
|
sw.WriteLine ("\t\t\t\treturn;");
|
|
} else
|
|
sw.WriteLine ("\t\t\t\tthrow new InvalidOperationException (\"Can't override this constructor.\");");
|
|
diff -Naur generator-upstream/DefaultSignalHandler.cs generator/DefaultSignalHandler.cs
|
|
--- generator-upstream/DefaultSignalHandler.cs 2009-04-13 19:44:48.000000000 +0200
|
|
+++ generator/DefaultSignalHandler.cs 2009-11-25 08:07:47.000000000 +0100
|
|
@@ -68,13 +68,13 @@
|
|
{
|
|
GenerateMethodBody (sw, implementor);
|
|
if (retval.IsVoid)
|
|
- sw.WriteLine ("\t\t\tGLib.Value ret = GLib.Value.Empty;");
|
|
+ sw.WriteLine ("\t\t\tGst.GLib.Value ret = Gst.GLib.Value.Empty;");
|
|
else
|
|
- sw.WriteLine ("\t\t\tGLib.Value ret = new GLib.Value (" + ReturnGType + ");");
|
|
+ sw.WriteLine ("\t\t\tGst.GLib.Value ret = new Gst.GLib.Value (" + ReturnGType + ");");
|
|
|
|
- sw.WriteLine ("\t\t\tGLib.ValueArray inst_and_params = new GLib.ValueArray (" + (parms.Count + 1) + ");");
|
|
- sw.WriteLine ("\t\t\tGLib.Value[] vals = new GLib.Value [" + (parms.Count + 1) + "];");
|
|
- sw.WriteLine ("\t\t\tvals [0] = new GLib.Value (this);");
|
|
+ sw.WriteLine ("\t\t\tGst.GLib.ValueArray inst_and_params = new Gst.GLib.ValueArray (" + (parms.Count + 1) + ");");
|
|
+ sw.WriteLine ("\t\t\tGst.GLib.Value[] vals = new Gst.GLib.Value [" + (parms.Count + 1) + "];");
|
|
+ sw.WriteLine ("\t\t\tvals [0] = new Gst.GLib.Value (this);");
|
|
sw.WriteLine ("\t\t\tinst_and_params.Append (vals [0]);");
|
|
string cleanup = "";
|
|
for (int i = 0; i < parms.Count; i++) {
|
|
@@ -82,24 +82,24 @@
|
|
if (p.PassAs != "") {
|
|
if (SymbolTable.Table.IsBoxed (p.CType)) {
|
|
if (p.PassAs == "ref")
|
|
- sw.WriteLine ("\t\t\tvals [" + (i + 1) + "] = new GLib.Value (" + p.Name + ");");
|
|
+ sw.WriteLine ("\t\t\tvals [" + (i + 1) + "] = new Gst.GLib.Value (" + p.Name + ");");
|
|
else
|
|
- sw.WriteLine ("\t\t\tvals [" + (i + 1) + "] = new GLib.Value ((GLib.GType)typeof (" + p.CSType + "));");
|
|
+ sw.WriteLine ("\t\t\tvals [" + (i + 1) + "] = new Gst.GLib.Value ((Gst.GLib.GType)typeof (" + p.CSType + "));");
|
|
cleanup += "\t\t\t" + p.Name + " = (" + p.CSType + ") vals [" + i + "];\n";
|
|
} else {
|
|
if (p.PassAs == "ref")
|
|
- sw.WriteLine ("\t\t\tIntPtr " + p.Name + "_ptr = GLib.Marshaller.StructureToPtrAlloc (" + p.Generatable.CallByName (p.Name) + ");");
|
|
+ sw.WriteLine ("\t\t\tIntPtr " + p.Name + "_ptr = Gst.GLib.Marshaller.StructureToPtrAlloc (" + p.Generatable.CallByName (p.Name) + ");");
|
|
else
|
|
sw.WriteLine ("\t\t\tIntPtr " + p.Name + "_ptr = Marshal.AllocHGlobal (Marshal.SizeOf (typeof (" + p.MarshalType + ")));");
|
|
|
|
- sw.WriteLine ("\t\t\tvals [" + (i + 1) + "] = new GLib.Value (" + p.Name + "_ptr);");
|
|
+ sw.WriteLine ("\t\t\tvals [" + (i + 1) + "] = new Gst.GLib.Value (" + p.Name + "_ptr);");
|
|
cleanup += "\t\t\t" + p.Name + " = " + p.FromNative ("(" + p.MarshalType + ") Marshal.PtrToStructure (" + p.Name + "_ptr, typeof (" + p.MarshalType + "))") + ";\n";
|
|
cleanup += "\t\t\tMarshal.FreeHGlobal (" + p.Name + "_ptr);\n";
|
|
}
|
|
} else if (p.IsLength && i > 0 && parms [i - 1].IsString)
|
|
- sw.WriteLine ("\t\t\tvals [" + (i + 1) + "] = new GLib.Value (System.Text.Encoding.UTF8.GetByteCount (" + parms [i-1].Name + "));");
|
|
+ sw.WriteLine ("\t\t\tvals [" + (i + 1) + "] = new Gst.GLib.Value (System.Text.Encoding.UTF8.GetByteCount (" + parms [i-1].Name + "));");
|
|
else
|
|
- sw.WriteLine ("\t\t\tvals [" + (i + 1) + "] = new GLib.Value (" + p.Name + ");");
|
|
+ sw.WriteLine ("\t\t\tvals [" + (i + 1) + "] = new Gst.GLib.Value (" + p.Name + ");");
|
|
|
|
sw.WriteLine ("\t\t\tinst_and_params.Append (vals [" + (i + 1) + "]);");
|
|
}
|
|
@@ -107,7 +107,7 @@
|
|
sw.WriteLine ("\t\t\tg_signal_chain_from_overridden (inst_and_params.ArrayPtr, ref ret);");
|
|
if (cleanup != "")
|
|
sw.WriteLine (cleanup);
|
|
- sw.WriteLine ("\t\t\tforeach (GLib.Value v in vals)");
|
|
+ sw.WriteLine ("\t\t\tforeach (Gst.GLib.Value v in vals)");
|
|
sw.WriteLine ("\t\t\t\tv.Dispose ();");
|
|
if (!retval.IsVoid) {
|
|
IGeneratable igen = SymbolTable.Table [retval.CType];
|
|
@@ -123,7 +123,9 @@
|
|
IGeneratable igen = SymbolTable.Table [retval.CType];
|
|
|
|
if (igen is ObjectGen)
|
|
- return "GLib.GType.Object";
|
|
+ return "Gst.GLib.GType.Object";
|
|
+ if (igen is MiniObjectGen)
|
|
+ return "Gst.MiniObject.GType";
|
|
if (igen is BoxedGen)
|
|
return retval.CSType + ".GType";
|
|
if (igen is EnumGen)
|
|
@@ -131,11 +133,11 @@
|
|
|
|
switch (retval.CSType) {
|
|
case "bool":
|
|
- return "GLib.GType.Boolean";
|
|
+ return "Gst.GLib.GType.Boolean";
|
|
case "string":
|
|
- return "GLib.GType.String";
|
|
+ return "Gst.GLib.GType.String";
|
|
case "int":
|
|
- return "GLib.GType.Int";
|
|
+ return "Gst.GLib.GType.Int";
|
|
default:
|
|
throw new Exception (retval.CSType);
|
|
}
|
|
diff -Naur generator-upstream/EnumGen.cs generator/EnumGen.cs
|
|
--- generator-upstream/EnumGen.cs 2009-09-03 21:50:53.000000000 +0200
|
|
+++ generator/EnumGen.cs 2009-11-25 08:07:47.000000000 +0100
|
|
@@ -98,7 +98,7 @@
|
|
if (Elem.GetAttribute("type") == "flags")
|
|
sw.WriteLine ("\t[Flags]");
|
|
if (Elem.HasAttribute("gtype"))
|
|
- sw.WriteLine ("\t[GLib.GType (typeof (" + NS + "." + Name + "GType))]");
|
|
+ sw.WriteLine ("\t[Gst.GLib.GType (typeof (" + NS + "." + Name + "GType))]");
|
|
|
|
string access = IsInternal ? "internal" : "public";
|
|
sw.WriteLine ("\t" + access + " enum " + Name + enum_type + " {");
|
|
@@ -115,9 +115,9 @@
|
|
sw.WriteLine ("\t\t[DllImport (\"" + LibraryName + "\", CallingConvention = CallingConvention.Cdecl)]");
|
|
sw.WriteLine ("\t\tstatic extern IntPtr " + Elem.GetAttribute ("gtype") + " ();");
|
|
sw.WriteLine ();
|
|
- sw.WriteLine ("\t\tpublic static GLib.GType GType {");
|
|
+ sw.WriteLine ("\t\tpublic static Gst.GLib.GType GType {");
|
|
sw.WriteLine ("\t\t\tget {");
|
|
- sw.WriteLine ("\t\t\t\treturn new GLib.GType (" + Elem.GetAttribute ("gtype") + " ());");
|
|
+ sw.WriteLine ("\t\t\t\treturn new Gst.GLib.GType (" + Elem.GetAttribute ("gtype") + " ());");
|
|
sw.WriteLine ("\t\t\t}");
|
|
sw.WriteLine ("\t\t}");
|
|
sw.WriteLine ("\t}");
|
|
diff -Naur generator-upstream/FieldBase.cs generator/FieldBase.cs
|
|
--- generator-upstream/FieldBase.cs 2009-08-13 16:46:33.000000000 +0200
|
|
+++ generator/FieldBase.cs 2009-11-25 08:07:47.000000000 +0100
|
|
@@ -89,7 +89,7 @@
|
|
void CheckGlue ()
|
|
{
|
|
getterName = setterName = getOffsetName = null;
|
|
- if (Access != "public")
|
|
+ if (DefaultAccess != "public" && (!elem.HasAttribute ("access") || (Access != "public" && Access != "protected" && Access != "internal")))
|
|
return;
|
|
|
|
string prefix = (container_type.NS + "Sharp_" + container_type.NS + "_" + container_type.Name).Replace(".", "__").ToLower ();
|
|
@@ -154,8 +154,9 @@
|
|
StreamWriter sw = gen_info.Writer;
|
|
string modifiers = elem.HasAttribute ("new_flag") ? "new " : "";
|
|
bool is_struct = table.IsStruct (CType) || table.IsBoxed (CType);
|
|
+ string access = elem.HasAttribute ("access") ? elem.GetAttribute ("access") : "public";
|
|
|
|
- sw.WriteLine (indent + "public " + modifiers + CSType + " " + Name + " {");
|
|
+ sw.WriteLine (indent + access + " " + modifiers + CSType + " " + Name + " {");
|
|
|
|
if (Getter != null) {
|
|
sw.Write (indent + "\tget ");
|
|
diff -Naur generator-upstream/gapi3-codegen.in generator/gapi3-codegen.in
|
|
diff -Naur generator-upstream/GObjectVM.cs generator/GObjectVM.cs
|
|
--- generator-upstream/GObjectVM.cs 2009-08-09 01:42:15.000000000 +0200
|
|
+++ generator/GObjectVM.cs 2009-11-25 08:07:47.000000000 +0100
|
|
@@ -154,17 +154,17 @@
|
|
sw.WriteLine ("\t\tpublic static " + Name + "Delegate " + Name + "Handler {");
|
|
sw.WriteLine ("\t\t\tset {");
|
|
sw.WriteLine ("\t\t\t\t{0}_handler = value;", CName);
|
|
- sw.WriteLine ("\t\t\t\tOverride{0} ((GLib.GType) typeof ({1}), value == null ? null : {0}VMCallback);", Name, container_type.Name);
|
|
+ sw.WriteLine ("\t\t\t\tOverride{0} ((Gst.GLib.GType) typeof ({1}), value == null ? null : {0}VMCallback);", Name, container_type.Name);
|
|
sw.WriteLine ("\t\t\t}");
|
|
sw.WriteLine ("\t\t}");
|
|
} else {
|
|
- sw.WriteLine ("\t\tstatic void Override{0} (GLib.GType gtype)", this.Name);
|
|
+ sw.WriteLine ("\t\tstatic void Override{0} (Gst.GLib.GType gtype)", this.Name);
|
|
sw.WriteLine ("\t\t{");
|
|
sw.WriteLine ("\t\t\tOverride{0} (gtype, {0}VMCallback);", this.Name);
|
|
sw.WriteLine ("\t\t}");
|
|
}
|
|
sw.WriteLine ();
|
|
- sw.WriteLine ("\t\tstatic void Override{0} (GLib.GType gtype, {0}NativeDelegate callback)", this.Name);
|
|
+ sw.WriteLine ("\t\tstatic void Override{0} (Gst.GLib.GType gtype, {0}NativeDelegate callback)", this.Name);
|
|
sw.WriteLine ("\t\t{");
|
|
}
|
|
|
|
@@ -181,7 +181,7 @@
|
|
|
|
protected void GenerateMethodBody (StreamWriter sw, ClassBase implementor)
|
|
{
|
|
- sw.WriteLine ("\t\t[GLib.DefaultSignalHandler(Type=typeof(" + (implementor != null ? implementor.QualifiedName : container_type.QualifiedName) + "), ConnectionMethod=\"Override" + this.Name +"\")]");
|
|
+ sw.WriteLine ("\t\t[Gst.GLib.DefaultSignalHandler(Type=typeof(" + (implementor != null ? implementor.QualifiedName : container_type.QualifiedName) + "), ConnectionMethod=\"Override" + this.Name +"\")]");
|
|
sw.Write ("\t\t{0} ", this.Protection);
|
|
if (this.modifiers != "")
|
|
sw.Write ("{0} ", this.modifiers);
|
|
@@ -261,7 +261,7 @@
|
|
return "FALSE";
|
|
case "true":
|
|
return "TRUE";
|
|
- case "GLib.GType.None":
|
|
+ case "Gst.GLib.GType.None":
|
|
return "G_TYPE_NONE";
|
|
default:
|
|
return val;
|
|
diff -Naur generator-upstream/gst-codegen.diff generator/gst-codegen.diff
|
|
diff -Naur generator-upstream/gst-gapi_codegen.exe generator/gst-gapi_codegen.exe
|
|
diff -Naur generator-upstream/gst-gapi_codegen.exe.mdb generator/gst-gapi_codegen.exe.mdb
|
|
diff -Naur generator-upstream/InterfaceGen.cs generator/InterfaceGen.cs
|
|
--- generator-upstream/InterfaceGen.cs 2009-08-19 18:13:17.000000000 +0200
|
|
+++ generator/InterfaceGen.cs 2009-11-25 08:07:47.000000000 +0100
|
|
@@ -60,7 +60,7 @@
|
|
|
|
public override string CallByName (string var, bool owned)
|
|
{
|
|
- return String.Format ("{0} == null ? IntPtr.Zero : (({0} is GLib.Object) ? ({0} as GLib.Object).{1} : ({0} as {2}Adapter).{1})", var, owned ? "OwnedHandle" : "Handle", QualifiedName);
|
|
+ return String.Format ("{0} == null ? IntPtr.Zero : (({0} is Gst.GLib.Object) ? ({0} as Gst.GLib.Object).{1} : ({0} as {2}Adapter).{1})", var, owned ? "OwnedHandle" : "Handle", QualifiedName);
|
|
}
|
|
|
|
public override string FromNative (string var, bool owned)
|
|
@@ -91,7 +91,7 @@
|
|
sw.WriteLine ();
|
|
sw.WriteLine ("\t\tstatic " + Name + "Adapter ()");
|
|
sw.WriteLine ("\t\t{");
|
|
- sw.WriteLine ("\t\t\tGLib.GType.Register (_gtype, typeof({0}Adapter));", Name);
|
|
+ sw.WriteLine ("\t\t\tGst.GLib.GType.Register (_gtype, typeof({0}Adapter));", Name);
|
|
foreach (InterfaceVM vm in interface_vms) {
|
|
if (vm.IsValid)
|
|
sw.WriteLine ("\t\t\tiface.{0} = new {0}NativeDelegate ({0}_cb);", vm.Name);
|
|
@@ -127,22 +127,22 @@
|
|
void GenerateCtors (StreamWriter sw)
|
|
{
|
|
// Native GObjects do not implement the *Implementor interfaces
|
|
- sw.WriteLine ("\t\tGLib.Object implementor;", Name);
|
|
+ sw.WriteLine ("\t\tGst.GLib.Object implementor;", Name);
|
|
sw.WriteLine ();
|
|
|
|
if (!IsConsumeOnly) {
|
|
sw.WriteLine ("\t\tpublic " + Name + "Adapter ()");
|
|
sw.WriteLine ("\t\t{");
|
|
- sw.WriteLine ("\t\t\tInitHandler = new GLib.GInterfaceInitHandler (Initialize);");
|
|
+ sw.WriteLine ("\t\t\tInitHandler = new Gst.GLib.GInterfaceInitHandler (Initialize);");
|
|
sw.WriteLine ("\t\t}");
|
|
sw.WriteLine ();
|
|
sw.WriteLine ("\t\tpublic {0}Adapter ({0}Implementor implementor)", Name);
|
|
sw.WriteLine ("\t\t{");
|
|
sw.WriteLine ("\t\t\tif (implementor == null)");
|
|
sw.WriteLine ("\t\t\t\tthrow new ArgumentNullException (\"implementor\");");
|
|
- sw.WriteLine ("\t\t\telse if (!(implementor is GLib.Object))");
|
|
- sw.WriteLine ("\t\t\t\tthrow new ArgumentException (\"implementor must be a subclass of GLib.Object\");");
|
|
- sw.WriteLine ("\t\t\tthis.implementor = implementor as GLib.Object;");
|
|
+ sw.WriteLine ("\t\t\telse if (!(implementor is Gst.GLib.Object))");
|
|
+ sw.WriteLine ("\t\t\t\tthrow new ArgumentException (\"implementor must be a subclass of Gst.GLib.Object\");");
|
|
+ sw.WriteLine ("\t\t\tthis.implementor = implementor as Gst.GLib.Object;");
|
|
sw.WriteLine ("\t\t}");
|
|
sw.WriteLine ();
|
|
}
|
|
@@ -151,7 +151,7 @@
|
|
sw.WriteLine ("\t\t{");
|
|
sw.WriteLine ("\t\t\tif (!_gtype.IsInstance (handle))");
|
|
sw.WriteLine ("\t\t\t\tthrow new ArgumentException (\"The gobject doesn't implement the GInterface of this adapter\", \"handle\");");
|
|
- sw.WriteLine ("\t\t\timplementor = GLib.Object.GetObject (handle);");
|
|
+ sw.WriteLine ("\t\t\timplementor = Gst.GLib.Object.GetObject (handle);");
|
|
sw.WriteLine ("\t\t}");
|
|
sw.WriteLine ();
|
|
}
|
|
@@ -160,9 +160,9 @@
|
|
{
|
|
Method m = GetMethod ("GetType");
|
|
m.GenerateImport (sw);
|
|
- sw.WriteLine ("\t\tprivate static GLib.GType _gtype = new GLib.GType ({0} ());", m.CName);
|
|
+ sw.WriteLine ("\t\tprivate static Gst.GLib.GType _gtype = new Gst.GLib.GType ({0} ());", m.CName);
|
|
sw.WriteLine ();
|
|
- sw.WriteLine ("\t\tpublic override GLib.GType GType {");
|
|
+ sw.WriteLine ("\t\tpublic override Gst.GLib.GType GType {");
|
|
sw.WriteLine ("\t\t\tget {");
|
|
sw.WriteLine ("\t\t\t\treturn _gtype;");
|
|
sw.WriteLine ("\t\t\t}");
|
|
@@ -190,11 +190,11 @@
|
|
{
|
|
sw.WriteLine ("\t\tpublic static " + Name + " GetObject (IntPtr handle, bool owned)");
|
|
sw.WriteLine ("\t\t{");
|
|
- sw.WriteLine ("\t\t\tGLib.Object obj = GLib.Object.GetObject (handle, owned);");
|
|
+ sw.WriteLine ("\t\t\tGst.GLib.Object obj = Gst.GLib.Object.GetObject (handle, owned);");
|
|
sw.WriteLine ("\t\t\treturn GetObject (obj);");
|
|
sw.WriteLine ("\t\t}");
|
|
sw.WriteLine ();
|
|
- sw.WriteLine ("\t\tpublic static " + Name + " GetObject (GLib.Object obj)");
|
|
+ sw.WriteLine ("\t\tpublic static " + Name + " GetObject (Gst.GLib.Object obj)");
|
|
sw.WriteLine ("\t\t{");
|
|
sw.WriteLine ("\t\t\tif (obj == null)");
|
|
sw.WriteLine ("\t\t\t\treturn null;");
|
|
@@ -230,7 +230,7 @@
|
|
sw.WriteLine ("\tusing System.Runtime.InteropServices;");
|
|
sw.WriteLine ();
|
|
sw.WriteLine ("#region Autogenerated code");
|
|
- sw.WriteLine ("\tpublic partial class " + Name + "Adapter : GLib.GInterfaceAdapter, " + QualifiedName + " {");
|
|
+ sw.WriteLine ("\tpublic partial class " + Name + "Adapter : Gst.GLib.GInterfaceAdapter, " + QualifiedName + " {");
|
|
sw.WriteLine ();
|
|
|
|
if (!IsConsumeOnly) {
|
|
@@ -249,7 +249,7 @@
|
|
GenProperties (gen_info, null);
|
|
|
|
foreach (Signal sig in sigs.Values)
|
|
- sig.GenEvent (sw, null, "GLib.Object.GetObject (Handle)");
|
|
+ sig.GenEvent (sw, null, "Gst.GLib.Object.GetObject (Handle)");
|
|
|
|
Method temp = methods ["GetType"] as Method;
|
|
if (temp != null)
|
|
@@ -275,9 +275,9 @@
|
|
return;
|
|
|
|
sw.WriteLine ();
|
|
- sw.WriteLine ("\t[GLib.GInterface (typeof (" + Name + "Adapter))]");
|
|
+ sw.WriteLine ("\t[Gst.GLib.GInterface (typeof (" + Name + "Adapter))]");
|
|
string access = IsInternal ? "internal" : "public";
|
|
- sw.WriteLine ("\t" + access + " partial interface " + Name + "Implementor : GLib.IWrapper {");
|
|
+ sw.WriteLine ("\t" + access + " partial interface " + Name + "Implementor : Gst.GLib.IWrapper {");
|
|
sw.WriteLine ();
|
|
Hashtable vm_table = new Hashtable ();
|
|
foreach (InterfaceVM vm in interface_vms) {
|
|
@@ -323,7 +323,7 @@
|
|
sw.WriteLine ();
|
|
sw.WriteLine ("#region Autogenerated code");
|
|
string access = IsInternal ? "internal" : "public";
|
|
- sw.WriteLine ("\t" + access + " partial interface " + Name + " : GLib.IWrapper {");
|
|
+ sw.WriteLine ("\t" + access + " partial interface " + Name + " : Gst.GLib.IWrapper {");
|
|
sw.WriteLine ();
|
|
|
|
foreach (Signal sig in sigs.Values) {
|
|
diff -Naur generator-upstream/Makefile generator/Makefile
|
|
diff -Naur generator-upstream/Makefile.am generator/Makefile.am
|
|
diff -Naur generator-upstream/Makefile.in generator/Makefile.in
|
|
diff -Naur generator-upstream/ManagedCallString.cs generator/ManagedCallString.cs
|
|
--- generator-upstream/ManagedCallString.cs 2009-08-13 16:46:33.000000000 +0200
|
|
+++ generator/ManagedCallString.cs 2009-11-25 08:07:47.000000000 +0100
|
|
@@ -50,12 +50,15 @@
|
|
error_param = p.Name;
|
|
continue;
|
|
}
|
|
+
|
|
this.parms.Add (p);
|
|
|
|
if (p.PassAs != String.Empty && (p.Name != p.FromNative (p.Name)))
|
|
this.special.Add (true);
|
|
else if (p.Generatable is CallbackGen)
|
|
this.special.Add (true);
|
|
+ else if (p.Scope == "call")
|
|
+ this.special.Add (true);
|
|
else
|
|
this.special.Add (false);
|
|
}
|
|
@@ -96,6 +99,11 @@
|
|
ret += indent + String.Format ("{0} {1}_invoker = new {0} ({1}, {2});\n", (igen as CallbackGen).InvokerName, p.Name, user_data_param);
|
|
else
|
|
ret += indent + String.Format ("{0} {1}_invoker = new {0} ({1}, {2}, {3});\n", (igen as CallbackGen).InvokerName, p.Name, user_data_param, destroy_param);
|
|
+ } else if (p.Scope == "call") {
|
|
+ if (igen is ObjectBase)
|
|
+ ret += indent + igen.QualifiedName + " my" + p.Name + " = " + (igen as ObjectBase).FromNative (p.Name, true) + ";\n";
|
|
+ else
|
|
+ throw new NotImplementedException();
|
|
} else {
|
|
ret += indent + igen.QualifiedName + " my" + p.Name;
|
|
if (p.PassAs == "ref")
|
|
@@ -137,16 +145,25 @@
|
|
Parameter p = parms [i] as Parameter;
|
|
IGeneratable igen = p.Generatable;
|
|
|
|
- if (igen is CallbackGen)
|
|
+ if (igen is CallbackGen) {
|
|
continue;
|
|
- else if (igen is StructBase || igen is ByRefGen)
|
|
+ } else if (igen is StructBase || igen is ByRefGen) {
|
|
ret += indent + String.Format ("if ({0} != IntPtr.Zero) System.Runtime.InteropServices.Marshal.StructureToPtr (my{0}, {0}, false);\n", p.Name);
|
|
- else if (igen is IManualMarshaler)
|
|
+ } else if (igen is IManualMarshaler) {
|
|
ret += String.Format ("{0}{1} = {2};", indent, p.Name, (igen as IManualMarshaler).AllocNative ("my" + p.Name));
|
|
- else
|
|
+ } else if (p.Scope == "call") {
|
|
+ if (igen is ObjectBase || igen is OpaqueGen) {
|
|
+ if (igen is ObjectBase)
|
|
+ ret += indent + "IntPtr dummy = my" + p.Name + ".OwnedHandle;\n";
|
|
+ else
|
|
+ throw new NotImplementedException();
|
|
+
|
|
+ ret += indent + "my" + p.Name + ".Dispose();\n";
|
|
+ }
|
|
+ } else {
|
|
ret += indent + p.Name + " = " + igen.CallByName ("my" + p.Name) + ";\n";
|
|
+ }
|
|
}
|
|
-
|
|
return ret;
|
|
}
|
|
}
|
|
diff -Naur generator-upstream/MethodBody.cs generator/MethodBody.cs
|
|
--- generator-upstream/MethodBody.cs 2009-01-07 18:10:08.000000000 +0100
|
|
+++ generator/MethodBody.cs 2009-11-25 08:07:47.000000000 +0100
|
|
@@ -111,7 +111,7 @@
|
|
sw.WriteLine (indent + "\t\t\t\t{0} = null;", parameters [i + 2].Name);
|
|
sw.WriteLine (indent + "\t\t\t} else {");
|
|
sw.WriteLine (indent + "\t\t\t\t{0} = (IntPtr) GCHandle.Alloc ({1}_wrapper);", parameters [i + 1].Name, name);
|
|
- sw.WriteLine (indent + "\t\t\t\t{0} = GLib.DestroyHelper.NotifyHandler;", parameters [i + 2].Name, parameters [i + 2].CSType);
|
|
+ sw.WriteLine (indent + "\t\t\t\t{0} = Gst.GLib.DestroyHelper.NotifyHandler;", parameters [i + 2].Name, parameters [i + 2].CSType);
|
|
sw.WriteLine (indent + "\t\t\t}");
|
|
break;
|
|
|
|
@@ -154,7 +154,7 @@
|
|
{
|
|
if (!ThrowsException)
|
|
return;
|
|
- sw.WriteLine (indent + "\t\t\tif (error != IntPtr.Zero) throw new GLib.GException (error);");
|
|
+ sw.WriteLine (indent + "\t\t\tif (error != IntPtr.Zero) throw new Gst.GLib.GException (error);");
|
|
}
|
|
|
|
public bool ThrowsException {
|
|
diff -Naur generator-upstream/Method.cs generator/Method.cs
|
|
--- generator-upstream/Method.cs 2009-09-03 21:50:53.000000000 +0200
|
|
+++ generator/Method.cs 2009-11-25 08:07:47.000000000 +0100
|
|
@@ -118,7 +118,7 @@
|
|
|
|
if (Name == "ToString" && Parameters.Count == 0)
|
|
sw.Write("override ");
|
|
- else if (Name == "GetGType" && container_type is ObjectGen)
|
|
+ else if (Name == "GetGType" && (container_type is ObjectGen || container_type is MiniObjectGen))
|
|
sw.Write("new ");
|
|
else if (Modifiers == "new " || (dup != null && ((dup.Signature != null && Signature != null && dup.Signature.ToString() == Signature.ToString()) || (dup.Signature == null && Signature == null))))
|
|
sw.Write("new ");
|
|
diff -Naur generator-upstream/MiniObjectGen.cs generator/MiniObjectGen.cs
|
|
--- generator-upstream/MiniObjectGen.cs 1970-01-01 01:00:00.000000000 +0100
|
|
+++ generator/MiniObjectGen.cs 2009-10-03 11:56:16.000000000 +0200
|
|
@@ -0,0 +1,326 @@
|
|
+// GtkSharp.Generation.MiniObjectGen.cs - The Mini Object Generatable.
|
|
+//
|
|
+// Author: Mike Kestner <mkestner@ximian.com>
|
|
+//
|
|
+// Copyright (c) 2001-2003 Mike Kestner
|
|
+// Copyright (c) 2003-2004 Novell, Inc.
|
|
+// Copyright (c) 2009 Sebastian Dröge <sebastian.droege@collabora.co.uk>.
|
|
+//
|
|
+// This program is free software; you can redistribute it and/or
|
|
+// modify it under the terms of version 2 of the GNU General Public
|
|
+// License as published by the Free Software Foundation.
|
|
+//
|
|
+// This program is distributed in the hope that it will be useful,
|
|
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
+// General Public License for more details.
|
|
+//
|
|
+// You should have received a copy of the GNU General Public
|
|
+// License along with this program; if not, write to the
|
|
+// Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
+// Boston, MA 02111-1307, USA.
|
|
+
|
|
+
|
|
+namespace GtkSharp.Generation {
|
|
+
|
|
+ using System;
|
|
+ using System.Collections;
|
|
+ using System.IO;
|
|
+ using System.Text;
|
|
+ using System.Xml;
|
|
+
|
|
+ public class MiniObjectGen : ObjectBase {
|
|
+
|
|
+ private ArrayList custom_attrs = new ArrayList();
|
|
+ private ArrayList strings = new ArrayList();
|
|
+ private static Hashtable dirs = new Hashtable ();
|
|
+
|
|
+ public MiniObjectGen (XmlElement ns, XmlElement elem) : base (ns, elem, false)
|
|
+ {
|
|
+ foreach (XmlNode node in elem.ChildNodes) {
|
|
+ if (!(node is XmlElement)) continue;
|
|
+ XmlElement member = (XmlElement) node;
|
|
+ if (member.HasAttribute ("hidden") && member.GetAttribute ("hidden") == "1") continue;
|
|
+
|
|
+ switch (node.Name) {
|
|
+ case "custom-attribute":
|
|
+ custom_attrs.Add (member.InnerXml);
|
|
+ break;
|
|
+
|
|
+ case "static-string":
|
|
+ strings.Add (node);
|
|
+ break;
|
|
+
|
|
+ default:
|
|
+ if (!IsNodeNameHandled (node.Name))
|
|
+ Console.WriteLine ("Unexpected node " + node.Name + " in " + CName);
|
|
+ break;
|
|
+ }
|
|
+ }
|
|
+ }
|
|
+
|
|
+ public override string CallByName (string var, bool owned)
|
|
+ {
|
|
+ return String.Format ("{0} == null ? IntPtr.Zero : {0}.{1}", var, owned ? "OwnedHandle" : "Handle");
|
|
+ }
|
|
+
|
|
+ public override bool Validate ()
|
|
+ {
|
|
+ ArrayList invalids = new ArrayList ();
|
|
+
|
|
+ return base.Validate ();
|
|
+ }
|
|
+
|
|
+ private bool DisableVoidCtor {
|
|
+ get {
|
|
+ return Elem.HasAttribute ("disable_void_ctor");
|
|
+ }
|
|
+ }
|
|
+
|
|
+ private bool DisableGTypeCtor {
|
|
+ get {
|
|
+ return Elem.HasAttribute ("disable_gtype_ctor");
|
|
+ }
|
|
+ }
|
|
+
|
|
+ private class DirectoryInfo {
|
|
+ public string assembly_name;
|
|
+ public Hashtable objects;
|
|
+
|
|
+ public DirectoryInfo (string assembly_name) {
|
|
+ this.assembly_name = assembly_name;
|
|
+ objects = new Hashtable ();
|
|
+ }
|
|
+ }
|
|
+
|
|
+ private static DirectoryInfo GetDirectoryInfo (string dir, string assembly_name)
|
|
+ {
|
|
+ DirectoryInfo result;
|
|
+
|
|
+ if (dirs.ContainsKey (dir)) {
|
|
+ result = dirs [dir] as DirectoryInfo;
|
|
+ if (result.assembly_name != assembly_name) {
|
|
+ Console.WriteLine ("Can't put multiple assemblies in one directory.");
|
|
+ return null;
|
|
+ }
|
|
+
|
|
+ return result;
|
|
+ }
|
|
+
|
|
+ result = new DirectoryInfo (assembly_name);
|
|
+ dirs.Add (dir, result);
|
|
+
|
|
+ return result;
|
|
+ }
|
|
+
|
|
+ public override void Generate (GenerationInfo gen_info)
|
|
+ {
|
|
+ gen_info.CurrentType = Name;
|
|
+
|
|
+ string asm_name = gen_info.AssemblyName.Length == 0 ? NS.ToLower () + "-sharp" : gen_info.AssemblyName;
|
|
+ DirectoryInfo di = GetDirectoryInfo (gen_info.Dir, asm_name);
|
|
+
|
|
+ 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.Runtime.InteropServices;");
|
|
+ sw.WriteLine ();
|
|
+
|
|
+ SymbolTable table = SymbolTable.Table;
|
|
+
|
|
+ sw.WriteLine ("#region Autogenerated code");
|
|
+ if (IsDeprecated)
|
|
+ sw.WriteLine ("\t[Obsolete]");
|
|
+ foreach (string attr in custom_attrs)
|
|
+ sw.WriteLine ("\t" + attr);
|
|
+ sw.Write ("\t{0} {1}class " + Name, IsInternal ? "internal" : "public", IsAbstract ? "abstract " : "");
|
|
+ string cs_parent = table.GetCSType(Elem.GetAttribute("parent"));
|
|
+ if (cs_parent != "") {
|
|
+ di.objects.Add (CName, QualifiedName);
|
|
+ sw.Write (" : " + cs_parent);
|
|
+ }
|
|
+ foreach (string iface in managed_interfaces) {
|
|
+ if (Parent != null && Parent.Implements (iface))
|
|
+ continue;
|
|
+ sw.Write (", " + iface);
|
|
+ }
|
|
+ sw.WriteLine (" {");
|
|
+ sw.WriteLine ();
|
|
+
|
|
+ GenCtors (gen_info);
|
|
+ GenFields (gen_info);
|
|
+
|
|
+ GenClassMembers (gen_info, cs_parent);
|
|
+ GenMethods (gen_info, null, null);
|
|
+
|
|
+ foreach (XmlElement str in strings) {
|
|
+ sw.Write ("\t\tpublic static string " + str.GetAttribute ("name"));
|
|
+ sw.WriteLine (" {\n\t\t\t get { return \"" + str.GetAttribute ("value") + "\"; }\n\t\t}");
|
|
+ }
|
|
+
|
|
+ if (cs_parent != String.Empty && GetExpected (CName) != QualifiedName) {
|
|
+ sw.WriteLine ();
|
|
+ sw.WriteLine ("\t\tstatic " + Name + " ()");
|
|
+ sw.WriteLine ("\t\t{");
|
|
+ sw.WriteLine ("\t\t\tGtkSharp." + Studlify (asm_name) + ".ObjectManager.Initialize ();");
|
|
+ sw.WriteLine ("\t\t}");
|
|
+ }
|
|
+
|
|
+ sw.WriteLine ("#endregion");
|
|
+ AppendCustom (sw, gen_info.CustomDir);
|
|
+
|
|
+ sw.WriteLine ("\t}");
|
|
+ sw.WriteLine ("}");
|
|
+
|
|
+ sw.Close ();
|
|
+ gen_info.Writer = null;
|
|
+ Statistics.ObjectCount++;
|
|
+ }
|
|
+
|
|
+ protected override void GenCtors (GenerationInfo gen_info)
|
|
+ {
|
|
+ if (!Elem.HasAttribute("parent"))
|
|
+ return;
|
|
+
|
|
+ if (!DisableGTypeCtor) {
|
|
+ gen_info.Writer.WriteLine("\t\t[Obsolete]");
|
|
+ gen_info.Writer.WriteLine("\t\tprotected " + Name + "(Gst.GLib.GType gtype) : base(gtype) {}");
|
|
+ }
|
|
+ gen_info.Writer.WriteLine("\t\tpublic " + Name + "(IntPtr raw) : base(raw) {}");
|
|
+ if (ctors.Count == 0 && !DisableVoidCtor) {
|
|
+ gen_info.Writer.WriteLine();
|
|
+ gen_info.Writer.WriteLine("\t\tprotected " + Name + "() : base(IntPtr.Zero)");
|
|
+ gen_info.Writer.WriteLine("\t\t{");
|
|
+ gen_info.Writer.WriteLine("\t\t\tCreateNativeObject ();");
|
|
+ gen_info.Writer.WriteLine("\t\t}");
|
|
+ }
|
|
+ gen_info.Writer.WriteLine();
|
|
+
|
|
+ base.GenCtors (gen_info);
|
|
+ }
|
|
+
|
|
+ void GenClassMembers (GenerationInfo gen_info, string cs_parent)
|
|
+ {
|
|
+ GenVirtualMethods (gen_info, null);
|
|
+
|
|
+ if (class_struct_name == null || !CanGenerateClassStruct) return;
|
|
+ StreamWriter sw = gen_info.Writer;
|
|
+ GenerateClassStruct (gen_info);
|
|
+ if (cs_parent == "")
|
|
+ sw.WriteLine ("\t\tstatic uint class_offset = 0;");
|
|
+ else
|
|
+ sw.WriteLine ("\t\tstatic uint class_offset = ((Gst.GLib.GType) typeof ({0})).GetClassSize ();", cs_parent);
|
|
+ sw.WriteLine ("\t\tstatic Hashtable class_structs;");
|
|
+ sw.WriteLine ();
|
|
+ sw.WriteLine ("\t\tstatic {0} GetClassStruct (Gst.GLib.GType gtype, bool use_cache)", class_struct_name);
|
|
+ sw.WriteLine ("\t\t{");
|
|
+ sw.WriteLine ("\t\t\tif (class_structs == null)");
|
|
+ sw.WriteLine ("\t\t\t\tclass_structs = new Hashtable ();");
|
|
+ sw.WriteLine ();
|
|
+ sw.WriteLine ("\t\t\tif (use_cache && class_structs.Contains (gtype))");
|
|
+ sw.WriteLine ("\t\t\t\treturn ({0}) class_structs [gtype];", class_struct_name);
|
|
+ sw.WriteLine ("\t\t\telse {");
|
|
+ sw.WriteLine ("\t\t\t\tIntPtr class_ptr = new IntPtr (gtype.GetClassPtr ().ToInt64 () + class_offset);");
|
|
+ sw.WriteLine ("\t\t\t\t{0} class_struct = ({0}) Marshal.PtrToStructure (class_ptr, typeof ({0}));", class_struct_name);
|
|
+ sw.WriteLine ("\t\t\t\tif (use_cache)");
|
|
+ sw.WriteLine ("\t\t\t\t\tclass_structs.Add (gtype, class_struct);");
|
|
+ sw.WriteLine ("\t\t\t\treturn class_struct;");
|
|
+ sw.WriteLine ("\t\t\t}");
|
|
+ sw.WriteLine ("\t\t}");
|
|
+ sw.WriteLine ();
|
|
+ sw.WriteLine ("\t\tstatic void OverrideClassStruct (Gst.GLib.GType gtype, {0} class_struct)", class_struct_name);
|
|
+ sw.WriteLine ("\t\t{");
|
|
+ sw.WriteLine ("\t\t\tIntPtr class_ptr = new IntPtr (gtype.GetClassPtr ().ToInt64 () + class_offset);");
|
|
+ sw.WriteLine ("\t\t\tMarshal.StructureToPtr (class_struct, class_ptr, false);");
|
|
+ sw.WriteLine ("\t\t}");
|
|
+ sw.WriteLine ();
|
|
+ }
|
|
+
|
|
+ /* Keep this in sync with the one in glib/GType.cs */
|
|
+ private static string GetExpected (string cname)
|
|
+ {
|
|
+ for (int i = 1; i < cname.Length; i++) {
|
|
+ if (Char.IsUpper (cname[i])) {
|
|
+ if (i == 1 && cname[0] == 'G')
|
|
+ return "Gst.GLib." + cname.Substring (1);
|
|
+ else
|
|
+ return cname.Substring (0, i) + "." + cname.Substring (i);
|
|
+ }
|
|
+ }
|
|
+
|
|
+ throw new ArgumentException ("cname doesn't follow the NamespaceType capitalization style: " + cname);
|
|
+ }
|
|
+
|
|
+ private static bool NeedsMap (Hashtable objs, string assembly_name)
|
|
+ {
|
|
+ foreach (string key in objs.Keys)
|
|
+ if (GetExpected (key) != ((string) objs[key]))
|
|
+ return true;
|
|
+
|
|
+ return false;
|
|
+ }
|
|
+
|
|
+ private static string Studlify (string name)
|
|
+ {
|
|
+ string result = "";
|
|
+
|
|
+ string[] subs = name.Split ('-');
|
|
+ foreach (string sub in subs)
|
|
+ result += Char.ToUpper (sub[0]) + sub.Substring (1);
|
|
+
|
|
+ return result;
|
|
+ }
|
|
+
|
|
+ public static void GenerateMappers ()
|
|
+ {
|
|
+ foreach (string dir in dirs.Keys) {
|
|
+
|
|
+ DirectoryInfo di = dirs[dir] as DirectoryInfo;
|
|
+
|
|
+ if (!NeedsMap (di.objects, di.assembly_name))
|
|
+ continue;
|
|
+
|
|
+ GenerationInfo gen_info = new GenerationInfo (dir, di.assembly_name);
|
|
+
|
|
+ GenerateMapper (di, gen_info);
|
|
+ }
|
|
+ }
|
|
+
|
|
+ private static void GenerateMapper (DirectoryInfo dir_info, GenerationInfo gen_info)
|
|
+ {
|
|
+ StreamWriter sw = gen_info.OpenStream ("ObjectManager");
|
|
+
|
|
+ sw.WriteLine ("namespace GtkSharp." + Studlify (dir_info.assembly_name) + " {");
|
|
+ sw.WriteLine ();
|
|
+ sw.WriteLine ("\tpublic class ObjectManager {");
|
|
+ sw.WriteLine ();
|
|
+ sw.WriteLine ("\t\tstatic bool initialized = false;");
|
|
+ sw.WriteLine ("\t\t// Call this method from the appropriate module init function.");
|
|
+ sw.WriteLine ("\t\tpublic static void Initialize ()");
|
|
+ sw.WriteLine ("\t\t{");
|
|
+ sw.WriteLine ("\t\t\tif (initialized)");
|
|
+ sw.WriteLine ("\t\t\t\treturn;");
|
|
+ sw.WriteLine ("");
|
|
+ sw.WriteLine ("\t\t\tinitialized = true;");
|
|
+
|
|
+ foreach (string key in dir_info.objects.Keys) {
|
|
+ if (GetExpected(key) != ((string) dir_info.objects[key]))
|
|
+ sw.WriteLine ("\t\t\tGst.GLib.GType.Register ({0}.GType, typeof ({0}));", dir_info.objects [key]);
|
|
+ }
|
|
+
|
|
+ sw.WriteLine ("\t\t}");
|
|
+ sw.WriteLine ("\t}");
|
|
+ sw.WriteLine ("}");
|
|
+ sw.Close ();
|
|
+ }
|
|
+
|
|
+ public override string FromNative (string var, bool owned)
|
|
+ {
|
|
+ return "Gst.MiniObject.GetObject(" + var + (owned ? ", true" : "") + ") as " + QualifiedName;
|
|
+ }
|
|
+ }
|
|
+}
|
|
+
|
|
diff -Naur generator-upstream/MiniObjectGen.cs.rej generator/MiniObjectGen.cs.rej
|
|
diff -Naur generator-upstream/ObjectBase.cs generator/ObjectBase.cs
|
|
--- generator-upstream/ObjectBase.cs 2009-08-05 08:24:27.000000000 +0200
|
|
+++ generator/ObjectBase.cs 2009-11-25 08:07:54.000000000 +0100
|
|
@@ -164,7 +164,7 @@
|
|
|
|
public override string FromNative (string var, bool owned)
|
|
{
|
|
- return "GLib.Object.GetObject(" + var + (owned ? ", true" : "") + ") as " + QualifiedName;
|
|
+ return "Gst.GLib.Object.GetObject(" + var + (owned ? ", true" : "") + ") as " + QualifiedName;
|
|
}
|
|
|
|
public string ClassStructName {
|
|
diff -Naur generator-upstream/ObjectGen.cs generator/ObjectGen.cs
|
|
--- generator-upstream/ObjectGen.cs 2009-08-19 18:13:17.000000000 +0200
|
|
+++ generator/ObjectGen.cs 2009-11-25 08:07:54.000000000 +0100
|
|
@@ -253,7 +253,7 @@
|
|
gen_info.Writer.WriteLine();
|
|
gen_info.Writer.WriteLine("\t\tprotected " + Name + "() : base(IntPtr.Zero)");
|
|
gen_info.Writer.WriteLine("\t\t{");
|
|
- gen_info.Writer.WriteLine("\t\t\tCreateNativeObject (new string [0], new GLib.Value [0]);");
|
|
+ gen_info.Writer.WriteLine("\t\t\tCreateNativeObject (new string [0], new Gst.GLib.Value [0]);");
|
|
gen_info.Writer.WriteLine("\t\t}");
|
|
}
|
|
gen_info.Writer.WriteLine();
|
|
@@ -302,10 +302,10 @@
|
|
if (cs_parent == "")
|
|
sw.WriteLine ("\t\tstatic uint class_offset = 0;");
|
|
else
|
|
- sw.WriteLine ("\t\tstatic uint class_offset = ((GLib.GType) typeof ({0})).GetClassSize ();", cs_parent);
|
|
+ sw.WriteLine ("\t\tstatic uint class_offset = ((Gst.GLib.GType) typeof ({0})).GetClassSize ();", cs_parent);
|
|
sw.WriteLine ("\t\tstatic Hashtable class_structs;");
|
|
sw.WriteLine ();
|
|
- sw.WriteLine ("\t\tstatic {0} GetClassStruct (GLib.GType gtype, bool use_cache)", class_struct_name);
|
|
+ sw.WriteLine ("\t\tstatic {0} GetClassStruct (Gst.GLib.GType gtype, bool use_cache)", class_struct_name);
|
|
sw.WriteLine ("\t\t{");
|
|
sw.WriteLine ("\t\t\tif (class_structs == null)");
|
|
sw.WriteLine ("\t\t\t\tclass_structs = new Hashtable ();");
|
|
@@ -321,7 +321,7 @@
|
|
sw.WriteLine ("\t\t\t}");
|
|
sw.WriteLine ("\t\t}");
|
|
sw.WriteLine ();
|
|
- sw.WriteLine ("\t\tstatic void OverrideClassStruct (GLib.GType gtype, {0} class_struct)", class_struct_name);
|
|
+ sw.WriteLine ("\t\tstatic void OverrideClassStruct (Gst.GLib.GType gtype, {0} class_struct)", class_struct_name);
|
|
sw.WriteLine ("\t\t{");
|
|
sw.WriteLine ("\t\t\tIntPtr class_ptr = new IntPtr (gtype.GetClassPtr ().ToInt64 () + class_offset);");
|
|
sw.WriteLine ("\t\t\tMarshal.StructureToPtr (class_struct, class_ptr, false);");
|
|
@@ -335,7 +335,7 @@
|
|
for (int i = 1; i < cname.Length; i++) {
|
|
if (Char.IsUpper (cname[i])) {
|
|
if (i == 1 && cname[0] == 'G')
|
|
- return "GLib." + cname.Substring (1);
|
|
+ return "Gst.GLib." + cname.Substring (1);
|
|
else
|
|
return cname.Substring (0, i) + "." + cname.Substring (i);
|
|
}
|
|
@@ -398,7 +398,7 @@
|
|
|
|
foreach (string key in dir_info.objects.Keys) {
|
|
if (GetExpected(key) != ((string) dir_info.objects[key]))
|
|
- sw.WriteLine ("\t\t\tGLib.GType.Register ({0}.GType, typeof ({0}));", dir_info.objects [key]);
|
|
+ sw.WriteLine ("\t\t\tGst.GLib.GType.Register ({0}.GType, typeof ({0}));", dir_info.objects [key]);
|
|
}
|
|
|
|
sw.WriteLine ("\t\t}");
|
|
diff -Naur generator-upstream/OpaqueGen.cs generator/OpaqueGen.cs
|
|
--- generator-upstream/OpaqueGen.cs 2009-08-19 18:13:17.000000000 +0200
|
|
+++ generator/OpaqueGen.cs 2009-11-25 08:07:54.000000000 +0100
|
|
@@ -32,7 +32,7 @@
|
|
|
|
public override string FromNative(string var, bool owned)
|
|
{
|
|
- return var + " == IntPtr.Zero ? null : (" + QualifiedName + ") GLib.Opaque.GetOpaque (" + var + ", typeof (" + QualifiedName + "), " + (owned ? "true" : "false") + ")";
|
|
+ return var + " == IntPtr.Zero ? null : (" + QualifiedName + ") Gst.GLib.Opaque.GetOpaque (" + var + ", typeof (" + QualifiedName + "), " + (owned ? "true" : "false") + ")";
|
|
}
|
|
|
|
private bool DisableRawCtor {
|
|
@@ -68,7 +68,7 @@
|
|
if (cs_parent != "")
|
|
sw.Write (" : " + cs_parent);
|
|
else
|
|
- sw.Write (" : GLib.Opaque");
|
|
+ sw.Write (" : Gst.GLib.Opaque");
|
|
|
|
foreach (string iface in managed_interfaces) {
|
|
if (Parent != null && Parent.Implements (iface))
|
|
@@ -165,7 +165,7 @@
|
|
sw.WriteLine ("\t\t\tif (!Owned)");
|
|
sw.WriteLine ("\t\t\t\treturn;");
|
|
sw.WriteLine ("\t\t\tFinalizerInfo info = new FinalizerInfo (Handle);");
|
|
- sw.WriteLine ("\t\t\tGLib.Timeout.Add (50, new GLib.TimeoutHandler (info.Handler));");
|
|
+ sw.WriteLine ("\t\t\tGst.GLib.Timeout.Add (50, new Gst.GLib.TimeoutHandler (info.Handler));");
|
|
sw.WriteLine ("\t\t}");
|
|
sw.WriteLine ();
|
|
}
|
|
@@ -173,9 +173,9 @@
|
|
#if false
|
|
Method copy = Methods ["Copy"] as Method;
|
|
if (copy != null && copy.Parameters.Count == 0) {
|
|
- sw.WriteLine ("\t\tprotected override GLib.Opaque Copy (IntPtr raw)");
|
|
+ sw.WriteLine ("\t\tprotected override Gst.GLib.Opaque Copy (IntPtr raw)");
|
|
sw.WriteLine ("\t\t{");
|
|
- sw.WriteLine ("\t\t\tGLib.Opaque result = new " + QualifiedName + " (" + copy.CName + " (raw));");
|
|
+ sw.WriteLine ("\t\t\tGst.GLib.Opaque result = new " + QualifiedName + " (" + copy.CName + " (raw));");
|
|
sw.WriteLine ("\t\t\tresult.Owned = true;");
|
|
sw.WriteLine ("\t\t\treturn result;");
|
|
sw.WriteLine ("\t\t}");
|
|
diff -Naur generator-upstream/Parameters.cs generator/Parameters.cs
|
|
--- generator-upstream/Parameters.cs 2009-07-13 00:01:52.000000000 +0200
|
|
+++ generator/Parameters.cs 2009-11-25 08:07:54.000000000 +0100
|
|
@@ -263,9 +263,9 @@
|
|
} else if (gen is IManualMarshaler)
|
|
call_parm = "native_" + CallName;
|
|
else if (gen is ObjectBase)
|
|
- call_parm = (gen as ObjectBase).CallByName (CallName, Owned);
|
|
+ call_parm = (gen as ObjectBase).CallByName(CallName, Owned);
|
|
else
|
|
- call_parm = gen.CallByName (CallName);
|
|
+ call_parm = gen.CallByName(CallName);
|
|
|
|
return call_parm;
|
|
}
|
|
diff -Naur generator-upstream/Parser.cs generator/Parser.cs
|
|
--- generator-upstream/Parser.cs 2009-04-13 19:44:48.000000000 +0200
|
|
+++ generator/Parser.cs 2009-11-25 08:07:54.000000000 +0100
|
|
@@ -138,6 +138,9 @@
|
|
case "object":
|
|
result.Add (new ObjectGen (ns, elem));
|
|
break;
|
|
+ case "mini-object":
|
|
+ result.Add (new MiniObjectGen (ns, elem));
|
|
+ break;
|
|
case "class":
|
|
result.Add (new ClassGen (ns, elem));
|
|
break;
|
|
diff -Naur generator-upstream/Property.cs generator/Property.cs
|
|
--- generator-upstream/Property.cs 2008-09-17 01:21:50.000000000 +0200
|
|
+++ generator/Property.cs 2009-11-25 08:07:54.000000000 +0100
|
|
@@ -64,7 +64,7 @@
|
|
}
|
|
|
|
protected virtual string PropertyAttribute (string qpname) {
|
|
- return "[GLib.Property (" + qpname + ")]";
|
|
+ return "[Gst.GLib.Property (" + qpname + ")]";
|
|
}
|
|
|
|
protected virtual string RawGetter (string qpname) {
|
|
@@ -117,9 +117,9 @@
|
|
|
|
string v_type = "";
|
|
if (table.IsInterface (CType)) {
|
|
- v_type = "(GLib.Object)";
|
|
+ v_type = "(Gst.GLib.Object)";
|
|
} else if (table.IsOpaque (CType)) {
|
|
- v_type = "(GLib.Opaque)";
|
|
+ v_type = "(Gst.GLib.Opaque)";
|
|
} else if (table.IsEnum (CType)) {
|
|
v_type = "(Enum)";
|
|
}
|
|
@@ -140,12 +140,12 @@
|
|
sw.WriteLine();
|
|
} else if (Readable) {
|
|
sw.WriteLine(indent + "get {");
|
|
- sw.WriteLine(indent + "\tGLib.Value val = " + RawGetter (qpname) + ";");
|
|
+ sw.WriteLine(indent + "\tGst.GLib.Value val = " + RawGetter (qpname) + ";");
|
|
if (table.IsOpaque (CType) || table.IsBoxed (CType)) {
|
|
sw.WriteLine(indent + "\t" + CSType + " ret = (" + CSType + ") val;");
|
|
} else if (table.IsInterface (CType)) {
|
|
- // Do we have to dispose the GLib.Object from the GLib.Value?
|
|
- sw.WriteLine (indent + "\t{0} ret = {0}Adapter.GetObject ((GLib.Object) val);", CSType);
|
|
+ // Do we have to dispose the Gst.GLib.Object from the Gst.GLib.Value?
|
|
+ sw.WriteLine (indent + "\t{0} ret = {0}Adapter.GetObject ((Gst.GLib.Object) val);", CSType);
|
|
} else {
|
|
sw.Write(indent + "\t" + CSType + " ret = ");
|
|
sw.Write ("(" + CSType + ") ");
|
|
@@ -166,13 +166,13 @@
|
|
sw.WriteLine();
|
|
} else if (Writable) {
|
|
sw.WriteLine(indent + "set {");
|
|
- sw.Write(indent + "\tGLib.Value val = ");
|
|
+ sw.Write(indent + "\tGst.GLib.Value val = ");
|
|
if (table.IsBoxed (CType)) {
|
|
- sw.WriteLine("(GLib.Value) value;");
|
|
+ sw.WriteLine("(Gst.GLib.Value) value;");
|
|
} else if (table.IsOpaque (CType)) {
|
|
- sw.WriteLine("new GLib.Value(value, \"{0}\");", CType);
|
|
+ sw.WriteLine("new Gst.GLib.Value(value, \"{0}\");", CType);
|
|
} else {
|
|
- sw.Write("new GLib.Value(");
|
|
+ sw.Write("new Gst.GLib.Value(");
|
|
if (v_type != "" && !(table.IsObject (CType) || table.IsInterface (CType) || table.IsOpaque (CType))) {
|
|
sw.Write(v_type + " ");
|
|
}
|
|
diff -Naur generator-upstream/ReturnValue.cs generator/ReturnValue.cs
|
|
--- generator-upstream/ReturnValue.cs 2009-09-23 23:27:15.000000000 +0200
|
|
+++ generator/ReturnValue.cs 2009-11-25 08:07:54.000000000 +0100
|
|
@@ -114,7 +114,9 @@
|
|
get {
|
|
if (IGen == null)
|
|
return String.Empty;
|
|
- return IGen.MarshalType + (is_array || is_null_term ? "[]" : String.Empty);
|
|
+ else if (is_null_term)
|
|
+ return "IntPtr";
|
|
+ return IGen.MarshalType + (is_array ? "[]" : String.Empty);
|
|
}
|
|
}
|
|
|
|
@@ -125,14 +127,14 @@
|
|
|
|
if (ElementType != String.Empty) {
|
|
string args = (owned ? "true" : "false") + ", " + (elements_owned ? "true" : "false");
|
|
- if (IGen.QualifiedName == "GLib.PtrArray")
|
|
- return String.Format ("({0}[]) GLib.Marshaller.PtrArrayToArray ({1}, {2}, typeof({0}))", ElementType, var, args);
|
|
+ if (IGen.QualifiedName == "Gst.GLib.PtrArray")
|
|
+ return String.Format ("({0}[]) Gst.GLib.Marshaller.PtrArrayToArray ({1}, {2}, typeof({0}))", ElementType, var, args);
|
|
else
|
|
- return String.Format ("({0}[]) GLib.Marshaller.ListPtrToArray ({1}, typeof({2}), {3}, typeof({4}))", ElementType, var, IGen.QualifiedName, args, element_ctype == "gfilename*" ? "GLib.ListBase.FilenameString" : ElementType);
|
|
+ return String.Format ("({0}[]) Gst.GLib.Marshaller.ListPtrToArray ({1}, typeof({2}), {3}, typeof({4}))", ElementType, var, IGen.QualifiedName, args, element_ctype == "gfilename*" ? "Gst.GLib.ListBase.FilenameString" : ElementType);
|
|
} else if (IGen is HandleBase)
|
|
return ((HandleBase)IGen).FromNative (var, owned);
|
|
else if (is_null_term)
|
|
- return String.Format ("GLib.Marshaller.NullTermPtrToStringArray ({0}, {1})", var, owned ? "true" : "false");
|
|
+ return String.Format ("Gst.Marshaller.NullTermPtrToStringArray ({0}, {1})", var, owned ? "true" : "false");
|
|
else
|
|
return IGen.FromNative (var);
|
|
}
|
|
@@ -146,11 +148,11 @@
|
|
string args = ", typeof (" + ElementType + "), " + (owned ? "true" : "false") + ", " + (elements_owned ? "true" : "false");
|
|
var = "new " + IGen.QualifiedName + "(" + var + args + ")";
|
|
} else if (is_null_term)
|
|
- return String.Format ("GLib.Marshaller.StringArrayToNullTermPointer ({0})", var);
|
|
+ return String.Format ("Gst.Marshaller.StringArrayToNullTermPointer ({0})", var);
|
|
|
|
if (IGen is IManualMarshaler)
|
|
return (IGen as IManualMarshaler).AllocNative (var);
|
|
- else if (IGen is ObjectGen && owned)
|
|
+ else if ((IGen is ObjectGen || IGen is MiniObjectGen) && owned)
|
|
return var + " == null ? IntPtr.Zero : " + var + ".OwnedHandle";
|
|
else if (IGen is OpaqueGen && owned)
|
|
return var + " == null ? IntPtr.Zero : " + var + ".OwnedCopy";
|
|
diff -Naur generator-upstream/Signal.cs generator/Signal.cs
|
|
--- generator-upstream/Signal.cs 2009-11-23 18:19:46.000000000 +0100
|
|
+++ generator/Signal.cs 2009-11-25 08:08:27.000000000 +0100
|
|
@@ -204,7 +204,7 @@
|
|
}
|
|
sw.WriteLine("\t\t\t} catch (Exception) {");
|
|
sw.WriteLine ("\t\t\t\tException ex = new Exception (\"args.RetVal or 'out' property unset or set to incorrect type in " + EventHandlerQualifiedName + " callback\");");
|
|
- sw.WriteLine("\t\t\t\tGLib.ExceptionManager.RaiseUnhandledException (ex, true);");
|
|
+ sw.WriteLine("\t\t\t\tGst.GLib.ExceptionManager.RaiseUnhandledException (ex, true);");
|
|
|
|
sw.WriteLine ("\t\t\t\t// NOTREACHED: above call doesn't return.");
|
|
sw.WriteLine ("\t\t\t\tthrow ex;");
|
|
@@ -228,15 +228,15 @@
|
|
sw.WriteLine("\t\t{");
|
|
sw.WriteLine("\t\t\t{0} args = new {0} ();", EventArgsQualifiedName);
|
|
sw.WriteLine("\t\t\ttry {");
|
|
- sw.WriteLine("\t\t\t\tGLib.Signal sig = ((GCHandle) gch).Target as GLib.Signal;");
|
|
+ sw.WriteLine("\t\t\t\tGst.GLib.Signal sig = ((GCHandle) gch).Target as Gst.GLib.Signal;");
|
|
sw.WriteLine("\t\t\t\tif (sig == null)");
|
|
sw.WriteLine("\t\t\t\t\tthrow new Exception(\"Unknown signal GC handle received \" + gch);");
|
|
sw.WriteLine();
|
|
string finish = GenArgsInitialization (sw);
|
|
sw.WriteLine("\t\t\t\t{0} handler = ({0}) sig.Handler;", EventHandlerQualifiedName);
|
|
- sw.WriteLine("\t\t\t\thandler (GLib.Object.GetObject (inst), args);");
|
|
+ sw.WriteLine("\t\t\t\thandler (Gst.GLib.Object.GetObject (inst), args);");
|
|
sw.WriteLine("\t\t\t} catch (Exception e) {");
|
|
- sw.WriteLine("\t\t\t\tGLib.ExceptionManager.RaiseUnhandledException (e, false);");
|
|
+ sw.WriteLine("\t\t\t\tGst.GLib.ExceptionManager.RaiseUnhandledException (e, false);");
|
|
sw.WriteLine("\t\t\t}");
|
|
GenArgsCleanup (sw, finish);
|
|
sw.WriteLine("\t\t}");
|
|
@@ -266,13 +266,13 @@
|
|
sw.WriteLine ();
|
|
sw.WriteLine ("\tpublic delegate void " + EventHandlerName + "(object o, " + EventArgsName + " args);");
|
|
sw.WriteLine ();
|
|
- sw.WriteLine ("\tpublic class " + EventArgsName + " : GLib.SignalArgs {");
|
|
+ sw.WriteLine ("\tpublic class " + EventArgsName + " : Gst.GLib.SignalArgs {");
|
|
for (int i = 0; i < parms.Count; i++) {
|
|
sw.WriteLine ("\t\tpublic " + parms[i].CSType + " " + parms[i].StudlyName + "{");
|
|
if (parms[i].PassAs != "out") {
|
|
sw.WriteLine ("\t\t\tget {");
|
|
if (SymbolTable.Table.IsInterface (parms [i].CType))
|
|
- sw.WriteLine ("\t\t\t\treturn {0}Adapter.GetObject (Args [{1}] as GLib.Object);", parms [i].CSType, i);
|
|
+ sw.WriteLine ("\t\t\t\treturn {0}Adapter.GetObject (Args [{1}] as Gst.GLib.Object);", parms [i].CSType, i);
|
|
else
|
|
sw.WriteLine ("\t\t\t\treturn ({0}) Args [{1}];", parms [i].CSType, i);
|
|
sw.WriteLine ("\t\t\t}");
|
|
@@ -302,17 +302,17 @@
|
|
args_type = ", new " + DelegateName + "(" + CallbackName + ")";
|
|
}
|
|
|
|
- sw.WriteLine("\t\t[GLib.Signal("+ CName + ")]");
|
|
+ sw.WriteLine("\t\t[Gst.GLib.Signal("+ CName + ")]");
|
|
sw.Write("\t\tpublic ");
|
|
if (NeedNew (implementor))
|
|
sw.Write("new ");
|
|
sw.WriteLine("event " + EventHandlerQualifiedName + " " + Name + " {");
|
|
sw.WriteLine("\t\t\tadd {");
|
|
- sw.WriteLine("\t\t\t\tGLib.Signal sig = GLib.Signal.Lookup (" + target + ", " + CName + args_type + ");");
|
|
+ sw.WriteLine("\t\t\t\tGst.GLib.Signal sig = Gst.GLib.Signal.Lookup (" + target + ", " + CName + args_type + ");");
|
|
sw.WriteLine("\t\t\t\tsig.AddDelegate (value);");
|
|
sw.WriteLine("\t\t\t}");
|
|
sw.WriteLine("\t\t\tremove {");
|
|
- sw.WriteLine("\t\t\t\tGLib.Signal sig = GLib.Signal.Lookup (" + target + ", " + CName + args_type + ");");
|
|
+ sw.WriteLine("\t\t\t\tGst.GLib.Signal sig = Gst.GLib.Signal.Lookup (" + target + ", " + CName + args_type + ");");
|
|
sw.WriteLine("\t\t\t\tsig.RemoveDelegate (value);");
|
|
sw.WriteLine("\t\t\t}");
|
|
sw.WriteLine("\t\t}");
|
|
diff -Naur generator-upstream/Signal.cs.orig generator/Signal.cs.orig
|
|
diff -Naur generator-upstream/StructBase.cs generator/StructBase.cs
|
|
--- generator-upstream/StructBase.cs 2009-08-19 18:13:17.000000000 +0200
|
|
+++ generator/StructBase.cs 2009-11-25 08:07:54.000000000 +0100
|
|
@@ -92,7 +92,7 @@
|
|
|
|
public string AllocNative (string var)
|
|
{
|
|
- return "GLib.Marshaller.StructureToPtrAlloc (" + var + ")";
|
|
+ return "Gst.GLib.Marshaller.StructureToPtrAlloc (" + var + ")";
|
|
}
|
|
|
|
public string ReleaseNative (string var)
|
|
diff -Naur generator-upstream/StructGen.cs generator/StructGen.cs
|
|
--- generator-upstream/StructGen.cs 2005-08-05 22:34:45.000000000 +0200
|
|
+++ generator/StructGen.cs 2009-11-25 08:07:54.000000000 +0100
|
|
@@ -36,8 +36,8 @@
|
|
StreamWriter sw = gen_info.Writer = gen_info.OpenStream (Name);
|
|
base.Generate (gen_info);
|
|
if (GetMethod ("GetType") == null && GetMethod ("GetGType") == null) {
|
|
- sw.WriteLine ("\t\tprivate static GLib.GType GType {");
|
|
- sw.WriteLine ("\t\t\tget { return GLib.GType.Pointer; }");
|
|
+ sw.WriteLine ("\t\tprivate static Gst.GLib.GType GType {");
|
|
+ sw.WriteLine ("\t\t\tget { return Gst.GLib.GType.Pointer; }");
|
|
sw.WriteLine ("\t\t}");
|
|
}
|
|
sw.WriteLine ("#endregion");
|
|
diff -Naur generator-upstream/SymbolTable.cs generator/SymbolTable.cs
|
|
--- generator-upstream/SymbolTable.cs 2009-08-13 16:46:33.000000000 +0200
|
|
+++ generator/SymbolTable.cs 2009-11-25 08:07:54.000000000 +0100
|
|
@@ -108,23 +108,24 @@
|
|
AddType (new ConstStringGen ("const-xmlChar"));
|
|
AddType (new ConstStringGen ("const-char"));
|
|
AddType (new ConstFilenameGen ("const-gfilename"));
|
|
- AddType (new MarshalGen ("gfilename", "string", "IntPtr", "GLib.Marshaller.StringToFilenamePtr({0})", "GLib.Marshaller.FilenamePtrToStringGFree({0})"));
|
|
- AddType (new MarshalGen ("gchar", "string", "IntPtr", "GLib.Marshaller.StringToPtrGStrdup({0})", "GLib.Marshaller.PtrToStringGFree({0})"));
|
|
- AddType (new MarshalGen ("char", "string", "IntPtr", "GLib.Marshaller.StringToPtrGStrdup({0})", "GLib.Marshaller.PtrToStringGFree({0})"));
|
|
+ AddType (new MarshalGen ("gfilename", "string", "IntPtr", "Gst.GLib.Marshaller.StringToFilenamePtr({0})", "Gst.GLib.Marshaller.FilenamePtrToStringGFree({0})"));
|
|
+ AddType (new MarshalGen ("gchar", "string", "IntPtr", "Gst.GLib.Marshaller.StringToPtrGStrdup({0})", "Gst.GLib.Marshaller.PtrToStringGFree({0})"));
|
|
+ AddType (new MarshalGen ("char", "string", "IntPtr", "Gst.GLib.Marshaller.StringToPtrGStrdup({0})", "Gst.GLib.Marshaller.PtrToStringGFree({0})"));
|
|
AddType (new SimpleGen ("GStrv", "string[]", "null"));
|
|
|
|
// manually wrapped types requiring more complex marshaling
|
|
- AddType (new ManualGen ("GInitiallyUnowned", "GLib.InitiallyUnowned", "GLib.Object.GetObject ({0})"));
|
|
- AddType (new ManualGen ("GObject", "GLib.Object", "GLib.Object.GetObject ({0})"));
|
|
- AddType (new ManualGen ("GList", "GLib.List"));
|
|
- AddType (new ManualGen ("GPtrArray", "GLib.PtrArray"));
|
|
- AddType (new ManualGen ("GSList", "GLib.SList"));
|
|
- AddType (new MarshalGen ("gunichar", "char", "uint", "GLib.Marshaller.CharToGUnichar ({0})", "GLib.Marshaller.GUnicharToChar ({0})"));
|
|
- AddType (new MarshalGen ("time_t", "System.DateTime", "IntPtr", "GLib.Marshaller.DateTimeTotime_t ({0})", "GLib.Marshaller.time_tToDateTime ({0})"));
|
|
- AddType (new MarshalGen ("GString", "string", "IntPtr", "new GLib.GString ({0}).Handle", "GLib.GString.PtrToString ({0})"));
|
|
- AddType (new MarshalGen ("GType", "GLib.GType", "IntPtr", "{0}.Val", "new GLib.GType({0})", "GLib.GType.None"));
|
|
- AddType (new ByRefGen ("GValue", "GLib.Value"));
|
|
- AddType (new SimpleGen ("GDestroyNotify", "GLib.DestroyNotify", "null"));
|
|
+ AddType (new ManualGen ("GInitiallyUnowned", "Gst.GLib.InitiallyUnowned", "Gst.GLib.Object.GetObject ({0})"));
|
|
+ AddType (new ManualGen ("GObject", "Gst.GLib.Object", "Gst.GLib.Object.GetObject ({0})"));
|
|
+ AddType (new ManualGen ("GstMiniObject", "Gst.MiniObject", "Gst.MiniObject.GetObject ({0})"));
|
|
+ AddType (new ManualGen ("GList", "Gst.GLib.List"));
|
|
+ AddType (new ManualGen ("GPtrArray", "Gst.GLib.PtrArray"));
|
|
+ AddType (new ManualGen ("GSList", "Gst.GLib.SList"));
|
|
+ AddType (new MarshalGen ("gunichar", "char", "uint", "Gst.GLib.Marshaller.CharToGUnichar ({0})", "Gst.GLib.Marshaller.GUnicharToChar ({0})"));
|
|
+ AddType (new MarshalGen ("time_t", "System.DateTime", "IntPtr", "Gst.GLib.Marshaller.DateTimeTotime_t ({0})", "Gst.GLib.Marshaller.time_tToDateTime ({0})"));
|
|
+ AddType (new MarshalGen ("GString", "string", "IntPtr", "new Gst.GLib.GString ({0}).Handle", "Gst.GLib.GString.PtrToString ({0})"));
|
|
+ AddType (new MarshalGen ("GType", "Gst.GLib.GType", "IntPtr", "{0}.Val", "new Gst.GLib.GType({0})", "Gst.GLib.GType.None"));
|
|
+ AddType (new ByRefGen ("GValue", "Gst.GLib.Value"));
|
|
+ AddType (new SimpleGen ("GDestroyNotify", "Gst.GLib.DestroyNotify", "null"));
|
|
|
|
// FIXME: These ought to be handled properly.
|
|
AddType (new SimpleGen ("GC", "IntPtr", "IntPtr.Zero"));
|
|
@@ -136,7 +137,7 @@
|
|
AddType (new SimpleGen ("GByteArray", "IntPtr", "IntPtr.Zero"));
|
|
AddType (new SimpleGen ("GData", "IntPtr", "IntPtr.Zero"));
|
|
AddType (new SimpleGen ("GIOChannel", "IntPtr", "IntPtr.Zero"));
|
|
- AddType (new SimpleGen ("GTypeModule", "GLib.Object", "null"));
|
|
+ AddType (new SimpleGen ("GTypeModule", "Gst.GLib.Object", "null"));
|
|
AddType (new SimpleGen ("GHashTable", "System.IntPtr", "IntPtr.Zero"));
|
|
AddType (new SimpleGen ("va_list", "IntPtr", "IntPtr.Zero"));
|
|
AddType (new SimpleGen ("GParamSpec", "IntPtr", "IntPtr.Zero"));
|
|
@@ -306,7 +307,8 @@
|
|
|
|
public bool IsObject(string c_type)
|
|
{
|
|
- if (this[c_type] is ObjectGen)
|
|
+ if ((this[c_type] is ObjectGen) ||
|
|
+ (this[c_type] is MiniObjectGen))
|
|
return true;
|
|
|
|
return false;
|
|
diff -Naur generator-upstream/VirtualMethod.cs generator/VirtualMethod.cs
|
|
--- generator-upstream/VirtualMethod.cs 2009-09-03 21:50:53.000000000 +0200
|
|
+++ generator/VirtualMethod.cs 2009-11-25 08:07:54.000000000 +0100
|
|
@@ -92,7 +92,7 @@
|
|
else
|
|
type = this.container_type.Name;
|
|
|
|
- sw.WriteLine ("\t\t\t\t{0} __obj = GLib.Object.GetObject (inst, false) as {0};", type);
|
|
+ sw.WriteLine ("\t\t\t\t{0} __obj = Gst.GLib.Object.GetObject (inst, false) as {0};", type);
|
|
}
|
|
|
|
sw.Write (call.Setup ("\t\t\t\t"));
|
|
@@ -108,7 +108,7 @@
|
|
|
|
bool fatal = parms.HasOutParam || !retval.IsVoid;
|
|
sw.WriteLine ("\t\t\t} catch (Exception e) {");
|
|
- sw.WriteLine ("\t\t\t\tGLib.ExceptionManager.RaiseUnhandledException (e, " + (fatal ? "true" : "false") + ");");
|
|
+ sw.WriteLine ("\t\t\t\tGst.GLib.ExceptionManager.RaiseUnhandledException (e, " + (fatal ? "true" : "false") + ");");
|
|
if (fatal) {
|
|
sw.WriteLine ("\t\t\t\t// NOTREACHED: above call does not return.");
|
|
sw.WriteLine ("\t\t\t\tthrow e;");
|