#region License Information
/* HeuristicLab
* Copyright (C) 2002-2008 Heuristic and Evolutionary Algorithms Laboratory (HEAL)
*
* This file is part of HeuristicLab.
*
* HeuristicLab is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* HeuristicLab is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with HeuristicLab. If not, see .
*/
#endregion
using System;
using System.Collections.Generic;
using System.Text;
using System.Xml;
namespace HeuristicLab.Core {
///
/// Represents a single operation with one operator and one scope.
///
public class AtomicOperation : ItemBase, IOperation {
private IOperator myOperator;
///
/// Gets the current operator as .
///
public IOperator Operator {
get { return myOperator; }
}
private IScope myScope;
///
/// Gets the current scope as .
///
public IScope Scope {
get { return myScope; }
}
///
/// Initializes a new instance of .
/// Empty constructor is needed for the persistence mechanism.
///
public AtomicOperation() { }
///
/// Initializes a new instance of with the given
/// and the given .
///
/// The operator to assign.
/// The scope to assign.
public AtomicOperation(IOperator op, IScope scope) {
myOperator = op;
myScope = scope;
}
///
/// Clones the current instance.
///
/// The operator and the scope objects are cloned with the
/// method of the class.
/// All already cloned objects. (Needed to avoid cycles.)
/// The cloned object as .
public override object Clone(IDictionary clonedObjects) {
AtomicOperation clone = new AtomicOperation();
clonedObjects.Add(Guid, clone);
clone.myOperator = (IOperator)Auxiliary.Clone(Operator, clonedObjects);
clone.myScope = (IScope)Auxiliary.Clone(Scope, clonedObjects);
return clone;
}
#region Persistence Methods
///
/// Saves the current instance as in the specified .
///
/// Calls of base
/// class .
/// The operator is saved as child node having the tag name Operator.
/// The scope is also saved as a child node having the tag name Scope.
/// The (tag)name of the .
/// The where to save the data.
/// The dictionary of all already persisted objects. (Needed to avoid cycles.)
/// The saved .
public override XmlNode GetXmlNode(string name, XmlDocument document, IDictionary persistedObjects) {
XmlNode node = base.GetXmlNode(name, document, persistedObjects);
node.AppendChild(PersistenceManager.Persist("Operator", Operator, document, persistedObjects));
node.AppendChild(PersistenceManager.Persist("Scope", Scope, document, persistedObjects));
return node;
}
///
/// Loads the persisted operation from the specified .
///
/// Calls of base class
/// .
/// The operator must be saved as a child node with the tag name Operator, also the scope must
/// be saved as a child node having the tag name Scope (see ).
/// The where the operation is saved.
/// A dictionary of all already restored objects. (Needed to avoid cycles.)
public override void Populate(XmlNode node, IDictionary restoredObjects) {
base.Populate(node, restoredObjects);
myOperator = (IOperator)PersistenceManager.Restore(node.SelectSingleNode("Operator"), restoredObjects);
myScope = (IScope)PersistenceManager.Restore(node.SelectSingleNode("Scope"), restoredObjects);
}
#endregion
}
}