mirror of
https://github.com/Ryujinx/GtkSharp.git
synced 2025-01-11 22:15:48 +00:00
1ac00ff205
[Rework of a patch from Ben Maurer to turn GLib.Value into a valuetype.] * generator/BoxedGen.cs : fix operators for new valuetype GValues. * generator/ByRefGen.cs : new generatable for byref value types. * generator/Makefile.am : add ByRefGen.cs. * generator/MethodBody.cs : remove GValue special casing. * generator/Property.cs : rework value handling. * generator/Signal.cs : fix base virtual method value passing. * generator/SymbolTable.cs : map GValue to ByRefGen. * glib/Object.cs : rework GetProperty and SetProperty. * glib/Value.cs : make it a value type. * glib/ValueArray.cs : fix GValue passing. * glib/glue/value.c : rework for valuetype GValues. * gnome/Program.custom : fix GValue passing * gtk/Gtk.metadata : make TreeModel.GetValue value param pass_as=ref. * gtk/ListStore.custom : fix GValue passing * gtk/NodeStore.cs : fix GValue passing * gtk/TextTag.custom : fix GValue passing * gtk/TreeModelSort.custom : fix GValue passing * gtk/TreeStore.custom : fix GValue passing svn path=/trunk/gtk-sharp/; revision=25368
196 lines
3.9 KiB
C#
196 lines
3.9 KiB
C#
// ValueArray.cs - ValueArray wrapper implementation
|
|
//
|
|
// Authors: Mike Kestner <mkestner@ximian.com>
|
|
//
|
|
// (c) 2003 Novell, Inc.
|
|
|
|
namespace GLib {
|
|
|
|
using System;
|
|
using System.Collections;
|
|
using System.Runtime.InteropServices;
|
|
|
|
public class ValueArray : IDisposable, ICollection, ICloneable, IWrapper {
|
|
|
|
private IntPtr handle = IntPtr.Zero;
|
|
|
|
[DllImport("libgobject-2.0-0.dll")]
|
|
static extern IntPtr g_value_array_new (uint n_preallocs);
|
|
|
|
public ValueArray (uint n_preallocs)
|
|
{
|
|
handle = g_value_array_new (n_preallocs);
|
|
}
|
|
|
|
internal ValueArray (IntPtr raw)
|
|
{
|
|
handle = raw;
|
|
}
|
|
|
|
~ValueArray ()
|
|
{
|
|
Dispose (false);
|
|
}
|
|
|
|
// IDisposable
|
|
public void Dispose ()
|
|
{
|
|
Dispose (true);
|
|
GC.SuppressFinalize (this);
|
|
}
|
|
|
|
[DllImport("libgobject-2.0-0.dll")]
|
|
static extern void g_value_array_free (IntPtr raw);
|
|
|
|
void Dispose (bool disposing)
|
|
{
|
|
if (Handle == IntPtr.Zero)
|
|
return;
|
|
|
|
g_value_array_free (Handle);
|
|
handle = IntPtr.Zero;
|
|
}
|
|
|
|
public IntPtr Handle {
|
|
get {
|
|
return handle;
|
|
}
|
|
}
|
|
|
|
[DllImport("glibsharpglue")]
|
|
static extern IntPtr gtksharp_value_array_get_array (IntPtr raw);
|
|
|
|
public IntPtr ArrayPtr {
|
|
get {
|
|
return gtksharp_value_array_get_array (Handle);
|
|
}
|
|
}
|
|
|
|
[DllImport("libgobject-2.0-0.dll")]
|
|
static extern void g_value_array_append (IntPtr raw, ref GLib.Value val);
|
|
|
|
public void Append (GLib.Value val)
|
|
{
|
|
g_value_array_append (Handle, ref val);
|
|
}
|
|
|
|
[DllImport("libgobject-2.0-0.dll")]
|
|
static extern void g_value_array_insert (IntPtr raw, uint idx, ref GLib.Value val);
|
|
|
|
public void Insert (uint idx, GLib.Value val)
|
|
{
|
|
g_value_array_insert (Handle, idx, ref val);
|
|
}
|
|
|
|
[DllImport("libgobject-2.0-0.dll")]
|
|
static extern void g_value_array_prepend (IntPtr raw, ref GLib.Value val);
|
|
|
|
public void Prepend (GLib.Value val)
|
|
{
|
|
g_value_array_prepend (Handle, ref val);
|
|
}
|
|
|
|
[DllImport("libgobject-2.0-0.dll")]
|
|
static extern void g_value_array_remove (IntPtr raw, uint idx);
|
|
|
|
public void Remove (uint idx)
|
|
{
|
|
g_value_array_remove (Handle, idx);
|
|
}
|
|
|
|
[DllImport("glibsharpglue")]
|
|
static extern int gtksharp_value_array_get_count (IntPtr raw);
|
|
|
|
// ICollection
|
|
public int Count {
|
|
get {
|
|
return gtksharp_value_array_get_count (Handle);
|
|
}
|
|
}
|
|
|
|
[DllImport("libgobject-2.0-0.dll")]
|
|
static extern IntPtr g_value_array_get_nth (IntPtr raw, uint idx);
|
|
|
|
public object this [int index] {
|
|
get {
|
|
GLib.Value val = Value.Empty;
|
|
Marshal.PtrToStructure (g_value_array_get_nth (Handle, (uint) index), val);
|
|
return val;
|
|
}
|
|
}
|
|
|
|
// Synchronization could be tricky here. Hmm.
|
|
public bool IsSynchronized {
|
|
get { return false; }
|
|
}
|
|
|
|
public object SyncRoot {
|
|
get { return null; }
|
|
}
|
|
|
|
public void CopyTo (Array array, int index)
|
|
{
|
|
if (array == null)
|
|
throw new ArgumentNullException ("Array can't be null.");
|
|
|
|
if (index < 0)
|
|
throw new ArgumentOutOfRangeException ("Index must be greater than 0.");
|
|
|
|
if (index + Count < array.Length)
|
|
throw new ArgumentException ("Array not large enough to copy into starting at index.");
|
|
|
|
for (int i = 0; i < Count; i++)
|
|
((IList) array) [index + i] = this [i];
|
|
}
|
|
|
|
private class ListEnumerator : IEnumerator
|
|
{
|
|
private int current = -1;
|
|
private ValueArray vals;
|
|
|
|
public ListEnumerator (ValueArray vals)
|
|
{
|
|
this.vals = vals;
|
|
}
|
|
|
|
public object Current {
|
|
get {
|
|
if (current == -1)
|
|
return null;
|
|
return vals [current];
|
|
}
|
|
}
|
|
|
|
public bool MoveNext ()
|
|
{
|
|
if (++current >= vals.Count) {
|
|
current = -1;
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
public void Reset ()
|
|
{
|
|
current = -1;
|
|
}
|
|
}
|
|
|
|
// IEnumerable
|
|
public IEnumerator GetEnumerator ()
|
|
{
|
|
return new ListEnumerator (this);
|
|
}
|
|
|
|
[DllImport("libgobject-2.0-0.dll")]
|
|
static extern IntPtr g_value_array_copy (IntPtr raw);
|
|
|
|
// ICloneable
|
|
public object Clone ()
|
|
{
|
|
return new ValueArray (g_value_array_copy (Handle));
|
|
}
|
|
}
|
|
}
|