X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=source%2Fmircoders%2Flocalizer%2Fbasic%2FMirBasicProducerLocalizer.java;h=24b9982f37a87801f89162a0740a7afb0b6e71dc;hb=04bf29aa1f1abf43e96d0272b2a286f0c1f9fea8;hp=741d0f1c3c558badf0896d5a48900f691e82a8d7;hpb=e42ecea2db8ff123f268edf48190d6b9b28fcedb;p=mir.git diff --git a/source/mircoders/localizer/basic/MirBasicProducerLocalizer.java b/source/mircoders/localizer/basic/MirBasicProducerLocalizer.java index 741d0f1c..24b9982f 100755 --- a/source/mircoders/localizer/basic/MirBasicProducerLocalizer.java +++ b/source/mircoders/localizer/basic/MirBasicProducerLocalizer.java @@ -1,142 +1,185 @@ +/* + * Copyright (C) 2001, 2002 The Mir-coders group + * + * This file is part of Mir. + * + * Mir 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 2 of the License, or + * (at your option) any later version. + * + * Mir 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 Mir; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * + * In addition, as a special exception, The Mir-coders gives permission to link + * the code of this program with any library licensed under the Apache Software License, + * The Sun (tm) Java Advanced Imaging library (JAI), The Sun JIMI library + * (or with modified versions of the above that use the same license as the above), + * and distribute linked combinations including the two. You must obey the + * GNU General Public License in all respects for all of the code used other than + * the above mentioned libraries. If you modify this file, you may extend this + * exception to your version of the file, but you are not obligated to do so. + * If you do not wish to do so, delete this exception statement from your version. + */ package mircoders.localizer.basic; -import java.util.*; -import java.io.*; -import mir.producer.*; -import mir.generator.*; -import mir.producer.reader.*; -import mir.misc.*; -import mir.util.*; -import mir.entity.adapter.*; -import mircoders.global.*; -import mircoders.global.*; -import mircoders.localizer.*; -import mircoders.producer.reader.*; -import mircoders.producer.*; +import java.io.File; +import java.util.HashMap; +import java.util.Iterator; +import java.util.List; +import java.util.Map; +import java.util.Vector; + +import mir.entity.adapter.EntityAdapterModel; +import mir.generator.Generator; +import mir.generator.WriterEngine; +import mir.log.LoggerWrapper; +import mir.producer.ProducerFactory; +import mir.producer.reader.DefaultProducerNodeBuilders; +import mir.producer.reader.ProducerConfigReader; +import mir.producer.reader.ProducerNodeBuilderLibrary; +import mir.util.FileMonitor; +import mir.util.StringRoutines; +import mircoders.global.MirGlobal; +import mircoders.global.ProducerEngine; +import mircoders.localizer.MirLocalizerExc; +import mircoders.localizer.MirLocalizerFailure; +import mircoders.localizer.MirProducerLocalizer; +import mircoders.producer.reader.SupplementalProducerNodeBuilders; public class MirBasicProducerLocalizer implements MirProducerLocalizer { - private Map producerFactories; + private List producerFactories; + private Map nameToFactory; + + private Map producerRecipes; + private List producerRecipeNames; + protected FileMonitor fileMonitor; protected EntityAdapterModel model; protected Generator.GeneratorLibrary generatorLibrary; protected WriterEngine writerEngine; - protected static Logfile logger = Logfile.getInstance( MirGlobal.getConfigProperty("Home") + "/" + MirGlobal.getConfigProperty("Mir.Localizer.Logfile")); + protected LoggerWrapper logger; public MirBasicProducerLocalizer() { - try { - producerFactories = new HashMap(); + logger = new LoggerWrapper("Localizer.Basic.Producer"); + + producerRecipes = new HashMap(); + producerRecipeNames = new Vector(); + + String[] recipes = MirGlobal.config().getStringArray("Mir.Localizer.Producer.ProducerRecipes"); + for (int i = 0; i0) { + producerRecipes.put("allnew", ProducerEngine.ProducerTask.parseProducerTaskList(allNewProducers)); + producerRecipeNames.add("allnew"); + } + + producerFactories = new Vector(); model = MirGlobal.localizer().dataModel().adapterModel(); - generatorLibrary = MirGlobal.localizer().generators().makeGeneratorLibrary(); + generatorLibrary = MirGlobal.localizer().generators().makeProducerGeneratorLibrary(); writerEngine = MirGlobal.localizer().generators().makeWriterEngine(); + nameToFactory = new HashMap(); } catch (Throwable t) { - logger.printError("MirBasicProducerLocalizer(): Exception "+t.getMessage()); + logger.error("MirBasicProducerLocalizer(): Exception "+t.getMessage()); model = new EntityAdapterModel(); } } - public Map factories() throws MirLocalizerException { + public List getRecipeNames() throws MirLocalizerExc, MirLocalizerFailure { + return producerRecipeNames; + } + + public void produceRecipe(String aName) throws MirLocalizerExc, MirLocalizerFailure { + if (producerRecipes.containsKey(aName)) + MirGlobal.producerEngine().addTasks((List) producerRecipes.get(aName)); + else + throw new MirLocalizerExc("Unknown recipe name: " + aName); + } + + public List factories() throws MirLocalizerExc { if (fileMonitor==null || producerFactories == null || fileMonitor.hasChanged()) { try { - Map newProducers = new HashMap(); + List newProducers = new Vector(); FileMonitor newFileMonitor = new FileMonitor(); setupFactories(newProducers, newFileMonitor); producerFactories = newProducers; fileMonitor = newFileMonitor; + logger.info("MirBasicProducerLocalizer.factories(): successfully setup factories"); + + nameToFactory.clear(); + Iterator i = producerFactories.iterator(); + while (i.hasNext()) { + ProducerFactory factory = (ProducerFactory) i.next(); + nameToFactory.put(factory.getName(), factory); + } } catch (Throwable t) { - logger.printError("MirBasicProducerLocalizer.factories(): Unable to setup factories: "+t.getMessage()); + logger.error("MirBasicProducerLocalizer.factories(): Unable to setup factories: "+t.getMessage()); + t.printStackTrace(logger.asPrintWriter(LoggerWrapper.DEBUG_MESSAGE)); } } return producerFactories; }; - protected void setupContentFactory(CompositeProducerNode aProducerNode) { - } - - protected void setupStartPageFactory(CompositeProducerNode aProducerNode) { - } - - protected void setupSynchronizationFactory(CompositeProducerNode aProducerNode) { - if(MirGlobal.getConfigBooleanProperty("Rsync")){ - aProducerNode.addSubNode( - new ScriptCallingProducerNode(MirGlobal.getConfigProperty("Rsync.Script.Path")) - ); + public ProducerFactory getFactoryForName(String aName) { + try { + factories(); + } + catch (Throwable t) { } - } - - protected void setupStaticFactory(CompositeProducerNode aProducerNode) { - } - protected void setupTopicsFactory(CompositeProducerNode aProducerNode) { + return (ProducerFactory) nameToFactory.get(aName); } - protected void setupProducerNodeBuilderLibrary(ProducerNodeBuilderLibrary aLibrary) { - DefaultProducerNodeBuilders.registerBuilders(aLibrary, model, generatorLibrary, writerEngine); - SupplementalProducerNodeBuilders.registerBuilders(aLibrary, model); + protected void setupProducerNodeBuilderLibrary(ProducerNodeBuilderLibrary aLibrary) throws MirLocalizerFailure { + try { + DefaultProducerNodeBuilders.registerBuilders( + aLibrary, model, generatorLibrary, writerEngine, + MirGlobal.config().getString("Home"), MirGlobal.config().getString("Producer.StorageRoot")); + SupplementalProducerNodeBuilders.registerBuilders(aLibrary, model); + } + catch (Throwable t) { + throw new MirLocalizerFailure(t.getMessage(), t); + } } - protected void setupFactories(Map aFactoriesMap, FileMonitor aFileMonitor) throws MirLocalizerException, MirLocalizerFailure { + protected void setupFactories(List aFactories, FileMonitor aFileMonitor) throws MirLocalizerExc, MirLocalizerFailure { ProducerConfigReader reader; ProducerNodeBuilderLibrary library = new ProducerNodeBuilderLibrary(); setupProducerNodeBuilderLibrary(library); - List usedFiles = new Vector(); aFileMonitor.clear(); reader = new ProducerConfigReader(); - reader.parseFile(MirGlobal.getConfigProperty("Home") + "/" + MirGlobal.getConfigProperty("Mir.Localizer.ProducerConfigFile"), library, aFactoriesMap, usedFiles); - - Iterator i = usedFiles.iterator(); - while (i.hasNext()) - aFileMonitor.addFile((File) i.next()); - setupFactories(aFactoriesMap); + File inputFile = new File(MirGlobal.config().getString("Home"), MirGlobal.config().getString("Mir.Localizer.ProducerConfigFile")); + aFileMonitor.addFile(inputFile); + reader.parse(inputFile, library, aFactories); } - - protected void setupFactories(Map aFactoriesMap ) throws MirLocalizerException, MirLocalizerFailure { - CompositeProducerNode node; - - try { - node = new CompositeProducerNode(); - setupContentFactory( node ); - if (node.getNrSubNodes()>0) - aFactoriesMap.put("content", new NodedProducerFactory(node)); - - node = new CompositeProducerNode(); - setupStartPageFactory( node ); - if (node.getNrSubNodes()>0) - aFactoriesMap.put("startpage", new NodedProducerFactory(node)); - - node = new CompositeProducerNode(); - setupSynchronizationFactory( node ); - if (node.getNrSubNodes()>0) - aFactoriesMap.put("synchronization", new NodedProducerFactory(node)); - - node = new CompositeProducerNode(); - setupStaticFactory( node ); - if (node.getNrSubNodes()>0) - aFactoriesMap.put("static", new NodedProducerFactory(node)); - - node = new CompositeProducerNode(); - setupTopicsFactory( node ); - if (node.getNrSubNodes()>0) - aFactoriesMap.put("topics", new NodedProducerFactory(node)); - - aFactoriesMap.put("media", - new CompositeProducerFactory( new ProducerFactory[] { - new OldProducerAdapterFactory(new ProducerImages()), - new OldProducerAdapterFactory(new ProducerAudio()), - new OldProducerAdapterFactory(new ProducerVideo()), - new OldProducerAdapterFactory(new ProducerOther()) - } ) - ); - } - catch (Exception e) { - throw new MirLocalizerFailure(e); - } - }; }