org.gradle.api.plugins.antlr.AntlrTask Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-api Show documentation
Show all versions of gradle-api Show documentation
Gradle 6.9.1 API redistribution.
/*
* Copyright 2010 the original author or authors.
*
* 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 org.gradle.api.plugins.antlr;
import org.gradle.api.Action;
import org.gradle.api.file.FileCollection;
import org.gradle.api.file.FileTree;
import org.gradle.api.file.SourceDirectorySet;
import org.gradle.api.plugins.antlr.internal.AntlrResult;
import org.gradle.api.plugins.antlr.internal.AntlrSourceGenerationException;
import org.gradle.api.plugins.antlr.internal.AntlrSpec;
import org.gradle.api.plugins.antlr.internal.AntlrSpecFactory;
import org.gradle.api.plugins.antlr.internal.AntlrWorkerManager;
import org.gradle.api.tasks.Input;
import org.gradle.api.tasks.InputFiles;
import org.gradle.api.tasks.Optional;
import org.gradle.api.tasks.OrderSensitive;
import org.gradle.api.tasks.OutputDirectory;
import org.gradle.api.tasks.SkipWhenEmpty;
import org.gradle.api.tasks.SourceTask;
import org.gradle.api.tasks.TaskAction;
import org.gradle.api.tasks.incremental.IncrementalTaskInputs;
import org.gradle.api.tasks.incremental.InputFileDetails;
import org.gradle.process.internal.worker.WorkerProcessFactory;
import org.gradle.util.GFileUtils;
import javax.inject.Inject;
import java.io.File;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.concurrent.atomic.AtomicBoolean;
/**
* Generates parsers from Antlr grammars.
*/
public class AntlrTask extends SourceTask {
private boolean trace;
private boolean traceLexer;
private boolean traceParser;
private boolean traceTreeWalker;
private List arguments = new ArrayList();
private FileCollection antlrClasspath;
private File outputDirectory;
private String maxHeapSize;
private SourceDirectorySet sourceDirectorySet;
/**
* Specifies that all rules call {@code traceIn}/{@code traceOut}.
*/
@Input
public boolean isTrace() {
return trace;
}
public void setTrace(boolean trace) {
this.trace = trace;
}
/**
* Specifies that all lexer rules call {@code traceIn}/{@code traceOut}.
*/
@Input
public boolean isTraceLexer() {
return traceLexer;
}
public void setTraceLexer(boolean traceLexer) {
this.traceLexer = traceLexer;
}
/**
* Specifies that all parser rules call {@code traceIn}/{@code traceOut}.
*/
@Input
public boolean isTraceParser() {
return traceParser;
}
public void setTraceParser(boolean traceParser) {
this.traceParser = traceParser;
}
/**
* Specifies that all tree walker rules call {@code traceIn}/{@code traceOut}.
*/
@Input
public boolean isTraceTreeWalker() {
return traceTreeWalker;
}
public void setTraceTreeWalker(boolean traceTreeWalker) {
this.traceTreeWalker = traceTreeWalker;
}
/**
* The maximum heap size for the forked antlr process (ex: '1g').
*/
@Optional @Input
public String getMaxHeapSize() {
return maxHeapSize;
}
public void setMaxHeapSize(String maxHeapSize) {
this.maxHeapSize = maxHeapSize;
}
public void setArguments(List arguments) {
if (arguments != null) {
this.arguments = arguments;
}
}
/**
* List of command-line arguments passed to the antlr process
*
* @return The antlr command-line arguments
*/
@Input
public List getArguments() {
return arguments;
}
/**
* Returns the directory to generate the parser source files into.
*
* @return The output directory.
*/
@OutputDirectory
public File getOutputDirectory() {
return outputDirectory;
}
/**
* Specifies the directory to generate the parser source files into.
*
* @param outputDirectory The output directory. Must not be null.
*/
public void setOutputDirectory(File outputDirectory) {
this.outputDirectory = outputDirectory;
}
/**
* Returns the classpath containing the Ant ANTLR task implementation.
*
* @return The Ant task implementation classpath.
*/
@OrderSensitive
@InputFiles
public FileCollection getAntlrClasspath() {
return antlrClasspath;
}
/**
* Specifies the classpath containing the Ant ANTLR task implementation.
*
* @param antlrClasspath The Ant task implementation classpath. Must not be null.
*/
protected void setAntlrClasspath(FileCollection antlrClasspath) {
this.antlrClasspath = antlrClasspath;
}
@Inject
protected WorkerProcessFactory getWorkerProcessBuilderFactory() {
throw new UnsupportedOperationException();
}
@TaskAction
public void execute(IncrementalTaskInputs inputs) {
final Set grammarFiles = new HashSet();
final Set sourceFiles = getSource().getFiles();
final AtomicBoolean cleanRebuild = new AtomicBoolean();
inputs.outOfDate(
new Action() {
public void execute(InputFileDetails details) {
File input = details.getFile();
if (sourceFiles.contains(input)) {
grammarFiles.add(input);
} else {
// classpath change?
cleanRebuild.set(true);
}
}
}
);
inputs.removed(new Action() {
@Override
public void execute(InputFileDetails details) {
if (details.isRemoved()) {
cleanRebuild.set(true);
}
}
});
if (cleanRebuild.get()) {
GFileUtils.cleanDirectory(outputDirectory);
grammarFiles.addAll(sourceFiles);
}
AntlrWorkerManager manager = new AntlrWorkerManager();
AntlrSpec spec = new AntlrSpecFactory().create(this, grammarFiles, sourceDirectorySet);
AntlrResult result = manager.runWorker(getProject().getProjectDir(), getWorkerProcessBuilderFactory(), getAntlrClasspath(), spec);
evaluate(result);
}
private void evaluate(AntlrResult result) {
int errorCount = result.getErrorCount();
if(errorCount < 0) {
throw new AntlrSourceGenerationException("There were errors during grammar generation", result.getException());
} else if (errorCount == 1) {
throw new AntlrSourceGenerationException("There was 1 error during grammar generation", result.getException());
} else if (errorCount > 1) {
throw new AntlrSourceGenerationException("There were "
+ errorCount
+ " errors during grammar generation", result.getException());
}
}
/**
* Sets the source for this task. Delegates to {@link SourceTask#setSource(Object)}.
*
* If the source is of type {@link SourceDirectorySet}, then the relative path of each source grammar files
* is used to determine the relative output path of the generated source
* If the source is not of type {@link SourceDirectorySet}, then the generated source files end up
* flattened in the specified output directory.
*
* @param source The source.
*/
@Override
public void setSource(Object source) {
super.setSource(source);
if (source instanceof SourceDirectorySet) {
this.sourceDirectorySet = (SourceDirectorySet) source;
}
}
/**
* Returns the source for this task, after the include and exclude patterns have been applied. Ignores source files which do not exist.
*
* @return The source.
*/
// This method is here as the Gradle DSL generation can't handle properties with setters and getters in different classes.
@InputFiles
@SkipWhenEmpty
public FileTree getSource() {
return super.getSource();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy