Search in sources :

Example 6 with CobiGenRuntimeException

use of com.devonfw.cobigen.api.exception.CobiGenRuntimeException in project cobigen by devonfw.

the class XmlMatcher method resolveVariablesXPath.

/**
 * Resolves the given xpath expression on the given doc.
 *
 * @param doc target document
 * @param xpathExpression xpath expression
 * @return the text content of the first node resulting from the xpath or the empty string if the xpath results in an
 *         empty list
 */
private String resolveVariablesXPath(Node doc, String xpathExpression) {
    XPath xPath = XPathFactory.newInstance().newXPath();
    LOG.debug("Evaluating xpath {}", xpathExpression);
    try {
        NodeList list = (NodeList) xPath.evaluate(xpathExpression, doc, XPathConstants.NODESET);
        if (list.getLength() > 0) {
            // currently, we just allow strings as variable assignment values
            LOG.debug("... found {} nodes.", list.getLength());
            return list.item(0).getTextContent();
        } else {
            LOG.debug("... nothing found.", list.getLength());
            // we have to return empty string as of Variables restrictions of cobigen-core
            return "";
        }
    } catch (XPathExpressionException e) {
        throw new CobiGenRuntimeException("Could not evaluate xpath expression " + xpathExpression, e);
    }
}
Also used : XPath(javax.xml.xpath.XPath) CobiGenRuntimeException(com.devonfw.cobigen.api.exception.CobiGenRuntimeException) XPathExpressionException(javax.xml.xpath.XPathExpressionException) NodeList(org.w3c.dom.NodeList)

Example 7 with CobiGenRuntimeException

use of com.devonfw.cobigen.api.exception.CobiGenRuntimeException in project cobigen by devonfw.

the class CobiGenWrapper method generate.

/**
 * Generates the the list of templates based on the given {@link #inputs}.
 *
 * @param templates to be generated
 * @param monitor to track the progress
 * @return the {@link GenerationReportTo generation report of CobiGen}
 * @throws Exception if anything during generation fails.
 */
public GenerationReportTo generate(List<TemplateTo> templates, IProgressMonitor monitor) throws Exception {
    final IProject proj = getGenerationTargetProject();
    if (proj != null) {
        LOG.debug("Generating files...");
        SubMonitor subMonitor = SubMonitor.convert(monitor, 105);
        if (monitor.isCanceled()) {
            throw new CancellationException("generation got Cancelled by the User");
        }
        monitor.setTaskName("Load templates...");
        SubMonitor loadTemplates = subMonitor.split(2);
        // set override flags individually for every template
        for (TemplateTo template : templates) {
            // wizard and does not declare any merge strategy), the complete file should be overwritten
            if (template.getMergeStrategy() == null) {
                template.setForceOverride(true);
            }
        }
        loadTemplates.done();
        if (monitor.isCanceled()) {
            throw new CancellationException("Generation got cancelled by the user");
        }
        monitor.setTaskName("Determine destination paths...");
        SubMonitor generateTargetUri = subMonitor.split(1);
        URI generationTargetUri = getGenerationTargetProject().getLocationURI();
        if (generationTargetUri == null) {
            throw new CobiGenRuntimeException("The location URI of the generation target project " + getGenerationTargetProject().getName() + " could not be resolved. This might be " + "a temporary issue. If this problem persists, please state a bug report.");
        }
        generateTargetUri.done();
        monitor.setTaskName("Generate files...");
        GenerationReportTo report;
        if (this.singleNonContainerInput) {
            // if we only consider one input, we want to allow some customizations of the generation
            LOG.debug("Generating with single non container input ...");
            report = this.cobiGen.generate(this.inputs.get(0), templates, Paths.get(generationTargetUri), false, (String taskName, Integer progress) -> {
                monitor.setTaskName(taskName);
                monitor.worked(progress);
            });
        } else {
            report = new GenerationReportTo();
            for (Object input : this.inputs) {
                report.aggregate(this.cobiGen.generate(input, templates, Paths.get(generationTargetUri), false, (taskname, progress) -> {
                    monitor.setTaskName(taskname);
                    monitor.worked(progress);
                }));
            }
        }
        monitor.setTaskName("Refresh workspace...");
        proj.getProject().refreshLocal(IResource.DEPTH_INFINITE, new NullProgressMonitor());
        monitor.done();
        if (report.isSuccessful()) {
            LOG.info("Generation finished successfully.");
        }
        return report;
    } else {
        throw new CobiGenRuntimeException("No generation target project configured! This is a Bug!");
    }
}
Also used : ConfigurationConstants(com.devonfw.cobigen.api.constants.ConfigurationConstants) IncrementTo(com.devonfw.cobigen.api.to.IncrementTo) Arrays(java.util.Arrays) ResourcesPlugin(org.eclipse.core.resources.ResourcesPlugin) SubMonitor(org.eclipse.core.runtime.SubMonitor) LoggerFactory(org.slf4j.LoggerFactory) CobiGen(com.devonfw.cobigen.api.CobiGen) Function(java.util.function.Function) PlatformUIUtil(com.devonfw.cobigen.eclipse.common.tools.PlatformUIUtil) InvalidInputException(com.devonfw.cobigen.eclipse.common.exceptions.InvalidInputException) HashSet(java.util.HashSet) Lists(com.google.common.collect.Lists) IProject(org.eclipse.core.resources.IProject) ComparableIncrement(com.devonfw.cobigen.eclipse.generator.entity.ComparableIncrement) Map(java.util.Map) URI(java.net.URI) Path(java.nio.file.Path) TemplateTo(com.devonfw.cobigen.api.to.TemplateTo) MapUtils(com.devonfw.cobigen.eclipse.common.tools.MapUtils) Trigger(org.eclipse.jface.bindings.Trigger) Logger(org.slf4j.Logger) CobiGenRuntimeException(com.devonfw.cobigen.api.exception.CobiGenRuntimeException) Iterator(java.util.Iterator) CancellationException(java.util.concurrent.CancellationException) Predicate(java.util.function.Predicate) Collection(java.util.Collection) ProgressMonitorDialog(org.eclipse.jface.dialogs.ProgressMonitorDialog) ConcurrentHashMap(java.util.concurrent.ConcurrentHashMap) Set(java.util.Set) IOException(java.io.IOException) CobiGenEclipseRuntimeException(com.devonfw.cobigen.eclipse.common.exceptions.CobiGenEclipseRuntimeException) Display(org.eclipse.swt.widgets.Display) InvalidConfigurationException(com.devonfw.cobigen.api.exception.InvalidConfigurationException) Maps(com.google.common.collect.Maps) Sets(com.google.common.collect.Sets) InvocationTargetException(java.lang.reflect.InvocationTargetException) IProgressMonitor(org.eclipse.core.runtime.IProgressMonitor) GenerationReportTo(com.devonfw.cobigen.api.to.GenerationReportTo) List(java.util.List) Paths(java.nio.file.Paths) NullProgressMonitor(org.eclipse.core.runtime.NullProgressMonitor) GeneratorProjectNotExistentException(com.devonfw.cobigen.eclipse.common.exceptions.GeneratorProjectNotExistentException) IResource(org.eclipse.core.resources.IResource) Entry(java.util.Map.Entry) NullProgressMonitor(org.eclipse.core.runtime.NullProgressMonitor) CobiGenRuntimeException(com.devonfw.cobigen.api.exception.CobiGenRuntimeException) GenerationReportTo(com.devonfw.cobigen.api.to.GenerationReportTo) CancellationException(java.util.concurrent.CancellationException) SubMonitor(org.eclipse.core.runtime.SubMonitor) URI(java.net.URI) IProject(org.eclipse.core.resources.IProject) TemplateTo(com.devonfw.cobigen.api.to.TemplateTo)

Example 8 with CobiGenRuntimeException

use of com.devonfw.cobigen.api.exception.CobiGenRuntimeException in project cobigen by devonfw.

the class CobiGenUtils method extractArtificialPom.

/**
 * Extracts an artificial POM which defines all the CobiGen plug-ins that are needed
 *
 * @return the extracted POM file
 */
