Exemple #1
0
        /// <summary>
        /// Map a string to an ID so it can be looked up when serializing and deserializing.
        /// </summary>
        /// <param name="id"></param>
        /// <param name="name"></param>
        private T MapID <T>(T instance) where T : class, ILogicEntity
        {
            if (_readerMap.ContainsKey(instance.Name))
            {
                _readerMap[instance.Name] = instance.ID;
            }
            else
            {
                _readerMap.Add(instance.Name, instance.ID);
            }
            _reader.MapInstance <T>(instance);

            if (_recordingEnabled)
            {
                IXmlLogWriter <T> writer = new OpenSimLogWriter <T>(_writerMap, instance, HostPrim.Pos, true);
                _writers.Add(instance.ID, writer);
                _writerMap.Add(instance.ID, instance.Name);
                if (_currentlyRecording)
                {
                    writer.StartRecording(_modelWriter.Log);
                }
                return(writer.Instance);
            }
            return(instance);
        }
        public T Make <T>(T instance, bool recursive) where T : class
        {
            if (!_recordingEnabled)
            {
                _reader.MapInstance <T>(instance, !recursive);
                return(instance);
            }

            IXmlLogWriter <T> writer = new OpenSimLogWriter <T>(_writerMap, instance, _hostPrim.Pos, true, recursive);;

            if (_baseWriter == null)
            {
                _baseWriter = writer;
            }
            else
            {
                _writers.Add(UUID.Random(), writer);
            }

            if (_currentlyRecording)
            {
                writer.StartRecording();
            }

            _reader.MapInstance <T>(writer.Instance, !recursive);
            return(writer.Instance);
        }
Exemple #3
0
        public OriginalControl(IKeyTableFactory tableFactory, IAsynchQueueFactory queueFactory, IPrimFactory primFactory, IModel model, UUID hostID, IConfigSource config)
            : base(tableFactory, queueFactory)
        {
            _hostPrim = primFactory[hostID];

            _readerMap = new Dictionary <string, UUID>();
            _writerMap = tableFactory.MakeKeyTable <string>();
            _paused    = tableFactory.MakeKeyTable <bool>();

            IConfig controlConfig = config.Configs["Control"];
            IConfig commonConfig  = config.Configs["Common"];

            if (controlConfig == null)
            {
                controlConfig = config.Configs[0];
            }
            if (commonConfig == null)
            {
                commonConfig = config.Configs[0];
            }

            _wait             = commonConfig.GetInt("Wait", 50);
            _userFolder       = controlConfig.Get("UserFolder", ".");
            _recordingEnabled = controlConfig.GetBoolean("RecordingEnabled", false);
            _timing           = controlConfig.GetBoolean("TimedPlayback", true);
            _schemaFile       = controlConfig.GetString("TopologySchema", null);

            _reader = new OpenSimLogReader(_readerMap, model, HostPrim.Pos);
            _reader.MapInstance <IModule>(this);
            _writers = tableFactory.MakeKeyTable <IXmlLogWriter>();

            _factory = primFactory;
            if (_recordingEnabled)
            {
                _modelWriter = new OpenSimLogWriter <IModel>(_writerMap, model, HostPrim.Pos, true, false);
                _model       = _modelWriter.Instance;
                IXmlLogWriter <IModule> baseWriter = new OpenSimLogWriter <IModule>(_writerMap, this, HostPrim.Pos, true);
                _recordingBase = baseWriter.Instance;
                _writers.Add(hostID, baseWriter);
            }
            else
            {
                _model = model;
            }

            Namespace = controlConfig.Get("Namespace", Namespace);
            Logger.Info("Control started.");
        }
        /// <summary>
        /// Map a string to an ID so it can be looked up when serializing and deserializing.
        /// </summary>
        /// <param name="id"></param>
        /// <param name="name"></param>
        public T MakeMapped <T>(T instance) where T : class, IEntity
        {
            _readerMap[instance.Name] = instance.ID;
            _reader.MapInstance <T>(instance);

            if (!_recordingEnabled)
            {
                return(instance);
            }

            IXmlLogWriter <T> writer = new OpenSimLogWriter <T>(_writerMap, instance, _hostPrim.Pos, true, true);

            _writers[instance.ID]   = writer;
            _writerMap[instance.ID] = instance.Name;
            if (_currentlyRecording)
            {
                writer.StartRecording(_baseWriter.Log);
            }
            return(writer.Instance);
        }