2009-08-13 Christian Hoff <christian_hoff@gmx.net>

* generator/IGeneratable.cs: Remove MarshalReturnType, ToNativeReturnType,
	FromNativeReturn and ToNativeReturn as they never returned something else
	than MarshalType, FromNative/AllocNative and CallByName, respectively.
	* generator/Signal.cs: Use AllocNative for IManualMarshalers.

svn path=/trunk/gtk-sharp/; revision=139849
This commit is contained in:
Christian Hoff 2009-08-13 14:46:33 +00:00
parent b244c750d3
commit 08b43fbd76
12 changed files with 33 additions and 124 deletions

View file

@ -1,3 +1,10 @@
2009-08-13 Christian Hoff <christian_hoff@gmx.net>
* generator/IGeneratable.cs: Remove MarshalReturnType, ToNativeReturnType,
FromNativeReturn and ToNativeReturn as they never returned something else
than MarshalType, FromNative/AllocNative and CallByName, respectively.
* generator/Signal.cs: Use AllocNative for IManualMarshalers.
2009-08-12 Christian Hoff <christian_hoff@gmx.net> 2009-08-12 Christian Hoff <christian_hoff@gmx.net>
* configure.in.in: Detect GDK backend. * configure.in.in: Detect GDK backend.

View file

@ -40,11 +40,6 @@ namespace GtkSharp.Generation {
return "GLib.Marshaller.Utf8PtrToString (" + var + ")"; return "GLib.Marshaller.Utf8PtrToString (" + var + ")";
} }
public override string ToNativeReturn (string var)
{
return "GLib.Marshaller.StringToPtrGStrdup (" + var + ")";
}
public string AllocNative (string managed_var) public string AllocNative (string managed_var)
{ {
return "GLib.Marshaller.StringToPtrGStrdup (" + managed_var + ")"; return "GLib.Marshaller.StringToPtrGStrdup (" + managed_var + ")";

View file

@ -115,7 +115,7 @@ namespace GtkSharp.Generation {
if (getterName != null) { if (getterName != null) {
sw.WriteLine (indent + "[DllImport (\"{0}\")]", gen_info.GluelibName); sw.WriteLine (indent + "[DllImport (\"{0}\")]", gen_info.GluelibName);
sw.WriteLine (indent + "extern static {0} {1} ({2} raw);", sw.WriteLine (indent + "extern static {0} {1} ({2} raw);",
table.GetMarshalReturnType (CType), getterName, table.GetMarshalType (CType), getterName,
container_type.MarshalType); container_type.MarshalType);
} }
@ -164,7 +164,7 @@ namespace GtkSharp.Generation {
} else if (getterName != null) { } else if (getterName != null) {
sw.WriteLine (indent + "\tget {"); sw.WriteLine (indent + "\tget {");
container_type.Prepare (sw, indent + "\t\t"); container_type.Prepare (sw, indent + "\t\t");
sw.WriteLine (indent + "\t\t" + CSType + " result = " + table.FromNativeReturn (ctype, getterName + " (" + container_type.CallByName () + ")") + ";"); sw.WriteLine (indent + "\t\t" + CSType + " result = " + table.FromNative (ctype, getterName + " (" + container_type.CallByName () + ")") + ";");
container_type.Finish (sw, indent + "\t\t"); container_type.Finish (sw, indent + "\t\t");
sw.WriteLine (indent + "\t\treturn result;"); sw.WriteLine (indent + "\t\treturn result;");
sw.WriteLine (indent + "\t}"); sw.WriteLine (indent + "\t}");
@ -175,13 +175,16 @@ namespace GtkSharp.Generation {
sw.WriteLine (indent + "\t\t\t" + CSType + "* raw_ptr = (" + CSType + "*)(((byte*)" + container_type.CallByName () + ") + " + offsetName + ");"); sw.WriteLine (indent + "\t\t\t" + CSType + "* raw_ptr = (" + CSType + "*)(((byte*)" + container_type.CallByName () + ") + " + offsetName + ");");
sw.WriteLine (indent + "\t\t\treturn *raw_ptr;"); sw.WriteLine (indent + "\t\t\treturn *raw_ptr;");
} else { } else {
sw.WriteLine (indent + "\t\t\t" + table.GetMarshalReturnType (CType) + "* raw_ptr = (" + table.GetMarshalReturnType (CType) + "*)(((byte*)" + container_type.CallByName () + ") + " + offsetName + ");"); sw.WriteLine (indent + "\t\t\t" + table.GetMarshalType (CType) + "* raw_ptr = (" + table.GetMarshalType (CType) + "*)(((byte*)" + container_type.CallByName () + ") + " + offsetName + ");");
sw.WriteLine (indent + "\t\t\treturn " + table.FromNativeReturn (ctype, "(*raw_ptr)") + ";"); sw.WriteLine (indent + "\t\t\treturn " + table.FromNative (ctype, "(*raw_ptr)") + ";");
} }
sw.WriteLine (indent + "\t\t}"); sw.WriteLine (indent + "\t\t}");
sw.WriteLine (indent + "\t}"); sw.WriteLine (indent + "\t}");
} }
IGeneratable gen = table [CType];
string to_native = (gen is IManualMarshaler) ? (gen as IManualMarshaler).AllocNative ("value") : gen.CallByName ("value");
if (Setter != null) { if (Setter != null) {
sw.Write (indent + "\tset "); sw.Write (indent + "\tset ");
Setter.GenerateBody (gen_info, container_type, "\t"); Setter.GenerateBody (gen_info, container_type, "\t");
@ -189,7 +192,7 @@ namespace GtkSharp.Generation {
} else if (setterName != null) { } else if (setterName != null) {
sw.WriteLine (indent + "\tset {"); sw.WriteLine (indent + "\tset {");
container_type.Prepare (sw, indent + "\t\t"); container_type.Prepare (sw, indent + "\t\t");
sw.WriteLine (indent + "\t\t" + setterName + " (" + container_type.CallByName () + ", " + table.CallByName (ctype, "value") + ");"); sw.WriteLine (indent + "\t\t" + setterName + " (" + container_type.CallByName () + ", " + to_native + ");");
container_type.Finish (sw, indent + "\t\t"); container_type.Finish (sw, indent + "\t\t");
sw.WriteLine (indent + "\t}"); sw.WriteLine (indent + "\t}");
} else if (Writable && offsetName != null) { } else if (Writable && offsetName != null) {
@ -199,8 +202,8 @@ namespace GtkSharp.Generation {
sw.WriteLine (indent + "\t\t\t" + CSType + "* raw_ptr = (" + CSType + "*)(((byte*)" + container_type.CallByName () + ") + " + offsetName + ");"); sw.WriteLine (indent + "\t\t\t" + CSType + "* raw_ptr = (" + CSType + "*)(((byte*)" + container_type.CallByName () + ") + " + offsetName + ");");
sw.WriteLine (indent + "\t\t\t*raw_ptr = value;"); sw.WriteLine (indent + "\t\t\t*raw_ptr = value;");
} else { } else {
sw.WriteLine (indent + "\t\t\t" + table.GetMarshalReturnType (CType) + "* raw_ptr = (" + table.GetMarshalReturnType (CType) + "*)(((byte*)" + container_type.CallByName () + ") + " + offsetName + ");"); sw.WriteLine (indent + "\t\t\t" + table.GetMarshalType (CType) + "* raw_ptr = (" + table.GetMarshalType (CType) + "*)(((byte*)" + container_type.CallByName () + ") + " + offsetName + ");");
sw.WriteLine (indent + "\t\t\t*raw_ptr = " + table.ToNativeReturn (ctype, "value") + ";"); sw.WriteLine (indent + "\t\t\t*raw_ptr = " + to_native + ";");
} }
sw.WriteLine (indent + "\t\t}"); sw.WriteLine (indent + "\t\t}");
sw.WriteLine (indent + "\t}"); sw.WriteLine (indent + "\t}");

View file

@ -72,12 +72,6 @@ namespace GtkSharp.Generation {
} }
} }
public virtual string MarshalReturnType {
get {
return MarshalType;
}
}
public abstract string MarshalType { get; } public abstract string MarshalType { get; }
public string Name { public string Name {
@ -100,12 +94,6 @@ namespace GtkSharp.Generation {
} }
} }
public virtual string ToNativeReturnType {
get {
return MarshalType;
}
}
protected void AppendCustom (StreamWriter sw, string custom_dir) protected void AppendCustom (StreamWriter sw, string custom_dir)
{ {
AppendCustom (sw, custom_dir, Name); AppendCustom (sw, custom_dir, Name);
@ -130,16 +118,6 @@ namespace GtkSharp.Generation {
public abstract string FromNative (string var); public abstract string FromNative (string var);
public virtual string FromNativeReturn (string var)
{
return FromNative (var);
}
public virtual string ToNativeReturn (string var)
{
return CallByName (var);
}
public abstract bool Validate (); public abstract bool Validate ();
public void Generate () public void Generate ()

View file

@ -58,16 +58,6 @@ namespace GtkSharp.Generation {
return FromNative (var, false); return FromNative (var, false);
} }
public string FromNativeReturn (string var, bool owned)
{
return FromNative (var, owned);
}
public override string FromNativeReturn (string var)
{
return FromNativeReturn (var, false);
}
public void WriteAccessors (StreamWriter sw, string indent, string var) public void WriteAccessors (StreamWriter sw, string indent, string var)
{ {
sw.WriteLine (indent + "get {"); sw.WriteLine (indent + "get {");

View file

@ -37,14 +37,6 @@ namespace GtkSharp.Generation {
// signature when passing this generatable to unmanaged code // signature when passing this generatable to unmanaged code
string MarshalType {get;} string MarshalType {get;}
// The type to use as the return type in an import signature when
// receiving this generatable back from unmanaged code
string MarshalReturnType {get;}
// The type to use in a managed callback signature when returning this
// generatable to unmanaged code
string ToNativeReturnType {get;}
// The value returned by callbacks that are interrupted prematurely // The value returned by callbacks that are interrupted prematurely
// by managed exceptions or other conditions where an appropriate // by managed exceptions or other conditions where an appropriate
// value can't be otherwise obtained. // value can't be otherwise obtained.
@ -56,12 +48,6 @@ namespace GtkSharp.Generation {
// Generates an expression to convert var from MarshalType // Generates an expression to convert var from MarshalType
string FromNative (string var); string FromNative (string var);
// Generates an expression to convert var from MarshalReturnType
string FromNativeReturn (string var);
// Generates an expression to convert var to ToNativeReturnType
string ToNativeReturn (string var);
bool Validate (); bool Validate ();
void Generate (); void Generate ();

View file

@ -141,8 +141,10 @@ namespace GtkSharp.Generation {
continue; 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); 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)
ret += String.Format ("{0}{1} = {2};", indent, p.Name, (igen as IManualMarshaler).AllocNative ("my" + p.Name));
else else
ret += indent + p.Name + " = " + igen.ToNativeReturn ("my" + p.Name) + ";\n"; ret += indent + p.Name + " = " + igen.CallByName ("my" + p.Name) + ";\n";
} }
return ret; return ret;

View file

@ -102,7 +102,7 @@ namespace GtkSharp.Generation {
return String.Empty; return String.Empty;
else if (is_null_term) else if (is_null_term)
return "IntPtr"; return "IntPtr";
return IGen.MarshalReturnType + (is_array ? "[]" : String.Empty); return IGen.MarshalType + (is_array ? "[]" : String.Empty);
} }
} }
@ -110,7 +110,7 @@ namespace GtkSharp.Generation {
get { get {
if (IGen == null) if (IGen == null)
return String.Empty; return String.Empty;
return IGen.ToNativeReturnType + (is_array || is_null_term ? "[]" : String.Empty); return IGen.MarshalType + (is_array || is_null_term ? "[]" : String.Empty);
} }
} }
@ -130,7 +130,7 @@ namespace GtkSharp.Generation {
else if (is_null_term) else if (is_null_term)
return String.Format ("GLib.Marshaller.NullTermPtrToStringArray ({0}, {1})", var, owned ? "true" : "false"); return String.Format ("GLib.Marshaller.NullTermPtrToStringArray ({0}, {1})", var, owned ? "true" : "false");
else else
return IGen.FromNativeReturn (var); return IGen.FromNative (var);
} }
public string ToNative (string var) public string ToNative (string var)
@ -151,7 +151,7 @@ namespace GtkSharp.Generation {
else if (IGen is OpaqueGen && owned) else if (IGen is OpaqueGen && owned)
return var + " == null ? IntPtr.Zero : " + var + ".OwnedCopy"; return var + " == null ? IntPtr.Zero : " + var + ".OwnedCopy";
else else
return IGen.ToNativeReturn (var); return IGen.CallByName (var);
} }
public bool Validate () public bool Validate ()

