Skip to content

Commit

Permalink
Support setting the bundleroot for manifest generated projects
Browse files Browse the repository at this point in the history
Currently we have only the option to set the bundleroot to a different
folder (what the will become the outputfolder). In some cases one might
want to set the bundle root also to the project root.

This now adds special handling for the case where bundle root != output
folder.

Fix #803
  • Loading branch information
laeubi committed Oct 22, 2023
1 parent 6790bd3 commit 6d0a83a
Show file tree
Hide file tree
Showing 2 changed files with 63 additions and 8 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
import org.eclipse.core.resources.IWorkspaceRoot;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.core.runtime.IPath;
import org.eclipse.core.runtime.NullProgressMonitor;
import org.eclipse.jdt.core.IClasspathEntry;
import org.eclipse.jdt.core.IJavaProject;
import org.eclipse.jdt.core.JavaCore;
Expand All @@ -38,10 +39,11 @@
public class ProjectJar extends Jar {

private final IContainer outputFolder;
private IFile manifestFile;

public ProjectJar(IProject project, Predicate<IResource> filter) throws CoreException {
super(project.getName());
outputFolder = PDEProject.getBundleRoot(project);
outputFolder = PDEProject.getJavaOutputFolder(project);
FileResource.addResources(this, outputFolder, filter);
if (project.hasNature(JavaCore.NATURE_ID)) {
IJavaProject javaProject = JavaCore.create(project);
Expand All @@ -57,12 +59,53 @@ public ProjectJar(IProject project, Predicate<IResource> filter) throws CoreExce
}
}
}
manifestFile = PDEProject.getManifest(project);
}

@Override
public void setManifest(Manifest manifest) {
super.setManifest(manifest);
putResource(JarFile.MANIFEST_NAME, new ManifestResource(manifest));
ManifestResource resource = new ManifestResource(manifest);
// We must handle this with a little care here, first we put it as a
// resource, what will make other parts of BND find it and copy it to
// the output location(so it can be found when using the output as a
// classpath)
putResource(JarFile.MANIFEST_NAME, resource);
// but we also need to make sure if BUNDLE_ROOT != output location
// another copy for PDE and other things that expect it at the bundle
// root...
IFile file = outputFolder.getFile(IPath.fromOSString(JarFile.MANIFEST_NAME));
if (!file.getFullPath().equals(manifestFile.getFullPath())) {
// bundle root is currently not where we store it...
if (manifestFile.exists()) {
try (InputStream stream = resource.openInputStream()) {
manifestFile.setContents(stream, true, false, null);
} catch (RuntimeException e) {
throw e;
} catch (Exception e) {
throw new RuntimeException(e);
}
} else {
try {
mkdirs(manifestFile);
} catch (CoreException e) {
throw new RuntimeException(e);
}
try (InputStream stream = resource.openInputStream()) {
manifestFile.create(stream, true, null);
} catch (RuntimeException e) {
throw e;
} catch (Exception e) {
throw new RuntimeException(e);
}
}
try {
manifestFile.setDerived(true, new NullProgressMonitor());
} catch (CoreException e) {
// if only that don't work just go on...
}
}

}

@Override
Expand Down Expand Up @@ -104,4 +147,9 @@ private void mkdirs(IResource resource) throws CoreException {
}
}

@Override
public String toString() {
return "Project" + super.toString(); //$NON-NLS-1$
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -68,13 +68,10 @@ public static IContainer getBundleRoot(IProject project) {
}
}
if (BndProject.isBndProject(project)) {

try {
if (project.hasNature(JavaCore.NATURE_ID)) {
IJavaProject javaProject = JavaCore.create(project);
IPath outputLocation = javaProject.getOutputLocation();
IWorkspaceRoot workspaceRoot = project.getWorkspace().getRoot();
return workspaceRoot.getFolder(outputLocation);
IFolder outputFolder = getJavaOutputFolder(project);
if (outputFolder != null) {
return outputFolder;
}
} catch (CoreException e) {
// can't determine the bundle root then from java settings!
Expand All @@ -84,6 +81,16 @@ public static IContainer getBundleRoot(IProject project) {
return project;
}

public static IFolder getJavaOutputFolder(IProject project) throws CoreException {
if (project.hasNature(JavaCore.NATURE_ID)) {
IJavaProject javaProject = JavaCore.create(project);
IPath outputLocation = javaProject.getOutputLocation();
IWorkspaceRoot workspaceRoot = project.getWorkspace().getRoot();
return workspaceRoot.getFolder(outputLocation);
}
return null;
}

/**
* Returns the launch shortcuts configured for this project
* or <code>null</code> if default launchers should be used.
Expand Down

0 comments on commit 6d0a83a

Please sign in to comment.