2003-05-29 Rachel Hestilow <rachel@nullenvoid.com>

* gconf/Value.cs: Update to use new string marshalling.

	* generator/StringGen.cs, ConstStringGen.cs: Added.
	* generator/IGeneratable.cs: Add new method ToNativeReturn.
	* generator/CallbackGen.cs: Implement ToNativeReturn. Call
	ToNativeReturn for the return statement. Fix a couple of
	places where s_ret was being used incorrectly for m_ret.
	* generator/ClassGen.cs, EnumGen.cs, ManualGen.cs,
	SimpleGen.cs, StructBase.cs: Implement ToNativeReturn.
	* generator/SignalHandler.cs: Call ToNativeReturn for the
	return statement, instead of CallByName.
	* generator/SymbolTable.cs: Use StringGen for gchar, char,
	and gunichar, and ConstStringGen for their const variants.
	Add a new method wrapper for ToNativeReturn.
	(Trim): Add a special-case for const strings so that the
	const is not stripped. Otherwise there is no way of
	resolving the const case.

	* glade/XML.custom: Update to use new string marshalling.

	* glib/Marshaller.cs: Added.
	* glib/GException.cs, Markup.cs, ObjectManager.cs,
	Value.cs: Update to use new string marshalling.
	* glib/Object.cs: Remove old g_type_name DllImport
	as it is no longer used.

	* glue/fileselection.c (gtksharp_file_selection_get_fileop_entry):
	Mark this as const return.

	* gtk/ColorSelection.custom, FileSelection.custom,
	SelectionData.custom: Update to use new string marshalling.

svn path=/trunk/gtk-sharp/; revision=15286
This commit is contained in:
Rachel Hestilow 2003-06-10 18:09:47 +00:00
parent 948a75e5e4
commit fe699e9fbb
24 changed files with 224 additions and 36 deletions

View file

@ -1,3 +1,37 @@
2003-05-29 Rachel Hestilow <rachel@nullenvoid.com>
* gconf/Value.cs: Update to use new string marshalling.
* generator/StringGen.cs, ConstStringGen.cs: Added.
* generator/IGeneratable.cs: Add new method ToNativeReturn.
* generator/CallbackGen.cs: Implement ToNativeReturn. Call
ToNativeReturn for the return statement. Fix a couple of
places where s_ret was being used incorrectly for m_ret.
* generator/ClassGen.cs, EnumGen.cs, ManualGen.cs,
SimpleGen.cs, StructBase.cs: Implement ToNativeReturn.
* generator/SignalHandler.cs: Call ToNativeReturn for the
return statement, instead of CallByName.
* generator/SymbolTable.cs: Use StringGen for gchar, char,
and gunichar, and ConstStringGen for their const variants.
Add a new method wrapper for ToNativeReturn.
(Trim): Add a special-case for const strings so that the
const is not stripped. Otherwise there is no way of
resolving the const case.
* glade/XML.custom: Update to use new string marshalling.
* glib/Marshaller.cs: Added.
* glib/GException.cs, Markup.cs, ObjectManager.cs,
Value.cs: Update to use new string marshalling.
* glib/Object.cs: Remove old g_type_name DllImport
as it is no longer used.
* glue/fileselection.c (gtksharp_file_selection_get_fileop_entry):
Mark this as const return.
* gtk/ColorSelection.custom, FileSelection.custom,
SelectionData.custom: Update to use new string marshalling.
2003-06-07 Martin Willemoes Hansen <mwh@sysrq.dk> 2003-06-07 Martin Willemoes Hansen <mwh@sysrq.dk>
* generator/SymbolTable.cs: Added ulong * generator/SymbolTable.cs: Added ulong

View file