public static File extractArtificialPom() {
    Path cliHome = getCliHomePath();
    File pomFile = cliHome.resolve(MavenConstants.POM).toFile();
    if (!pomFile.exists()) {
        try (InputStream resourcesIs1 = CobiGenUtils.class.getResourceAsStream("/" + MavenConstants.POM);
            InputStream resourcesIs2 = CobiGenUtils.class.getClass().getResourceAsStream("/" + MavenConstants.POM)) {
            if (resourcesIs1 != null) {
                LOG.debug("Taking pom.xml from classpath");
                Files.createDirectories(pomFile.toPath().getParent());
                Files.copy(resourcesIs1, pomFile.getAbsoluteFile().toPath());
            } else if (resourcesIs2 != null) {
                LOG.debug("Taking pom.xml from system classpath");
                Files.createDirectories(pomFile.toPath().getParent());
                Files.copy(resourcesIs1, pomFile.getAbsoluteFile().toPath());
            } else {
                if (CobiGenUtils.class.getClassLoader() instanceof URLClassLoader) {
                    LOG.debug("Classloader URLs:");
                    Arrays.stream(((URLClassLoader) CobiGenUtils.class.getClassLoader()).getURLs()).forEach(url -> LOG.debug("  - {}", url));
                }
                if (CobiGenUtils.class.getClass().getClassLoader() instanceof URLClassLoader) {
                    LOG.debug("System Classloader URLs:");
                    Arrays.stream(((URLClassLoader) CobiGenUtils.class.getClassLoader()).getURLs()).forEach(url -> LOG.debug("  - {}", url));
                }
                throw new CobiGenRuntimeException("Unable to locate pom.xml on classpath");
            }
        } catch (IOException e1) {
            throw new CobiGenRuntimeException("Failed to extract CobiGen plugins pom.", e1);
        }
    }
    return pomFile;
}
Also used : Path(java.nio.file.Path) IncrementTo(com.devonfw.cobigen.api.to.IncrementTo) Arrays(java.util.Arrays) InputReaderException(com.devonfw.cobigen.api.exception.InputReaderException) LoggerFactory(org.slf4j.LoggerFactory) CobiGen(com.devonfw.cobigen.api.CobiGen) ArrayList(java.util.ArrayList) URLClassLoader(java.net.URLClassLoader) CobiGenFactory(com.devonfw.cobigen.impl.CobiGenFactory) CobiGenCLI(com.devonfw.cobigen.cli.CobiGenCLI) InputInterpreter(com.devonfw.cobigen.api.InputInterpreter) Path(java.nio.file.Path) TemplateTo(com.devonfw.cobigen.api.to.TemplateTo) ClassServiceLoader(com.devonfw.cobigen.impl.extension.ClassServiceLoader) Charsets(com.google.common.base.Charsets) Logger(org.slf4j.Logger) CobiGenRuntimeException(com.devonfw.cobigen.api.exception.CobiGenRuntimeException) Files(java.nio.file.Files) MavenUtil(com.devonfw.cobigen.api.util.MavenUtil) IOException(java.io.IOException) File(java.io.File) List(java.util.List) Paths(java.nio.file.Paths) CobiGenPaths(com.devonfw.cobigen.api.util.CobiGenPaths) MavenConstants(com.devonfw.cobigen.api.constants.MavenConstants) InputStream(java.io.InputStream) CobiGenRuntimeException(com.devonfw.cobigen.api.exception.CobiGenRuntimeException) InputStream(java.io.InputStream) URLClassLoader(java.net.URLClassLoader) IOException(java.io.IOException) File(java.io.File)

Example 9 with CobiGenRuntimeException

use of com.devonfw.cobigen.api.exception.CobiGenRuntimeException in project cobigen by devonfw.

the class TemplateFolder method scanChildren.

/**
 * Scans and creates all children.
 */