View file

@ -178,10 +178,12 @@ namespace GtkSharp.Generation {
} else } else
sw.WriteLine("\t\t\t\targs.Args[" + idx + "] = " + p.FromNative ("arg" + idx) + ";"); sw.WriteLine("\t\t\t\targs.Args[" + idx + "] = " + p.FromNative ("arg" + idx) + ";");
} }
if (igen is StructBase && p.PassAs == "ref") if ((igen is StructBase || igen is ByRefGen) && p.PassAs != "")
finish += "\t\t\t\tif (arg" + idx + " != IntPtr.Zero) System.Runtime.InteropServices.Marshal.StructureToPtr (args.Args[" + idx + "], arg" + idx + ", false);\n"; finish += "\t\t\t\tif (arg" + idx + " != IntPtr.Zero) System.Runtime.InteropServices.Marshal.StructureToPtr (args.Args[" + idx + "], arg" + idx + ", false);\n";
else if (igen is IManualMarshaler && p.PassAs != "")
finish += String.Format ("\t\t\t\targ{0} = {1};\n", idx, (igen as IManualMarshaler).AllocNative ("args.Args[" + idx + "]"));
else if (p.PassAs != "") else if (p.PassAs != "")
finish += "\t\t\t\targ" + idx + " = " + igen.ToNativeReturn ("((" + p.CSType + ")args.Args[" + idx + "])") + ";\n"; finish += "\t\t\t\targ" + idx + " = " + igen.CallByName ("((" + p.CSType + ")args.Args[" + idx + "])") + ";\n";
} }
return finish; return finish;
} }
@ -198,7 +200,7 @@ namespace GtkSharp.Generation {
sw.WriteLine ("\t\t\t\tif (args.RetVal == null)"); sw.WriteLine ("\t\t\t\tif (args.RetVal == null)");
sw.WriteLine ("\t\t\t\t\treturn false;"); sw.WriteLine ("\t\t\t\t\treturn false;");
} }
sw.WriteLine("\t\t\t\treturn " + SymbolTable.Table.ToNativeReturn (retval.CType, "((" + retval.CSType + ")args.RetVal)") + ";"); sw.WriteLine ("\t\t\t\treturn {0};", retval.ToNative (String.Format ("(({0}) args.RetVal)", retval.CSType)));
} }
sw.WriteLine("\t\t\t} catch (Exception) {"); 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\tException ex = new Exception (\"args.RetVal or 'out' property unset or set to incorrect type in " + EventHandlerQualifiedName + " callback\");");

View file

@ -66,24 +66,12 @@ namespace GtkSharp.Generation {
} }
} }
public virtual string MarshalReturnType {
get {
return MarshalType;
}
}
public virtual string DefaultValue { public virtual string DefaultValue {
get { get {
return default_value; return default_value;
} }
} }
public virtual string ToNativeReturnType {
get {
return MarshalType;
}
}
public virtual string CallByName (string var) public virtual string CallByName (string var)
{ {
return var; return var;
@ -94,16 +82,6 @@ namespace GtkSharp.Generation {
return var; return var;
} }
public virtual string FromNativeReturn(string var)
{
return FromNative (var);
}
public virtual string ToNativeReturn(string var)
{
return CallByName (var);
}
public bool Validate () public bool Validate ()
{ {
return true; return true;

View file

@ -134,7 +134,7 @@ namespace GtkSharp.Generation {
sw.WriteLine (); sw.WriteLine ();
if (Access != "private") { if (Access != "private") {
sw.WriteLine (indent + Access + " " + wrapped + " " + wrapped_name + " {"); sw.WriteLine (indent + Access + " " + wrapped + " " + wrapped_name + " {");
sw.WriteLine (indent + "\tget { return " + table.FromNativeReturn (CType, Name) + "; }"); sw.WriteLine (indent + "\tget { return " + table.FromNative (CType, Name) + "; }");
sw.WriteLine (indent + "}"); sw.WriteLine (indent + "}");
} }
} else if (IsPointer && CSType != "string") { } else if (IsPointer && CSType != "string") {

View file

@ -213,22 +213,6 @@ namespace GtkSharp.Generation {
return types [type]; return types [type];
} }
public string FromNativeReturn(string c_type, string val)
{
IGeneratable gen = this[c_type];
if (gen == null)
return "";
return gen.FromNativeReturn (val);
}
public string ToNativeReturn(string c_type, string val)
{
IGeneratable gen = this[c_type];
if (gen == null)
return "";
return gen.ToNativeReturn (val);
}
public string FromNative(string c_type, string val) public string FromNative(string c_type, string val)
{ {
IGeneratable gen = this[c_type]; IGeneratable gen = this[c_type];
@ -253,22 +237,6 @@ namespace GtkSharp.Generation {
return gen.Name; return gen.Name;
} }
public string GetMarshalReturnType(string c_type)
{
IGeneratable gen = this[c_type];
if (gen == null)
return "";
return gen.MarshalReturnType;
}
public string GetToNativeReturnType(string c_type)
{
IGeneratable gen = this[c_type];
if (gen == null)
return "";
return gen.ToNativeReturnType;
}
public string GetMarshalType(string c_type) public string GetMarshalType(string c_type)
{ {
IGeneratable gen = this[c_type]; IGeneratable gen = this[c_type];