/* * SchemaCrawler * http://sourceforge.net/projects/schemacrawler * Copyright (c) 2000-2013, Sualeh Fatehi. * This library is free software; you can redistribute it and/or modify it under * the terms * of the GNU Lesser General Public License as published by the Free Software * Foundation; * either version 2.1 of the License, or (at your option) any later version. * This library 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 Lesser General Public License for more details. * You should have received a copy of the GNU Lesser General Public License * along with this * library; if not, write to the Free Software Foundation, Inc., 59 Temple * Place, Suite 330, * Boston, MA 02111-1307, USA. */ package schemacrawler.tools.integration.freemarker; import java.io.File; import java.io.Writer; import java.sql.Connection; import java.util.HashMap; import java.util.Locale; import java.util.Map; import java.util.logging.Level; import java.util.logging.Logger; import schemacrawler.schema.Database; import schemacrawler.tools.executable.BaseExecutable; import schemacrawler.tools.options.OutputWriter; import freemarker.cache.ClassTemplateLoader; import freemarker.cache.FileTemplateLoader; import freemarker.cache.MultiTemplateLoader; import freemarker.cache.TemplateLoader; import freemarker.template.Configuration; import freemarker.template.DefaultObjectWrapper; import freemarker.template.Template; /** * Main executor for the FreeMarker integration. * * @author Sualeh Fatehi */ public final class FreeMarkerRenderer extends BaseExecutable { private static final Logger LOGGER = Logger .getLogger(FreeMarkerRenderer.class.getName()); static final String COMMAND = "freemarker"; public FreeMarkerRenderer() { super(COMMAND); } /** * {@inheritDoc} */ @Override protected final void executeOn(final Database database, final Connection connection) throws Exception { // Set the file path, in case the template is a file template // This allows Velocity to load templates from any directory String templateLocation = outputOptions.getOutputFormatValue(); String templatePath = "."; final File templateFilePath = new File(templateLocation); if (templateFilePath.exists()) { templatePath = templateFilePath.getAbsoluteFile().getParent(); templateLocation = templateFilePath.getName(); } freemarker.log.Logger .selectLoggerLibrary(freemarker.log.Logger.LIBRARY_JAVA); // Create a new instance of the configuration final Configuration cfg = new Configuration(); final TemplateLoader ctl = new ClassTemplateLoader(FreeMarkerRenderer.class, "/"); final TemplateLoader ftl = new FileTemplateLoader(new File(templatePath)); final TemplateLoader mtl = new MultiTemplateLoader(new TemplateLoader[] { ctl, ftl }); cfg.setTemplateLoader(mtl); cfg .setEncoding(Locale.getDefault(), outputOptions.getInputCharset().name()); cfg.setStrictSyntaxMode(true); cfg.setWhitespaceStripping(true); cfg.setObjectWrapper(new DefaultObjectWrapper()); LOGGER.log(Level.INFO, Configuration.getVersionNumber()); LOGGER.log(Level.INFO, "FreeMarker configuration properties - " + cfg); // Create the root hash final Map<String, Object> objectMap = new HashMap<>(); objectMap.put("database", database); try (final Writer writer = new OutputWriter(outputOptions);) { // Evaluate the template final Template template = cfg.getTemplate(templateLocation); template.process(objectMap, writer); } } }