private void scanChildren() {
    if (this.childrenScanned) {
        return;
    }
    Path templatePath = getPath();
    try (DirectoryStream<Path> directoryStream = Files.newDirectoryStream(templatePath)) {
        for (Path childName : directoryStream) {
            String filename = childName.getFileName().toString();
            if (filename.endsWith("/")) {
                filename = filename.substring(0, filename.length() - 1);
            }
            if (!ConfigurationConstants.COBIGEN_PROPERTIES.equals(filename) && !this.children.containsKey(filename)) {
                TemplatePath child = createChild(childName);
                this.children.put(filename, child);
            }
        }
        if (this.childFiles == null) {
            this.childFiles = Collections.emptyList();
        } else {
            this.childFiles = Collections.unmodifiableList(this.childFiles);
        }
        if (this.childFolders == null) {
            this.childFolders = Collections.emptyList();
        } else {
            this.childFolders = Collections.unmodifiableList(this.childFolders);
        }
        this.childrenScanned = true;
    } catch (IOException e) {
        throw new CobiGenRuntimeException("Failed to list directory of " + templatePath, e);
    }
}
Also used : Path(java.nio.file.Path) CobiGenRuntimeException(com.devonfw.cobigen.api.exception.CobiGenRuntimeException) IOException(java.io.IOException)

Example 10 with CobiGenRuntimeException

use of com.devonfw.cobigen.api.exception.CobiGenRuntimeException in project cobigen by devonfw.

the class GenerationProcessorImpl method generate.

@Override
public GenerationReportTo generate(Object input, List<? extends GenerableArtifact> generableArtifacts, Path targetRootPath, boolean forceOverride, Map<String, Object> rawModel, BiConsumer<String, Integer> progressCallback) {
    InputValidator.validateInputsUnequalNull(input, generableArtifacts);
    List<Class<?>> logicClasses = null;
    // only implicit dependency to javaplugin to lower classloader complexity
    ClassLoader inputProjectClassLoader = null;
    if (input instanceof Class) {
        inputProjectClassLoader = ((Class<?>) input).getClassLoader();
    } else if (input instanceof Object[]) {
        for (Object obj : (Object[]) input) {
            if (obj instanceof Class) {
                inputProjectClassLoader = ((Class<?>) obj).getClassLoader();
            }
        }
    }
    Path templateConfigPath = Paths.get(this.configurationHolder.getConfigurationLocation());
    progressCallback.accept("Prepend Templates Classloader", 10);
    inputProjectClassLoader = prependTemplatesClassloader(templateConfigPath, inputProjectClassLoader);
    if (inputProjectClassLoader != null) {
        try {
            logicClasses = ConfigurationClassLoaderUtil.resolveUtilClasses(this.configurationHolder, inputProjectClassLoader);
        } catch (IOException e) {
            LOG.error("An IOException occured while resolving utility classes!", e);
        }
    }
    // initialize
    this.forceOverride = forceOverride;
    this.input = input;
    if (logicClasses != null) {
        progressCallback.accept("Load Template logic classes", 20);
        loadLogicClasses(progressCallback, logicClasses);
    }
    progressCallback.accept("Create Temporary Target Directory", 40);
    this.rawModel = rawModel;
    try {
        this.tmpTargetRootPath = Files.createTempDirectory("cobigen-");
        LOG.info("Temporary working directory: {}", this.tmpTargetRootPath);
    } catch (IOException e) {
        throw new CobiGenRuntimeException("Could not create temporary folder.", e);
    }
    this.targetRootPath = targetRootPath;
    this.generationReport = new GenerationReportTo();
    progressCallback.accept("Load templates", 50);
    LOG.debug("Collecting templates");
    Collection<TemplateTo> templatesToBeGenerated = flatten(generableArtifacts);
    // generate
    Map<File, File> origToTmpFileTrace = Maps.newHashMap();
    try {
        LOG.debug("Generating {} templates", templatesToBeGenerated.size());
        for (TemplateTo template : templatesToBeGenerated) {
            try {
                Trigger trigger = this.configurationHolder.readContextConfiguration().getTrigger(template.getTriggerId());
                TriggerInterpreter triggerInterpreter = PluginRegistry.getTriggerInterpreter(trigger.getType());
                InputValidator.validateTriggerInterpreter(triggerInterpreter, trigger);
                progressCallback.accept("Generating " + template.getId(), Math.round(1 / (float) templatesToBeGenerated.size() * 800));
                generate(template, triggerInterpreter, origToTmpFileTrace, progressCallback);
            } catch (CobiGenCancellationException e) {
                throw (e);
            } catch (CobiGenRuntimeException e) {
                this.generationReport.setTemporaryWorkingDirectory(this.tmpTargetRootPath);
                this.generationReport.addError(e);
            } catch (Throwable e) {
                this.generationReport.setTemporaryWorkingDirectory(this.tmpTargetRootPath);
                this.generationReport.addError(new CobiGenRuntimeException("Something unexpected happened" + ((e.getMessage() != null) ? ": " + e.getMessage() : "!"), e));
            }
        }
    } catch (CobiGenCancellationException e) {
        LOG.error("the Generation has been Canceled.", e);
        this.generationReport.setCancelled(true);
    }
    if (this.generationReport.isCancelled()) {
        this.generationReport.setTemporaryWorkingDirectory(this.tmpTargetRootPath);
        this.tmpTargetRootPath.toFile().deleteOnExit();
    // do nothing if cancelled
    } else if (this.generationReport.isSuccessful()) {
        try {
            for (Entry<File, File> origToTmpFile : origToTmpFileTrace.entrySet()) {
                Files.createDirectories(origToTmpFile.getKey().toPath().getParent());
                Files.copy(origToTmpFile.getValue().toPath(), origToTmpFile.getKey().toPath(), StandardCopyOption.REPLACE_EXISTING);
                this.generationReport.addGeneratedFile(origToTmpFile.getKey().toPath());
            }
            this.tmpTargetRootPath.toFile().deleteOnExit();
        } catch (IOException e) {
            this.generationReport.setTemporaryWorkingDirectory(this.tmpTargetRootPath);
            throw new CobiGenRuntimeException("Could not copy generated files to target location!", e);
        }
    } else {
        this.generationReport.setTemporaryWorkingDirectory(this.tmpTargetRootPath);
        LOG.warn("Generation finished non-successful. Generated contents can be reviewed in " + this.tmpTargetRootPath.toUri());
    }
    return this.generationReport;
}
Also used : Path(java.nio.file.Path) TriggerInterpreter(com.devonfw.cobigen.api.extension.TriggerInterpreter) CobiGenRuntimeException(com.devonfw.cobigen.api.exception.CobiGenRuntimeException) CobiGenCancellationException(com.devonfw.cobigen.api.exception.CobiGenCancellationException) IOException(java.io.IOException) Entry(java.util.Map.Entry) GenerationReportTo(com.devonfw.cobigen.api.to.GenerationReportTo) Trigger(com.devonfw.cobigen.impl.config.entity.Trigger) URLClassLoader(java.net.URLClassLoader) File(java.io.File) TemplateTo(com.devonfw.cobigen.api.to.TemplateTo)

Aggregations

CobiGenRuntimeException (com.devonfw.cobigen.api.exception.CobiGenRuntimeException)43 IOException (java.io.IOException)22 Path (java.nio.file.Path)15 File (java.io.File)8 LoggerFactory (org.slf4j.LoggerFactory)5 InvalidConfigurationException (com.devonfw.cobigen.api.exception.InvalidConfigurationException)4 TextTemplateEngine (com.devonfw.cobigen.api.extension.TextTemplateEngine)4 GenerationReportTo (com.devonfw.cobigen.api.to.GenerationReportTo)4 Trigger (com.devonfw.cobigen.impl.config.entity.Trigger)4 InputStream (java.io.InputStream)4 URL (java.net.URL)4 URLClassLoader (java.net.URLClassLoader)4 CobiGen (com.devonfw.cobigen.api.CobiGen)3 TriggerInterpreter (com.devonfw.cobigen.api.extension.TriggerInterpreter)3 TemplateTo (com.devonfw.cobigen.api.to.TemplateTo)3 BackupFailedException (com.devonfw.cobigen.impl.exceptions.BackupFailedException)3 Paths (java.nio.file.Paths)3 HashMap (java.util.HashMap)3 List (java.util.List)3 Logger (org.slf4j.Logger)3