mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-17 12:55:53 +00:00
Add hack to the codegenerator to handle "owned-in-call-scope" functionality to virtual methods
This is needed for things like BaseTransform.OnTransformIp's buffer parameter. During the call we own the reference but not afterwards.
This commit is contained in:
parent
108a304f7a
commit
c751dcaf07
1 changed files with 23 additions and 6 deletions
|
@ -50,12 +50,15 @@ namespace GtkSharp.Generation {
|
||||||
error_param = p.Name;
|
error_param = p.Name;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.parms.Add (p);
|
this.parms.Add (p);
|
||||||
|
|
||||||
if (p.PassAs != String.Empty && (p.Name != p.FromNative (p.Name)))
|
if (p.PassAs != String.Empty && (p.Name != p.FromNative (p.Name)))
|
||||||
this.special.Add (true);
|
this.special.Add (true);
|
||||||
else if (p.Generatable is CallbackGen)
|
else if (p.Generatable is CallbackGen)
|
||||||
this.special.Add (true);
|
this.special.Add (true);
|
||||||
|
else if (p.Scope == "call")
|
||||||
|
this.special.Add (true);
|
||||||
else
|
else
|
||||||
this.special.Add (false);
|
this.special.Add (false);
|
||||||
}
|
}
|
||||||
|
@ -96,6 +99,11 @@ namespace GtkSharp.Generation {
|
||||||
ret += indent + String.Format ("{0} {1}_invoker = new {0} ({1}, {2});\n", (igen as CallbackGen).InvokerName, p.Name, user_data_param);
|
ret += indent + String.Format ("{0} {1}_invoker = new {0} ({1}, {2});\n", (igen as CallbackGen).InvokerName, p.Name, user_data_param);
|
||||||
else
|
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);
|
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 {
|
} else {
|
||||||
ret += indent + igen.QualifiedName + " my" + p.Name;
|
ret += indent + igen.QualifiedName + " my" + p.Name;
|
||||||
if (p.PassAs == "ref")
|
if (p.PassAs == "ref")
|
||||||
|
@ -137,16 +145,25 @@ namespace GtkSharp.Generation {
|
||||||
Parameter p = parms [i] as Parameter;
|
Parameter p = parms [i] as Parameter;
|
||||||
IGeneratable igen = p.Generatable;
|
IGeneratable igen = p.Generatable;
|
||||||
|
|
||||||
if (igen is CallbackGen)
|
if (igen is CallbackGen) {
|
||||||
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)
|
} else if (igen is IManualMarshaler) {
|
||||||
ret += String.Format ("{0}{1} = {2};", indent, p.Name, (igen as IManualMarshaler).AllocNative ("my" + p.Name));
|
ret += String.Format ("{0}{1} = {2};", indent, p.Name, (igen as IManualMarshaler).AllocNative ("my" + p.Name));
|
||||||
else
|
} else if (p.Scope == "call") {
|
||||||
ret += indent + p.Name + " = " + igen.CallByName ("my" + p.Name) + ";\n";
|
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;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue