
org.gradle.api.internal.tasks.compile.daemon.AbstractDaemonCompiler Maven / Gradle / Ivy
/*
* Copyright 2014 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.internal.tasks.compile.daemon;
import org.gradle.api.tasks.WorkResult;
import org.gradle.internal.UncheckedException;
import org.gradle.language.base.internal.compile.CompileSpec;
import org.gradle.language.base.internal.compile.Compiler;
import org.gradle.workers.internal.DaemonForkOptions;
import org.gradle.workers.internal.WorkSpec;
import org.gradle.workers.internal.WorkerDaemonAction;
import org.gradle.workers.internal.DefaultWorkResult;
import org.gradle.workers.internal.WorkerDaemon;
import org.gradle.workers.internal.WorkerDaemonFactory;
import org.gradle.workers.internal.WorkerDaemonServer;
import java.io.File;
public abstract class AbstractDaemonCompiler implements Compiler {
private final Compiler delegate;
private final WorkerDaemonFactory compilerDaemonFactory;
private final File daemonWorkingDir;
public AbstractDaemonCompiler(File daemonWorkingDir, Compiler delegate, WorkerDaemonFactory compilerDaemonFactory) {
this.daemonWorkingDir = daemonWorkingDir;
this.delegate = delegate;
this.compilerDaemonFactory = compilerDaemonFactory;
}
public Compiler getDelegate() {
return delegate;
}
@Override
public WorkResult execute(T spec) {
DaemonForkOptions daemonForkOptions = toDaemonOptions(spec);
WorkerDaemon daemon = compilerDaemonFactory.getDaemon(CompilerDaemonServer.class, daemonWorkingDir, daemonForkOptions);
DefaultWorkResult result = daemon.execute(adapter(delegate), spec);
if (result.isSuccess()) {
return result;
}
throw UncheckedException.throwAsUncheckedException(result.getException());
}
private CompilerWorkerAdapter adapter(Compiler compiler) {
return new CompilerWorkerAdapter(compiler);
}
protected abstract DaemonForkOptions toDaemonOptions(T spec);
private static class CompilerWorkerAdapter implements WorkerDaemonAction {
private final Compiler compiler;
CompilerWorkerAdapter(Compiler compiler) {
this.compiler = compiler;
}
@Override
public DefaultWorkResult execute(T spec) {
return new DefaultWorkResult(compiler.execute(spec).getDidWork(), null);
}
@Override
public String getDescription() {
return compiler.getClass().getName();
}
}
// TODO Come up with a better way to set up the worker implementation classpath
// This is a hack to get the appropriate classpath on the worker implementation classpath for compiler daemons.
// The classpath is derived from the implementation class and when this is WorkerDaemonServer, we get the classpath
// from the classloader in the Gradle Core API classloader scope (which only contains certain jars). Using this
// class causes the classpath to be inferred from the Gradle API scope classloader instead so that we get the necessary
// jars for a compiler daemon.
public static class CompilerDaemonServer extends WorkerDaemonServer {
@Override
public DefaultWorkResult execute(WorkerDaemonAction action, T spec) {
return super.execute(action, spec);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy