blob: aeae21578061e4d9dc95f02ceb855ea42ea3bad2 [file] [log] [blame]
/*
*
* Copyright 2001-2005 The Ant-Contrib project
*
* Licensed 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 net.sf.antcontrib.cpptasks;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.util.Vector;
import net.sf.antcontrib.cpptasks.compiler.Assembler;
import net.sf.antcontrib.cpptasks.compiler.Processor;
import net.sf.antcontrib.cpptasks.gcc.GccAssembler;
import net.sf.antcontrib.cpptasks.types.AssemblerArgument;
import net.sf.antcontrib.cpptasks.types.ConditionalPath;
import net.sf.antcontrib.cpptasks.types.IncludePath;
import net.sf.antcontrib.cpptasks.types.SystemIncludePath;
import org.apache.tools.ant.BuildException;
import org.apache.tools.ant.Project;
/**
* A assembler definition. Assembler elements may be placed either as children
* of a cc element or the project element. A assembler element with an id
* attribute may be referenced from assembler elements with refid or extends
* attributes.
*
*/
public final class AssemblerDef extends ProcessorDef {
private final Vector includePaths = new Vector();
private final Vector sysIncludePaths = new Vector();
private Boolean defaultflag = new Boolean(true);
public AssemblerDef () {
}
/**
* Adds a assembler command-line arg.
*/
public void addConfiguredAssemblerArg(AssemblerArgument arg) {
if (isReference()) {
throw noChildrenAllowed();
}
addConfiguredProcessorArg(arg);
}
/**
* Creates an include path.
*/
public IncludePath createIncludePath() {
Project p = getProject();
if (p == null) {
throw new java.lang.IllegalStateException("project must be set");
}
if (isReference()) {
throw noChildrenAllowed();
}
IncludePath path = new IncludePath(p);
includePaths.addElement(path);
return path;
}
/**
* Creates an include path.
*/
public SystemIncludePath createSysIncludePath() {
Project p = getProject();
if (p == null) {
throw new java.lang.IllegalStateException("project must be set");
}
if (isReference()) {
throw noChildrenAllowed();
}
SystemIncludePath path = new SystemIncludePath(p);
sysIncludePaths.addElement(path);
return path;
}
/**
* Add a <includepath>or <sysincludepath> if specify the file attribute
*
* @throws BuildException
* if the specify file not exist
*/
protected void loadFile(Vector activePath, File file) throws BuildException {
FileReader fileReader;
BufferedReader in;
String str;
if (!file.exists()) {
throw new BuildException("The file " + file + " is not existed");
}
try {
fileReader = new FileReader(file);
in = new BufferedReader(fileReader);
while ((str = in.readLine()) != null) {
if (str.trim() == "") {
continue;
}
str = getProject().replaceProperties(str);
activePath.addElement(str.trim());
}
} catch (Exception e) {
throw new BuildException(e.getMessage());
}
}
public void execute() throws org.apache.tools.ant.BuildException {
throw new org.apache.tools.ant.BuildException(
"Not an actual task, but looks like one for documentation purposes");
}
/**
* Returns the assembler-specific include path.
*/
public String[] getActiveIncludePaths() {
if (isReference()) {
return ((AssemblerDef) getCheckedRef(AssemblerDef.class,
"AssemblerDef")).getActiveIncludePaths();
}
return getActivePaths(includePaths);
}
/**
* Returns the assembler-specific sysinclude path.
*/
public String[] getActiveSysIncludePaths() {
if (isReference()) {
return ((AssemblerDef) getCheckedRef(AssemblerDef.class,
"AssemblerDef")).getActiveSysIncludePaths();
}
return getActivePaths(sysIncludePaths);
}
private String[] getActivePaths(Vector paths) {
Project p = getProject();
if (p == null) {
throw new java.lang.IllegalStateException("project not set");
}
Vector activePaths = new Vector(paths.size());
for (int i = 0; i < paths.size(); i++) {
ConditionalPath path = (ConditionalPath) paths.elementAt(i);
if (path.isActive(p)) {
if (path.getFile() == null) {
String[] pathEntries = path.list();
for (int j = 0; j < pathEntries.length; j++) {
activePaths.addElement(pathEntries[j]);
}
} else {
loadFile(activePaths, path.getFile());
}
}
}
String[] pathNames = new String[activePaths.size()];
activePaths.copyInto(pathNames);
return pathNames;
}
public final Boolean getDefaultflag(AssemblerDef[] defaultProviders,
int index) {
if (isReference()) {
return ((AssemblerDef) getCheckedRef(AssemblerDef.class,
"AssemblerDef")).getDefaultflag(defaultProviders,
index);
}
return defaultflag;
}
public Processor getProcessor() {
Processor processor = super.getProcessor();
if (processor == null) {
processor = GccAssembler.getInstance();
}
return processor;
}
/**
* Sets r type.
*
* <table width="100%" border="1"> <thead>Supported assemblers</thead>
* <tr>
* <td>gcc (default)</td>
* <td>GAS assembler</td>
* </tr>
* <tr>
* <td>masm</td>
* <td>MASM assembler</td>
* </tr>
* </table>
*
*/
public void setName(AssemblerEnum name) throws BuildException {
if (isReference()) {
throw tooManyAttributes();
}
Assembler assembler = name.getAssembler();
setProcessor(assembler);
}
protected void setProcessor(Processor proc) throws BuildException {
try {
super.setProcessor((Assembler) proc);
} catch (ClassCastException ex) {
throw new BuildException(ex);
}
}
/**
* Enables or disables default flags.
*
* @param defaultflag
* if true, default flags will add to command line.
*
*/
public void setDefaultflag(boolean defaultflag) {
if (isReference()) {
throw tooManyAttributes();
}
this.defaultflag = booleanValueOf(defaultflag);
}
}