2002-01-17 00:26:46 +00:00
|
|
|
// GtkSharp.Boxed.cs - Base class for deriving marshallable structures.
|
|
|
|
//
|
|
|
|
// Author: Mike Kestner <mkestner@speakeasy.net>
|
|
|
|
//
|
|
|
|
// (c) 2001-2002 Mike Kestner
|
|
|
|
|
|
|
|
namespace GtkSharp {
|
|
|
|
|
|
|
|
using System;
|
|
|
|
using System.Runtime.InteropServices;
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Boxed Class
|
|
|
|
/// </summary>
|
|
|
|
///
|
|
|
|
/// <remarks>
|
|
|
|
/// An abstract base class to derive structures and marshal them.
|
|
|
|
/// </remarks>
|
|
|
|
|
|
|
|
public abstract class Boxed {
|
|
|
|
|
|
|
|
IntPtr _raw;
|
|
|
|
|
|
|
|
// Destructor is required since we are allocating unmanaged
|
|
|
|
// heap resources.
|
|
|
|
|
|
|
|
~Boxed ()
|
|
|
|
{
|
|
|
|
Marshal.FreeHGlobal (_raw);
|
|
|
|
}
|
|
|
|
|
2002-02-19 19:46:44 +00:00
|
|
|
/// <summary>
|
|
|
|
/// Boxed Constructor
|
|
|
|
/// </summary>
|
|
|
|
///
|
|
|
|
/// <remarks>
|
|
|
|
/// Dummy constructor needed for subclasses.
|
|
|
|
/// </remarks>
|
|
|
|
|
|
|
|
public Boxed()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Boxed Constructor
|
|
|
|
/// </summary>
|
|
|
|
///
|
|
|
|
/// <remarks>
|
|
|
|
/// Wraps a raw boxed type reference.
|
|
|
|
/// </remarks>
|
|
|
|
|
|
|
|
public Boxed(IntPtr raw)
|
|
|
|
{
|
|
|
|
Raw = raw;
|
|
|
|
}
|
|
|
|
|
2002-01-17 00:26:46 +00:00
|
|
|
/// <summary>
|
|
|
|
/// Raw Property
|
|
|
|
/// </summary>
|
|
|
|
///
|
|
|
|
/// <remarks>
|
|
|
|
/// Gets a marshallable IntPtr.
|
|
|
|
/// </remarks>
|
|
|
|
|
2002-02-19 19:46:44 +00:00
|
|
|
protected IntPtr Raw {
|
2002-01-17 00:26:46 +00:00
|
|
|
get {
|
|
|
|
if (_raw == IntPtr.Zero) {
|
|
|
|
// FIXME: Ugly hack.
|
|
|
|
_raw = Marshal.AllocHGlobal (128);
|
|
|
|
Marshal.StructureToPtr (this, _raw, true);
|
|
|
|
}
|
|
|
|
return _raw;
|
|
|
|
}
|
2002-02-19 19:46:44 +00:00
|
|
|
set {
|
|
|
|
_raw = value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Handle Property
|
|
|
|
/// </summary>
|
|
|
|
///
|
|
|
|
/// <remarks>
|
|
|
|
/// Gets a marshallable IntPtr.
|
|
|
|
/// </remarks>
|
|
|
|
|
|
|
|
public IntPtr Handle {
|
|
|
|
get {
|
|
|
|
return _raw;
|
|
|
|
}
|
2002-01-17 00:26:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// GetBoxed Shared Method
|
|
|
|
/// </summary>
|
|
|
|
///
|
|
|
|
/// <remarks>
|
|
|
|
/// Gets a managed class representing a raw ref.
|
|
|
|
/// </remarks>
|
|
|
|
|
|
|
|
public static Boxed GetBoxed (IntPtr raw)
|
|
|
|
{
|
|
|
|
// FIXME: Use the type manager to box the raw ref.
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|