flex2.compiler.common.Configuration Maven / Gradle / Ivy
/*
*
* 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.common;
//import flash.localization.LocalizationManager;
import flex2.compiler.common.FramesConfiguration.FrameInfo;
import flex2.compiler.config.AdvancedConfigurationInfo;
import flex2.compiler.config.CommandLineConfigurator;
import flex2.compiler.config.ConfigurationException;
import flex2.compiler.config.ConfigurationValue;
import flex2.compiler.config.ConfigurationInfo;
import flex2.compiler.io.VirtualFile;
import flex2.compiler.util.QName;
//import flex2.compiler.util.ThreadLocalToolkit;
import flex2.linker.LinkerConfiguration;
import flex2.tools.LicensesConfiguration;
import java.util.ArrayList;
import java.util.Collections;
import java.util.LinkedHashSet;
import java.util.Map;
import java.util.HashMap;
import java.util.List;
import java.util.LinkedList;
import java.util.HashSet;
import java.util.Set;
import java.util.Collection;
import java.util.Iterator;
import java.util.SortedSet;
import java.util.TreeSet;
import java.io.File;
import javax.xml.parsers.SAXParserFactory;
import javax.xml.parsers.SAXParser;
import macromedia.asc.util.ObjectList;
import org.xml.sax.helpers.DefaultHandler;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
/**
* Tools like mxmlc and compc use configuration objects to store
* configuration options parsed from config files and command-line options.
*
* The configuration object is produced by
* flex2.tools.Mxmlc.processConfiguration().
* This method can produce instances of various subclasses:
*
* Configuration
* ToolsConfiguration
* ASDocConfiguration (for asdoc command-line tool)
* CommandLineConfiguration (for mxmlc command-line tool)
* CompcConfiguration (for compc command-line tool)
* ApplicationCompilerConfiguration (for OEM ApplicationCompiler)
* LibraryCompilerConfiguration (for OEM LibraryCompiler)
*
* There are also "sub-configuration" classes such as
* CompilerConfiguration and MetadataConfiguration.
* Instances of these classes store dotted/nested config options.
* For example, the -compiler.library-path command line option
* (corresponding to ...
* in an XML config file) is stored in CompilerConfiguration,
* which is owned by Configuration.
*
* A configuration class does not have to extend Configuration
* or implement any interface.
* Instead, configuration objects get populated with configuration
* information via reflection.
* A configuration class declares that it support a particular
* option such as -library-path / simply by having
* the public methods getLibraryPathInfo() and cfgLibraryPath().
* (Note the change in spelling from library-path to LibraryPath.)
*
* A method like getLibraryPathInfo() returns a ConfigurationInfo object
* which has metadata about the option, such as its description,
* whether it can have a single value or multiple values, etc.
*
* After the ConfigurationBuffer has accumulated all ConfigurationValue
* objects parsed from various source by "configurators"
* such as DefaultsConfigurator, SystemPropertyConfiguration,
* FileConfigurator, and CommandLineConfigurator, it pushes these
* ConfigurationValues into the configuration objects that accept them
* via methods like cfgLibraryPath().
* The ConfigurationBuffer inspects the type of the second parameter
* of this method and can pass, for example, a String array
* in addition to the general ConfigurationValue.
*
* Typically a cfgXXX() method will simply store the option value,
* or some transformed version of it, in a private field such as
* libraryPath.
* A public method such as getLibraryPath() -- whose name doesn't
* matter because it doesn't get called through reflection --
* then exposes the option to the tool.
*
* You can force one configuration option to be set before another,
* and avoid race conditions, by using the
* ConfigurationInfo.getSoftPrerequisites() method.
*
* @author Roger Gonzalez
* @author Gordon Smith (notes below)
*/
public class Configuration implements LinkerConfiguration, Cloneable
{
// ATTENTION:
// Please specify default values inside DefaultsConfigurator.
public Configuration()
{
this.compilerConfiguration = new CompilerConfiguration(this);
frames = new FramesConfiguration();
metadataConfiguration = new MetadataConfiguration();
licensesConfiguration = new LicensesConfiguration();
rslSettingsConfiguration = new RuntimeSharedLibrarySettingsConfiguration(this);
}
/**
*
* @param compilerConfig - may not be null
* @param configuration - may be null
* @return excluded libraries summed from all configuration options
*/
public static VirtualFile[] getAllExcludedLibraries(CompilerConfiguration compilerConfig,
Configuration configuration)
{
return (VirtualFile[]) CompilerConfiguration.merge(
compilerConfig.getExternalLibraryPath(),
((configuration == null) ? null
: configuration.getRslExcludedLibraries()),
VirtualFile.class);
}
/**
* The path of a given file name based on the context of the
* configuration value or the default output directory token.
*
* @param cv
* @param fileName
* @return the full path of the file.
*/
public static String getOutputPath(ConfigurationValue cv, String fileName)
{
String result = fileName;
if (fileName != null)
{
File file = new File(fileName);
if (!file.isAbsolute())
{
String directory = cv.getBuffer().getToken(flex2.tools.oem.Configuration.DEFAULT_OUTPUT_DIRECTORY_TOKEN);
// if no default output directory, then use the configuration context.
if (directory == null)
{
directory = cv.getContext();
}
if (directory != null)
{
result = directory + File.separatorChar + fileName;
}
}
}
return result;
}
protected ConfigurationPathResolver configResolver;
public void setConfigPathResolver( ConfigurationPathResolver resolver )
{
this.configResolver = resolver;
this.compilerConfiguration.setConfigPathResolver( resolver );
this.rslSettingsConfiguration.setConfigPathResolver(resolver);
}
static private Map aliases = null;
static public Map getAliases()
{
if (aliases == null)
{
aliases = new HashMap();
aliases.put( "l", "compiler.library-path" );
aliases.put( "el", "compiler.external-library-path" );
aliases.put( "sp", "compiler.source-path");
aliases.put( "rsl", "runtime-shared-libraries");
aliases.put( "keep", "compiler.keep-generated-actionscript");
aliases.put( "o", "output" );
aliases.put("rslp", "runtime-shared-library-path");
aliases.put("static-rsls", "static-link-runtime-shared-libraries");
aliases.put("rsl-domain", "runtime-shared-library-settings.application-domain");
}
return aliases;
}
/**
* SWF width
*/
private String width = null;
private String widthPercent = null;
public String width()
{
return width;
}
public String widthPercent()
{
return widthPercent;
}
public void setWidth( String width )
{
this.width = width;
}
public void setWidthPercent(String widthPercent)
{
this.widthPercent = widthPercent;
}
/**
* SWF height
*/
private String height = null;
private String heightPercent = null;
public String height()
{
return height;
}
public String heightPercent()
{
return heightPercent;
}
public void setHeight( String height )
{
this.height = height;
}
public void setHeightPercent(String heightPercent)
{
this.heightPercent = heightPercent;
}
/**
* Page title
*/
private String pageTitle = null;
public String pageTitle()
{
return pageTitle;
}
public void setPageTitle(String title)
{
this.pageTitle = title;
}
/**
* Root class name
*/
private String rootClassName;
public String getRootClassName()
{
return (rootClassName != null)? rootClassName : mainDefinition;
}
public void setRootClassName( String rootClassName )
{
this.rootClassName = rootClassName;
}
/**
* Main definition
*/
private String mainDefinition;
public String getMainDefinition()
{
return mainDefinition;
}
public void setMainDefinition( String mainDefinition )
{
this.mainDefinition = mainDefinition;
}
/**
* Resource bundles
*/
private SortedSet resourceBundles = new TreeSet();
// this list is just used for resourceBundleList. See CU.resourceBundle for the
// names of resource bundles that are linked in
public SortedSet getResourceBundles()
{
return resourceBundles;
}
/**
* Unresolved
*/
private Set unresolved = new HashSet();
public Set getUnresolved()
{
return unresolved;
}
//
// 'framework' option
//
private static final String DEFAULT_FRAMEWORK = "halo";
private String framework = DEFAULT_FRAMEWORK;
public String getFramework()
{
return framework;
}
public void cfgFramework(ConfigurationValue cv, String s)
{
framework = s;
}
//
// 'benchmark' option
//
private boolean benchmark = false;
public boolean benchmark()
{
return benchmark;
}
public void cfgBenchmark(ConfigurationValue cv, boolean b)
{
benchmark = b;
}
public static ConfigurationInfo getBenchmarkInfo()
{
return new ConfigurationInfo() {
public boolean doChecksum()
{
return false;
}
};
}
private int benchmarkCompilerDetails; // 0 = none, 1 = light, 5 = verbose
public int getBenchmarkCompilerDetails()
{
return benchmarkCompilerDetails;
}
/**
* @param cv
* @param b
*/
public void cfgBenchmarkCompilerDetails(ConfigurationValue cv, int details)
{
benchmarkCompilerDetails = details;
}
public static ConfigurationInfo getBenchmarkCompilerDetailsInfo()
{
return new ConfigurationInfo() {
public boolean isHidden()
{
return true;
}
public boolean doChecksum()
{
return false;
}
};
}
private long benchmarkTimeFilter; // min time of units to log in ms
public long getBenchmarkTimeFilter()
{
return benchmarkTimeFilter;
}
/**
* @param cv
* @param b
*/
public void cfgBenchmarkTimeFilter(ConfigurationValue cv, long timeFilter)
{
benchmarkTimeFilter = timeFilter;
}
public static ConfigurationInfo getBenchmarkTimeFilterInfo()
{
return new ConfigurationInfo() {
public boolean isHidden()
{
return true;
}
public boolean doChecksum()
{
return false;
}
};
}
//
// 'compiler.*' options
//
private CompilerConfiguration compilerConfiguration;
public CompilerConfiguration getCompilerConfiguration()
{
return compilerConfiguration;
}
public boolean debug()
{
return compilerConfiguration.debug();
}
public void setDebug(boolean debug)
{
compilerConfiguration.setDebug(debug);
}
public boolean verboseStacktraces()
{
return compilerConfiguration.verboseStacktraces();
}
public boolean optimize()
{
return compilerConfiguration.optimize();
}
public void setOptimize(boolean optimize)
{
compilerConfiguration.setOptimize(optimize);
}
/**
* Includes user specified metadata and extra metadata added by the linker.
*/
public String[] getMetadataToKeep()
{
return getCompilerConfiguration().getKeepAs3Metadata();
}
//
// 'debug-password' option
//
private String debugPassword;
/**
* The password to include in debuggable swfs.
*/
public String debugPassword()
{
return debugPassword;
}
public void setDebugPassword(String debugPassword)
{
this.debugPassword = debugPassword;
}
public void cfgDebugPassword( ConfigurationValue cv, String debugPassword )
{
this.debugPassword = debugPassword;
}
public static ConfigurationInfo getDebugPasswordInfo()
{
return new AdvancedConfigurationInfo();
}
//
// 'default-background-color' option
//
private int backgroundColor = 0x50727E;
public int backgroundColor()
{
return this.backgroundColor;
}
public void setBackgroundColor( int backgroundColor )
{
this.backgroundColor = backgroundColor;
}
public void cfgDefaultBackgroundColor( ConfigurationValue cv, int backgroundColor )
{
this.backgroundColor = backgroundColor;
}
public static ConfigurationInfo getDefaultBackgroundColorInfo()
{
return new AdvancedConfigurationInfo();
}
//
// 'default-frame-rate' option
//
private int frameRate = 24;
public int getFrameRate()
{
return frameRate;
}
public void setFrameRate( int rate )
{
frameRate = rate;
}
public void cfgDefaultFrameRate( ConfigurationValue cv, int rate )
throws ConfigurationException
{
if (rate <= 0)
throw new ConfigurationException.GreaterThanZero( cv.getVar(),
cv.getSource(), cv.getLine() );
frameRate = rate;
}
public static ConfigurationInfo getDefaultFrameRateInfo()
{
return new AdvancedConfigurationInfo();
}
//
// 'default-script-limits' option
//
private int scriptLimit = 60;
private int scriptRecursionLimit = 1000;
private boolean scriptLimitsSet = false;
public int getScriptTimeLimit()
{
return scriptLimit;
}
public int getScriptRecursionLimit()
{
return scriptRecursionLimit;
}
public void setScriptTimeLimit( int scriptLimit )
{
scriptLimitsSet = true;
this.scriptLimit = scriptLimit;
}
public void setScriptRecursionLimit( int recursionLimit )
{
scriptLimitsSet = true;
this.scriptRecursionLimit = recursionLimit;
}
public boolean scriptLimitsSet()
{
return scriptLimitsSet;
}
public void cfgDefaultScriptLimits( ConfigurationValue cv, int maxRecursionDepth, int maxExecutionTime )
throws ConfigurationException
{
if (maxRecursionDepth <= 0)
throw new ConfigurationException.GreaterThanZero( cv.getVar(), cv.getSource(), cv.getLine() );
if (maxExecutionTime <= 0)
throw new ConfigurationException.GreaterThanZero( cv.getVar(),
cv.getSource(), cv.getLine() );
this.scriptLimitsSet = true;
this.scriptLimit = maxExecutionTime;
this.scriptRecursionLimit = maxRecursionDepth;
}
public static ConfigurationInfo getDefaultScriptLimitsInfo()
{
return new ConfigurationInfo( new String[] { "max-recursion-depth", "max-execution-time" } )
{
public boolean isAdvanced()
{
return true;
}
};
}
//
// 'default-size' option
//
private int defaultWidth = 500;
private int defaultHeight = 375;
public int defaultWidth()
{
return defaultWidth;
}
public int defaultHeight()
{
return defaultHeight;
}
public void cfgDefaultSize( ConfigurationValue cv, int width, int height )
throws ConfigurationException
{
if ((width < 1) || (width > 4096) || (height < 1) || (height > 4096)) // whatever
{
throw new ConfigurationException.IllegalDimensions( width, height, cv.getVar(), cv.getSource(), cv.getLine() );
}
this.defaultWidth = width;
this.defaultHeight = height;
}
public static ConfigurationInfo getDefaultSizeInfo()
{
return new ConfigurationInfo( new String[] {"width", "height"} )
{
public boolean isAdvanced()
{
return true;
}
};
}
//
// 'externs' option
//
private Set externs = new HashSet();
public Set getExterns()
{
Collection compilerExterns = compilerConfiguration.getExterns();
if (compilerExterns != null)
{
externs.addAll(compilerExterns);
}
return externs;
}
public void addExterns( Collection externs )
{
this.externs.addAll( externs );
}
public void addExterns(QName[] qNames)
{
for (int i = 0, len = qNames == null ? 0 : qNames.length; i < len; i++)
{
this.externs.add(qNames[i].toString());
}
}
public void cfgExterns( ConfigurationValue cfgval, List vals )
{
externs.addAll(toQNameString(vals));
}
public static ConfigurationInfo getExternsInfo()
{
return new ConfigurationInfo( -1, "symbol" )
{
public boolean allowMultiple()
{
return true;
}
public boolean isAdvanced()
{
return true;
}
public boolean doChecksum()
{
return false;
}
};
}
public void removeExterns(Collection externs)
{
this.externs.removeAll(externs);
}
protected List toQNameString(List vals)
{
if(vals != null) {
int size = vals.size();
for (int i = 0; i < size; i++) {
String name = vals.get(i);
if ((name.indexOf(':') == -1) && (name.indexOf('.') != -1)) {
int dot = name.lastIndexOf('.');
name = name.substring(0, dot) + ':' + name.substring(dot + 1);
}
vals.set(i, name);
}
}
return vals;
}
//
// 'frames.*' options
//
private FramesConfiguration frames;
public FramesConfiguration getFramesConfiguration()
{
return frames;
}
public List getFrameList()
{
return frames.getFrameList();
}
//
// 'generated-frame-loader' option (hidden)
//
public boolean generateFrameLoader = true;
public void cfgGenerateFrameLoader( ConfigurationValue cv, boolean value )
{
this.generateFrameLoader = value;
}
public static ConfigurationInfo getGenerateFrameLoaderInfo()
{
return new AdvancedConfigurationInfo()
{
public boolean isHidden()
{
return true;
}
};
}
//
// 'generated-output' option
//
/*
// TODO - enable this, add hooks to use it!
private String generatedOutput = null;
public String getGeneratedOutput()
{
return generatedOutput;
}
public void cfgGeneratedOutput( ConfigurationValue cfgVal, String path )
{
// We should probably resolve this here or in validate, but its kinda painful right now.
generatedOutput = path;
}
public static ConfigurationInfo getGeneratedOutputInfo()
{
return new ConfigurationInfo( 1, "directory" )
{
public boolean isHidden()
{
return true;
}
public String[] getPrerequisites()
{
return new String[] { "flexlib" };
}
};
}
*/
//
// 'includes' option
//
private Set includes = new LinkedHashSet();
public Set getIncludes()
{
return includes;
}
public void addIncludes( Collection includes )
{
this.includes.addAll(includes);
}
public void cfgIncludes( ConfigurationValue cfgval, List vals )
{
includes.addAll(toQNameString(vals));
}
public static ConfigurationInfo getIncludesInfo()
{
return new ConfigurationInfo( -1, "symbol" )
{
public boolean allowMultiple()
{
return true;
}
public boolean isAdvanced()
{
return true;
}
};
}
//
// 'lazy-init' option (hidden)
//
private boolean lazyInit = false;
public boolean lazyInit()
{
return lazyInit;
}
public void cfgLazyInit(ConfigurationValue cv, boolean b)
{
lazyInit = b;
}
public static ConfigurationInfo getLazyInitInfo()
{
return new AdvancedConfigurationInfo()
{
public boolean isHidden()
{
return true;
}
};
}
//
// 'link-report' option
//
private String linkReportFileName = null;
public String getLinkReportFileName()
{
return linkReportFileName;
}
public boolean generateLinkReport()
{
return linkReportFileName != null;
}
public void cfgLinkReport( ConfigurationValue cv, String filename )
{
this.linkReportFileName = getOutputPath(cv, filename);
}
public static ConfigurationInfo getLinkReportInfo()
{
return new ConfigurationInfo(new String[] {"filename"})
{
public boolean isAdvanced()
{
return true;
}
};
}
//
// 'size-report' option
//
private String sizeReportFileName = null;
public String getSizeReportFileName()
{
return sizeReportFileName;
}
public boolean generateSizeReport()
{
return sizeReportFileName != null;
}
public void cfgSizeReport( ConfigurationValue cv, String filename )
{
this.sizeReportFileName = getOutputPath(cv, filename);
}
public static ConfigurationInfo getSizeReportInfo()
{
return new ConfigurationInfo(new String[] {"filename"})
{
public boolean isAdvanced()
{
return true;
}
};
}
//
// 'load-externs' option
//
public void cfgLoadExterns( ConfigurationValue cfgval, String filename ) throws ConfigurationException
{
VirtualFile f = ConfigurationPathResolver.getVirtualFile( filename, configResolver, cfgval );
SAXParserFactory factory = SAXParserFactory.newInstance();
factory.setNamespaceAware(false);
try
{
SAXParser parser = factory.newSAXParser();
parser.parse(f.getInputStream(),
new DefaultHandler()
{
public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException
{
if ("def".equals( qName ) || "pre".equals( qName ) || "ext".equals( qName ))
{
String id = attributes.getValue( "id" );
externs.add( id );
}
}
});
}
catch (Exception e)
{
throw new ConfigurationException.ConfigurationIOError( filename, cfgval.getVar(), cfgval.getSource(), cfgval.getLine() );
}
}
public static ConfigurationInfo getLoadExternsInfo()
{
return new ConfigurationInfo( 1, "filename" )
{
public boolean allowMultiple()
{
return true;
}
public boolean isAdvanced()
{
return true;
}
};
}
//
// 'metadata.*' options
//
private MetadataConfiguration metadataConfiguration;
public MetadataConfiguration getMetadataConfiguration()
{
return metadataConfiguration;
}
//
// 'license.*' options. These must be here rather than in
// ToolsConfiguration so they can be discovered when
// introspection is done on Configuration.class to discover the options.
//
private LicensesConfiguration licensesConfiguration;
public LicensesConfiguration getLicensesConfiguration()
{
return licensesConfiguration;
}
/**
* The RuntimeSharedLibraryPathItem Configuration contains
* options to modify runtime-shared-library-path options
* the user has already specified.
*/
private RuntimeSharedLibrarySettingsConfiguration rslSettingsConfiguration;
public RuntimeSharedLibrarySettingsConfiguration getRuntimeSharedLibrarySettingsConfiguration()
{
return rslSettingsConfiguration;
}
//
// 'raw-metadata' option
//
private String metadata = null;
public String getMetadata()
{
return (metadata == null)? getMetadataConfiguration().toString() : metadata;
}
public void cfgRawMetadata( ConfigurationValue cv, String xml )
throws ConfigurationException
{
if (metadata != null)
{
throw new ConfigurationException.BadMetadataCombo( cv.getVar(), cv.getSource(), cv.getLine() );
}
this.metadata = xml;
}
public static ConfigurationInfo getRawMetadataInfo()
{
return new ConfigurationInfo( 1, "text" )
{
public boolean isAdvanced()
{
return true;
}
};
}
//
// 'resource-bundle-list' option
//
private String rbListFileName = null;
public String getRBListFileName()
{
return rbListFileName;
}
public boolean generateRBList()
{
return rbListFileName != null;
}
public void cfgResourceBundleList( ConfigurationValue cv, String filename )
{
this.rbListFileName = getOutputPath(cv, filename);
}
public static ConfigurationInfo getResourceBundleListInfo()
{
return new ConfigurationInfo(new String[] {"filename"})
{
public boolean isAdvanced()
{
return true;
}
};
}
//
// 'resource-shared-libraries' option
//
private List rslList = new LinkedList();
public List getRuntimeSharedLibraries()
{
return rslList;
}
public void cfgRuntimeSharedLibraries( ConfigurationValue cfgval, String[] urls ) throws ConfigurationException
{
for (int i = 0; i < urls.length; ++i)
{
// can't really validate these easily...
rslList.add( urls[i] );
}
}
public static ConfigurationInfo getRuntimeSharedLibrariesInfo()
{
return new ConfigurationInfo( -1, new String[] { "url" } )
{
public boolean allowMultiple()
{
return true;
}
};
}
//
// 'use-network' option
//
private boolean useNetwork;
public boolean useNetwork()
{
return useNetwork;
}
public void cfgUseNetwork( ConfigurationValue cv, boolean b)
{
this.useNetwork = b;
}
/**
* Capture the information in one argument specifing -runtime-shared-libraries-path
* information.
*
* @author dloverin
*
*/
public class RslPathInfo
{
/**
* The extension given to a signed RLS that is assumed to be signed.
* Unsigned RSLs should use the standard "swf" extension.
*/
public static final String SIGNED_RSL_URL_EXTENSION = "swz";
public static final String SIGNED_RSL_URL_DOT_EXTENSION = "." + SIGNED_RSL_URL_EXTENSION;
// path to swc to link against, this is logically added
// -external-library-path option
private String swcPath;
private VirtualFile swcVf; // the swc's virtual file
// rsls in the order to load. The first if the primary rsl, the
// others are failover rsls.
private List rslUrls;
// policy file urls, optional. The first in the list if applies to the
// first rsl in _rslUrls. The second in the list applies to the second
// in _rslUrls and so on. If there are more policy file urls than rsl
// urls,
// then display a warning.
private List policyFileUrls;
//
// List of type Boolean. Entry i in this list tells if entry i in the list
// given by getRslUrls() is targeting a signed or unsigned rsl.
//
private List isSignedList;
/**
* Create a new cross-domain RSL entry. The info specified the swc file to
* exclude put a list of RSL urls and policy file urls. The first RSL url/policy
* file url pair are the primary urls. The remaining urls are failovers and are
* only used if the primary RSL fails to load.
*
*/
public RslPathInfo()
{
rslUrls = new ArrayList();
}
/**
* Test is the url is signed.
*
* @param url url to test, the file specified by the url does not
* need to exist.
* @return true if the url specifies a signed rsl, false otherwise.
*/
public boolean isRslUrlSigned(String url) {
if (url == null) {
return false;
}
return url.endsWith(SIGNED_RSL_URL_DOT_EXTENSION);
}
/**
* Set the path to the swc.
*
* @param swcPath
*/
public void setSwcPath(String swcPath)
{
this.swcPath = swcPath;
}
/**
*
* @return the path to the swc
*/
public String getSwcPath()
{
return swcPath;
}
/**
* Set the virtual file associated with the swc path.
*
* @param vf
*/
public void setSwcVf(VirtualFile vf)
{
swcVf = vf;
}
/**
*
* @return
*/
public VirtualFile getSwcVirtualFile() {
return swcVf;
}
/**
* Add an RSL to the list of RSLs.
*
* @param url url of the RSL, may not be null
*/
public void addRslUrl(String url)
{
if (url == null) {
throw new NullPointerException("url may not be null"); // $NON-NLS-1$
}
rslUrls.add(url);
addSignedFlag(isRslUrlSigned(url));
}
/**
*
* @return List of urls to RSLs. Each entry in the list is of type String
.
*/
public List getRslUrls()
{
return rslUrls;
}
/**
* Add a policy file to support the associated entry in the RSL URL list. Policy file
* entries my be empty, but must be specified.
* @param url url of the policy file.
*/
public void addPolicyFileUrl(String url)
{
if (policyFileUrls == null)
{
policyFileUrls = new ArrayList();
}
policyFileUrls.add(url == null ? "" : url); // $NON-NLS-1$
}
/**
* Get the list of policy files.
*
* @return Listof policy file urls. Each entry in the list of type String
*/
public List getPolicyFileUrls()
{
return policyFileUrls == null ? Collections.emptyList() : policyFileUrls;
}
/**
* Return a list of booleans that indicate if an RSL URL is signed or unsigned. There is a matching entry
* is this list for every entry in the RSL URL list.
*
* @return List of boolean signed flags for the RSL URL list. Each entry in the list is
* of type Boolean
.
*/
public List getSignedFlags() {
return isSignedList;
}
/**
* Add a signed flag to the list of flags. This flag is determines if the RSL URL
* associated with this entry is considered signed or unsigned.
*
* @param isSigned true if the RSL URL is signed.
*/
private void addSignedFlag(boolean isSigned) {
if (isSignedList == null) {
isSignedList = new ArrayList();
}
isSignedList.add(Boolean.valueOf(isSigned));
}
}
private List rslPathInfoList; // list of CdRslInfo objects
//private Set loadedRsls; // swc location of the rsls that will be loaded
/**
* @return List of of all the -runtime-shared-libraries-path options.
* Each-runtime-shared-libraries-path option supplied results in
* a RslPathInfo object.
* Each object in the list is of type RslPathInfo.
* The list will be empty if -static-link-runtime-shared-libraries=true.
*/
public List getRslPathInfo() {
return rslPathInfoList == null ? Collections.emptyList() : rslPathInfoList;
}
public VirtualFile[] getRslExcludedLibraries() {
if (rslPathInfoList == null || getStaticLinkRsl()) {
return new VirtualFile[0];
}
List libraries = new ArrayList();
for (Iterator iter = rslPathInfoList.iterator(); iter.hasNext();)
{
RslPathInfo info = iter.next();
libraries.add(info.getSwcVirtualFile());
}
return libraries.toArray(new VirtualFile[0]);
}
public void cfgRuntimeSharedLibraryPath(ConfigurationValue cfgval,
String[] urls) throws ConfigurationException
{
if (urls.length == 0) {
return; // ignore option
}
// Usage rule: if you use -rslp on the command line
// it will take effect unless you also specify -static-rsls=true on the command line.
if (CommandLineConfigurator.SOURCE_COMMAND_LINE.equals(cfgval.getSource())) {
setOverrideStaticLinkRsl(false);
}
// ignore rsl if told to
if (getStaticLinkRsl()) {
return;
}
if (urls.length < 2)
{
// insufficent arguments
throw new ConfigurationException.MissingArgument("rsl-url",
"runtime-shared-library-path", cfgval.getSource(),
cfgval.getLine());
}
RslPathInfo info = new RslPathInfo();
// validate the first argument, the swc or open directory, required.
VirtualFile include = ConfigurationPathResolver.getVirtualFile(urls[0],
configResolver,
cfgval );
info.setSwcPath(urls[0]);
info.setSwcVf(include);
// the rest of the args are: rsl-url, policy-file-url, rsl-url, policy-file-url,...
for (int i = 1; i < urls.length; ++i)
{
if ((i + 1) % 2 == 0)
{
if (urls[i].length() == 0) {
// rsl urls is required
throw new ConfigurationException.MissingArgument("rsl-url",
"runtime-shared-library-path", cfgval.getSource(),
cfgval.getLine());
}
info.addRslUrl(urls[i]);
}
else {
info.addPolicyFileUrl(urls[i]);
}
}
// if the last policy file was not specified, then add an empty one so
// there are always the same number of rsls and policy files.
if ((urls.length % 2) == 0) {
info.addPolicyFileUrl(""); // $NON-NLS-1$
}
// take local variables and add to overall arguments.
if (rslPathInfoList == null)
{
rslPathInfoList = new ArrayList();
}
rslPathInfoList.add(info);
}
public static ConfigurationInfo getRuntimeSharedLibraryPathInfo()
{
return new ConfigurationInfo()
{
public boolean allowMultiple()
{
return true;
}
public String[] getSoftPrerequisites()
{
return new String[] {"static-link-runtime-shared-libraries"};
}
public String getArgName(int argnum)
{
String argName = null;
if (argnum == 0)
{
argName = "path-element";
}
else
{
argnum = (argnum + 1) % 2;
if (argnum == 0)
{
argName = "rsl-url";
}
else
{
argName = "policy-file-url";
}
}
return argName;
}
public boolean doChecksum()
{
return false;
}
};
}
//
// 'static-link-runtime-shared-libraries' option
//
private boolean staticLinkRsl = true;
private String staticLinkRslSource;
/**
*
* @return true if -cd-rsl option should be used. False otherwise.
*/
public boolean getStaticLinkRsl()
{
return staticLinkRsl;
}
/**
* Allow another option, namely -rslp to override the value of
* static-rsls. But you can not override a -static-rsls option that came from the command line.
*
* @param staticLinkRsl
*/
protected void setOverrideStaticLinkRsl(boolean staticLinkRsl)
{
if (CommandLineConfigurator.SOURCE_COMMAND_LINE.equals(staticLinkRslSource))
{
return;
}
this.staticLinkRsl = staticLinkRsl;
}
/**
*
* @param cv
* @param b
*/
public void cfgStaticLinkRuntimeSharedLibraries(ConfigurationValue cv, boolean b)
{
staticLinkRsl = b;
staticLinkRslSource = cv.getSource();
}
//
// 'verify-digests' options
//
private boolean verifyDigests = true;
/**
*
* @return true if digest information associated with the
* -cd-rsl option is used by the application at runtime. False otherwise.
*/
public boolean getVerifyDigests()
{
return verifyDigests;
}
/**
*
* @param cv
* @param b
*/
public void cfgVerifyDigests(ConfigurationValue cv, boolean b)
{
verifyDigests = b;
}
public static ConfigurationInfo getVerifyDigestsInfo()
{
return new AdvancedConfigurationInfo();
}
//
// 'remove-unused-rsls' option
//
private boolean removeUnusedRSLs = true;
/**
*
* @return true if the user wants to remove unused RSLs. Otherwise false.
*/
public boolean getRemoveUnusedRsls()
{
return removeUnusedRSLs;
}
/**
*
* @param cv
* @param b
*/
public void cfgRemoveUnusedRsls(ConfigurationValue cv, boolean b)
{
removeUnusedRSLs = b;
}
public static ConfigurationInfo getRemoveUnusedRslsInfo()
{
return new AdvancedConfigurationInfo();
}
//
// '-include-inheritance-dependencies-only' option
//
private boolean includeInheritanceDependenciesOnly = false;
/**
*
* @return true if the user want to include inheritance dependencies only.
*/
public boolean getIncludeInheritanceDependenciesOnly()
{
return includeInheritanceDependenciesOnly;
}
/**
*
* @param cv
* @param b
*/
public void cfgIncludeInheritanceDependenciesOnly(ConfigurationValue cv, boolean b)
{
includeInheritanceDependenciesOnly = b;
}
public static ConfigurationInfo getIncludeInheritanceDependenciesOnlyInfo()
{
return new AdvancedConfigurationInfo();
}
//
// 'target-player' option
//
/**
* Returns the correct macromedia.asc.embedding.avmplus.Features.TARGET_AVM*
* for the current target player.
*
* @see macromedia.asc.util.ContextStatics.getTargetAVM()
*/
public int getTargetPlayerTargetAVM()
{
return getTargetPlayerTargetAVM(getTargetPlayerMajorVersion());
}
/**
* Returns the correct macromedia.asc.embedding.avmplus.Features.TARGET_AVM*
* for the given target player major revision (e.g. 10).
*
* @see macromedia.asc.util.ContextStatics.getTargetAVM()
*/
public static int getTargetPlayerTargetAVM(int targetPlayerMajorVersion)
{
return 1; // ContextStatics.getTargetAVM(targetPlayerMajorVersion);
}
/**
* Returns an ObjectList filled with the correct namespaces that need to be
* automagically opened for the current target player, e.g. flash10.
*
* @see macromedia.asc.util.ContextStatics.use_namespaces
*/
public ObjectList getTargetPlayerRequiredUseNamespaces()
{
return getTargetPlayerRequiredUseNamespaces(getTargetPlayerMajorVersion());
}
/**
* Returns an ObjectList filled with the correct namespaces that need to be
* automagically opened for the current target player, e.g. flash10.
*
* @see macromedia.asc.util.ContextStatics.use_namespaces
*/
public static ObjectList getTargetPlayerRequiredUseNamespaces(int targetPlayerMajorVersion)
{
return new ObjectList();
}
// targeted player version (also set in DefaultsConfigurator)
private int majorVersionTarget = 11;
private int minorVersionTarget = 1;
private int revisionTarget = 0;
/**
*
* @return The major version of the player targeted by this application.
* The returned value will be greater to or equal to 9.
*/
public int getTargetPlayerMajorVersion()
{
return majorVersionTarget;
}
/**
*
* @return The minor version of the player targeted by this application.
* The returned value will be greater to or equal to 0.
*/
public int getTargetPlayerMinorVersion()
{
return minorVersionTarget;
}
/**
*
* @return The revision of the player targeted by this application.
* The returned value will be greater to or equal to 0.
*/
public int getTargetPlayerRevision()
{
return revisionTarget;
}
/**
*
* @param cv
* @param b
*/
public void cfgTargetPlayer(ConfigurationValue cv, String version)
throws ConfigurationException
{
if (version == null)
{
return;
}
String[] results = version.split("\\.");
if (results.length == 0)
{
throw new ConfigurationException.BadVersion(version, "target-player");
}
for (int i = 0; i < results.length; i++)
{
int versionNum = 0;
try
{
versionNum = Integer.parseInt(results[i]);
}
catch (NumberFormatException e)
{
throw new ConfigurationException.BadVersion(version, "target-player");
}
if (i == 0)
{
if (versionNum >= 9)
{
this.majorVersionTarget = versionNum;
}
else
{
throw new ConfigurationException.BadVersion(version, "target-player");
}
}
else
{
if (versionNum >= 0)
{
if (i == 1)
{
this.minorVersionTarget = versionNum;
}
else
{
this.revisionTarget = versionNum;
}
}
else
{
throw new ConfigurationException.BadVersion(version, "target-player");
}
}
}
}
public static ConfigurationInfo getTargetPlayerInfo()
{
return new ConfigurationInfo(new String[] {"version"});
}
//
// 'swf-version' option
//
private int swfVersion = 14;
public int getSwfVersion()
{
assert swfVersion > 0;
return swfVersion;
}
public void setSwfVersion(final int version)
{
assert version > 0;
swfVersion = version;
}
public void cfgSwfVersion(ConfigurationValue cv, int version)
{
setSwfVersion(version);
}
public boolean getComputeDigest()
{
throw new InternalError("compute-digest");
}
//
// 'use-direct-blit' option
//
private boolean useDirectBlit = false;
public boolean getUseDirectBlit()
{
return useDirectBlit;
}
public void setUseDirectBlit(boolean value)
{
useDirectBlit = value;
}
public void cfgUseDirectBlit(ConfigurationValue cv, boolean value)
{
setUseDirectBlit(value);
}
//
// 'use-gpu' option
//
private boolean useGpu = false;
public boolean getUseGpu()
{
return useGpu;
}
public void setUseGpu(boolean value)
{
useGpu = value;
}
public void cfgUseGpu(ConfigurationValue cv, boolean value)
{
setUseGpu(value);
}
//
// 'swc-checksum' options
//
private boolean swcChecksumEnabled = true;
/**
*
* @return true if optimization using signature checksums are enabled.
*/
public boolean isSwcChecksumEnabled()
{
return swcChecksumEnabled;
}
/**
*
* @param cv
* @param b
*/
public void cfgSwcChecksum(ConfigurationValue cv, boolean b)
{
swcChecksumEnabled = b;
}
public static ConfigurationInfo getSwcChecksumInfo()
{
return new ConfigurationInfo() {
public boolean isHidden()
{
return true;
}
public boolean doChecksum()
{
return false;
}
};
}
// cssArchiveFiles and l10nArchiveFiles
private Map cssArchiveFiles;
private Map l10nArchiveFiles;
public void addCSSArchiveFiles(Map m)
{
if (cssArchiveFiles == null)
{
cssArchiveFiles = new HashMap();
}
cssArchiveFiles.putAll(m);
}
public Map getCSSArchiveFiles()
{
return cssArchiveFiles;
}
public void addL10nArchiveFiles(Map m)
{
if (l10nArchiveFiles == null)
{
l10nArchiveFiles = new HashMap();
}
l10nArchiveFiles.putAll(m);
}
public Map getL10NArchiveFiles()
{
return l10nArchiveFiles;
}
/**
* The compatibility version specified in the configuration.
*/
public String getCompatibilityVersionString()
{
return compilerConfiguration.getCompatibilityVersionString();
}
public int getCompatibilityVersion()
{
return compilerConfiguration.getCompatibilityVersion();
}
/**
* The minimum supported library version specified in the configuration.
*/
public String getMinimumSupportedVersionString()
{
return compilerConfiguration.getMinimumSupportedVersionString();
}
public int getMinimumSupportedVersion()
{
return compilerConfiguration.getMinimumSupportedVersion();
}
public boolean getQualifiedTypeSelectors()
{
return compilerConfiguration.getQualifiedTypeSelectors();
}
/**
* Configures the LocalizationManager's locale, which is used when
* reporting compile time errors, warnings, and info.
*
* @param toolsLocale A locale in Java format. For example, "en" or "ja_JP".
* @throws ConfigurationException When the specified toolsLocale is
* not available a ToolsLocaleNotAvailable error is reported.
public void cfgToolsLocale(ConfigurationValue cv, String toolsLocale)
throws ConfigurationException
{
Locale[] locales = Locale.getAvailableLocales();
for (int i = 0; i < locales.length; i++)
{
if (locales[i].toString().equals(toolsLocale))
{
LocalizationManager localizationManager = ThreadLocalToolkit.getLocalizationManager();
if (localizationManager != null)
{
localizationManager.setLocale(locales[i]);
}
else
{
assert false : "LocalizationManager not setup yet.";
}
return;
}
}
throw new ConfigurationException.ToolsLocaleNotAvailable(cv.getVar(),
cv.getSource(),
cv.getLine() );
}
*/
public void setAdvancedTelemetry(boolean enableTelemetry)
{
compilerConfiguration.setAdvancedTelemetry(enableTelemetry);
}
public boolean getAdvancedTelemetry()
{
return compilerConfiguration.getAdvancedTelemetry();
}
//
// 'closure-lib' option
//
private String closureLibDirName = null;
public String getClosureLibDirName()
{
return closureLibDirName;
}
public void cfgClosureLib( ConfigurationValue cv, String filename )
{
this.closureLibDirName = getOutputPath(cv, filename);
}
//
// 'sdk-js-lib' option
//
private List sdkJsLibraries = new LinkedList();
public List getSDKJSLib()
{
return sdkJsLibraries;
}
public void cfgSDKJSLib( ConfigurationValue cfgval, String[] urls ) throws ConfigurationException
{
for (int i = 0; i < urls.length; ++i)
{
VirtualFile f = ConfigurationPathResolver.getVirtualFile( urls[i], configResolver, cfgval );
if (f != null)
sdkJsLibraries.add( urls[i] );
}
}
//
// 'external-js-lib' option
//
private List externalJsLibraries = new LinkedList();
public List getExternalJSLib()
{
return externalJsLibraries;
}
public void cfgExternalJSLib( ConfigurationValue cfgval, String[] urls ) throws ConfigurationException
{
for (int i = 0; i < urls.length; ++i)
{
VirtualFile f = ConfigurationPathResolver.getVirtualFile( urls[i], configResolver, cfgval );
if (f != null)
externalJsLibraries.add( urls[i] );
}
}
//
// 'remove-circulars' option
//
private boolean removeCirculars = false;
public boolean getRemoveCirculars()
{
return removeCirculars;
}
public void setRemoveCirculars(boolean value)
{
removeCirculars = value;
}
public void cfgRemoveCirculars(ConfigurationValue cv, boolean value)
{
setRemoveCirculars(value);
}
//
// 'skip-transpile' option
//
private boolean skipTranspile = false;
public boolean getSkipTranspile()
{
return skipTranspile;
}
public void setSkipTranspile(boolean value)
{
skipTranspile = value;
}
public void cfgSkipTranspile(ConfigurationValue cv, boolean value)
{
setSkipTranspile(value);
}
//
// 'js-compiler-option' option
//
private List jsCompilerOption = new LinkedList();
public List getJsCompilerOption()
{
return jsCompilerOption;
}
public void cfgJsCompilerOption( ConfigurationValue cfgval, String[] urls ) throws ConfigurationException
{
for (int i = 0; i < urls.length; ++i)
{
jsCompilerOption.add( urls[i] );
}
}
//
// 'js-output-optimization' option
//
private List jsOutputOptimization = new LinkedList();
public List getJsOutputOptimization()
{
return jsOutputOptimization;
}
public void cfgJsOutputOptimization( ConfigurationValue cfgval, String[] urls ) throws ConfigurationException
{
for (int i = 0; i < urls.length; ++i)
{
jsOutputOptimization.add( urls[i] );
}
}
//
// 'html-template' option
//
private String htmlTemplateFileName = null;
public String getHtmlTemplateFileName()
{
return htmlTemplateFileName;
}
public void cfgHtmlTemplate( ConfigurationValue cv, String filename )
{
this.htmlTemplateFileName = getOutputPath(cv, filename);
}
//
// 'html-output-filename' option
//
private String htmlOutputFileName = null;
public String getHtmlOutputFilename()
{
return htmlOutputFileName;
}
public void cfgHtmlOutputFilename( ConfigurationValue cv, String filename )
{
this.htmlOutputFileName = getOutputPath(cv, filename);
}
//
// 'compiler-targets' option
//
private List compilerTargets = new LinkedList();
public List getCompilerTargets()
{
return compilerTargets;
}
public void cfgCompilerTargets( ConfigurationValue cfgval, String[] urls ) throws ConfigurationException
{
for (int i = 0; i < urls.length; ++i)
{
compilerTargets.add( urls[i] );
}
}
//
// 'source-map' option
//
private boolean sourceMap = false;
public boolean getSourceMap()
{
return sourceMap;
}
public void setSourceMap(boolean value)
{
sourceMap = value;
}
public void cfgSourceMap(ConfigurationValue cv, boolean value)
{
setSkipTranspile(value);
}
//
// 'compiler.js-external-library-path' option
//
private List jsExternalLibrariesPath = new LinkedList();
public List getJsExternalLibraryPath()
{
return jsExternalLibrariesPath;
}
public void cfgJsExternalLibraryPath( ConfigurationValue cfgval, String[] urls ) throws ConfigurationException
{
for (int i = 0; i < urls.length; ++i)
{
VirtualFile f = ConfigurationPathResolver.getVirtualFile( urls[i], configResolver, cfgval );
if (f != null)
jsExternalLibrariesPath.add( urls[i] );
}
}
//
// 'compiler.swf-external-library-path' option
//
private List swfExternalLibrariesPath = new LinkedList();
public List getSwfExternalLibraryPath()
{
return swfExternalLibrariesPath;
}
public void cfgSwfExternalLibraryPath( ConfigurationValue cfgval, String[] urls ) throws ConfigurationException
{
for (int i = 0; i < urls.length; ++i)
{
VirtualFile f = ConfigurationPathResolver.getVirtualFile( urls[i], configResolver, cfgval );
if (f != null)
swfExternalLibrariesPath.add( urls[i] );
}
}
//
// 'compiler.js-library-path' option
//
private List jsLibrariesPath = new LinkedList();
public List getJsLibraryPath()
{
return jsLibrariesPath;
}
public void cfgJsLibraryPath( ConfigurationValue cfgval, String[] urls ) throws ConfigurationException
{
for (int i = 0; i < urls.length; ++i)
{
VirtualFile f = ConfigurationPathResolver.getVirtualFile( urls[i], configResolver, cfgval );
if (f != null)
jsLibrariesPath.add( urls[i] );
}
}
//
// 'compiler.swf-library-path' option
//
private List swfLibrariesPath = new LinkedList();
public List getSwfLibraryPath()
{
return swfLibrariesPath;
}
public void cfgSwfLibraryPath( ConfigurationValue cfgval, String[] urls ) throws ConfigurationException
{
for (int i = 0; i < urls.length; ++i)
{
VirtualFile f = ConfigurationPathResolver.getVirtualFile( urls[i], configResolver, cfgval );
if (f != null)
swfLibrariesPath.add( urls[i] );
}
}
@Override
public Configuration clone()
throws CloneNotSupportedException
{
Configuration cloneConfig = (Configuration) super.clone();
CompilerConfiguration cloneCompilerConfiguration = (CompilerConfiguration) this.compilerConfiguration.clone();
cloneConfig.compilerConfiguration = cloneCompilerConfiguration;
return cloneConfig;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy