TemplateApp.java
- /*
- * $Source$
- * $Revision$
- *
- * Copyright (C) 2005 Tim Pizey
- *
- * Part of Melati (http://melati.org), a framework for the rapid
- * development of clean, maintainable web applications.
- *
- * Melati is free software; Permission is granted to copy, distribute
- * and/or modify this software under the terms either:
- *
- * a) 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,
- *
- * or
- *
- * b) any version of the Melati Software License, as published
- * at http://melati.org
- *
- * You should have received a copy of the GNU General Public License and
- * the Melati Software License along with this program;
- * if not, write to the Free Software Foundation, Inc.,
- * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA to obtain the
- * GNU General Public License and visit http://melati.org to obtain the
- * Melati Software License.
- *
- * Feel free to contact the Developers of Melati (http://melati.org),
- * if you would like to work out a different arrangement than the options
- * outlined here. It is our intention to allow Melati to be used by as
- * wide an audience as possible.
- *
- * This program 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.
- *
- * Contact details for copyright holder:
- *
- * Tim Pizey <timp At paneris.org>
- * http://paneris.org/~timp
- */
- package org.melati.app;
- import org.melati.Melati;
- import org.melati.template.TemplateContext;
- /**
- * An example of how to use a Template Engine with a Poem database
- * from the command line.
- *
- * Invoke:
- *
- * java -cp melati.jar:site\properties:lib\hsqldb.jar: \
- * lib\webmacro.jar:lib\servlet.jar \
- * org.melati.app.TemplateApp poemtest user 0 \
- * org/melati/app/TemplateAppExample
- *
- * Where poemtest is your database, user is your table, 0 is the record id and
- * org/melati/app/TemplateAppExample is the full name of a template.
- *
- * From within Maven try:
- *
- <plugin>
- <groupId>org.codehaus.mojo</groupId>
- <artifactId>exec-maven-plugin</artifactId>
- <executions>
- <execution>
- <id>generate</id>
- <phase>test</phase>
- <goals>
- <goal>java</goal>
- </goals>
- <configuration>
- <mainClass>org.melati.app.TemplateApp</mainClass>
- <arguments>
- <argument>mydb</argument>
- <argument>mytable</argument>
- <argument>mytroid</argument>
- <argument>mytemplate</argument>
- <argument>-output</argument>
- <argument>${basedir}/src/main/webapp/WEB-INF/web.xml</argument>
- </arguments>
- <cleanupDaemonThreads>true</cleanupDaemonThreads>
- </configuration>
- </execution>
- </executions>
- </plugin>
- *
- *
- *
- */
- public class TemplateApp extends AbstractTemplateApp {
- /**
- * The main method to override.
- *
- * @param melati A {@link Melati} with arguments and properties set
- * @param templateContext A {@link TemplateContext} containing a {@link Melati}
- * @return the name of a template to expand
- * @throws Exception if anything goes wrong
- * @see org.melati.app.AbstractTemplateApp#doTemplateRequest
- * (org.melati.Melati, org.melati.template.ServletTemplateContext)
- */
- protected String doTemplateRequest(Melati melati,
- TemplateContext templateContext) throws Exception {
- return melati.getMethod();
- }
- /**
- * The main entry point.
- *
- * @param args in format <code>db table troid method</code>
- * where method is a template name
- */
- public static void main(String[] args) throws Exception {
- TemplateApp me = new TemplateApp();
- me.run(args);
- }
- }