AntPropertyFileGenerator.java :  » Issue-Tracking » scarab-0.21 » org » tigris » scarab » util » build » Java Open Source

Java Open Source » Issue Tracking » scarab 0.21 
scarab 0.21 » org » tigris » scarab » util » build » AntPropertyFileGenerator.java
package org.tigris.scarab.util.build;

/* ================================================================
 * Copyright (c) 2000-2002 CollabNet.  All rights reserved.
 * 
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are
 * met:
 * 
 * 1. Redistributions of source code must retain the above copyright
 * notice, this list of conditions and the following disclaimer.
 * 
 * 2. Redistributions in binary form must reproduce the above copyright
 * notice, this list of conditions and the following disclaimer in the
 * documentation and/or other materials provided with the distribution.
 * 
 * 3. The end-user documentation included with the redistribution, if
 * any, must include the following acknowlegement: "This product includes
 * software developed by Collab.Net <http://www.Collab.Net/>."
 * Alternately, this acknowlegement may appear in the software itself, if
 * and wherever such third-party acknowlegements normally appear.
 * 
 * 4. The hosted project names must not be used to endorse or promote
 * products derived from this software without prior written
 * permission. For written permission, please contact info@collab.net.
 * 
 * 5. Products derived from this software may not use the "Tigris" or 
 * "Scarab" names nor may "Tigris" or "Scarab" appear in their names without 
 * prior written permission of Collab.Net.
 * 
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
 * IN NO EVENT SHALL COLLAB.NET OR ITS CONTRIBUTORS BE LIABLE FOR ANY
 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
 * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
 * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
 * ====================================================================
 * 
 * This software consists of voluntary contributions made by many
 * individuals on behalf of Collab.Net.
 */

import java.io.FileNotFoundException;
import java.io.IOException;

import org.apache.tools.ant.BuildException;
import org.apache.tools.ant.Task;

/**
 * This class is used as ant task backend for the generation
 * of a property file by use of a template file.
 *
 * @author <a href="mailto:dabbous@saxess.com">Hussayn Dabbous</a>
 * @version $Id: AntPropertyFileGenerator.java 9421 2005-02-20 22:32:38Z jorgeuriarte $
 */

public class AntPropertyFileGenerator extends Task implements PropertyGetter
{
    
    /**
     * Setter: set the path to the template file.
     * Throws an exception, if the template file does not exist.
     * @param theTemplatePath
     */
    
    /**
     * The reusable property file generator
     */
    private PropertyFileGenerator generator = new PropertyFileGenerator();
    
    public void setTemplate(String theTemplatePath)
    {
        boolean status = generator.setTemplate(theTemplatePath);
        if(!status)
        {
           throw new BuildException("the template["
                + theTemplatePath
                + "] does not exist.");
        }
    }

    /**
     * Setter: set the path to the final property file.
     * Throws an exception, if the customFile exist, 
     * but can't be overwritten (due to permission settings).
     * @param theCustomPath
     */
    public void setCustom(String theCustomPath)
    {
        boolean status = generator.setCustom(theCustomPath);
        if(!status)
        {
            throw new BuildException("custom file ["
                    + generator.getCustom()
                    + "] is not writable.");

        }
    }

    /**
     * Setter: set the path to the final property file.
     * Throws an exception, if the customFile exist, 
     * but can't be overwritten (due to permission settings).
     * @param theCustomPath
     */
    public void setProperties(String thePropertyFilePathes)
    {
        boolean status = generator.setProperties(thePropertyFilePathes);
        if(!status)
        {
            throw new BuildException("problem with the propretyFilePathlist["
                    + thePropertyFilePathes
                    + "] one file is not readable.");

        }
    }

    
    /**
     * Read the templateFile and behave according to 
     * following rule set:
     * <ul>
     * <li> rule 1: Copy every line, which does NOT contain
     *      a property verbatim to the customFile.</li>
     * 
     * <li> rule 2: Retrieve the current online value of each 
     *      property found in the templateFile and generate an 
     *      appropriate name/value pair in the customFile.</li>
     * 
     * <li> rule 3: If a property value starts with a "${" in 
     *      the templateFile, keep the value as is. By this we 
     *      can propagate ${variables} to the customFile, which 
     *      will be resolved during startup of Scarab.</li>
     * </ul>
     * 
     */
    public void execute() {
        log("Create custom file: '" + generator.getCustom() + "'.");
        log("Using  template   : '" + generator.getTemplate() );
        
        try {
            generator.execute(this);
        }
        catch (FileNotFoundException e)
        {
            throw new BuildException( "File not found: " + e.getMessage() );
        }
        catch (IOException e)
        {
            throw new BuildException("Error during read from ["
                    + generator.getTemplate()
                    + "]: "+e.getMessage());
        }

    }

    /**
     * This is the method by which the generator can retrieve
     * property values.
     * @param name
     * @return
     */
    public Object getProperty(String name, Object def)
    {
        String result = null;

        String value = (String) def;
        if (value==null || !value.startsWith("$"))
        {
            result = getProject().getProperty(name);
        }
        if(result == null)
        {
            result = value;
        }
        return result;
    }
}
java2s.com  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.