b6d7f14268
* generator/CodeGenerator.cs: add a --glue-includes flag * generator/GenerationInfo.cs: Accept glue_includes value from Main and output it to the glue_filename. * generator/FieldBase.cs (Ignored): handle more ignorable cases. (CheckGlue): New method to figure out what kind of glue we'll need for a field. (GenerateImports): generate appropriate imports per CheckGlue. (GenerateGlue): Generate C glue for accessing a struct field; either a fully-C-based accessor, or a method to just return the field's offset in the struct. (Generate): Use the generated glue to read the field. * generator/PropertyBase.cs (CType): if the field is a single bit, set its type to gboolean. * generator/ObjectGen.cs (Generate): * generator/OpaqueGen.cs (Generate): Call GenFields. * generator/StructField.cs: Use FieldBase's glue-generation code to handle bitfields. [#54489] * generator/ObjectField.cs: Generates accessors for public fields of objects and opaque structs. [#69514] * generator/ClassBase.cs (ClassBase): Parse <fields> nodes and create ObjectField objects. (GenFields): Output field properties (IgnoreMethod): Ignore Get/Set methods that duplicate fields * generator/Makefile.am (sources): update * {gdk,gnome,gtk,pango}/*.metadata: Mark some additional fields as public. Rename/retype some fields for consistency with earlier hand-coded bindings. * {gdk,gnome,gtk,pango}/*.custom: Remove custom methods that can now be autogenerated. * {gdk,gnome,gtk,pango}/glue/*.c: Remove glue methods that can now be autogenerated * {gdk,glade,gnome,gtk,pango,vte}/Makefile.am * {gdk,glade,gnome,gtk,pango,vte}/glue/Makefile.am * {gdk,gnome,gtk,pango}/glue/makefile.win32: Update svn path=/trunk/gtk-sharp/; revision=44563
67 lines
2.3 KiB
Text
67 lines
2.3 KiB
Text
//
|
|
// Gtk.Dialog.custom - Gtk Dialog class customizations
|
|
//
|
|
// Author: Duncan Mak (duncan@ximian.com)
|
|
// Mike Kestner (mkestner@speakeasy.net)
|
|
//
|
|
// Copyright (C) 2002 Ximian, Inc. and Mike Kestner
|
|
//
|
|
// This code is inserted after the automatically generated code.
|
|
//
|
|
//
|
|
// 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 IntPtr gtk_dialog_new_with_buttons (IntPtr title, IntPtr i, int flags, IntPtr dummy);
|
|
public Dialog (string title, Gtk.Window parent, Gtk.DialogFlags flags, params object[] button_data) : base(IntPtr.Zero)
|
|
{
|
|
if (GetType() != typeof (Dialog)) {
|
|
GLib.Value[] vals = new GLib.Value [1];
|
|
string[] names = new string [1];
|
|
names [0] = "title";
|
|
vals [0] = new GLib.Value (title);
|
|
CreateNativeObject (names, vals);
|
|
TransientFor = parent;
|
|
if ((flags & DialogFlags.Modal) > 0)
|
|
Modal = true;
|
|
if ((flags & DialogFlags.DestroyWithParent) > 0)
|
|
DestroyWithParent = true;
|
|
if ((flags & DialogFlags.NoSeparator) > 0)
|
|
HasSeparator = false;
|
|
} else {
|
|
IntPtr native = GLib.Marshaller.StringToPtrGStrdup (title);
|
|
Raw = gtk_dialog_new_with_buttons (native, parent.Handle, (int) flags, IntPtr.Zero);
|
|
GLib.Marshaller.Free (native);
|
|
}
|
|
|
|
for (int i = 0; i < button_data.Length - 1; i += 2)
|
|
AddButton ((string) button_data [i], (int) button_data [i + 1]);
|
|
}
|
|
|
|
public void AddActionWidget (Widget child, ResponseType response)
|
|
{
|
|
this.AddActionWidget (child, (int) response);
|
|
}
|
|
|
|
public Gtk.Widget AddButton (string button_text, ResponseType response)
|
|
{
|
|
return this.AddButton (button_text, (int) response);
|
|
}
|
|
|
|
public void Respond (ResponseType response)
|
|
{
|
|
this.Respond ((int) response);
|
|
}
|