#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 HeuristicLab.Core; using HeuristicLab.Data; using System.Threading; using HeuristicLab.CEDMA.DB.Interfaces; using System.ServiceModel; using HeuristicLab.CEDMA.Core; using HeuristicLab.Operators; namespace HeuristicLab.CEDMA.Operators { public class InjectedVariableExtractor : OperatorBase { public override string Description { get { return "TASK."; } } public InjectedVariableExtractor() : base() { AddVariableInfo(new VariableInfo("AgentId", "Id of the agent to extract injected variables from.", typeof(IntData), VariableKind.In)); AddVariableInfo(new VariableInfo("CedmaServerUri", "Uri of the CEDMA server", typeof(StringData), VariableKind.In)); AddVariableInfo(new VariableInfo("VariableNames", "The names of injected variables that should be extracted", typeof(ItemList), VariableKind.In)); } public override IOperation Apply(IScope scope) { string serverUrl = GetVariableValue("CedmaServerUri", scope, true).Data; long agentId = GetVariableValue("AgentId", scope, true).Data; ItemList variableNames = GetVariableValue>("VariableNames", scope, true); NetTcpBinding binding = new NetTcpBinding(); binding.MaxReceivedMessageSize = 10000000; // 10Mbytes binding.ReaderQuotas.MaxStringContentLength = 10000000; // also 10M chars binding.ReaderQuotas.MaxArrayLength = 10000000; // also 10M elements; binding.Security.Mode = SecurityMode.None; using(ChannelFactory factory = new ChannelFactory(binding)) { IDatabase database = factory.CreateChannel(new EndpointAddress(serverUrl)); IOperatorGraph opGraph = (IOperatorGraph)PersistenceManager.RestoreFromGZip(database.GetAgentRawData(agentId)); OperatorLinkPatcher.LinkDatabase(opGraph, database); ItemList clone = new ItemList(); foreach(StringData name in variableNames) clone.Add(name); List vars = FindInjectedVariable(database, clone, opGraph); foreach(IVariable var in vars) { scope.AddVariable(var); } } return null; } private List FindInjectedVariable(IDatabase database, ItemList variableNames, IOperatorGraph opGraph) { List vars = new List(); foreach(IOperator op in opGraph.Operators) { vars.AddRange(FindInjectedVariable(database, variableNames, op)); } return vars; } private List FindInjectedVariable(IDatabase database, ItemList variableNames, IOperator op) { List vars = new List(); List missingVariables = new List(); foreach(StringData variableName in variableNames) missingVariables.Add(variableName.Data); foreach(string variableName in missingVariables) { IVariable var = op.GetVariable(variableName); if(var != null) { vars.Add(var); variableNames.Remove(new StringData(variableName)); } } if(op is CombinedOperator) { vars.AddRange(FindInjectedVariable(database, variableNames, ((CombinedOperator)op).OperatorGraph)); } else if(op is OperatorLink) { OperatorLink link = op as OperatorLink; OperatorEntry targetEntry = database.GetOperator(link.Id); IOperator target = (IOperator)PersistenceManager.RestoreFromGZip(targetEntry.RawData); OperatorLinkPatcher.LinkDatabase(target, database); link.Operator = target; vars.AddRange(FindInjectedVariable(database, variableNames, link.Operator)); } return vars; } } }