@ -88,7 +88,7 @@ namespace GConf
} }
[DllImport("gconf-2")] [DllImport("gconf-2")]
static extern string gconf_value_get_string (IntPtr value); static extern IntPtr gconf_value_get_string (IntPtr value);
[DllImport("gconf-2")] [DllImport("gconf-2")]
static extern int gconf_value_get_int (IntPtr value); static extern int gconf_value_get_int (IntPtr value);
@ -104,7 +104,7 @@ namespace GConf
switch (val_type) switch (val_type)
{ {
case ValueType.String: case ValueType.String:
return gconf_value_get_string (Raw); return Marshal.PtrToStringAnsi (gconf_value_get_string (Raw));
case ValueType.Int: case ValueType.Int:
return gconf_value_get_int (Raw); return gconf_value_get_int (Raw);
case ValueType.Float: case ValueType.Float:

View file

@ -49,6 +49,11 @@ namespace GtkSharp.Generation {
return FromNative (var); return FromNative (var);
} }
public virtual String ToNativeReturn(String var)
{
return CallByName (var);
}
public void GenWrapper (string ns) public void GenWrapper (string ns)
{ {
char sep = Path.DirectorySeparatorChar; char sep = Path.DirectorySeparatorChar;
@ -101,7 +106,7 @@ namespace GtkSharp.Generation {
} else if (ret_wrapper != null && (ret_wrapper is ObjectGen || ret_wrapper is OpaqueGen)) { } else if (ret_wrapper != null && (ret_wrapper is ObjectGen || ret_wrapper is OpaqueGen)) {
// Do nothing // Do nothing
} else if (!table.IsStruct (rettype) && !table.IsBoxed (rettype)) { } else if (!table.IsStruct (rettype) && !table.IsBoxed (rettype)) {
sw.WriteLine ("\t\tstatic {0} _dummy;", s_ret); sw.WriteLine ("\t\tstatic {0} _dummy;", m_ret);
} }
} }
@ -162,7 +167,7 @@ namespace GtkSharp.Generation {
else if (table.IsEnum (rettype)) else if (table.IsEnum (rettype))
sw.WriteLine ("return (int) {0};", invoke); sw.WriteLine ("return (int) {0};", invoke);
else else
sw.WriteLine ("return ({0}) {1};", s_ret, invoke); sw.WriteLine ("return ({0}) {1};", m_ret, table.ToNativeReturn (rettype, invoke));
} }
else else
sw.WriteLine (invoke + ";"); sw.WriteLine (invoke + ";");

View file

