/* * Copyright (c) 2007-2009, Osmorc Development Team * All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, * are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright notice, this list * of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright notice, this * list of conditions and the following disclaimer in the documentation and/or other * materials provided with the distribution. * * Neither the name of 'Osmorc Development Team' nor the names of its contributors may be * used to endorse or promote products derived from this software without specific * prior written permission. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL * THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ package org.osmorc.make; import aQute.lib.osgi.Builder; import com.intellij.openapi.compiler.CompileContext; import com.intellij.openapi.compiler.CompilerMessageCategory; import com.intellij.openapi.components.ServiceManager; import com.intellij.openapi.module.Module; import com.intellij.openapi.vfs.VfsUtil; import com.intellij.openapi.vfs.VirtualFile; import com.intellij.psi.PsiFile; import org.jetbrains.idea.maven.model.MavenPlugin; import org.jetbrains.idea.maven.project.MavenProject; import org.jetbrains.idea.maven.project.MavenProjectsManager; import org.osmorc.BundleManager; import org.osmorc.facet.OsmorcFacet; import org.osmorc.facet.OsmorcFacetConfiguration; import org.osmorc.manifest.BundleManifest; import java.text.MessageFormat; /** * Created by IntelliJ IDEA. User: kork Date: Jul 20, 2009 Time: 9:51:18 PM To change this template use File | Settings * | File Templates. */ class ReportingBuilder extends Builder { private final CompileContext myContext; private String mySourceFileName; private String myMessagePrefix; public ReportingBuilder(CompileContext context, String sourceFileName, Module module) { super(); myContext = context; OsmorcFacet facet = OsmorcFacet.getInstance(module); mySourceFileName = sourceFileName; // link back to the original manifest if it's manually edited if ( facet != null ) { OsmorcFacetConfiguration configuration = facet.getConfiguration(); if (configuration.isManifestManuallyEdited()) { BundleManager bundleManager = ServiceManager.getService(module.getProject(), BundleManager.class); BundleManifest bundleManifest = bundleManager.getBundleManifest(module); if (bundleManifest != null) { PsiFile manifestFile = bundleManifest.getManifestFile(); VirtualFile virtualFile = manifestFile.getVirtualFile(); if ( virtualFile != null ) mySourceFileName = VfsUtil.pathToUrl(virtualFile.getPath()); } }else { // try if module was imported from maven. MavenProjectsManager projectsManager = MavenProjectsManager.getInstance(module.getProject()); MavenProject project = projectsManager.findProject(module); if ( project != null ) { MavenPlugin plugin = project.findPlugin("org.apache.felix", "maven-bundle-plugin"); if ( plugin != null ) { // ok it's imported from maven, link warnings/errors back to pom.xml mySourceFileName = VfsUtil.pathToUrl(project.getPath()); } } } } myMessagePrefix = "[" + module.getName() + "] "; } @Override public void error(String s, Object... objects) { myContext.addMessage(CompilerMessageCategory.ERROR, MessageFormat.format(myMessagePrefix +s, objects), mySourceFileName, 0,0); } @Override public void error(String s, Throwable throwable, Object... objects) { myContext.addMessage(CompilerMessageCategory.ERROR, MessageFormat.format(myMessagePrefix + s, objects) + "(" + throwable.getMessage() + ")", mySourceFileName, 0, 0); } @Override public void warning(String s, Object... objects) { myContext.addMessage(CompilerMessageCategory.WARNING, MessageFormat.format(myMessagePrefix + s, objects), mySourceFileName, 0,0); } @Override public void progress(String s, Object... objects) { myContext.addMessage(CompilerMessageCategory.INFORMATION, MessageFormat.format(myMessagePrefix + s, objects), mySourceFileName, 0,0); } /** * Overridden to make it public. */ public void begin() { super.begin(); } }