All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.greenlaw110.rythm.extension.ISourceCodeEnhancer Maven / Gradle / Ivy

Go to download

A strong typed high performance Java Template engine with .Net Razor like syntax

The newest version!
/* 
 * Copyright (C) 2013 The Rythm Engine project
 * Gelin Luo 
 *
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
*/
package com.greenlaw110.rythm.extension;

import com.greenlaw110.rythm.template.ITemplate;

import java.util.List;
import java.util.Map;

/**
 * Allow user application or more probably a framework plugin based on rythm to inject
 * common import statements, render arguments and source code into generated java source code
 */
public interface ISourceCodeEnhancer {

    /**
     * Return a list of import statement to be injected into the generated java source code.
     * 

*

Note, only package declaration part needs to be put inside the Strings. the * import directive is not required. E.g.

*

*


     * List ls = new ArrayList();
     * ls.put("models.*");
     * ls.put("controllers.*);
     * 
*

*

This method is called by rythm when generating java source * code out from a template souce code

* * @return list of imports */ List imports(); /** * Return source code to be added to template class. This method * is called during code generation to inject customized source code * into final generated template source. The string returned will be * injected into the generated template source code class body directly * * @return the added source code */ String sourceCode(); /** * Return implicit render args type information indexed by render arg name. * The type info could be either a Class instance or a String * of the class name. E.g, if the implicit render args are *

*


     * Map descs = new HashMap();
     * descs.put("_play", play.Play.class); // arg type with Class instance
     * descs.put("request", "play.mvc.Request"); // arg type with class name
     * 
*

*

The method is called when {@link com.greenlaw110.rythm.internal.CodeBuilder code builder} * generating the java source out from the template source

* * @return render arg types mapped by name */ Map getRenderArgDescriptions(); /** * Set implicit render arg values to a * {@link com.greenlaw110.rythm.template.ITemplate template instance}. Usually inside this * method, the implicit arguments to be set should be corresponding to the * render args described in {@link #getRenderArgDescriptions()} method. E.g. *

*


     * template.__setRenderArg("_play", new play.Play());
     * template.__setRenderArg("request", play.mvc.Request.current());
     * 
*

*

This method is called before {@link com.greenlaw110.rythm.RythmEngine rythm engine} start * to execute a template instance

* * @param template */ void setRenderArgs(ITemplate template); /** * This is used by {@link com.greenlaw110.rythm.conf.RythmConfiguration} and user application * should not use this static member */ public static final class INSTS { public static final ISourceCodeEnhancer NULL = new ISourceCodeEnhancer() { @Override public Map getRenderArgDescriptions() { return null; } @Override public void setRenderArgs(ITemplate template) { } @Override public String sourceCode() { return null; } @Override public List imports() { return null; } }; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy