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

flex2.compiler.extensions.ExtensionsConfiguration Maven / Gradle / Ivy

There is a newer version: 0.9.12
Show newest version
/*
 *
 *  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 flex2.compiler.extensions;

import java.io.File;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;

import flex2.compiler.common.ConfigurationPathResolver;
import flex2.compiler.config.ConfigurationException;
import flex2.compiler.config.ConfigurationInfo;
import flex2.compiler.config.ConfigurationValue;

/**
 * This class handles extension specific configuration options.
 * Currently, there is only one, -compiler.extensions.extension.
 *
 * @author Andrew Westberg
 */
public class ExtensionsConfiguration
{
    private ConfigurationPathResolver configResolver;

    public void setConfigPathResolver( ConfigurationPathResolver resolver )
    {
        this.configResolver = resolver;
    }

    private Map> extensionMappings;

    public Map> getExtensionMappings()
    {
        if ( extensionMappings == null )
        {
            extensionMappings = new LinkedHashMap>();
        }
        return extensionMappings;
    }

    public void setExtensionMappings( Map> extensionMappings )
    {
        this.extensionMappings = extensionMappings;
    }

    //
    // 'compiler.extensions.extension' option
    //

    public String[] getExtension()
    {
        if ( extensionMappings != null )
        {
            return extensionMappings.keySet().toArray( new String[0] );
        }
        else
        {
            return null;
        }
    }

    /**
     * Configures a list of many extensions mapped to a single Extension URI. 
     * something-extension.jar version=1.1,content=1.2 
     * 
     * @param cfgval The configuration value context.
     * @param args A List of values for the Extension element, with the first item expected to be the uri and the
     *            remaining are extension paths.
     * @throws ConfigurationException When no arg is provided or when the jar does not exist.
     */
    public void cfgExtension( ConfigurationValue cfgval, List args )
        throws ConfigurationException
    {
        if ( args == null )
        {
            throw new ConfigurationException.CannotOpen( null, cfgval.getVar(), cfgval.getSource(), cfgval.getLine() );
        }

        if ( configResolver == null )
        {
            throw new ConfigurationException.CannotOpen( null, cfgval.getVar(), cfgval.getSource(), cfgval.getLine() );
        }

        Iterator iterator = args.iterator();
        String extension = iterator.next();

        File file = new File( extension );
        if ( !file.exists() )
        {
            throw new ConfigurationException.NotAFile( extension, cfgval.getVar(), cfgval.getSource(), cfgval.getLine() );
        }

        List parameters = new ArrayList();
        while ( iterator.hasNext() )
        {
            parameters.add( iterator.next() );
        }

        getExtensionMappings().put( file.getAbsolutePath(), parameters );
    }

    public static ConfigurationInfo getExtensionInfo()
    {
        return new ConfigurationInfo( -1, new String[] { "extension", "parameters" } )
        {
            public boolean allowMultiple()
            {
                return true;
            }
        };
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy