Free cookie consent management tool by TermsFeed Policy Generator

source: trunk/sources/HeuristicLab.Core/3.3/Item.cs @ 3376

Last change on this file since 3376 was 3376, checked in by swagner, 14 years ago

Moved interfaces and classes for deep cloning from HeuristicLab.Core to HeuristicLab.Common (#975).

File size: 3.7 KB
RevLine 
[2]1#region License Information
2/* HeuristicLab
[2790]3 * Copyright (C) 2002-2010 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
[2]4 *
5 * This file is part of HeuristicLab.
6 *
7 * HeuristicLab is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * HeuristicLab is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with HeuristicLab. If not, see <http://www.gnu.org/licenses/>.
19 */
20#endregion
21
[2932]22using System;
[2546]23using System.Drawing;
[3376]24using HeuristicLab.Common;
[1853]25using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;
[2]26
27namespace HeuristicLab.Core {
[776]28  /// <summary>
29  /// Represents the base class for all basic item types.
30  /// </summary>
[3017]31  [StorableClass]
[2664]32  [Item("Item", "Base class for all HeuristicLab items.")]
[3376]33  public abstract class Item : IDeepCloneable, IItem {
[2653]34    public virtual string ItemName {
35      get { return ItemAttribute.GetName(this.GetType()); }
[2546]36    }
[2653]37    public virtual string ItemDescription {
38      get { return ItemAttribute.GetDescription(this.GetType()); }
[2546]39    }
[2653]40    public virtual Image ItemImage {
[3317]41      get { return HeuristicLab.Common.Resources.VS2008ImageLibrary.Class; }
[2546]42    }
43
[3317]44    [Storable]
45    private bool readOnlyView;
[3370]46    public virtual bool ReadOnlyView {
[3317]47      get { return readOnlyView; }
48      set {
49        if (readOnlyView != value) {
50          readOnlyView = value;
51          OnReadOnlyViewChanged();
52        }
53      }
54    }
55
56    protected Item()
57      : base() {
58      readOnlyView = false;
59    }
[3280]60    [StorableConstructor]
[3376]61    protected Item(bool deserializing) { }
[3280]62
63
[776]64    /// <summary>
[3376]65    /// Creates a deep clone of this instance.
66    /// </summary>
67    /// <remarks>
68    /// This method is the entry point for creating a deep clone of a whole object graph.
69    /// </remarks>
70    /// <returns>A clone of this instance.</returns>
71    public object Clone() {
72      return Clone(new Cloner());
73    }
74
75    /// <summary>
[3317]76    /// Clones the current instance (deep clone).
77    /// </summary>
78    /// <param name="clonedObjects">Dictionary of all already cloned objects. (Needed to avoid cycles.)</param>
79    /// <returns>The cloned object as <see cref="Variable"/>.</returns>
[3376]80    public virtual IDeepCloneable Clone(Cloner cloner) {
81      Item clone = (Item)Activator.CreateInstance(this.GetType());
82      cloner.RegisterClonedObject(this, clone);
[3317]83      clone.readOnlyView = readOnlyView;
84      return clone;
85    }
86
87    /// <summary>
[776]88    /// Gets the string representation of the current instance.
89    /// </summary>
90    /// <returns>The type name of the current instance.</returns>
[2]91    public override string ToString() {
[2653]92      return ItemName;
[2]93    }
94
[3306]95    public event EventHandler ItemImageChanged;
96    protected virtual void OnItemImageChanged() {
97      EventHandler handler = ItemImageChanged;
98      if (handler != null) handler(this, EventArgs.Empty);
99    }
[3317]100    public event EventHandler ReadOnlyViewChanged;
101    protected virtual void OnReadOnlyViewChanged() {
102      EventHandler handler = ReadOnlyViewChanged;
103      if (handler != null) handler(this, EventArgs.Empty);
104    }
[2932]105    public event EventHandler ToStringChanged;
106    protected virtual void OnToStringChanged() {
[3306]107      EventHandler handler = ToStringChanged;
108      if (handler != null) handler(this, EventArgs.Empty);
[2]109    }
110  }
111}
Note: See TracBrowser for help on using the repository browser.