use of org.jetbrains.jps.incremental.messages.ProgressMessage in project intellij-community by JetBrains.
the class MavenResourcesBuilder method build.
@Override
public void build(@NotNull final MavenResourcesTarget target, @NotNull final DirtyFilesHolder<MavenResourceRootDescriptor, MavenResourcesTarget> holder, @NotNull final BuildOutputConsumer outputConsumer, @NotNull final CompileContext context) throws ProjectBuildException, IOException {
final BuildDataPaths dataPaths = context.getProjectDescriptor().dataManager.getDataPaths();
final MavenProjectConfiguration projectConfig = JpsMavenExtensionService.getInstance().getMavenProjectConfiguration(dataPaths);
if (projectConfig == null) {
context.processMessage(new CompilerMessage(BUILDER_NAME, BuildMessage.Kind.ERROR, "Maven project configuration required for module '" + target.getModule().getName() + "' isn't available. Compilation of Maven projects is supported only if external build is started from an IDE."));
throw new StopBuildException();
}
final MavenModuleResourceConfiguration config = target.getModuleResourcesConfiguration(dataPaths);
if (config == null) {
return;
}
final Map<MavenResourceRootDescriptor, List<File>> files = new HashMap<>();
holder.processDirtyFiles(new FileProcessor<MavenResourceRootDescriptor, MavenResourcesTarget>() {
@Override
public boolean apply(MavenResourcesTarget t, File file, MavenResourceRootDescriptor rd) throws IOException {
assert target == t;
List<File> fileList = files.get(rd);
if (fileList == null) {
fileList = new ArrayList<>();
files.put(rd, fileList);
}
fileList.add(file);
return true;
}
});
MavenResourceRootDescriptor[] roots = files.keySet().toArray(new MavenResourceRootDescriptor[files.keySet().size()]);
Arrays.sort(roots, (r1, r2) -> {
int res = r1.getIndexInPom() - r2.getIndexInPom();
if (r1.isOverwrite()) {
// 'overwrite' parameters is common for all roots in module.
assert r2.isOverwrite();
return res;
}
if (r1.getConfiguration().isFiltered && !r2.getConfiguration().isFiltered)
return 1;
if (!r1.getConfiguration().isFiltered && r2.getConfiguration().isFiltered)
return -1;
if (!r1.getConfiguration().isFiltered) {
res = -res;
}
return res;
});
MavenResourceFileProcessor fileProcessor = new MavenResourceFileProcessor(projectConfig, target.getModule().getProject(), config);
context.processMessage(new ProgressMessage("Copying resources... [" + target.getModule().getName() + "]"));
for (MavenResourceRootDescriptor rd : roots) {
for (File file : files.get(rd)) {
String relPath = FileUtil.getRelativePath(rd.getRootFile(), file);
if (relPath == null) {
continue;
}
final String outputDirectory = target.isTests() ? config.testOutputDirectory : config.outputDirectory;
final File outputDir = MavenResourcesTarget.getOutputDir(target.getModuleOutputDir(), rd.getConfiguration(), outputDirectory);
if (outputDir == null) {
continue;
}
File outputFile = new File(outputDir, relPath);
String sourcePath = file.getPath();
try {
fileProcessor.copyFile(file, outputFile, rd.getConfiguration(), context, FileUtilRt.ALL_FILES);
outputConsumer.registerOutputFile(outputFile, Collections.singleton(sourcePath));
} catch (UnsupportedEncodingException e) {
context.processMessage(new CompilerMessage(BUILDER_NAME, BuildMessage.Kind.INFO, "Resource was not copied: " + e.getMessage(), sourcePath));
} catch (IOException e) {
context.processMessage(new CompilerMessage(BUILDER_NAME, BuildMessage.Kind.ERROR, "Failed to copy '" + sourcePath + "' to '" + outputFile.getAbsolutePath() + "': " + e.getMessage()));
LOG.info(e);
}
if (context.getCancelStatus().isCanceled()) {
return;
}
}
}
context.checkCanceled();
context.processMessage(new ProgressMessage(""));
}
use of org.jetbrains.jps.incremental.messages.ProgressMessage in project intellij-community by JetBrains.
the class DependencyResolvingBuilder method getRepositoryManager.
private static ArtifactRepositoryManager getRepositoryManager(final CompileContext context) {
ArtifactRepositoryManager manager = MANAGER_KEY.get(context);
if (manager == null) {
manager = new ArtifactRepositoryManager(getLocalRepoDir(context), new ProgressConsumer() {
public void consume(String message) {
context.processMessage(new ProgressMessage(message));
}
});
// further init manager here
MANAGER_KEY.set(context, manager);
}
return manager;
}
Aggregations