2007-08-13 Mike Kestner <mkestner@novell.com>
* generator/*.cs : switch to IntPtr marshaling for struct types in the managed to native direction. * gtk/*.custom : adjust to new gapi struct pinvoke sigs. svn path=/trunk/gtk-sharp/; revision=83961
This commit is contained in:
parent
d24e54974d
commit
fc06f3829a
19 changed files with 204 additions and 177 deletions
|
@ -1,3 +1,9 @@
|
||||||
|
2007-08-13 Mike Kestner <mkestner@novell.com>
|
||||||
|
|
||||||
|
* generator/*.cs : switch to IntPtr marshaling for struct types
|
||||||
|
in the managed to native direction.
|
||||||
|
* gtk/*.custom : adjust to new gapi struct pinvoke sigs.
|
||||||
|
|
||||||
2007-08-01 Mike Kestner <mkestner@novell.com>
|
2007-08-01 Mike Kestner <mkestner@novell.com>
|
||||||
|
|
||||||
* generator/CallbackGen.cs : use Parameters.NativeCallbackSignature.
|
* generator/CallbackGen.cs : use Parameters.NativeCallbackSignature.
|
||||||
|
|
|
@ -91,6 +91,9 @@ namespace GtkSharp.Generation {
|
||||||
string wrapper = Name + "Native";
|
string wrapper = Name + "Native";
|
||||||
string qualname = MarshalType;
|
string qualname = MarshalType;
|
||||||
|
|
||||||
|
if (!Validate ())
|
||||||
|
return String.Empty;
|
||||||
|
|
||||||
StreamWriter sw = gen_info.OpenStream (qualname);
|
StreamWriter sw = gen_info.OpenStream (qualname);
|
||||||
|
|
||||||
sw.WriteLine ("namespace " + NS + "Sharp {");
|
sw.WriteLine ("namespace " + NS + "Sharp {");
|
||||||
|
@ -100,11 +103,11 @@ namespace GtkSharp.Generation {
|
||||||
sw.WriteLine ();
|
sw.WriteLine ();
|
||||||
sw.WriteLine ("#region Autogenerated code");
|
sw.WriteLine ("#region Autogenerated code");
|
||||||
sw.WriteLine ("\t[GLib.CDeclCallback]");
|
sw.WriteLine ("\t[GLib.CDeclCallback]");
|
||||||
sw.WriteLine ("\tinternal delegate " + retval.MarshalType + " " + wrapper + "(" + parms.NativeCallbackSignature + ");");
|
sw.WriteLine ("\tinternal delegate " + retval.MarshalType + " " + wrapper + "(" + parms.ImportSignature + ");");
|
||||||
sw.WriteLine ();
|
sw.WriteLine ();
|
||||||
sw.WriteLine ("\tinternal class " + Name + "Wrapper {");
|
sw.WriteLine ("\tinternal class " + Name + "Wrapper {");
|
||||||
sw.WriteLine ();
|
sw.WriteLine ();
|
||||||
sw.WriteLine ("\t\tpublic " + retval.MarshalType + " NativeCallback (" + parms.NativeCallbackSignature + ")");
|
sw.WriteLine ("\t\tpublic " + retval.MarshalType + " NativeCallback (" + parms.ImportSignature + ")");
|
||||||
sw.WriteLine ("\t\t{");
|
sw.WriteLine ("\t\t{");
|
||||||
sw.WriteLine ("\t\t\ttry {");
|
sw.WriteLine ("\t\t\ttry {");
|
||||||
|
|
||||||
|
|
|
@ -281,8 +281,11 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected bool IgnoreMethod (Method method)
|
protected bool IgnoreMethod (Method method, ClassBase implementor)
|
||||||
{
|
{
|
||||||
|
if (implementor != null && implementor.QualifiedName != this.QualifiedName && method.IsStatic)
|
||||||
|
return true;
|
||||||
|
|
||||||
string mname = method.Name;
|
string mname = method.Name;
|
||||||
return ((method.IsSetter || (method.IsGetter && mname.StartsWith("Get"))) &&
|
return ((method.IsSetter || (method.IsGetter && mname.StartsWith("Get"))) &&
|
||||||
((props != null) && props.ContainsKey(mname.Substring(3)) ||
|
((props != null) && props.ContainsKey(mname.Substring(3)) ||
|
||||||
|
@ -295,7 +298,7 @@ namespace GtkSharp.Generation {
|
||||||
return;
|
return;
|
||||||
|
|
||||||
foreach (Method method in methods.Values) {
|
foreach (Method method in methods.Values) {
|
||||||
if (IgnoreMethod (method))
|
if (IgnoreMethod (method, implementor))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
string oname = null, oprotection = null;
|
string oname = null, oprotection = null;
|
||||||
|
@ -449,5 +452,12 @@ namespace GtkSharp.Generation {
|
||||||
ctor.Generate (gen_info);
|
ctor.Generate (gen_info);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public virtual void Finish (StreamWriter sw, string indent)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public virtual void Prepare (StreamWriter sw, string indent)
|
||||||
|
{
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -159,11 +159,14 @@ namespace GtkSharp.Generation {
|
||||||
|
|
||||||
if (Getter != null) {
|
if (Getter != null) {
|
||||||
sw.Write (indent + "\tget ");
|
sw.Write (indent + "\tget ");
|
||||||
Getter.GenerateBody (gen_info, "\t");
|
Getter.GenerateBody (gen_info, container_type, "\t");
|
||||||
sw.WriteLine ("");
|
sw.WriteLine ("");
|
||||||
} else if (getterName != null) {
|
} else if (getterName != null) {
|
||||||
sw.WriteLine (indent + "\tget {");
|
sw.WriteLine (indent + "\tget {");
|
||||||
sw.WriteLine (indent + "\t\treturn " + table.FromNativeReturn (ctype, getterName + " (" + container_type.CallByName () + ")") + ";");
|
container_type.Prepare (sw, indent + "\t\t");
|
||||||
|
sw.WriteLine (indent + "\t\t" + CSType + " result = " + table.FromNativeReturn (ctype, getterName + " (" + container_type.CallByName () + ")") + ";");
|
||||||
|
container_type.Finish (sw, indent + "\t\t");
|
||||||
|
sw.WriteLine (indent + "\t\treturn result;");
|
||||||
sw.WriteLine (indent + "\t}");
|
sw.WriteLine (indent + "\t}");
|
||||||
} else if (Readable && offsetName != null) {
|
} else if (Readable && offsetName != null) {
|
||||||
sw.WriteLine (indent + "\tget {");
|
sw.WriteLine (indent + "\tget {");
|
||||||
|
@ -181,11 +184,13 @@ namespace GtkSharp.Generation {
|
||||||
|
|
||||||
if (Setter != null) {
|
if (Setter != null) {
|
||||||
sw.Write (indent + "\tset ");
|
sw.Write (indent + "\tset ");
|
||||||
Setter.GenerateBody (gen_info, "\t");
|
Setter.GenerateBody (gen_info, container_type, "\t");
|
||||||
sw.WriteLine ("");
|
sw.WriteLine ("");
|
||||||
} else if (setterName != null) {
|
} else if (setterName != null) {
|
||||||
sw.WriteLine (indent + "\tset {");
|
sw.WriteLine (indent + "\tset {");
|
||||||
|
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 () + ", " + table.CallByName (ctype, "value") + ");");
|
||||||
|
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) {
|
||||||
sw.WriteLine (indent + "\tset {");
|
sw.WriteLine (indent + "\tset {");
|
||||||
|
|
|
@ -63,12 +63,6 @@ namespace GtkSharp.Generation {
|
||||||
|
|
||||||
public abstract string MarshalType { get; }
|
public abstract string MarshalType { get; }
|
||||||
|
|
||||||
public virtual string NativeCallbackType {
|
|
||||||
get {
|
|
||||||
return MarshalType;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public string Name {
|
public string Name {
|
||||||
get {
|
get {
|
||||||
return elem.GetAttribute ("name");
|
return elem.GetAttribute ("name");
|
||||||
|
|
|
@ -37,10 +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 in the native delegate signature when marshaling to
|
|
||||||
// managed code from a native callback.
|
|
||||||
string NativeCallbackType {get;}
|
|
||||||
|
|
||||||
// The type to use as the return type in an import signature when
|
// The type to use as the return type in an import signature when
|
||||||
// receiving this generatable back from unmanaged code
|
// receiving this generatable back from unmanaged code
|
||||||
string MarshalReturnType {get;}
|
string MarshalReturnType {get;}
|
||||||
|
|
|
@ -287,7 +287,7 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach (Method method in methods.Values) {
|
foreach (Method method in methods.Values) {
|
||||||
if (IgnoreMethod (method))
|
if (IgnoreMethod (method, this))
|
||||||
continue;
|
continue;
|
||||||
method.GenerateDecl (sw);
|
method.GenerateDecl (sw);
|
||||||
}
|
}
|
||||||
|
|
|
@ -212,11 +212,12 @@ namespace GtkSharp.Generation {
|
||||||
|
|
||||||
public void Generate (GenerationInfo gen_info, ClassBase implementor)
|
public void Generate (GenerationInfo gen_info, ClassBase implementor)
|
||||||
{
|
{
|
||||||
|
if (!Validate ())
|
||||||
|
return;
|
||||||
|
|
||||||
Method comp = null;
|
Method comp = null;
|
||||||
|
|
||||||
gen_info.CurrentMember = Name;
|
gen_info.CurrentMember = Name;
|
||||||
if (implementor != null && IsStatic)
|
|
||||||
return;
|
|
||||||
|
|
||||||
/* we are generated by the get Method, if there is one */
|
/* we are generated by the get Method, if there is one */
|
||||||
if (is_set || is_get)
|
if (is_set || is_get)
|
||||||
|
@ -253,10 +254,10 @@ namespace GtkSharp.Generation {
|
||||||
{
|
{
|
||||||
gen_info.Writer.Write ("\t\t\t");
|
gen_info.Writer.Write ("\t\t\t");
|
||||||
gen_info.Writer.Write ((is_get) ? "get" : "set");
|
gen_info.Writer.Write ((is_get) ? "get" : "set");
|
||||||
GenerateBody (gen_info, "\t");
|
GenerateBody (gen_info, implementor, "\t");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
GenerateBody (gen_info, "");
|
GenerateBody (gen_info, implementor, "");
|
||||||
|
|
||||||
if (is_get || is_set)
|
if (is_get || is_set)
|
||||||
{
|
{
|
||||||
|
@ -264,7 +265,7 @@ namespace GtkSharp.Generation {
|
||||||
{
|
{
|
||||||
gen_info.Writer.WriteLine ();
|
gen_info.Writer.WriteLine ();
|
||||||
gen_info.Writer.Write ("\t\t\tset");
|
gen_info.Writer.Write ("\t\t\tset");
|
||||||
comp.GenerateBody (gen_info, "\t");
|
comp.GenerateBody (gen_info, implementor, "\t");
|
||||||
}
|
}
|
||||||
gen_info.Writer.WriteLine ();
|
gen_info.Writer.WriteLine ();
|
||||||
gen_info.Writer.WriteLine ("\t\t}");
|
gen_info.Writer.WriteLine ("\t\t}");
|
||||||
|
@ -277,10 +278,12 @@ namespace GtkSharp.Generation {
|
||||||
Statistics.MethodCount++;
|
Statistics.MethodCount++;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void GenerateBody (GenerationInfo gen_info, string indent)
|
public void GenerateBody (GenerationInfo gen_info, ClassBase implementor, string indent)
|
||||||
{
|
{
|
||||||
StreamWriter sw = gen_info.Writer;
|
StreamWriter sw = gen_info.Writer;
|
||||||
sw.WriteLine(" {");
|
sw.WriteLine(" {");
|
||||||
|
if (!IsStatic && implementor != null)
|
||||||
|
implementor.Prepare (sw, indent + "\t\t\t");
|
||||||
if (IsAccessor)
|
if (IsAccessor)
|
||||||
Body.InitAccessor (sw, Signature, indent);
|
Body.InitAccessor (sw, Signature, indent);
|
||||||
Body.Initialize(gen_info, is_get, is_set, indent);
|
Body.Initialize(gen_info, is_get, is_set, indent);
|
||||||
|
@ -294,6 +297,8 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
|
|
||||||
Body.Finish (sw, indent);
|
Body.Finish (sw, indent);
|
||||||
|
if (!IsStatic && implementor != null)
|
||||||
|
implementor.Finish (sw, indent + "\t\t\t");
|
||||||
Body.HandleException (sw, indent);
|
Body.HandleException (sw, indent);
|
||||||
|
|
||||||
if (is_get && Parameters.Count > 0)
|
if (is_get && Parameters.Count > 0)
|
||||||
|
|
|
@ -155,11 +155,11 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public string MarshalType {
|
public virtual string MarshalType {
|
||||||
get {
|
get {
|
||||||
string type = SymbolTable.Table.GetMarshalType( elem.GetAttribute("type"));
|
string type = SymbolTable.Table.GetMarshalType( elem.GetAttribute("type"));
|
||||||
if (type == "void")
|
if (type == "void" || Generatable is IManualMarshaler)
|
||||||
type = "System.IntPtr";
|
type = "IntPtr";
|
||||||
if (IsArray) {
|
if (IsArray) {
|
||||||
type += "[]";
|
type += "[]";
|
||||||
type = type.Replace ("ref ", "");
|
type = type.Replace ("ref ", "");
|
||||||
|
@ -168,18 +168,6 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public string NativeCallbackType {
|
|
||||||
get {
|
|
||||||
string type = Generatable.NativeCallbackType;
|
|
||||||
if (type == "void")
|
|
||||||
type = "System.IntPtr";
|
|
||||||
if (IsArray) {
|
|
||||||
type += "[]";
|
|
||||||
type = type.Replace ("ref ", "");
|
|
||||||
}
|
|
||||||
return type;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
public string Name {
|
public string Name {
|
||||||
get {
|
get {
|
||||||
return SymbolTable.Table.MangleName (elem.GetAttribute("name"));
|
return SymbolTable.Table.MangleName (elem.GetAttribute("name"));
|
||||||
|
@ -192,17 +180,6 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual string NativeCallbackSignature {
|
|
||||||
get {
|
|
||||||
string sig = NativeCallbackType + " " + Name;
|
|
||||||
if (PassAs != String.Empty && !(Generatable is StructBase))
|
|
||||||
sig = PassAs + " " + sig;
|
|
||||||
sig = sig.Replace ("out ref", "out");
|
|
||||||
sig = sig.Replace ("ref ref", "ref");
|
|
||||||
return sig;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public virtual string NativeSignature {
|
public virtual string NativeSignature {
|
||||||
get {
|
get {
|
||||||
string sig = MarshalType + " " + Name;
|
string sig = MarshalType + " " + Name;
|
||||||
|
@ -259,7 +236,7 @@ namespace GtkSharp.Generation {
|
||||||
get {
|
get {
|
||||||
IGeneratable gen = Generatable;
|
IGeneratable gen = Generatable;
|
||||||
if (gen is IManualMarshaler) {
|
if (gen is IManualMarshaler) {
|
||||||
string result = " IntPtr native_" + CallName;
|
string result = "IntPtr native_" + CallName;
|
||||||
if (PassAs != "out")
|
if (PassAs != "out")
|
||||||
result += " = " + (gen as IManualMarshaler).AllocNative (CallName);
|
result += " = " + (gen as IManualMarshaler).AllocNative (CallName);
|
||||||
return new string [] { result + ";" };
|
return new string [] { result + ";" };
|
||||||
|
@ -279,7 +256,7 @@ namespace GtkSharp.Generation {
|
||||||
return SymbolTable.Table.CallByName (CType, CallName + "_wrapper");
|
return SymbolTable.Table.CallByName (CType, CallName + "_wrapper");
|
||||||
else if (PassAs != String.Empty) {
|
else if (PassAs != String.Empty) {
|
||||||
call_parm = PassAs + " ";
|
call_parm = PassAs + " ";
|
||||||
if (CSType != MarshalType && !(gen is StructBase || gen is ByRefGen))
|
if (CSType != MarshalType && !(gen is ByRefGen))
|
||||||
call_parm += "native_";
|
call_parm += "native_";
|
||||||
call_parm += CallName;
|
call_parm += CallName;
|
||||||
} else if (gen is IManualMarshaler)
|
} else if (gen is IManualMarshaler)
|
||||||
|
@ -336,6 +313,15 @@ namespace GtkSharp.Generation {
|
||||||
|
|
||||||
public ArrayParameter (XmlElement elem) : base (elem) {}
|
public ArrayParameter (XmlElement elem) : base (elem) {}
|
||||||
|
|
||||||
|
public override string MarshalType {
|
||||||
|
get {
|
||||||
|
if (Generatable is StructBase)
|
||||||
|
return CSType;
|
||||||
|
else
|
||||||
|
return base.MarshalType;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public override string[] Prepare {
|
public override string[] Prepare {
|
||||||
get {
|
get {
|
||||||
if (CSType == MarshalType)
|
if (CSType == MarshalType)
|
||||||
|
@ -365,6 +351,9 @@ namespace GtkSharp.Generation {
|
||||||
|
|
||||||
public override string[] Finish {
|
public override string[] Finish {
|
||||||
get {
|
get {
|
||||||
|
if (CSType == MarshalType)
|
||||||
|
return new string [0];
|
||||||
|
|
||||||
IGeneratable gen = Generatable;
|
IGeneratable gen = Generatable;
|
||||||
if (gen is IManualMarshaler) {
|
if (gen is IManualMarshaler) {
|
||||||
string [] result = new string [4];
|
string [] result = new string [4];
|
||||||
|
@ -453,46 +442,57 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public class StructParameter : Parameter {
|
||||||
|
|
||||||
|
public StructParameter (XmlElement elem) : base (elem) {}
|
||||||
|
|
||||||
|
public override string MarshalType {
|
||||||
|
get {
|
||||||
|
return "IntPtr";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public override string[] Prepare {
|
||||||
|
get {
|
||||||
|
if (PassAs == "out")
|
||||||
|
return new string [] { "IntPtr native_" + CallName + " = Marshal.AllocHGlobal (Marshal.SizeOf (typeof (" + Generatable.QualifiedName + ")));"};
|
||||||
|
else
|
||||||
|
return new string [] { "IntPtr native_" + CallName + " = " + (Generatable as IManualMarshaler).AllocNative (CallName) + ";"};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public override string CallString {
|
||||||
|
get {
|
||||||
|
return "native_" + CallName;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public override string[] Finish {
|
||||||
|
get {
|
||||||
|
string[] result = new string [2];
|
||||||
|
result [0] = CallName + " = " + FromNative ("native_" + CallName) + ";";
|
||||||
|
result [1] = (Generatable as IManualMarshaler).ReleaseNative ("native_" + CallName) + ";";
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public override string NativeSignature {
|
||||||
|
get {
|
||||||
|
return "IntPtr " + CallName;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public class Parameters : IEnumerable {
|
public class Parameters : IEnumerable {
|
||||||
|
|
||||||
ArrayList param_list = new ArrayList ();
|
ArrayList param_list = new ArrayList ();
|
||||||
|
XmlElement elem;
|
||||||
|
|
||||||
public Parameters (XmlElement elem) {
|
public Parameters (XmlElement elem)
|
||||||
|
{
|
||||||
if (elem == null)
|
if (elem == null)
|
||||||
return;
|
valid = true;
|
||||||
|
this.elem = elem;
|
||||||
for (int i = 0; i < elem.ChildNodes.Count; i++) {
|
|
||||||
XmlElement parm = elem.ChildNodes [i] as XmlElement;
|
|
||||||
if (parm == null || parm.Name != "parameter")
|
|
||||||
continue;
|
|
||||||
Parameter p = new Parameter (parm);
|
|
||||||
if (p.IsArray) {
|
|
||||||
p = new ArrayParameter (parm);
|
|
||||||
if (i < elem.ChildNodes.Count - 1) {
|
|
||||||
XmlElement next = elem.ChildNodes [i + 1] as XmlElement;
|
|
||||||
if (next != null || next.Name == "parameter") {
|
|
||||||
Parameter c = new Parameter (next);
|
|
||||||
if (c.IsCount) {
|
|
||||||
p = new ArrayCountPair (parm, next, false);
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else if (p.IsCount && i < elem.ChildNodes.Count - 1) {
|
|
||||||
Console.WriteLine (elem.GetAttribute ("name"));
|
|
||||||
XmlElement next = elem.ChildNodes [i + 1] as XmlElement;
|
|
||||||
if (next != null || next.Name == "parameter") {
|
|
||||||
Parameter a = new Parameter (next);
|
|
||||||
if (a.IsArray) {
|
|
||||||
p = new ArrayCountPair (next, parm, true);
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else if (p.CType == "GError**")
|
|
||||||
p = new ErrorParameter (parm);
|
|
||||||
param_list.Add (p);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public int Count {
|
public int Count {
|
||||||
|
@ -564,11 +564,11 @@ namespace GtkSharp.Generation {
|
||||||
set { is_static = value; }
|
set { is_static = value; }
|
||||||
}
|
}
|
||||||
|
|
||||||
bool cleared = false;
|
|
||||||
void Clear ()
|
void Clear ()
|
||||||
{
|
{
|
||||||
cleared = true;
|
elem = null;
|
||||||
param_list.Clear ();
|
param_list.Clear ();
|
||||||
|
param_list = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public IEnumerator GetEnumerator ()
|
public IEnumerator GetEnumerator ()
|
||||||
|
@ -576,18 +576,25 @@ namespace GtkSharp.Generation {
|
||||||
return param_list.GetEnumerator ();
|
return param_list.GetEnumerator ();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool valid = false;
|
||||||
|
|
||||||
public bool Validate ()
|
public bool Validate ()
|
||||||
{
|
{
|
||||||
if (cleared)
|
if (valid)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
if (elem == null)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
for (int i = 0; i < param_list.Count; i++) {
|
for (int i = 0; i < elem.ChildNodes.Count; i++) {
|
||||||
Parameter p = this [i];
|
XmlElement parm = elem.ChildNodes [i] as XmlElement;
|
||||||
|
if (parm == null || parm.Name != "parameter")
|
||||||
|
continue;
|
||||||
|
Parameter p = new Parameter (parm);
|
||||||
|
|
||||||
if (p.IsEllipsis) {
|
if (p.IsEllipsis) {
|
||||||
Console.Write("Ellipsis parameter ");
|
Console.Write("Ellipsis parameter ");
|
||||||
Clear ();
|
Clear ();
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -598,15 +605,43 @@ namespace GtkSharp.Generation {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (p.Generatable is CallbackGen) {
|
IGeneratable gen = p.Generatable;
|
||||||
|
|
||||||
|
if (p.IsArray) {
|
||||||
|
p = new ArrayParameter (parm);
|
||||||
|
if (i < elem.ChildNodes.Count - 1) {
|
||||||
|
XmlElement next = elem.ChildNodes [i + 1] as XmlElement;
|
||||||
|
if (next != null || next.Name == "parameter") {
|
||||||
|
Parameter c = new Parameter (next);
|
||||||
|
if (c.IsCount) {
|
||||||
|
p = new ArrayCountPair (parm, next, false);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (p.IsCount && i < elem.ChildNodes.Count - 1) {
|
||||||
|
XmlElement next = elem.ChildNodes [i + 1] as XmlElement;
|
||||||
|
if (next != null || next.Name == "parameter") {
|
||||||
|
Parameter a = new Parameter (next);
|
||||||
|
if (a.IsArray) {
|
||||||
|
p = new ArrayCountPair (next, parm, true);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (p.CType == "GError**")
|
||||||
|
p = new ErrorParameter (parm);
|
||||||
|
else if (gen is StructBase) {
|
||||||
|
p = new StructParameter (parm);
|
||||||
|
} else if (gen is CallbackGen) {
|
||||||
has_cb = true;
|
has_cb = true;
|
||||||
if (i == Count - 3 &&
|
|
||||||
this [i + 1].IsUserData &&
|
|
||||||
this [i + 2].IsDestroyNotify)
|
|
||||||
p.Scope = "notified";
|
|
||||||
}
|
}
|
||||||
|
param_list.Add (p);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (has_cb && Count > 2 && this [Count - 3].Generatable is CallbackGen && this [Count - 2].IsUserData && this [Count - 1].IsDestroyNotify)
|
||||||
|
this [Count - 3].Scope = "notified";
|
||||||
|
|
||||||
|
valid = true;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -658,19 +693,6 @@ namespace GtkSharp.Generation {
|
||||||
return String.Join (", ", result);
|
return String.Join (", ", result);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public string NativeCallbackSignature {
|
|
||||||
get {
|
|
||||||
if (Count == 0)
|
|
||||||
return String.Empty;
|
|
||||||
|
|
||||||
string[] result = new string [Count];
|
|
||||||
for (int i = 0; i < Count; i++)
|
|
||||||
result [i] = this [i].NativeCallbackSignature;
|
|
||||||
|
|
||||||
return String.Join (", ", result);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -135,7 +135,7 @@ namespace GtkSharp.Generation {
|
||||||
|
|
||||||
if (Getter != null) {
|
if (Getter != null) {
|
||||||
sw.Write(indent + "get ");
|
sw.Write(indent + "get ");
|
||||||
Getter.GenerateBody(gen_info, "\t");
|
Getter.GenerateBody(gen_info, implementor, "\t");
|
||||||
sw.WriteLine();
|
sw.WriteLine();
|
||||||
} else if (Readable) {
|
} else if (Readable) {
|
||||||
sw.WriteLine(indent + "get {");
|
sw.WriteLine(indent + "get {");
|
||||||
|
@ -158,7 +158,7 @@ namespace GtkSharp.Generation {
|
||||||
|
|
||||||
if (Setter != null) {
|
if (Setter != null) {
|
||||||
sw.Write(indent + "set ");
|
sw.Write(indent + "set ");
|
||||||
Setter.GenerateBody(gen_info, "\t");
|
Setter.GenerateBody(gen_info, implementor, "\t");
|
||||||
sw.WriteLine();
|
sw.WriteLine();
|
||||||
} else if (Writable) {
|
} else if (Writable) {
|
||||||
sw.WriteLine(indent + "set {");
|
sw.WriteLine(indent + "set {");
|
||||||
|
|
|
@ -101,7 +101,7 @@ namespace GtkSharp.Generation {
|
||||||
Parameter p = parms [i];
|
Parameter p = parms [i];
|
||||||
if (p.PassAs != "" && !(p.Generatable is StructBase))
|
if (p.PassAs != "" && !(p.Generatable is StructBase))
|
||||||
result += p.PassAs + " ";
|
result += p.PassAs + " ";
|
||||||
result += (p.NativeCallbackType + " arg" + i);
|
result += (p.MarshalType + " arg" + i);
|
||||||
}
|
}
|
||||||
result += ", IntPtr gch";
|
result += ", IntPtr gch";
|
||||||
|
|
||||||
|
@ -374,9 +374,9 @@ namespace GtkSharp.Generation {
|
||||||
{
|
{
|
||||||
ManagedCallString call = new ManagedCallString (parms);
|
ManagedCallString call = new ManagedCallString (parms);
|
||||||
sw.WriteLine ("\t\t[GLib.CDeclCallback]");
|
sw.WriteLine ("\t\t[GLib.CDeclCallback]");
|
||||||
sw.WriteLine ("\t\tdelegate " + retval.ToNativeType + " " + Name + "VMDelegate (" + parms.NativeCallbackSignature + ");\n");
|
sw.WriteLine ("\t\tdelegate " + retval.ToNativeType + " " + Name + "VMDelegate (" + parms.ImportSignature + ");\n");
|
||||||
sw.WriteLine ("\t\tstatic {0} {1};\n", Name + "VMDelegate", Name + "VMCallback");
|
sw.WriteLine ("\t\tstatic {0} {1};\n", Name + "VMDelegate", Name + "VMCallback");
|
||||||
sw.WriteLine ("\t\tstatic " + retval.ToNativeType + " " + Name.ToLower() + "_cb (" + parms.NativeCallbackSignature + ")");
|
sw.WriteLine ("\t\tstatic " + retval.ToNativeType + " " + Name.ToLower() + "_cb (" + parms.ImportSignature + ")");
|
||||||
sw.WriteLine ("\t\t{");
|
sw.WriteLine ("\t\t{");
|
||||||
sw.WriteLine ("\t\t\ttry {");
|
sw.WriteLine ("\t\t\ttry {");
|
||||||
sw.WriteLine ("\t\t\t\t{0} {1}_managed = GLib.Object.GetObject ({1}, false) as {0};", implementor != null ? implementor.Name : container_type.Name, parms[0].Name);
|
sw.WriteLine ("\t\t\t\t{0} {1}_managed = GLib.Object.GetObject ({1}, false) as {0};", implementor != null ? implementor.Name : container_type.Name, parms[0].Name);
|
||||||
|
|
|
@ -64,12 +64,6 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public virtual string NativeCallbackType {
|
|
||||||
get {
|
|
||||||
return MarshalType;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public virtual string MarshalReturnType {
|
public virtual string MarshalReturnType {
|
||||||
get {
|
get {
|
||||||
return MarshalType;
|
return MarshalType;
|
||||||
|
|
|
@ -27,9 +27,10 @@ namespace GtkSharp.Generation {
|
||||||
using System.Text.RegularExpressions;
|
using System.Text.RegularExpressions;
|
||||||
using System.Xml;
|
using System.Xml;
|
||||||
|
|
||||||
public abstract class StructBase : ClassBase {
|
public abstract class StructBase : ClassBase, IManualMarshaler {
|
||||||
|
|
||||||
new ArrayList fields = new ArrayList ();
|
new ArrayList fields = new ArrayList ();
|
||||||
|
bool need_read_native = false;
|
||||||
|
|
||||||
protected StructBase (XmlElement ns, XmlElement elem) : base (ns, elem)
|
protected StructBase (XmlElement ns, XmlElement elem) : base (ns, elem)
|
||||||
{
|
{
|
||||||
|
@ -56,51 +57,41 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
|
|
||||||
public override string MarshalType {
|
public override string MarshalType {
|
||||||
get {
|
|
||||||
return "ref " + QualifiedName;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public override string NativeCallbackType {
|
|
||||||
get {
|
get {
|
||||||
return "IntPtr";
|
return "IntPtr";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public override string MarshalReturnType {
|
public override string AssignToName {
|
||||||
get {
|
get { throw new NotImplementedException (); }
|
||||||
return "IntPtr";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public override string ToNativeReturnType {
|
|
||||||
get {
|
|
||||||
return QualifiedName;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public override string CallByName (string var_name)
|
|
||||||
{
|
|
||||||
return "ref " + var_name;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public override string CallByName ()
|
public override string CallByName ()
|
||||||
{
|
{
|
||||||
return "ref this";
|
return "this_as_native";
|
||||||
}
|
}
|
||||||
|
|
||||||
public override string AssignToName {
|
public override string CallByName (string var)
|
||||||
get { return "raw"; }
|
|
||||||
}
|
|
||||||
|
|
||||||
public override string FromNative(string var)
|
|
||||||
{
|
{
|
||||||
return QualifiedName + ".New (" + var + ")";
|
return var + "_as_native";
|
||||||
}
|
}
|
||||||
|
|
||||||
public override string ToNativeReturn(string var)
|
public override string FromNative (string var)
|
||||||
{
|
{
|
||||||
return var;
|
if (DisableNew)
|
||||||
|
return var + " == IntPtr.Zero ? " + QualifiedName + ".Zero : (" + QualifiedName + ") System.Runtime.InteropServices.Marshal.PtrToStructure (" + var + ", typeof (" + QualifiedName + "))";
|
||||||
|
else
|
||||||
|
return QualifiedName + ".New (" + var + ")";
|
||||||
|
}
|
||||||
|
|
||||||
|
public string AllocNative (string var)
|
||||||
|
{
|
||||||
|
return "GLib.Marshaller.StructureToPtrAlloc (" + var + ")";
|
||||||
|
}
|
||||||
|
|
||||||
|
public string ReleaseNative (string var)
|
||||||
|
{
|
||||||
|
return "Marshal.FreeHGlobal (" +var + ")";
|
||||||
}
|
}
|
||||||
|
|
||||||
private bool DisableNew {
|
private bool DisableNew {
|
||||||
|
@ -165,10 +156,13 @@ namespace GtkSharp.Generation {
|
||||||
sw.WriteLine ("\tpublic struct " + Name + " {");
|
sw.WriteLine ("\tpublic struct " + Name + " {");
|
||||||
sw.WriteLine ();
|
sw.WriteLine ();
|
||||||
|
|
||||||
|
need_read_native = false;
|
||||||
GenFields (gen_info);
|
GenFields (gen_info);
|
||||||
sw.WriteLine ();
|
sw.WriteLine ();
|
||||||
GenCtors (gen_info);
|
GenCtors (gen_info);
|
||||||
GenMethods (gen_info, null, null);
|
GenMethods (gen_info, null, this);
|
||||||
|
if (need_read_native)
|
||||||
|
GenReadNative (sw);
|
||||||
|
|
||||||
if (!need_close)
|
if (!need_close)
|
||||||
return;
|
return;
|
||||||
|
@ -203,6 +197,27 @@ namespace GtkSharp.Generation {
|
||||||
base.GenCtors (gen_info);
|
base.GenCtors (gen_info);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void GenReadNative (StreamWriter sw)
|
||||||
|
{
|
||||||
|
sw.WriteLine ("\t\tstatic void ReadNative (IntPtr native, ref {0} target)", QualifiedName);
|
||||||
|
sw.WriteLine ("\t\t{");
|
||||||
|
sw.WriteLine ("\t\t\ttarget = New (native);");
|
||||||
|
sw.WriteLine ("\t\t}");
|
||||||
|
sw.WriteLine ();
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void Prepare (StreamWriter sw, string indent)
|
||||||
|
{
|
||||||
|
sw.WriteLine (indent + "IntPtr this_as_native = System.Runtime.InteropServices.Marshal.AllocHGlobal (System.Runtime.InteropServices.Marshal.SizeOf (this));");
|
||||||
|
sw.WriteLine (indent + "System.Runtime.InteropServices.Marshal.StructureToPtr (this, this_as_native, false);");
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void Finish (StreamWriter sw, string indent)
|
||||||
|
{
|
||||||
|
need_read_native = true;
|
||||||
|
sw.WriteLine (indent + "ReadNative (this_as_native, ref this);");
|
||||||
|
sw.WriteLine (indent + "System.Runtime.InteropServices.Marshal.FreeHGlobal (this_as_native);");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -30,8 +30,6 @@
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
[DllImport("libgtk-win32-2.0-0.dll")]
|
|
||||||
static extern int gtk_tree_model_iter_n_children (IntPtr raw, IntPtr iter);
|
|
||||||
public int IterNChildren ()
|
public int IterNChildren ()
|
||||||
{
|
{
|
||||||
int raw_ret = gtk_tree_model_iter_n_children (Handle, IntPtr.Zero);
|
int raw_ret = gtk_tree_model_iter_n_children (Handle, IntPtr.Zero);
|
||||||
|
|
|
@ -48,9 +48,6 @@ public void Delete (TextIter start, TextIter end )
|
||||||
}
|
}
|
||||||
|
|
||||||
// overload to paste clipboard contents at cursor editable by default.
|
// overload to paste clipboard contents at cursor editable by default.
|
||||||
[DllImport("libgtk-win32-2.0-0.dll")]
|
|
||||||
static extern void gtk_text_buffer_paste_clipboard (IntPtr raw, IntPtr clip, IntPtr iter, bool default_edit);
|
|
||||||
|
|
||||||
public void PasteClipboard (Gtk.Clipboard clipboard)
|
public void PasteClipboard (Gtk.Clipboard clipboard)
|
||||||
{
|
{
|
||||||
gtk_text_buffer_paste_clipboard(Handle, clipboard.Handle, IntPtr.Zero, true);
|
gtk_text_buffer_paste_clipboard(Handle, clipboard.Handle, IntPtr.Zero, true);
|
||||||
|
|
|
@ -6,8 +6,6 @@
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
[DllImport("libgtk-win32-2.0-0.dll")]
|
|
||||||
static extern int gtk_tree_model_iter_n_children (IntPtr raw, IntPtr iter);
|
|
||||||
public int IterNChildren () {
|
public int IterNChildren () {
|
||||||
int raw_ret = gtk_tree_model_iter_n_children (Handle, IntPtr.Zero);
|
int raw_ret = gtk_tree_model_iter_n_children (Handle, IntPtr.Zero);
|
||||||
int ret = raw_ret;
|
int ret = raw_ret;
|
||||||
|
|
|
@ -29,8 +29,6 @@
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
[DllImport("libgtk-win32-2.0-0.dll")]
|
|
||||||
static extern int gtk_tree_model_iter_n_children (IntPtr raw, IntPtr iter);
|
|
||||||
public int IterNChildren () {
|
public int IterNChildren () {
|
||||||
int raw_ret = gtk_tree_model_iter_n_children (Handle, IntPtr.Zero);
|
int raw_ret = gtk_tree_model_iter_n_children (Handle, IntPtr.Zero);
|
||||||
int ret = raw_ret;
|
int ret = raw_ret;
|
||||||
|
|
|
@ -201,8 +201,6 @@
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
[DllImport("libgtk-win32-2.0-0.dll")]
|
|
||||||
static extern int gtk_tree_model_iter_n_children (IntPtr raw, IntPtr iter);
|
|
||||||
public int IterNChildren () {
|
public int IterNChildren () {
|
||||||
int raw_ret = gtk_tree_model_iter_n_children (Handle, IntPtr.Zero);
|
int raw_ret = gtk_tree_model_iter_n_children (Handle, IntPtr.Zero);
|
||||||
int ret = raw_ret;
|
int ret = raw_ret;
|
||||||
|
|
|
@ -358,33 +358,21 @@ public Widget[] ListMnemonicLabels ()
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
[DllImport("libgtk-win32-2.0-0.dll")]
|
|
||||||
static extern void gtk_widget_modify_base (IntPtr raw, int state, IntPtr color);
|
|
||||||
|
|
||||||
public void ModifyBase (Gtk.StateType state)
|
public void ModifyBase (Gtk.StateType state)
|
||||||
{
|
{
|
||||||
gtk_widget_modify_base (Handle, (int) state, IntPtr.Zero);
|
gtk_widget_modify_base (Handle, (int) state, IntPtr.Zero);
|
||||||
}
|
}
|
||||||
|
|
||||||
[DllImport("libgtk-win32-2.0-0.dll")]
|
|
||||||
static extern void gtk_widget_modify_bg (IntPtr raw, int state, IntPtr color);
|
|
||||||
|
|
||||||
public void ModifyBg (Gtk.StateType state)
|
public void ModifyBg (Gtk.StateType state)
|
||||||
{
|
{
|
||||||
gtk_widget_modify_bg (Handle, (int) state, IntPtr.Zero);
|
gtk_widget_modify_bg (Handle, (int) state, IntPtr.Zero);
|
||||||
}
|
}
|
||||||
|
|
||||||
[DllImport("libgtk-win32-2.0-0.dll")]
|
|
||||||
static extern void gtk_widget_modify_fg (IntPtr raw, int state, IntPtr color);
|
|
||||||
|
|
||||||
public void ModifyFg (Gtk.StateType state)
|
public void ModifyFg (Gtk.StateType state)
|
||||||
{
|
{
|
||||||
gtk_widget_modify_fg (Handle, (int) state, IntPtr.Zero);
|
gtk_widget_modify_fg (Handle, (int) state, IntPtr.Zero);
|
||||||
}
|
}
|
||||||
|
|
||||||
[DllImport("libgtk-win32-2.0-0.dll")]
|
|
||||||
static extern void gtk_widget_modify_text (IntPtr raw, int state, IntPtr color);
|
|
||||||
|
|
||||||
public void ModifyText (Gtk.StateType state)
|
public void ModifyText (Gtk.StateType state)
|
||||||
{
|
{
|
||||||
gtk_widget_modify_text (Handle, (int) state, IntPtr.Zero);
|
gtk_widget_modify_text (Handle, (int) state, IntPtr.Zero);
|
||||||
|
|
Loading…
Reference in a new issue