#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 MakeStatement : OperatorBase { public override string Description { get { return "TASK."; } } public MakeStatement() : 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("Subject", "", typeof(IItem), VariableKind.In)); AddVariableInfo(new VariableInfo("Predicate", "", typeof(IItem), VariableKind.In)); AddVariableInfo(new VariableInfo("Property", "", typeof(IItem), VariableKind.In)); } public override IOperation Apply(IScope scope) { string serverUrl = GetVariableValue("CedmaServerUri", scope, true).Data; long agentId = GetVariableValue("AgentId", scope, true).Data; IItem subject = GetVariableValue("Subject", scope, true); IItem predicate = GetVariableValue("Predicate", scope, true); IItem property = GetVariableValue("Property", 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)); ItemEntry subjectEntry = new ItemEntry(); subjectEntry.Guid = subject.Guid; subjectEntry.RawData = PersistenceManager.SaveToGZip(subject); ItemEntry predicateEntry = new ItemEntry(); predicateEntry.Guid = predicate.Guid; predicateEntry.RawData = PersistenceManager.SaveToGZip(predicate); ItemEntry propertyEntry = new ItemEntry(); propertyEntry.Guid = property.Guid; propertyEntry.RawData = PersistenceManager.SaveToGZip(property); database.LinkItems(subjectEntry, predicateEntry, propertyEntry); } return null; } private IVariable FindInjectedVariable(IDatabase database, string variableName, IOperatorGraph opGraph) { foreach(IOperator op in opGraph.Operators) { IVariable var = FindInjectedVariable(database, variableName, op); if(var != null) return var; } return null; } private IVariable FindInjectedVariable(IDatabase database, string variableName, IOperator op) { IVariable var = op.GetVariable(variableName); if(var != null) return var; else if(op is CombinedOperator) { var = FindInjectedVariable(database, variableName, ((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; var = FindInjectedVariable(database, variableName, link.Operator); } return var; } } }