2004-12-30 Mike Kestner <mkestner@novell.com>

* glib/Object.cs : mark the Data hashtable obsolete.

svn path=/trunk/gtk-sharp/; revision=38201
This commit is contained in:
Mike Kestner 2004-12-30 18:59:09 +00:00
parent ecb6c75c26
commit 56a0288b7b
3 changed files with 12 additions and 1 deletions

View file

@ -1,3 +1,7 @@
2004-12-30 Mike Kestner <mkestner@novell.com>
* glib/Object.cs : mark the Data hashtable obsolete.
2004-12-30 Mike Kestner <mkestner@novell.com> 2004-12-30 Mike Kestner <mkestner@novell.com>
* gtk/Gtk.metadata : hide TreeView.InsertColumnWith*. * gtk/Gtk.metadata : hide TreeView.InsertColumnWith*.

View file

@ -87,6 +87,12 @@
<summary>Stores and Accesses arbitrary data on the Object.</summary> <summary>Stores and Accesses arbitrary data on the Object.</summary>
<returns>a <see cref="T:System.Collections.Hashtable" /></returns> <returns>a <see cref="T:System.Collections.Hashtable" /></returns>
<remarks> <remarks>
This property is obsolete and should not be used unless you explicitly retain a reference to the
<see cref="T:GLib.Object"/>. Otherwise the Data hashtable will be lost when the Garbage Collector
releases your managed object wrapper. There are much better alternatives to this anyway. Consider
using a Hashtable on your class that is keyed by <see cref="T:GLib.Object"/> or a subclass with
an object property for the data you want to store instead. There are many better ways to accompish
the role of this property.
</remarks> </remarks>
</Docs> </Docs>
</Member> </Member>
@ -383,4 +389,4 @@
</Docs> </Docs>
</Member> </Member>
</Members> </Members>
</Type> </Type>

View file

@ -285,6 +285,7 @@ namespace GLib {
return Handle.GetHashCode (); return Handle.GetHashCode ();
} }
[Obsolete("Can cause instability due to garbage collection of GLib.Objects.")]
public Hashtable Data { public Hashtable Data {
get { get {
if (data == null) if (data == null)