/// <summary> /// Initializes the context and loads necessary data into memory through the configured database adapter. /// This must be done before the context is usable. /// </summary> public virtual void Initialize() { if (this.Adapter == null) { throw new InvalidConfigurationException("DBContext requires a configured database adapter. Please check your configuration."); } // Initiaze NHibernate session this.Adapter.Initialize(this); new Thread(delegate() { using (InitLock.WriteLock()) { // Initialize ingredient parser this.ingredientParser = new IngredientParser(); var ingredientIndex = this.Adapter.LoadIngredientsForIndex(); this.ingredientParser.CreateIndex(ingredientIndex); // Initialize modeler this.modeler = new ModelerProxy(this); this.modeler.LoadSnapshot(); // Initialize natural language parsing IngredientSynonyms.InitIndex(this.Adapter.IngredientLoader); UnitSynonyms.InitIndex(this.Adapter.UnitLoader); FormSynonyms.InitIndex(this.Adapter.FormLoader); PrepNotes.InitIndex(this.Adapter.PrepLoader); Anomalies.InitIndex(this.Adapter.AnomalyLoader); NumericVocab.InitIndex(); this.parser = new Parser(); this.LoadTemplates(); } }).Start(); Thread.Sleep(500); // Provides time for initialize thread to start and acquire InitLock }
public void Initialize() { ModelerProxy = new ModelerProxy(this); ModelerProxy.LoadSnapshot(); }
/// <summary> /// Initializes the context and loads necessary data into memory through the configured data file. /// This must be done before the context is usable. /// </summary> public void Initialize() { var file = CompressedStore ? "KPCData.gz" : "KPCData.xml"; var path = Path.Combine(DataDirectory, file); KPCContext.Log.DebugFormat("Attempting to open local data file: {0}", path); if (!File.Exists(path)) throw new FileNotFoundException("Could not initialize StaticContext. Data file not found.", path); var serializer = new XmlSerializer(typeof (DataStore)); using (var fileReader = new FileStream(path, FileMode.Open)) { if (CompressedStore) { using (var reader = new GZipStream(fileReader, CompressionMode.Decompress)) { store = serializer.Deserialize(reader) as DataStore; } } else { store = serializer.Deserialize(fileReader) as DataStore; } if (store == null) throw new DataStoreException("Could not deserialize data store. It might be correct or an invalid format."); } // Initialize ingredient parser ingParser = new IngredientParser(); ingParser.CreateIndex(store.Ingredients.Select(i => new IngredientSource(i.IngredientId, i.DisplayName))); // Initialize modeler ModelerProxy = new ModelerProxy(this); ModelerProxy.LoadSnapshot(); // Initialize natural language parsing IngredientSynonyms.InitIndex(new StaticIngredientLoader(store)); UnitSynonyms.InitIndex(new StaticUnitLoader(store)); FormSynonyms.InitIndex(new StaticFormLoader(store)); PrepNotes.InitIndex(new StaticPrepLoader(store)); Anomalies.InitIndex(new StaticAnomalyLoader(store)); NumericVocab.InitIndex(); Parser = new Parser(); LoadTemplates(); }