[Gtk-sharp-list] some drag+drop fixups
Dan Winship
danw@novell.com
Mon, 18 Oct 2004 16:08:53 -0400
--=-9BITUyZJkZiCcN+BDwJz
Content-Type: text/plain
Content-Transfer-Encoding: 7bit
Updated/rototilled patch after talking with Mike...
--=-9BITUyZJkZiCcN+BDwJz
Content-Disposition: attachment; filename=drag.diff
Content-Type: text/x-patch; name=drag.diff; charset=utf-8
Content-Transfer-Encoding: 7bit
Index: ChangeLog
===================================================================
RCS file: /cvs/public/gtk-sharp/ChangeLog,v
retrieving revision 1.922
diff -u -r1.922 ChangeLog
--- ChangeLog 7 Oct 2004 15:44:00 -0000 1.922
+++ ChangeLog 18 Oct 2004 18:42:10 -0000
@@ -1,3 +1,20 @@
+2004-10-18 Dan Winship <danw@novell.com>
+
+ * generator/OpaqueGen.cs: Don't build the (IntPtr raw) constructor
+ if "disable_raw_ctor" is set on the opaque type.
+
+ * gtk/Gtk.metadata: Make GtkTargetList opaque (fixes a crash in
+ Gtk.Drag.Begin), hide the generated constructor and ref/unref
+ methods, and fix up the interpretation of AddTable.
+
+ * gtk/TargetList.custom (TargetList, ~TargetList): Implement the
+ suppressed constructors and add a finalizer, which handle
+ refcounting the underlying struct.
+ (Add, Find, Remove): convenience overloads that take string
+ instead of Gdk.Atom.
+
+ * gtk/Makefile.am (customs): add TargetList.custom
+
2004-10-07 Mike Kestner <mkestner@ximian.com>
* gdk/Makefile.am : add missing custom file.
Index: generator/OpaqueGen.cs
===================================================================
RCS file: /cvs/public/gtk-sharp/generator/OpaqueGen.cs,v
retrieving revision 1.9
diff -u -r1.9 OpaqueGen.cs
--- generator/OpaqueGen.cs 25 Jun 2004 16:35:15 -0000 1.9
+++ generator/OpaqueGen.cs 18 Oct 2004 18:42:10 -0000
@@ -42,6 +42,12 @@
return FromNative (var);
}
+ private bool DisableRawCtor {
+ get {
+ return Elem.HasAttribute ("disable_raw_ctor");
+ }
+ }
+
public void Generate ()
{
GenerationInfo gen_info = new GenerationInfo (NSElem);
@@ -91,8 +97,10 @@
protected override void GenCtors (GenerationInfo gen_info)
{
- gen_info.Writer.WriteLine("\t\tpublic " + Name + "(IntPtr raw) : base(raw) {}");
- gen_info.Writer.WriteLine();
+ if (!DisableRawCtor) {
+ gen_info.Writer.WriteLine("\t\tpublic " + Name + "(IntPtr raw) : base(raw) {}");
+ gen_info.Writer.WriteLine();
+ }
base.GenCtors (gen_info);
}
Index: gtk/Gtk.metadata
===================================================================
RCS file: /cvs/public/gtk-sharp/gtk/Gtk.metadata,v
retrieving revision 1.76
diff -u -r1.76 Gtk.metadata
--- gtk/Gtk.metadata 5 Oct 2004 14:09:05 -0000 1.76
+++ gtk/Gtk.metadata 18 Oct 2004 18:42:10 -0000
@@ -366,6 +366,13 @@
<attr path="/api/namespace/struct[@cname='GtkTableChild']" name="hidden">1</attr>
<attr path="/api/namespace/struct[@cname='GtkTableRowCol']" name="hidden">1</attr>
<attr path="/api/namespace/struct[@cname='GtkTargetEntry']/field[@cname='flags']" name="type">GtkTargetFlags</attr>
+ <attr path="/api/namespace/struct[@cname='GtkTargetList']" name="opaque">1</attr>
+ <attr path="/api/namespace/struct[@cname='GtkTargetList']" name="disable_raw_ctor">1</attr>
+ <attr path="/api/namespace/struct[@cname='GtkTargetList']/constructor[@cname='gtk_target_list_new']" name="hidden">1</attr>
+ <attr path="/api/namespace/struct[@cname='GtkTargetList']/method[@name='AddTable']/*/*[@name='targets']" name="array">1</attr>
+ <attr path="/api/namespace/struct[@cname='GtkTargetList']/method[@name='AddTable']/*/*[@name='ntargets']" name="name">n_targets</attr>
+ <attr path="/api/namespace/struct[@cname='GtkTargetList']/method[@name='Ref']" name="hidden">1</attr>
+ <attr path="/api/namespace/struct[@cname='GtkTargetList']/method[@name='Unref']" name="hidden">1</attr>
<attr path="/api/namespace/struct[@cname='GtkToolbarChild']" name="hidden">1</attr>
<attr path="/api/namespace/struct[@cname='GtkTreeDataList']" name="hidden">1</attr>
<attr path="/api/namespace/struct[@cname='GtkTreeDataSortHeader']" name="hidden">1</attr>
Index: gtk/Makefile.am
===================================================================
RCS file: /cvs/public/gtk-sharp/gtk/Makefile.am,v
retrieving revision 1.23
diff -u -r1.23 Makefile.am
--- gtk/Makefile.am 24 Sep 2004 15:58:05 -0000 1.23
+++ gtk/Makefile.am 18 Oct 2004 18:42:10 -0000
@@ -73,6 +73,7 @@
Style.custom \
Table.custom \
TargetEntry.custom \
+ TargetList.custom \
TextBuffer.custom \
TextChildAnchor.custom \
TextIter.custom \
Index: gtk/TargetList.custom
===================================================================
RCS file: gtk/TargetList.custom
diff -N gtk/TargetList.custom
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ gtk/TargetList.custom 18 Oct 2004 18:42:10 -0000
@@ -0,0 +1,50 @@
+// TargetList.custom - customizations for Gtk.TargetList
+//
+// Copyright (c) 2004 Novell, Inc.
+//
+// This program is free software; you can redistribute it and/or
+// modify it under the terms of version 2 of the Lesser 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
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser 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.
+
+ [DllImport("libgtk-win32-2.0-0.dll")]
+ static extern void gtk_target_list_ref(IntPtr raw);
+
+ public TargetList(IntPtr raw) : base(raw) {
+ gtk_target_list_ref(raw);
+ }
+
+ [DllImport("libgtk-win32-2.0-0.dll")]
+ static extern void gtk_target_list_unref(IntPtr raw);
+
+ ~TargetList() {
+ gtk_target_list_unref(Handle);
+ }
+
+ [DllImport("libgtk-win32-2.0-0.dll")]
+ static extern IntPtr gtk_target_list_new(Gtk.TargetEntry[] targets, uint n_targets);
+
+ public TargetList() : base(gtk_target_list_new(null, 0)) {}
+
+ public TargetList (Gtk.TargetEntry[] targets) : this(gtk_target_list_new(targets, (uint) targets.Length)) {}
+
+ public void Add(string target, uint flags, uint info) {
+ Add(Gdk.Atom.Intern (target, false), flags, info);
+ }
+
+ public bool Find(string target, out uint info) {
+ return Find(Gdk.Atom.Intern (target, false), out info);
+ }
+
+ public void Remove(string target) {
+ Remove(Gdk.Atom.Intern (target, false));
+ }
--=-9BITUyZJkZiCcN+BDwJz--