#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.Linq; using System.Text; using HeuristicLab.Core; using System.Xml; using HeuristicLab.CEDMA.DB.Interfaces; using HeuristicLab.Operators; namespace HeuristicLab.CEDMA.Core { public class Agent : IAgent { public IDatabase Database { get; set; } public long Id { get; set; } public string Name { get; set; } public ProcessStatus Status { get; set; } public bool Terminated { get; set; } private OperatorGraph operatorGraph; public IOperatorGraph OperatorGraph { get { return operatorGraph; } } public Agent() : base() { operatorGraph = new OperatorGraph(); } public Agent(IDatabase database, long id) : this() { Database = database; Id = id; } public void Save() { Database.UpdateAgent(Id, Name); Database.UpdateAgent(Id, Status); Database.UpdateAgent(Id, PersistenceManager.SaveToGZip(OperatorGraph)); } public void Start() { Status = ProcessStatus.Waiting; Save(); } public ICollection SubAgents { get { List agents = new List(); foreach(AgentEntry entry in Database.GetSubAgents(Id)) { Agent newAgent = new Agent(Database, entry.Id); newAgent.Name = entry.Name; newAgent.Status = entry.Status; agents.Add(newAgent); } return agents; } } public ICollection Results { get { List results = new List(); foreach(ResultEntry entry in Database.GetResults(Id)) { Result result = new Result(Database, entry.Id); result.Summary = entry.Summary; result.Description = entry.Description; results.Add(result); } return results; } } public IView CreateView() { if(OperatorGraph.Operators.Count == 0) { byte[] rawData = Database.GetAgentRawData(Id); IOperatorGraph opGraph = (IOperatorGraph)PersistenceManager.RestoreFromGZip(rawData); foreach(IOperator op in opGraph.Operators) OperatorGraph.AddOperator(op); OperatorGraph.InitialOperator = opGraph.InitialOperator; OperatorLinkPatcher.LinkDatabase(OperatorGraph, Database); } return new AgentView(this); } } }