@ -142,6 +142,11 @@ namespace GtkSharp.Generation {
return FromNative (var); return FromNative (var);
} }
public virtual String ToNativeReturn(String var)
{
return CallByName (var);
}
protected void GenProperties (StreamWriter sw) protected void GenProperties (StreamWriter sw)
{ {
if (props == null) if (props == null)

View file

@ -0,0 +1,30 @@
// GtkSharp.Generation.ConstStringGen.cs - The Const String type Generatable.
//
// Author: Rachel Hestilow <rachel@nullenvoid.com>
//
// (c) 2003 Rachel Hestilow
namespace GtkSharp.Generation {
using System;
public class ConstStringGen : SimpleGen {
public ConstStringGen (string ctype) : base (ctype, "string")
{
}
public override String MarshalReturnType {
get
{
return "IntPtr";
}
}
public override String FromNativeReturn(String var)
{
return "Marshal.PtrToStringAnsi(" + var + ")";
}
}
}

View file

@ -42,6 +42,11 @@ namespace GtkSharp.Generation {
return FromNative (var); return FromNative (var);
} }
public virtual String ToNativeReturn(String var)
{
return CallByName (var);
}
public void Generate () public void Generate ()
{ {
if (!DoGenerate) if (!DoGenerate)

View file

@ -26,6 +26,8 @@ namespace GtkSharp.Generation {
String FromNativeReturn (String var); String FromNativeReturn (String var);
String ToNativeReturn (String var);
bool DoGenerate {get;set;} bool DoGenerate {get;set;}
void Generate (); void Generate ();

View file

@ -81,6 +81,11 @@ namespace GtkSharp.Generation {
return FromNative (var); return FromNative (var);
} }
public virtual String ToNativeReturn(String var)
{
return CallByName (var);
}
public bool DoGenerate { public bool DoGenerate {
get { get {
return false; return false;

View file

@ -162,7 +162,7 @@ namespace GtkSharp.Generation {
else else
sw.WriteLine ("\t\t\t\tthrow new Exception(\"args.RetVal unset in callback\");"); sw.WriteLine ("\t\t\t\tthrow new Exception(\"args.RetVal unset in callback\");");
sw.WriteLine("\t\t\treturn (" + p_ret + ") " + table.CallByName (retval, "((" + s_ret + ")args.RetVal)") + ";"); sw.WriteLine("\t\t\treturn (" + p_ret + ") " + table.ToNativeReturn (retval, "((" + s_ret + ")args.RetVal)") + ";");
} }
sw.WriteLine("\t\t}"); sw.WriteLine("\t\t}");
sw.WriteLine(); sw.WriteLine();

View file

@ -68,6 +68,11 @@ namespace GtkSharp.Generation {
return var; return var;
} }
public String ToNativeReturn(String var)
{
return var;
}
public bool DoGenerate { public bool DoGenerate {
get { get {
return false; return false;

28
generator/StringGen.cs Normal file
View file

@ -0,0 +1,28 @@
// GtkSharp.Generation.StringGen.cs - The String type Generatable.
//
// Author: Rachel Hestilow <rachel@nullenvoid.com>
//
// (c) 2003 Rachel Hestilow
namespace GtkSharp.Generation {
using System;
public class StringGen : ConstStringGen {
public StringGen (string ctype) : base (ctype)
{
}
public override String FromNativeReturn(String var)
{
return "GLibSharp.Marshaller.PtrToStringGFree(" + var + ")";
}
public override String ToNativeReturn(String var)
{
return "GLibSharp.Marshaller.StringToPtrGStrdup(" + var + ")";
}
}
}

View file

@ -81,6 +81,12 @@ namespace GtkSharp.Generation {
return QualifiedName + ".New (" + var + ")"; return QualifiedName + ".New (" + var + ")";
} }
public override String ToNativeReturn(String var)
{
// FIXME
return var;
}
bool IsBit (XmlElement field) bool IsBit (XmlElement field)
{ {
return (field.HasAttribute("bits") && (field.GetAttribute("bits") == "1")); return (field.HasAttribute("bits") && (field.GetAttribute("bits") == "1"));

View file

@ -39,9 +39,11 @@ namespace GtkSharp.Generation {
AddType (new SimpleGen ("gushort", "ushort")); AddType (new SimpleGen ("gushort", "ushort"));
AddType (new SimpleGen ("guint32", "uint")); AddType (new SimpleGen ("guint32", "uint"));
AddType (new SimpleGen ("guint64", "ulong")); AddType (new SimpleGen ("guint64", "ulong"));
AddType (new SimpleGen ("const-gchar", "string")); // Const returned strings must be generated
AddType (new SimpleGen ("const-char", "string")); // differently from memory-managed strings
AddType (new SimpleGen ("gchar", "string")); AddType (new ConstStringGen ("const-gchar"));
AddType (new ConstStringGen ("const-char"));
AddType (new StringGen ("gchar"));
AddType (new SimpleGen ("gfloat", "float")); AddType (new SimpleGen ("gfloat", "float"));
AddType (new SimpleGen ("gdouble", "double")); AddType (new SimpleGen ("gdouble", "double"));
AddType (new SimpleGen ("gint8", "sbyte")); AddType (new SimpleGen ("gint8", "sbyte"));
@ -58,10 +60,10 @@ namespace GtkSharp.Generation {
AddType (new SimpleGen ("gulong", "ulong")); AddType (new SimpleGen ("gulong", "ulong"));
AddType (new SimpleGen ("GQuark", "int")); AddType (new SimpleGen ("GQuark", "int"));
AddType (new SimpleGen ("int", "int")); AddType (new SimpleGen ("int", "int"));
AddType (new SimpleGen ("char", "string")); AddType (new StringGen ("char"));
AddType (new SimpleGen ("double", "double")); AddType (new SimpleGen ("double", "double"));
AddType (new SimpleGen ("float", "float")); AddType (new SimpleGen ("float", "float"));
AddType (new SimpleGen ("gunichar", "string")); AddType (new StringGen ("gunichar"));
AddType (new SimpleGen ("uint1", "bool")); AddType (new SimpleGen ("uint1", "bool"));
AddType (new SimpleGen ("GPtrArray", "IntPtr[]")); AddType (new SimpleGen ("GPtrArray", "IntPtr[]"));
AddType (new SimpleGen ("GType", "uint")); AddType (new SimpleGen ("GType", "uint"));
@ -128,6 +130,10 @@ namespace GtkSharp.Generation {
if (type == "void*" || type == "const-void*") return "gpointer"; if (type == "void*" || type == "const-void*") return "gpointer";
string trim_type = type.TrimEnd('*'); string trim_type = type.TrimEnd('*');
// HACK: Similar to above, but for const strings
if (trim_type == "const-gchar" || trim_type == "const-char") return trim_type;
if (trim_type.StartsWith("const-")) return trim_type.Substring(6); if (trim_type.StartsWith("const-")) return trim_type.Substring(6);
return trim_type; return trim_type;
} }
@ -148,6 +154,14 @@ namespace GtkSharp.Generation {
return ""; return "";
return gen.FromNativeReturn (val); 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)
{ {

View file

@ -23,14 +23,14 @@
} }
[DllImport("gtksharpglue")] [DllImport("gtksharpglue")]
static extern string gtksharp_glade_xml_get_filename (IntPtr raw); static extern IntPtr gtksharp_glade_xml_get_filename (IntPtr raw);
/// <summary>Filename Property</summary> /// <summary>Filename Property</summary>
/// <remarks>Gets the filename used to create this GladeXML object /// <remarks>Gets the filename used to create this GladeXML object
/// </remarks> /// </remarks>
public string Filename { public string Filename {
get { get {
string ret = gtksharp_glade_xml_get_filename (Handle); string ret = Marshal.PtrToStringAnsi (gtksharp_glade_xml_get_filename (Handle));
return ret; return ret;
} }
} }
@ -44,10 +44,10 @@
} }
[DllImport("libglade-2.0-0.dll")] [DllImport("libglade-2.0-0.dll")]
static extern string glade_get_widget_name (IntPtr widget); static extern IntPtr glade_get_widget_name (IntPtr widget);
static public string GetWidgetName (Gtk.Widget w) { static public string GetWidgetName (Gtk.Widget w) {
string ret = glade_get_widget_name (w.Handle); string ret = Marshal.PtrToStringAnsi (glade_get_widget_name (w.Handle));
return ret; return ret;
} }

View file

@ -19,10 +19,10 @@ namespace GLib {
} }
[DllImport("gtksharpglue")] [DllImport("gtksharpglue")]
static extern string gtksharp_error_get_message (IntPtr errptr); static extern IntPtr gtksharp_error_get_message (IntPtr errptr);
public override string Message { public override string Message {
get { get {
return gtksharp_error_get_message (errptr); return Marshal.PtrToStringAnsi (gtksharp_error_get_message (errptr));
} }
} }

View file

@ -14,14 +14,14 @@ namespace GLib {
public class Markup { public class Markup {
[DllImport("libglib-2.0-0.dll")] [DllImport("libglib-2.0-0.dll")]
static extern string g_markup_escape_text (string text, int len); static extern IntPtr g_markup_escape_text (string text, int len);
static public string EscapeText (string s) static public string EscapeText (string s)
{ {
if (s == null) if (s == null)
return ""; return "";
return g_markup_escape_text (s, s.Length); return GLibSharp.Marshaller.PtrToStringGFree (g_markup_escape_text (s, s.Length));
} }
} }
} }

52
glib/Marshaller.cs Normal file
View file

@ -0,0 +1,52 @@
// GLibSharp.Marshaller.cs : Marshalling utils
//
// Author: Rachel Hestilow <rachel@nullenvoid.com>
//
// (c) 2002, 2003 Rachel Hestilow
namespace GLibSharp {
using System;
using System.Runtime.InteropServices;
/// <summary>
/// Marshalling utilities
/// </summary>
///
/// <remarks>
/// Utility class for internal wrapper use
/// </remarks>
public class Marshaller {
[DllImport("libglib-2.0-0.dll")]
static extern void g_free (IntPtr mem);
public static string PtrToStringGFree (IntPtr ptr) {
string ret = Marshal.PtrToStringAnsi (ptr);
g_free (ptr);
return ret;
}
[DllImport("libglib-2.0-0.dll")]
static extern void g_strfreev (IntPtr mem);
public static string[] PtrToStringGFree (IntPtr[] ptrs) {
// The last pointer is a null terminator.
string[] ret = new string[ptrs.Length - 1];
for (int i = 0; i < ret.Length; i++) {
ret[i] = Marshal.PtrToStringAnsi (ptrs[i]);
g_free (ptrs[i]);
}
return ret;
}
[DllImport("libglib-2.0-0.dll")]
static extern IntPtr g_strdup (string str);
public static IntPtr StringToPtrGStrdup (string str) {
return g_strdup (str);
}
}
}

View file

@ -236,9 +236,6 @@ namespace GLib {
/// Handle property. /// Handle property.
/// </remarks> /// </remarks>
[DllImport("libgobject-2.0.so")]
private static extern string g_type_name (uint gtype);
protected virtual IntPtr Raw { protected virtual IntPtr Raw {
get { get {
return _obj; return _obj;

View file

@ -13,14 +13,14 @@ namespace GtkSharp {
private static Hashtable types = new Hashtable (); private static Hashtable types = new Hashtable ();
[DllImport("gtksharpglue")] [DllImport("gtksharpglue")]
static extern string gtksharp_get_type_name (IntPtr raw); static extern IntPtr gtksharp_get_type_name (IntPtr raw);
public static GLib.Object CreateObject (IntPtr raw) public static GLib.Object CreateObject (IntPtr raw)
{ {
if (raw == IntPtr.Zero) if (raw == IntPtr.Zero)
return null; return null;
string typename = gtksharp_get_type_name (raw); string typename = Marshal.PtrToStringAnsi (gtksharp_get_type_name (raw));
string mangled; string mangled;
if (types.ContainsKey(typename)) if (types.ContainsKey(typename))
mangled = (string)types[typename]; mangled = (string)types[typename];
@ -88,7 +88,7 @@ namespace GtkSharp {
static extern int gtksharp_get_parent_type (int typ); static extern int gtksharp_get_parent_type (int typ);
[DllImport("gtksharpglue")] [DllImport("gtksharpglue")]
static extern string gtksharp_get_type_name_for_id (int typ); static extern IntPtr gtksharp_get_type_name_for_id (int typ);
static Type GetValidParentType (IntPtr raw) static Type GetValidParentType (IntPtr raw)
{ {
@ -99,7 +99,7 @@ namespace GtkSharp {
// We will always end up at GObject and will break this loop // We will always end up at GObject and will break this loop
while (true) { while (true) {
type_id = gtksharp_get_parent_type (type_id); type_id = gtksharp_get_parent_type (type_id);
typename = gtksharp_get_type_name_for_id (type_id); typename = Marshal.PtrToStringAnsi (gtksharp_get_type_name_for_id (type_id));
if (types.ContainsKey (typename)) if (types.ContainsKey (typename))
mangled = (string)types[typename]; mangled = (string)types[typename];
else else

View file

@ -517,7 +517,7 @@ namespace GLib {
} }
[DllImport("libgobject-2.0-0.dll")] [DllImport("libgobject-2.0-0.dll")]
static extern string g_value_get_string (IntPtr val); static extern IntPtr g_value_get_string (IntPtr val);
/// <summary> /// <summary>
/// Value to String Conversion /// Value to String Conversion
@ -533,7 +533,7 @@ namespace GLib {
{ {
// FIXME: Insert an appropriate exception here if // FIXME: Insert an appropriate exception here if
// _val.type indicates an error. // _val.type indicates an error.
return g_value_get_string (val._val); return Marshal.PtrToStringAnsi (g_value_get_string (val._val));
} }
[DllImport("libgobject-2.0-0.dll")] [DllImport("libgobject-2.0-0.dll")]

View file

@ -32,7 +32,7 @@ GtkWidget *gtksharp_file_selection_get_fileop_dialog (GtkFileSelection *file);
GtkWidget *gtksharp_file_selection_get_fileop_entry (GtkFileSelection *file); GtkWidget *gtksharp_file_selection_get_fileop_entry (GtkFileSelection *file);
gchar *gtksharp_file_selection_get_fileop_file (GtkFileSelection *file); const gchar *gtksharp_file_selection_get_fileop_file (GtkFileSelection *file);
GtkWidget *gtksharp_file_selection_get_fileop_c_dir (GtkFileSelection *file); GtkWidget *gtksharp_file_selection_get_fileop_c_dir (GtkFileSelection *file);
@ -117,7 +117,7 @@ gtksharp_file_selection_get_fileop_entry (GtkFileSelection *file)
return file->fileop_entry; return file->fileop_entry;
} }
gchar* const gchar*
gtksharp_file_selection_get_fileop_file (GtkFileSelection *file) gtksharp_file_selection_get_fileop_file (GtkFileSelection *file)
{ {
return file->fileop_file; return file->fileop_file;

View file

@ -3,13 +3,13 @@
// Author: Justin Malcolm // Author: Justin Malcolm
[DllImport("libgtk-win32-2.0-0.dll")] [DllImport("libgtk-win32-2.0-0.dll")]
static extern string gtk_color_selection_palette_to_string(Gdk.Color[] colors, int n_colors); static extern IntPtr gtk_color_selection_palette_to_string(Gdk.Color[] colors, int n_colors);
/// <summary> PaletteToString Method </summary> /// <summary> PaletteToString Method </summary>
public static string PaletteToString(Gdk.Color[] colors) { public static string PaletteToString(Gdk.Color[] colors) {
int n_colors = colors.Length; int n_colors = colors.Length;
string raw_ret = gtk_color_selection_palette_to_string(colors, n_colors); IntPtr raw_ret = gtk_color_selection_palette_to_string(colors, n_colors);
string ret = raw_ret; string ret = GLibSharp.Marshaller.PtrToStringGFree (raw_ret);
return ret; return ret;
} }

View file

@ -88,10 +88,10 @@ public Gtk.Entry FileopEntry {
} }
[DllImport("gtksharpglue", CallingConvention=CallingConvention.Cdecl)] [DllImport("gtksharpglue", CallingConvention=CallingConvention.Cdecl)]
static extern string gtksharp_file_selection_get_fileop_file (IntPtr i); static extern IntPtr gtksharp_file_selection_get_fileop_file (IntPtr i);
public string FileopFile { public string FileopFile {
get { get {
return gtksharp_file_selection_get_fileop_file (this.Handle); return Marshal.PtrToStringAnsi (gtksharp_file_selection_get_fileop_file (this.Handle));
} }
} }

View file

@ -1,13 +1,13 @@
[DllImport("libgtk-win32-2.0-0.dll")] [DllImport("libgtk-win32-2.0-0.dll")]
private static extern string gtk_selection_data_get_text (ref Gtk.SelectionData selection_data); private static extern IntPtr gtk_selection_data_get_text (ref Gtk.SelectionData selection_data);
[DllImport("libgtk-win32-2.0-0.dll")] [DllImport("libgtk-win32-2.0-0.dll")]
private static extern void gtk_selection_data_set_text (ref Gtk.SelectionData selection_data, string str, int len); private static extern void gtk_selection_data_set_text (ref Gtk.SelectionData selection_data, string str, int len);
public string Text { public string Text {
get { get {
return gtk_selection_data_get_text (ref this); return GLibSharp.Marshaller.PtrToStringGFree (gtk_selection_data_get_text (ref this));
} }
set { set {
gtk_selection_data_set_text (ref this, value, value.Length); gtk_selection_data_set_text (ref this, value, value.Length);