mirror of
https://github.com/Ryujinx/GtkSharp.git
synced 2025-01-11 09:25:30 +00:00
2002-01-11 Mike Kestner <mkestner@speakeasy.net>
* generator/ObjectGen.cs : Add property generation. * generator/SymbolTable.cs : More fixage to simple_types. Add GetMarshalType and IsObject methods. * glib/Object.cs : Rename Events prop to EventList to avoid name collision. Add float, double, uint, and IntPtr GetProp and SetProp methods. * parser/TODO : Add a couple prop related bugs to come back for. * parser/gapi2xml.pl (addPropElems): Restructure. It was thoroughly broken. It's better now. svn path=/trunk/gtk-sharp/; revision=1960
This commit is contained in:
parent
d828b8ce59
commit
9fcf82d28e
14
ChangeLog
14
ChangeLog
|
@ -1,4 +1,16 @@
|
||||||
2002-01-08 Mike Kestner <mkestner@speakeasy.net>
|
2002-01-11 Mike Kestner <mkestner@speakeasy.net>
|
||||||
|
|
||||||
|
* generator/ObjectGen.cs : Add property generation.
|
||||||
|
* generator/SymbolTable.cs : More fixage to simple_types. Add
|
||||||
|
GetMarshalType and IsObject methods.
|
||||||
|
* glib/Object.cs : Rename Events prop to EventList to avoid name
|
||||||
|
collision. Add float, double, uint, and IntPtr GetProp and SetProp
|
||||||
|
methods.
|
||||||
|
* parser/TODO : Add a couple prop related bugs to come back for.
|
||||||
|
* parser/gapi2xml.pl (addPropElems): Restructure. It was thoroughly
|
||||||
|
broken. It's better now.
|
||||||
|
|
||||||
|
2002-01-10 Mike Kestner <mkestner@speakeasy.net>
|
||||||
|
|
||||||
* generator/StructBase.cs (GenField): Return a bool success indicator.
|
* generator/StructBase.cs (GenField): Return a bool success indicator.
|
||||||
* generator/ObjectGen.cs : Check the return of GenField.
|
* generator/ObjectGen.cs : Check the return of GenField.
|
||||||
|
|
|
@ -101,6 +101,9 @@ namespace GtkSharp.Generation {
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "property":
|
case "property":
|
||||||
|
if (!GenProperty(member, table, sw)) {
|
||||||
|
Console.WriteLine("in object " + CName);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "signal":
|
case "signal":
|
||||||
|
@ -120,6 +123,62 @@ namespace GtkSharp.Generation {
|
||||||
sw.Flush();
|
sw.Flush();
|
||||||
sw.Close();
|
sw.Close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public bool GenProperty (XmlElement prop, SymbolTable table, StreamWriter sw)
|
||||||
|
{
|
||||||
|
String c_type = prop.GetAttribute("type");
|
||||||
|
|
||||||
|
char[] ast = {'*'};
|
||||||
|
c_type = c_type.TrimEnd(ast);
|
||||||
|
String cs_type = table.GetCSType(c_type);
|
||||||
|
String m_type;
|
||||||
|
|
||||||
|
if (table.IsObject(c_type)) {
|
||||||
|
m_type = "GLib.Object";
|
||||||
|
} else {
|
||||||
|
m_type = table.GetMarshalType(c_type);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((cs_type == "") || (m_type == "")) {
|
||||||
|
Console.Write("Property has unknown Type {0} ", c_type);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (prop.HasAttribute("construct-only") && !prop.HasAttribute("readable")) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
XmlElement parent = (XmlElement) prop.ParentNode;
|
||||||
|
String name = prop.GetAttribute("name");
|
||||||
|
if (name == parent.GetAttribute("name")) {
|
||||||
|
name += "Prop";
|
||||||
|
}
|
||||||
|
|
||||||
|
sw.WriteLine("\t\tpublic " + cs_type + " " + name + " {");
|
||||||
|
if (prop.HasAttribute("readable")) {
|
||||||
|
sw.WriteLine("\t\t\tget {");
|
||||||
|
sw.WriteLine("\t\t\t\t" + m_type + " val;");
|
||||||
|
sw.WriteLine("\t\t\t\tGetProperty(\"" + prop.GetAttribute("cname") + "\", out val);");
|
||||||
|
sw.Write("\t\t\t\treturn ");
|
||||||
|
if (cs_type != m_type) {
|
||||||
|
sw.Write("(" + cs_type + ") ");
|
||||||
|
}
|
||||||
|
sw.WriteLine("val;");
|
||||||
|
sw.WriteLine("\t\t\t}");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (prop.HasAttribute("writeable") && !prop.HasAttribute("construct-only")) {
|
||||||
|
sw.WriteLine("\t\t\tset {");
|
||||||
|
sw.WriteLine("\t\t\t\tSetProperty(\"" + prop.GetAttribute("cname") + "\", (" + m_type + ") value);");
|
||||||
|
sw.WriteLine("\t\t\t}");
|
||||||
|
}
|
||||||
|
|
||||||
|
sw.WriteLine("\t\t}");
|
||||||
|
sw.WriteLine();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -44,6 +44,7 @@ namespace GtkSharp.Generation {
|
||||||
simple_types.Add ("int", "int");
|
simple_types.Add ("int", "int");
|
||||||
simple_types.Add ("char", "char");
|
simple_types.Add ("char", "char");
|
||||||
simple_types.Add ("double", "double");
|
simple_types.Add ("double", "double");
|
||||||
|
simple_types.Add ("float", "float");
|
||||||
simple_types.Add ("gunichar", "String");
|
simple_types.Add ("gunichar", "String");
|
||||||
simple_types.Add ("uint1", "bool");
|
simple_types.Add ("uint1", "bool");
|
||||||
simple_types.Add ("GPtrArray", "IntPtr[]");
|
simple_types.Add ("GPtrArray", "IntPtr[]");
|
||||||
|
@ -75,15 +76,15 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public IDictionaryEnumerator GetEnumerator ()
|
public IDictionaryEnumerator GetEnumerator()
|
||||||
{
|
{
|
||||||
return complex_types.GetEnumerator();
|
return complex_types.GetEnumerator();
|
||||||
}
|
}
|
||||||
|
|
||||||
public String GetCSType (String c_type)
|
public String GetCSType(String c_type)
|
||||||
{
|
{
|
||||||
if (simple_types.ContainsKey(c_type)) {
|
if (simple_types.ContainsKey(c_type)) {
|
||||||
return (String) simple_types [c_type];
|
return (String) simple_types[c_type];
|
||||||
} else if (complex_types.ContainsKey(c_type)) {
|
} else if (complex_types.ContainsKey(c_type)) {
|
||||||
IGeneratable gen = (IGeneratable) complex_types[c_type];
|
IGeneratable gen = (IGeneratable) complex_types[c_type];
|
||||||
return gen.QualifiedName;
|
return gen.QualifiedName;
|
||||||
|
@ -92,6 +93,29 @@ namespace GtkSharp.Generation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String GetMarshalType(String c_type)
|
||||||
|
{
|
||||||
|
if (simple_types.ContainsKey(c_type)) {
|
||||||
|
return (String) simple_types[c_type];
|
||||||
|
} else if (complex_types.ContainsKey(c_type)) {
|
||||||
|
IGeneratable gen = (IGeneratable) complex_types[c_type];
|
||||||
|
return gen.MarshalType;
|
||||||
|
} else {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool IsObject(String c_type)
|
||||||
|
{
|
||||||
|
if (complex_types.ContainsKey(c_type)) {
|
||||||
|
IGeneratable gen = (IGeneratable) complex_types[c_type];
|
||||||
|
if (gen is ObjectGen) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
File diff suppressed because one or more lines are too long
157
glib/Object.cs
157
glib/Object.cs
|
@ -90,7 +90,7 @@ namespace GLib {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Events Property
|
/// EventList Property
|
||||||
/// </summary>
|
/// </summary>
|
||||||
///
|
///
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
|
@ -98,7 +98,7 @@ namespace GLib {
|
||||||
/// object indexed by the Gtk+ signal name.
|
/// object indexed by the Gtk+ signal name.
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
|
|
||||||
protected EventHandlerList Events {
|
protected EventHandlerList EventList {
|
||||||
get {
|
get {
|
||||||
if (_events == null)
|
if (_events == null)
|
||||||
_events = new EventHandlerList ();
|
_events = new EventHandlerList ();
|
||||||
|
@ -209,6 +209,46 @@ namespace GLib {
|
||||||
out val, new IntPtr (0));
|
out val, new IntPtr (0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// GetProperty Method
|
||||||
|
/// </summary>
|
||||||
|
///
|
||||||
|
/// <remarks>
|
||||||
|
/// Accesses a double Property.
|
||||||
|
/// </remarks>
|
||||||
|
|
||||||
|
[DllImport("gobject-1.3.dll", CharSet=CharSet.Ansi,
|
||||||
|
CallingConvention=CallingConvention.Cdecl)]
|
||||||
|
static extern void g_object_get (IntPtr obj, IntPtr name,
|
||||||
|
out double val, IntPtr term);
|
||||||
|
|
||||||
|
public void GetProperty (String name, out double val)
|
||||||
|
{
|
||||||
|
g_object_get (RawObject,
|
||||||
|
Marshal.StringToHGlobalAnsi (name),
|
||||||
|
out val, new IntPtr (0));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// GetProperty Method
|
||||||
|
/// </summary>
|
||||||
|
///
|
||||||
|
/// <remarks>
|
||||||
|
/// Accesses a float Property.
|
||||||
|
/// </remarks>
|
||||||
|
|
||||||
|
[DllImport("gobject-1.3.dll", CharSet=CharSet.Ansi,
|
||||||
|
CallingConvention=CallingConvention.Cdecl)]
|
||||||
|
static extern void g_object_get (IntPtr obj, IntPtr name,
|
||||||
|
out float val, IntPtr term);
|
||||||
|
|
||||||
|
public void GetProperty (String name, out float val)
|
||||||
|
{
|
||||||
|
g_object_get (RawObject,
|
||||||
|
Marshal.StringToHGlobalAnsi (name),
|
||||||
|
out val, new IntPtr (0));
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// GetProperty Method
|
/// GetProperty Method
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -229,6 +269,26 @@ namespace GLib {
|
||||||
out val, new IntPtr (0));
|
out val, new IntPtr (0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// GetProperty Method
|
||||||
|
/// </summary>
|
||||||
|
///
|
||||||
|
/// <remarks>
|
||||||
|
/// Accesses an unsigned integer Property.
|
||||||
|
/// </remarks>
|
||||||
|
|
||||||
|
[DllImport("gobject-1.3.dll", CharSet=CharSet.Ansi,
|
||||||
|
CallingConvention=CallingConvention.Cdecl)]
|
||||||
|
static extern void g_object_get (IntPtr obj, IntPtr name,
|
||||||
|
out uint val, IntPtr term);
|
||||||
|
|
||||||
|
public void GetProperty (String name, out uint val)
|
||||||
|
{
|
||||||
|
g_object_get (RawObject,
|
||||||
|
Marshal.StringToHGlobalAnsi (name),
|
||||||
|
out val, new IntPtr (0));
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// GetProperty Method
|
/// GetProperty Method
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -246,6 +306,24 @@ namespace GLib {
|
||||||
val = GLib.Object.GetObject (obj);
|
val = GLib.Object.GetObject (obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// GetProperty Method
|
||||||
|
/// </summary>
|
||||||
|
///
|
||||||
|
/// <remarks>
|
||||||
|
/// Accesses an IntPtr Property.
|
||||||
|
/// </remarks>
|
||||||
|
|
||||||
|
public void GetProperty (String name, out IntPtr val)
|
||||||
|
{
|
||||||
|
g_object_get (RawObject,
|
||||||
|
Marshal.StringToHGlobalAnsi (name),
|
||||||
|
out val, new IntPtr (0));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// SetProperty Method
|
||||||
|
/// </summary>
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// SetProperty Method
|
/// SetProperty Method
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -287,6 +365,26 @@ namespace GLib {
|
||||||
val, new IntPtr (0));
|
val, new IntPtr (0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// SetProperty Method
|
||||||
|
/// </summary>
|
||||||
|
///
|
||||||
|
/// <remarks>
|
||||||
|
/// Changes the value of an unsigned integer Property.
|
||||||
|
/// </remarks>
|
||||||
|
|
||||||
|
[DllImport("gobject-1.3.dll", CharSet=CharSet.Ansi,
|
||||||
|
CallingConvention=CallingConvention.Cdecl)]
|
||||||
|
static extern void g_object_set (IntPtr obj, IntPtr name,
|
||||||
|
uint val, IntPtr term);
|
||||||
|
|
||||||
|
public void SetProperty (String name, uint val)
|
||||||
|
{
|
||||||
|
g_object_set (RawObject,
|
||||||
|
Marshal.StringToHGlobalAnsi (name),
|
||||||
|
val, new IntPtr (0));
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// SetProperty Method
|
/// SetProperty Method
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -307,6 +405,61 @@ namespace GLib {
|
||||||
val, new IntPtr (0));
|
val, new IntPtr (0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// SetProperty Method
|
||||||
|
/// </summary>
|
||||||
|
///
|
||||||
|
/// <remarks>
|
||||||
|
/// Changes the value of a double Property.
|
||||||
|
/// </remarks>
|
||||||
|
|
||||||
|
[DllImport("gobject-1.3.dll", CharSet=CharSet.Ansi,
|
||||||
|
CallingConvention=CallingConvention.Cdecl)]
|
||||||
|
static extern void g_object_set (IntPtr obj, IntPtr name,
|
||||||
|
double val, IntPtr term);
|
||||||
|
|
||||||
|
public void SetProperty (String name, double val)
|
||||||
|
{
|
||||||
|
g_object_set (RawObject,
|
||||||
|
Marshal.StringToHGlobalAnsi (name),
|
||||||
|
val, new IntPtr (0));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// SetProperty Method
|
||||||
|
/// </summary>
|
||||||
|
///
|
||||||
|
/// <remarks>
|
||||||
|
/// Changes the value of a float Property.
|
||||||
|
/// </remarks>
|
||||||
|
|
||||||
|
[DllImport("gobject-1.3.dll", CharSet=CharSet.Ansi,
|
||||||
|
CallingConvention=CallingConvention.Cdecl)]
|
||||||
|
static extern void g_object_set (IntPtr obj, IntPtr name,
|
||||||
|
float val, IntPtr term);
|
||||||
|
|
||||||
|
public void SetProperty (String name, float val)
|
||||||
|
{
|
||||||
|
g_object_set (RawObject,
|
||||||
|
Marshal.StringToHGlobalAnsi (name),
|
||||||
|
val, new IntPtr (0));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// SetProperty Method
|
||||||
|
/// </summary>
|
||||||
|
///
|
||||||
|
/// <remarks>
|
||||||
|
/// Changes the value of an IntPtr Property.
|
||||||
|
/// </remarks>
|
||||||
|
|
||||||
|
public void SetProperty (String name, IntPtr val)
|
||||||
|
{
|
||||||
|
g_object_set (RawObject,
|
||||||
|
Marshal.StringToHGlobalAnsi (name),
|
||||||
|
val, new IntPtr (0));
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// SetProperty Method
|
/// SetProperty Method
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
464
gtk/Button.cs
464
gtk/Button.cs
|
@ -1,464 +0,0 @@
|
||||||
// GTK.Button.cs - GTK Button class implementation
|
|
||||||
//
|
|
||||||
// Authors: Bob Smith <bob@thestuff.net>
|
|
||||||
// Mike Kestner <mkestner@speakeasy.net>
|
|
||||||
//
|
|
||||||
// (c) 2001 Bob Smith and Mike Kestner
|
|
||||||
|
|
||||||
namespace Gtk {
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections;
|
|
||||||
using System.Runtime.InteropServices;
|
|
||||||
using GLib;
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Button Class
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// A Button user interface element.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
public class Button : Widget {
|
|
||||||
|
|
||||||
private Hashtable Signals = new Hashtable ();
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Button Constructor
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Constructs a Button with no label.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3.dll", CharSet=CharSet.Ansi,
|
|
||||||
CallingConvention=CallingConvention.Cdecl)]
|
|
||||||
static extern IntPtr gtk_button_new ();
|
|
||||||
|
|
||||||
public Button ()
|
|
||||||
{
|
|
||||||
RawObject = gtk_button_new ();
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Button Object Constructor
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Constructs a Button Wrapper from a raw object. This
|
|
||||||
/// constructor is primarily used internally by gtk-sharp,
|
|
||||||
/// but could conceivably be called by an application if
|
|
||||||
/// the need to wrap a raw button object presents itself.
|
|
||||||
/// </remarks>
|
|
||||||
///
|
|
||||||
/// <param name="obj">
|
|
||||||
/// Raw object reference from the native library.
|
|
||||||
/// </param>
|
|
||||||
|
|
||||||
public Button (IntPtr obj)
|
|
||||||
{
|
|
||||||
RawObject = obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Button Constructor
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Constructs a new Button with the specified label.
|
|
||||||
/// Note, that underlines in the label provided will
|
|
||||||
/// be converted into mnemonics and the label will be
|
|
||||||
/// interpreted as a stock system identifier if possible.
|
|
||||||
/// If this behavior is not desired, more control can be
|
|
||||||
/// obtained with an overloaded constructor.
|
|
||||||
/// </remarks>
|
|
||||||
///
|
|
||||||
/// <param name="label">
|
|
||||||
/// Text label or stock system id to display on the button.
|
|
||||||
/// </param>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3.dll", CharSet=CharSet.Ansi,
|
|
||||||
CallingConvention=CallingConvention.Cdecl)]
|
|
||||||
static extern IntPtr gtk_button_new_from_stock (IntPtr str);
|
|
||||||
|
|
||||||
public Button (String label)
|
|
||||||
{
|
|
||||||
RawObject = gtk_button_new_from_stock (
|
|
||||||
Marshal.StringToHGlobalAnsi (label));
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Button Constructor
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Constructs a new Button with the specified label.
|
|
||||||
/// Underlines in the label can be converted to mnemonics
|
|
||||||
/// based on the specified flag. The label can identify
|
|
||||||
/// a stock button if desired as well.
|
|
||||||
/// </remarks>
|
|
||||||
///
|
|
||||||
/// <param name="label">
|
|
||||||
/// Text label to display on the button face.
|
|
||||||
/// </param>
|
|
||||||
///
|
|
||||||
/// <param name="stock">
|
|
||||||
/// Indicates if the stock system should be used. If the
|
|
||||||
/// label does not represent a known stock button, it will
|
|
||||||
/// instead be used verbatim with mnemonic if an underline
|
|
||||||
/// is included.
|
|
||||||
/// </param>
|
|
||||||
///
|
|
||||||
/// <param name="mnemonic">
|
|
||||||
/// Convert underscore to a mnemonic which can be used
|
|
||||||
/// to activate the button with the keyboard.
|
|
||||||
/// </param>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3.dll", CharSet=CharSet.Ansi,
|
|
||||||
CallingConvention=CallingConvention.Cdecl)]
|
|
||||||
static extern IntPtr gtk_button_new_with_mnemonic (IntPtr str);
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3.dll", CharSet=CharSet.Ansi,
|
|
||||||
CallingConvention=CallingConvention.Cdecl)]
|
|
||||||
static extern IntPtr gtk_button_new_with_label (IntPtr str);
|
|
||||||
|
|
||||||
public Button (String label, bool stock, bool mnemonic)
|
|
||||||
{
|
|
||||||
if (stock)
|
|
||||||
RawObject = gtk_button_new_from_stock (
|
|
||||||
Marshal.StringToHGlobalAnsi (label));
|
|
||||||
else if (mnemonic)
|
|
||||||
RawObject = gtk_button_new_with_mnemonic (
|
|
||||||
Marshal.StringToHGlobalAnsi (label));
|
|
||||||
else
|
|
||||||
RawObject = gtk_button_new_with_label (
|
|
||||||
Marshal.StringToHGlobalAnsi (label));
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Label Property
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Text label to display on the button face.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
public String Label {
|
|
||||||
get {
|
|
||||||
String val;
|
|
||||||
GetProperty ("label", out val);
|
|
||||||
return val;
|
|
||||||
}
|
|
||||||
set {
|
|
||||||
SetProperty ("label", value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Relief Property
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Relief style used to draw the button.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
public ReliefStyle Relief {
|
|
||||||
get {
|
|
||||||
int val;
|
|
||||||
GetProperty ("relief", out val);
|
|
||||||
return (ReliefStyle) val;
|
|
||||||
}
|
|
||||||
set {
|
|
||||||
SetProperty ("relief", (int) value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// UseStock Property
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Indicates if stock button images should be used.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
public bool UseStock {
|
|
||||||
get {
|
|
||||||
bool val;
|
|
||||||
GetProperty ("use-stock", out val);
|
|
||||||
return val;
|
|
||||||
}
|
|
||||||
set {
|
|
||||||
SetProperty ("use-stock", value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// UseUnderline Property
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Indicates if underlines in the label text should be
|
|
||||||
/// treated as a mnemonic.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
public bool UseUnderline {
|
|
||||||
get {
|
|
||||||
bool val;
|
|
||||||
GetProperty ("use-underline", out val);
|
|
||||||
return val;
|
|
||||||
}
|
|
||||||
set {
|
|
||||||
SetProperty ("use-underline", value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Activated Event
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Signal indicating that the button has been activated.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
private static readonly string ActName = "activate";
|
|
||||||
|
|
||||||
public event EventHandler Activated
|
|
||||||
{
|
|
||||||
add {
|
|
||||||
if (Events [ActName] == null)
|
|
||||||
Signals [ActName] = new SimpleSignal (
|
|
||||||
this, RawObject,
|
|
||||||
ActName, value);
|
|
||||||
|
|
||||||
Events.AddHandler (ActName, value);
|
|
||||||
}
|
|
||||||
remove {
|
|
||||||
Events.RemoveHandler (ActName, value);
|
|
||||||
if (Events [ActName] == null)
|
|
||||||
Signals.Remove (ActName);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Clicked Event
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Signal indicating that the button has been clicked.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
private static readonly string ClkName = "clicked";
|
|
||||||
|
|
||||||
public event EventHandler Clicked
|
|
||||||
{
|
|
||||||
add {
|
|
||||||
if (Events [ClkName] == null)
|
|
||||||
Signals [ClkName] = new SimpleSignal (
|
|
||||||
this, RawObject,
|
|
||||||
ClkName, value);
|
|
||||||
|
|
||||||
Events.AddHandler (ClkName, value);
|
|
||||||
}
|
|
||||||
remove {
|
|
||||||
Events.RemoveHandler (ClkName, value);
|
|
||||||
if (Events [ClkName] == null)
|
|
||||||
Signals.Remove (ClkName);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Entered Event
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Signal indicating that the focus has entered the button.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
private static readonly string EnterName = "enter";
|
|
||||||
|
|
||||||
public event EventHandler Entered
|
|
||||||
{
|
|
||||||
add {
|
|
||||||
if (Events [EnterName] == null)
|
|
||||||
Signals [EnterName] = new SimpleSignal (
|
|
||||||
this, RawObject,
|
|
||||||
EnterName, value);
|
|
||||||
|
|
||||||
Events.AddHandler (EnterName, value);
|
|
||||||
}
|
|
||||||
remove {
|
|
||||||
Events.RemoveHandler (EnterName, value);
|
|
||||||
if (Events [EnterName] == null)
|
|
||||||
Signals.Remove (EnterName);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Left Event
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Signal indicating that the focus has left the button.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
private static readonly string LeaveName = "leave";
|
|
||||||
|
|
||||||
public event EventHandler Left
|
|
||||||
{
|
|
||||||
add {
|
|
||||||
if (Events [LeaveName] == null)
|
|
||||||
Signals [LeaveName] = new SimpleSignal (
|
|
||||||
this, RawObject,
|
|
||||||
LeaveName, value);
|
|
||||||
|
|
||||||
Events.AddHandler (LeaveName, value);
|
|
||||||
}
|
|
||||||
remove {
|
|
||||||
Events.RemoveHandler (LeaveName, value);
|
|
||||||
if (Events [LeaveName] == null)
|
|
||||||
Signals.Remove (LeaveName);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Pressed Event
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Signal indicating that the button has been pressed.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
private static readonly string PressName = "pressed";
|
|
||||||
|
|
||||||
public event EventHandler Pressed
|
|
||||||
{
|
|
||||||
add {
|
|
||||||
if (Events [PressName] == null)
|
|
||||||
Signals [PressName] = new SimpleSignal (
|
|
||||||
this, RawObject,
|
|
||||||
PressName, value);
|
|
||||||
|
|
||||||
Events.AddHandler (PressName, value);
|
|
||||||
}
|
|
||||||
remove {
|
|
||||||
Events.RemoveHandler (PressName, value);
|
|
||||||
if (Events [PressName] == null)
|
|
||||||
Signals.Remove (PressName);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Released Event
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Signal indicating that the button has been released.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
private static readonly string RelName = "released";
|
|
||||||
|
|
||||||
public event EventHandler Released
|
|
||||||
{
|
|
||||||
add {
|
|
||||||
if (Events [RelName] == null)
|
|
||||||
Signals [RelName] = new SimpleSignal (
|
|
||||||
this, RawObject,
|
|
||||||
RelName, value);
|
|
||||||
|
|
||||||
Events.AddHandler (RelName, value);
|
|
||||||
}
|
|
||||||
remove {
|
|
||||||
Events.RemoveHandler (RelName, value);
|
|
||||||
if (Events [RelName] == null)
|
|
||||||
Signals.Remove (RelName);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Click Method
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Emit a Signal indicating that the button has been
|
|
||||||
/// clicked.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3.dll")]
|
|
||||||
static extern void gtk_button_clicked (IntPtr obj);
|
|
||||||
|
|
||||||
public void Click ()
|
|
||||||
{
|
|
||||||
gtk_button_clicked (RawObject);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Enter Method
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Emit a Signal indicating that the focus has entered
|
|
||||||
/// the button.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3.dll")]
|
|
||||||
static extern void gtk_button_enter (IntPtr obj);
|
|
||||||
|
|
||||||
public void Enter ()
|
|
||||||
{
|
|
||||||
gtk_button_enter (RawObject);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Leave Method
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Emit a Signal indicating that the focus has left the
|
|
||||||
/// button.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3.dll")]
|
|
||||||
static extern void gtk_button_leave (IntPtr obj);
|
|
||||||
|
|
||||||
public void Leave ()
|
|
||||||
{
|
|
||||||
gtk_button_leave (RawObject);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Pressed Method
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Emit a Signal indicating that the button has been
|
|
||||||
/// pressed.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3.dll")]
|
|
||||||
static extern void gtk_button_pressed (IntPtr obj);
|
|
||||||
|
|
||||||
public void Press ()
|
|
||||||
{
|
|
||||||
gtk_button_pressed (RawObject);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Release Method
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Emit a Signal indicating that the button has been
|
|
||||||
/// released.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3.dll")]
|
|
||||||
static extern void gtk_button_released (IntPtr obj);
|
|
||||||
|
|
||||||
public void Release ()
|
|
||||||
{
|
|
||||||
gtk_button_released (RawObject);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
100
gtk/Container.cs
100
gtk/Container.cs
|
@ -1,100 +0,0 @@
|
||||||
// Gtk.Container.cs - GtkContainer class wrapper implementation
|
|
||||||
//
|
|
||||||
// Author: Mike Kestner <mkestner@speakeasy.net>
|
|
||||||
//
|
|
||||||
// (c) 2001 Mike Kestner
|
|
||||||
|
|
||||||
namespace Gtk {
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Runtime.InteropServices;
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Container Class
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Abstract class which provides the capability to embed a
|
|
||||||
/// widget within its boundaries.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
public abstract class Container : Widget {
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// BorderWidth Property
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// The Width, in pixels, of the border around the
|
|
||||||
/// Container.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
public int BorderWidth {
|
|
||||||
get {
|
|
||||||
int val;
|
|
||||||
GetProperty ("border-width", out val);
|
|
||||||
return val;
|
|
||||||
}
|
|
||||||
set {
|
|
||||||
SetProperty ("border-width", value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// FIXME: Implement Child property.
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// ResizeMode Property
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Indicates the resizing policy for the Container.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
public ResizeMode ResizeMode {
|
|
||||||
get {
|
|
||||||
int val;
|
|
||||||
GetProperty ("border-width", out val);
|
|
||||||
return (ResizeMode) val;
|
|
||||||
}
|
|
||||||
set {
|
|
||||||
SetProperty ("border-width", (int) value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Add Method
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Adds a child Widget to the Container.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3.dll", CharSet=CharSet.Ansi,
|
|
||||||
CallingConvention=CallingConvention.Cdecl)]
|
|
||||||
static extern void gtk_container_add (IntPtr obj, IntPtr child);
|
|
||||||
|
|
||||||
public void Add (Widget child)
|
|
||||||
{
|
|
||||||
gtk_container_add (Handle, child.Handle);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Remove Method
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Remove a child Widget from the Container.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3.dll", CharSet=CharSet.Ansi,
|
|
||||||
CallingConvention=CallingConvention.Cdecl)]
|
|
||||||
static extern void gtk_container_remove (IntPtr obj,
|
|
||||||
IntPtr child);
|
|
||||||
|
|
||||||
public void Remove (Widget child)
|
|
||||||
{
|
|
||||||
gtk_container_remove (Handle, child.Handle);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
240
gtk/Label.cs
240
gtk/Label.cs
|
@ -1,240 +0,0 @@
|
||||||
// GTK.Label.cs - GTK Label class implementation
|
|
||||||
//
|
|
||||||
// Author: Bob Smith <bob@thestuff.net>
|
|
||||||
//
|
|
||||||
// (c) 2001 Bob Smith
|
|
||||||
|
|
||||||
namespace Gtk {
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Runtime.InteropServices;
|
|
||||||
|
|
||||||
public class Label : Widget {
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Label Object Constructor
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Constructs a Label Wrapper.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
public Label (IntPtr o)
|
|
||||||
{
|
|
||||||
RawObject = o;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Label Constructor
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Constructs a new Label with the specified content.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3")]
|
|
||||||
static extern IntPtr gtk_label_new (String str);
|
|
||||||
|
|
||||||
public Label (String str)
|
|
||||||
{
|
|
||||||
RawObject = gtk_label_new (str);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Text Property
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// The raw text of the label.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3")]
|
|
||||||
static extern void gtk_label_set_text (IntPtr hnd, String str);
|
|
||||||
[DllImport("gtk-1.3")]
|
|
||||||
static extern String gtk_label_get_text (IntPtr hnd);
|
|
||||||
|
|
||||||
public String Text {
|
|
||||||
get
|
|
||||||
{
|
|
||||||
return gtk_label_get_text (RawObject);
|
|
||||||
}
|
|
||||||
set
|
|
||||||
{
|
|
||||||
gtk_label_set_text (RawObject, value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Markup Property
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Text to parse.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3")]
|
|
||||||
static extern void gtk_label_set_markup (IntPtr hnd, String str);
|
|
||||||
|
|
||||||
public String Markup {
|
|
||||||
set
|
|
||||||
{
|
|
||||||
gtk_label_set_markup (RawObject, value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Label Property
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Parsed content.
|
|
||||||
/// </remarks>
|
|
||||||
/*
|
|
||||||
[DllImport("gtk-1.3")]
|
|
||||||
static extern void gtk_label_set_label (IntPtr hnd, String str);
|
|
||||||
[DllImport("gtk-1.3")]
|
|
||||||
static extern String gtk_label_get_label (IntPtr hnd);
|
|
||||||
|
|
||||||
public String Label {
|
|
||||||
get
|
|
||||||
{
|
|
||||||
return gtk_label_get_label (RawObject);
|
|
||||||
}
|
|
||||||
set
|
|
||||||
{
|
|
||||||
gtk_label_set_label (RawObject, value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
/// <summary>
|
|
||||||
/// Selectable Property
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Is the user able to select text from the label.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3")]
|
|
||||||
static extern void gtk_label_set_selectable (IntPtr hnd, bool setting);
|
|
||||||
[DllImport("gtk-1.3")]
|
|
||||||
static extern bool gtk_label_get_selectable (IntPtr hnd);
|
|
||||||
|
|
||||||
public bool Selectable {
|
|
||||||
get
|
|
||||||
{
|
|
||||||
return gtk_label_get_selectable (RawObject);
|
|
||||||
}
|
|
||||||
set
|
|
||||||
{
|
|
||||||
gtk_label_set_selectable (RawObject, value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// UseUnderline Property
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Indicates that the next character after an underline should be the accelerator key.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3")]
|
|
||||||
static extern void gtk_label_set_use_underline (IntPtr hnd, bool setting);
|
|
||||||
[DllImport("gtk-1.3")]
|
|
||||||
static extern bool gtk_label_get_use_underline (IntPtr hnd);
|
|
||||||
|
|
||||||
public bool UseUnderline {
|
|
||||||
get
|
|
||||||
{
|
|
||||||
return gtk_label_get_use_underline (RawObject);
|
|
||||||
}
|
|
||||||
set
|
|
||||||
{
|
|
||||||
gtk_label_set_use_underline (RawObject, value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// UseMarkup Property
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Indicates that the text contains markup.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3")]
|
|
||||||
static extern void gtk_label_set_use_markup (IntPtr hnd, bool setting);
|
|
||||||
[DllImport("gtk-1.3")]
|
|
||||||
static extern bool gtk_label_get_use_markup (IntPtr hnd);
|
|
||||||
|
|
||||||
public bool UseMarkup {
|
|
||||||
get
|
|
||||||
{
|
|
||||||
return gtk_label_get_use_markup (RawObject);
|
|
||||||
}
|
|
||||||
set
|
|
||||||
{
|
|
||||||
gtk_label_set_use_markup (RawObject, value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// LineWrap Property
|
|
||||||
/// </summary>
|
|
||||||
///
|
|
||||||
/// <remarks>
|
|
||||||
/// Indicates that the text is automatically wrapped if to long.
|
|
||||||
/// </remarks>
|
|
||||||
|
|
||||||
[DllImport("gtk-1.3")]
|
|
||||||
static extern void gtk_label_set_line_wrap (IntPtr hnd, bool setting);
|
|
||||||
[DllImport("gtk-1.3")]
|
|
||||||
static extern bool gtk_label_get_line_wrap (IntPtr hnd);
|
|
||||||
|
|
||||||
public bool LineWrap {
|
|
||||||
get
|
|
||||||
{
|
|
||||||
return gtk_label_get_line_wrap (RawObject);
|
|
||||||
}
|
|
||||||
set
|
|
||||||
{
|
|
||||||
gtk_label_set_line_wrap (RawObject, value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
TODO:
|
|
||||||
|
|
||||||
void gtk_label_set_attributes(GtkLabel *label, PangoAttrList *attrs);
|
|
||||||
void gtk_label_set_markup_with_mnemonic(GtkLabel *label, const gchar *str);
|
|
||||||
void gtk_label_set_pattern(GtkLabel *label, const gchar *pattern);
|
|
||||||
void gtk_label_set_justify(GtkLabel *label, GtkJustification jtype);
|
|
||||||
guint gtk_label_parse_uline(GtkLabel *label, const gchar *string);
|
|
||||||
void gtk_label_get_layout_offsets (GtkLabel *label,
|
|
||||||
gint *x,
|
|
||||||
gint *y);
|
|
||||||
guint gtk_label_get_mnemonic_keyval (GtkLabel *label);
|
|
||||||
GtkWidget* gtk_label_new_with_mnemonic (const char *str);
|
|
||||||
void gtk_label_select_region (GtkLabel *label,
|
|
||||||
gint start_offset,
|
|
||||||
gint end_offset);
|
|
||||||
void gtk_label_set_mnemonic_widget (GtkLabel *label,
|
|
||||||
GtkWidget *widget);
|
|
||||||
void gtk_label_set_text_with_mnemonic
|
|
||||||
(GtkLabel *label,
|
|
||||||
const gchar *str);
|
|
||||||
PangoAttrList* gtk_label_get_attributes (GtkLabel *label);
|
|
||||||
GtkJustification gtk_label_get_justify (GtkLabel *label);
|
|
||||||
PangoLayout* gtk_label_get_layout (GtkLabel *label);
|
|
||||||
|
|
||||||
GtkWidget* gtk_label_get_mnemonic_widget (GtkLabel *label);
|
|
||||||
gboolean gtk_label_get_selection_bounds (GtkLabel *label,
|
|
||||||
gint *start,
|
|
||||||
gint *end);
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,16 +0,0 @@
|
||||||
// Object.cs - GtkObject class wrapper implementation
|
|
||||||
//
|
|
||||||
// Author: Mike Kestner <mkestner@speakeasy.net>
|
|
||||||
//
|
|
||||||
// (c) 2001 Mike Kestner
|
|
||||||
|
|
||||||
namespace Gtk {
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.ComponentModel;
|
|
||||||
using System.Runtime.InteropServices;
|
|
||||||
|
|
||||||
public abstract class Object : GLib.Object {
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1 +1,3 @@
|
||||||
Fix enum bug where symbolic values are used (eg Gdk.ModifierType.ModifierMask).
|
Fix enum bug where symbolic values are used (eg Gdk.ModifierType.ModifierMask).
|
||||||
|
Fix property names where a variable is used instead of a string literal.
|
||||||
|
Fix the bool property macro definitions in GtkTextTag and CellRendererText.
|
||||||
|
|
|
@ -425,46 +425,45 @@ sub addPropElem
|
||||||
{
|
{
|
||||||
my ($spec, $node) = @_;
|
my ($spec, $node) = @_;
|
||||||
my ($name, $mode, $docs);
|
my ($name, $mode, $docs);
|
||||||
$spec =~ /g_param_spec_(\w+)\s*\((.*)/;
|
$spec =~ /g_param_spec_(\w+)\s*\((.*)\s*\)\s*\)/;
|
||||||
my $type = $1;
|
my $type = $1;
|
||||||
my $params = $2;
|
my @params = split(/,/, $2);
|
||||||
|
|
||||||
if ($type =~ /boolean|^u*int|pointer/) {
|
# FIXME: Handle non-literals. Needs work in the pp too.
|
||||||
$params =~ /\"(.+)\",.+\".+\".+\"(.+)\".*(,\s*G_PARAM_\w+.*)\)\s*\)/;
|
$name = $params[0];
|
||||||
$name = $1; $docs = $2; $mode = $3;
|
$name =~ s/\"//g;
|
||||||
|
|
||||||
|
while ($params[2] !~ /\"\s*\)?$/) {
|
||||||
|
die "Unable to reconstruct doc string.\n" if (!$params[3]);
|
||||||
|
$params[2] .= ",$params[3]";
|
||||||
|
@params = (@params[0..2],@params[4..$#params]);
|
||||||
|
}
|
||||||
|
$docs = $params[2];
|
||||||
|
$docs =~ s/\"//g;
|
||||||
|
$docs =~ s/\s+/ /g;
|
||||||
|
$mode = $params[$#params];
|
||||||
|
|
||||||
|
if ($type =~ /boolean|float|double|^u?int|pointer/) {
|
||||||
$type = "g$type";
|
$type = "g$type";
|
||||||
} elsif ($type =~ /string/) {
|
} elsif ($type =~ /string/) {
|
||||||
$params =~ /\"(.+)\",.+\".+\".+\"(.+)\".*(,\s*G_PARAM_\w+.*)\)\s*\)/;
|
|
||||||
$name = $1; $docs = $2; $mode = $3;
|
|
||||||
$type = "gchar*";
|
$type = "gchar*";
|
||||||
} elsif ($type =~ /enum|flags/) {
|
} elsif ($type =~ /enum|flags|object/) {
|
||||||
$params =~ /\"(.+)\",.+,.+\"(.+)\".*,\s+(\w+),.*,(\s*G_PARAM_\w+.*)\)\s*\)/;
|
$type = $params[3];
|
||||||
$name = $1; $docs = $2; $type = $3; $mode = $4;
|
|
||||||
$type =~ s/TYPE_//;
|
|
||||||
$type = StudlyCaps(lc($type));
|
|
||||||
} elsif ($type =~ /object/) {
|
|
||||||
$params =~ /\"(.+)\",.+,.+\"(.+)\".*,\s+(\w+),(\s*G_PARAM_\w+.*)\)\s*\)/;
|
|
||||||
$name = $1; $docs = $2; $type = $3; $mode = $4;
|
|
||||||
$type =~ s/TYPE_//;
|
$type =~ s/TYPE_//;
|
||||||
|
$type =~ s/\s+//g;
|
||||||
$type = StudlyCaps(lc($type));
|
$type = StudlyCaps(lc($type));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$prop_elem = $doc->createElement('property');
|
$prop_elem = $doc->createElement('property');
|
||||||
$node->appendChild($prop_elem);
|
$node->appendChild($prop_elem);
|
||||||
$prop_elem->setAttribute('name', $name);
|
$prop_elem->setAttribute('name', StudlyCaps($name));
|
||||||
|
$prop_elem->setAttribute('cname', $name);
|
||||||
$prop_elem->setAttribute('type', $type);
|
$prop_elem->setAttribute('type', $type);
|
||||||
$prop_elem->setAttribute('doc-string', $docs);
|
$prop_elem->setAttribute('doc-string', $docs);
|
||||||
|
|
||||||
if ($mode =~ /READ/) {
|
$prop_elem->setAttribute('readable', "true") if ($mode =~ /READ/);
|
||||||
$prop_elem->setAttribute('readable', "true");
|
$prop_elem->setAttribute('writeable', "true") if ($mode =~ /WRIT/);
|
||||||
}
|
$prop_elem->setAttribute('construct-only', "true") if ($mode =~ /CONS/);
|
||||||
if ($mode =~ /WRIT/) {
|
|
||||||
$prop_elem->setAttribute('writeable', "true");
|
|
||||||
}
|
|
||||||
if ($mode =~ /CONS/) {
|
|
||||||
$prop_elem->setAttribute('construct-only', "true");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub addSignalElem
|
sub addSignalElem
|
||||||
|
@ -526,26 +525,23 @@ sub parseInitFunc
|
||||||
|
|
||||||
my $line = $init_lines[$linenum];
|
my $line = $init_lines[$linenum];
|
||||||
|
|
||||||
while ($linenum < @init_lines) {
|
if ($line =~ /#define/) {
|
||||||
$line = $init_lines[$linenum];
|
# FIXME: This ignores the bool helper macro thingie.
|
||||||
if ($line =~ /g_object_class_install_prop/) {
|
} elsif ($line =~ /g_object_class_install_prop/) {
|
||||||
my $prop = $line;
|
my $prop = $line;
|
||||||
do {
|
do {
|
||||||
$prop .= $init_lines[++$linenum];
|
$prop .= $init_lines[++$linenum];
|
||||||
} until ($init_lines[$linenum] =~ /;/);
|
} until ($init_lines[$linenum] =~ /;/);
|
||||||
addPropElem ($prop, $obj_el);
|
addPropElem ($prop, $obj_el);
|
||||||
$propcnt++;
|
$propcnt++;
|
||||||
} elsif ($line =~ /g(tk)?_signal_new/) {
|
} elsif ($line =~ /g(tk)?_signal_new/) {
|
||||||
my $sig = $line;
|
my $sig = $line;
|
||||||
do {
|
do {
|
||||||
$sig .= $init_lines[++$linenum];
|
$sig .= $init_lines[++$linenum];
|
||||||
} until ($init_lines[$linenum] =~ /;/);
|
} until ($init_lines[$linenum] =~ /;/);
|
||||||
addSignalElem ($sig, $classdef, $obj_el);
|
addSignalElem ($sig, $classdef, $obj_el);
|
||||||
$sigcnt++;
|
$sigcnt++;
|
||||||
}
|
|
||||||
$linenum++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$linenum++;
|
$linenum++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue