2004-11-17 16:00:00 +00:00
|
|
|
// GtkSharp.Generation.ReturnValue.cs - The ReturnValue Generatable.
|
|
|
|
//
|
|
|
|
// Author: Mike Kestner <mkestner@novell.com>
|
|
|
|
//
|
2005-06-23 22:28:06 +00:00
|
|
|
// Copyright (c) 2004-2005 Novell, Inc.
|
2004-11-17 16:00:00 +00:00
|
|
|
//
|
|
|
|
// 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.Xml;
|
|
|
|
|
|
|
|
public class ReturnValue {
|
2005-06-23 22:28:06 +00:00
|
|
|
|
2004-11-17 16:00:00 +00:00
|
|
|
|
2008-02-29 23:42:27 +00:00
|
|
|
bool is_null_term;
|
|
|
|
bool is_array;
|
|
|
|
bool elements_owned;
|
|
|
|
bool owned;
|
2011-04-28 23:38:07 +00:00
|
|
|
string array_length_param = String.Empty;
|
2008-02-29 23:42:27 +00:00
|
|
|
string ctype = String.Empty;
|
2009-09-23 21:27:15 +00:00
|
|
|
string default_value = String.Empty;
|
2008-02-29 23:42:27 +00:00
|
|
|
string element_ctype = String.Empty;
|
2011-04-28 23:38:07 +00:00
|
|
|
Parameter count_param;
|
2004-11-17 16:00:00 +00:00
|
|
|
|
|
|
|
public ReturnValue (XmlElement elem)
|
|
|
|
{
|
2008-02-29 23:42:27 +00:00
|
|
|
if (elem != null) {
|
2012-10-21 16:10:34 +00:00
|
|
|
is_null_term = elem.GetAttributeAsBoolean ("null_term_array");
|
|
|
|
is_array = elem.GetAttributeAsBoolean ("array") || elem.HasAttribute ("array_length_param");
|
2011-04-28 23:38:07 +00:00
|
|
|
array_length_param = elem.GetAttribute ("array_length_param");
|
2012-10-21 16:10:34 +00:00
|
|
|
elements_owned = elem.GetAttributeAsBoolean ("elements_owned");
|
|
|
|
owned = elem.GetAttributeAsBoolean ("owned");
|
2008-02-29 23:42:27 +00:00
|
|
|
ctype = elem.GetAttribute("type");
|
2009-09-23 21:27:15 +00:00
|
|
|
default_value = elem.GetAttribute ("default_value");
|
2008-02-29 23:42:27 +00:00
|
|
|
element_ctype = elem.GetAttribute ("element_type");
|
|
|
|
}
|
2004-11-17 16:00:00 +00:00
|
|
|
}
|
|
|
|
|
2011-04-28 23:38:07 +00:00
|
|
|
public Parameter CountParameter {
|
|
|
|
get { return count_param; }
|
|
|
|
set { count_param = value; }
|
|
|
|
}
|
|
|
|
|
|
|
|
public string CountParameterName {
|
|
|
|
get { return array_length_param; }
|
|
|
|
}
|
|
|
|
|
2004-11-17 16:00:00 +00:00
|
|
|
public string CType {
|
|
|
|
get {
|
2008-02-29 23:42:27 +00:00
|
|
|
return ctype;
|
2004-11-17 16:00:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public string CSType {
|
|
|
|
get {
|
2005-03-07 15:54:49 +00:00
|
|
|
if (IGen == null)
|
|
|
|
return String.Empty;
|
2005-06-08 16:53:12 +00:00
|
|
|
|
|
|
|
if (ElementType != String.Empty)
|
|
|
|
return ElementType + "[]";
|
|
|
|
|
2008-02-29 23:42:27 +00:00
|
|
|
return IGen.QualifiedName + (is_array || is_null_term ? "[]" : String.Empty);
|
2004-11-17 16:00:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-10-02 15:57:45 +00:00
|
|
|
public string DefaultValue {
|
|
|
|
get {
|
2009-09-23 21:27:15 +00:00
|
|
|
if (default_value != null && default_value.Length > 0)
|
|
|
|
return default_value;
|
2007-10-02 15:57:45 +00:00
|
|
|
if (IGen == null)
|
|
|
|
return String.Empty;
|
|
|
|
return IGen.DefaultValue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-03-07 15:54:49 +00:00
|
|
|
string ElementType {
|
2004-11-17 16:00:00 +00:00
|
|
|
get {
|
2008-02-29 23:42:27 +00:00
|
|
|
if (element_ctype.Length > 0)
|
|
|
|
return SymbolTable.Table.GetCSType (element_ctype);
|
2005-06-23 22:28:06 +00:00
|
|
|
|
|
|
|
return String.Empty;
|
2004-11-17 16:00:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-03-07 15:54:49 +00:00
|
|
|
IGeneratable igen;
|
2009-04-13 17:44:48 +00:00
|
|
|
public IGeneratable IGen {
|
2005-03-07 15:54:49 +00:00
|
|
|
get {
|
|
|
|
if (igen == null)
|
|
|
|
igen = SymbolTable.Table [CType];
|
|
|
|
return igen;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-03-04 16:02:44 +00:00
|
|
|
public bool IsVoid {
|
|
|
|
get {
|
|
|
|
return CSType == "void";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2004-11-17 16:00:00 +00:00
|
|
|
public string MarshalType {
|
|
|
|
get {
|
2005-03-07 15:54:49 +00:00
|
|
|
if (IGen == null)
|
|
|
|
return String.Empty;
|
2011-04-28 23:38:07 +00:00
|
|
|
else if (is_array || is_null_term)
|
2008-02-29 23:42:27 +00:00
|
|
|
return "IntPtr";
|
2011-04-28 23:38:07 +00:00
|
|
|
return IGen.MarshalType;
|
2005-01-19 02:58:42 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2004-11-17 16:00:00 +00:00
|
|
|
public string ToNativeType {
|
|
|
|
get {
|
2005-03-07 15:54:49 +00:00
|
|
|
if (IGen == null)
|
|
|
|
return String.Empty;
|
2009-08-13 14:46:33 +00:00
|
|
|
return IGen.MarshalType + (is_array || is_null_term ? "[]" : String.Empty);
|
2004-11-17 16:00:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-03-04 16:02:44 +00:00
|
|
|
public string FromNative (string var)
|
|
|
|
{
|
2005-03-07 15:54:49 +00:00
|
|
|
if (IGen == null)
|
|
|
|
return String.Empty;
|
2005-06-23 22:28:06 +00:00
|
|
|
|
|
|
|
if (ElementType != String.Empty) {
|
2008-08-20 19:48:26 +00:00
|
|
|
string args = (owned ? "true" : "false") + ", " + (elements_owned ? "true" : "false");
|
2008-11-04 20:17:00 +00:00
|
|
|
if (IGen.QualifiedName == "GLib.PtrArray")
|
|
|
|
return String.Format ("({0}[]) GLib.Marshaller.PtrArrayToArray ({1}, {2}, typeof({0}))", ElementType, var, args);
|
|
|
|
else
|
2009-01-08 18:43:00 +00:00
|
|
|
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);
|
2011-04-21 23:04:47 +00:00
|
|
|
} else if (IGen is IOwnable)
|
|
|
|
return ((IOwnable)IGen).FromNative (var, owned);
|
2008-02-29 23:42:27 +00:00
|
|
|
else if (is_null_term)
|
|
|
|
return String.Format ("GLib.Marshaller.NullTermPtrToStringArray ({0}, {1})", var, owned ? "true" : "false");
|
2011-04-28 23:38:07 +00:00
|
|
|
else if (is_array)
|
|
|
|
return String.Format ("({0}) GLib.Marshaller.ArrayPtrToArray ({1}, typeof ({2}), (int){3}native_{4}, true)", CSType, var, IGen.QualifiedName, CountParameter.CSType == "int" ? String.Empty : "(" + CountParameter.CSType + ")", CountParameter.Name);
|
Automatic memory management for opaque types [#49565]
* glib/Opaque.cs (Owned): new property saying whether or not gtk#
owns the memory.
(Opaque): Set Owned to true in the void ctor and false in the
IntPtr one.
(GetOpaque): add a new overload that can also create opaques, a la
GLib.Object.GetObject.
(Ref, Unref, Free): empty virtual methods to be overridden by
subclasses.
(set_Raw): Unref() and possibly Free() the old value, Ref() the
new one.
(~Opaque, Dispose): set Raw to IntPtr.Zero (triggering Free/Unref
if needed)
* parser/gapi2xml.pl (addReturnElem): if the method is named Copy
and returns a pointer, set the "owned" attribute on the
return-type.
* */*-api.raw: Regen
* generator/HandleBase.cs (FromNative): Add new
FromNative/FromNativeReturn overloads that takes a "bool owned"
param. Implement the 1-arg FromNative and FromNativeReturn in
terms of that.
* generator/ObjectBase.cs (FromNative): Implement HandleBase's new
overload. Use the two-arg version of GLib.Object.GetObject when
"owned" is true.
* generator/OpaqueGen.cs (Generate): Pull out Ref, Unref, and
Free/Destroy/Dispose methods and handle them specially by
overriding Opaque.Ref, .Unref, and .Free appropriately. (If any
of the methods are marked deprecated, output a deprecated
do-nothing method as well, to save us from having to write all
those deprecated methods by hand.)
(FromNative): use GetOpaque, passing "owned".
* generator/ReturnValue.cs (FromNative): if the value is a
HandleBase, pass Owned to its FromNative().
* generator/Parameters.cs (Owned): new property (for use on out
params)
(FromNative): Call FromNative() on the generatable, handling Owned
in the case of HandleBase.
* generator/ManagedCallString.cs:
* generator/MethodBody.cs:
* generator/Signal.cs: use param.FromNative() rather than
param.Generatable.FromNative(), to get ownership right.
* */*.metadata: Mark opaque ref/unref/free methods deprecated
(except where we were hiding them before). Add "owned" attributes
to return values and out params as needed.
* pango/AttrIterator.custom (GetFont): work around a
memory-management oddity of the underlying method.
* pango/AttrFontDesc.cs (AttrFontDesc): copy the passed-in
FontDescriptor, since the attribute will assume ownership of it.
* gtk/TreeView.custom (GetPathAtPos): set the "owned" flag on the
returned TreePaths.
* gtk/TargetList.custom: Remove refcounting stuff, which is
now handled automatically
* gtk/NodeStore.cs (GetPath): clear the Owned flag on the created
TreePath so that the underlying structure doesn't get freed when
the function returns
* gtkhtml/HTMLStream.custom (Destroy): hide this and then
reimplement it by hand to keep OpaqueGen from using it in
Dispose(), since calling it after an HTMLStream.Close() will
result in a crash.
svn path=/trunk/gtk-sharp/; revision=47928
2005-08-02 18:45:21 +00:00
|
|
|
else
|
2009-08-13 14:46:33 +00:00
|
|
|
return IGen.FromNative (var);
|
2005-03-04 16:02:44 +00:00
|
|
|
}
|
|
|
|
|
2007-09-11 20:34:24 +00:00
|
|
|
public string ToNative (string var)
|
|
|
|
{
|
|
|
|
if (IGen == null)
|
|
|
|
return String.Empty;
|
|
|
|
|
|
|
|
if (ElementType.Length > 0) {
|
2008-02-29 23:42:27 +00:00
|
|
|
string args = ", typeof (" + ElementType + "), " + (owned ? "true" : "false") + ", " + (elements_owned ? "true" : "false");
|
2007-09-11 20:34:24 +00:00
|
|
|
var = "new " + IGen.QualifiedName + "(" + var + args + ")";
|
2008-02-29 23:42:27 +00:00
|
|
|
} else if (is_null_term)
|
2009-05-06 16:20:35 +00:00
|
|
|
return String.Format ("GLib.Marshaller.StringArrayToNullTermPointer ({0})", var);
|
2011-04-28 23:38:07 +00:00
|
|
|
else if (is_array)
|
|
|
|
return String.Format ("GLib.Marshaller.ArrayToArrayPtr ({0})", var);
|
2007-09-11 20:34:24 +00:00
|
|
|
|
|
|
|
if (IGen is IManualMarshaler)
|
|
|
|
return (IGen as IManualMarshaler).AllocNative (var);
|
2008-04-04 16:10:08 +00:00
|
|
|
else if (IGen is ObjectGen && owned)
|
|
|
|
return var + " == null ? IntPtr.Zero : " + var + ".OwnedHandle";
|
2008-04-15 19:43:16 +00:00
|
|
|
else if (IGen is OpaqueGen && owned)
|
|
|
|
return var + " == null ? IntPtr.Zero : " + var + ".OwnedCopy";
|
2007-09-11 20:34:24 +00:00
|
|
|
else
|
2009-08-13 14:46:33 +00:00
|
|
|
return IGen.CallByName (var);
|
2007-09-11 20:34:24 +00:00
|
|
|
}
|
|
|
|
|
2011-02-20 18:11:08 +00:00
|
|
|
public bool Validate (LogWriter log)
|
2004-11-17 16:00:00 +00:00
|
|
|
{
|
|
|
|
if (MarshalType == "" || CSType == "") {
|
2011-02-20 18:11:08 +00:00
|
|
|
log.Warn ("Unknown return type: {0}", CType);
|
2004-11-17 16:00:00 +00:00
|
|
|
return false;
|
2011-02-20 18:11:08 +00:00
|
|
|
} else if ((CSType == "GLib.List" || CSType == "GLib.SList") && String.IsNullOrEmpty (ElementType))
|
|
|
|
log.Warn ("Returns {0} with unknown element type. Add element_type attribute with gapi-fixup.", CType);
|
2005-06-08 16:53:12 +00:00
|
|
|
|
2004-11-17 16:00:00 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|