blob: 5e12c1d3702ebd9bdbd2e6e56aeb53910b0013b0 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2008, 2013 IBM Corporation and others.
*
* This program and the accompanying materials
* are made available under the terms of the Eclipse Public License 2.0
* which accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* IBM Corporation - initial API and implementation
* Ferenc Hechler, ferenc_hechler@users.sourceforge.net - 219530 [jar application] add Jar-in-Jar ClassLoader option
* Ferenc Hechler, ferenc_hechler@users.sourceforge.net - 262748 [jar exporter] extract constants for string literals in JarRsrcLoader et al.
*******************************************************************************/
package org.eclipse.jdt.internal.ui.jarpackagerfat;
import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.jar.Attributes;
import java.util.jar.Manifest;
import org.eclipse.jdt.core.IPackageFragmentRoot;
import org.eclipse.jdt.ui.jarpackager.JarPackageData;
import org.eclipse.jdt.internal.ui.JavaPlugin;
/**
* A manifest provider creates manifest files for a fat jar with a JAR in JAR loader.
*
* @since 3.5
*/
public class FatJarRsrcUrlManifestProvider extends FatJarManifestProvider {
public FatJarRsrcUrlManifestProvider(FatJarRsrcUrlBuilder builder) {
super(builder);
}
private void setManifestRsrcClasspath(Manifest ownManifest, JarPackageData jarPackage) {
ArrayList<String> jarNames= new ArrayList<>();
for (Object element : jarPackage.getElements()) {
if (element instanceof IPackageFragmentRoot && ((IPackageFragmentRoot) element).isArchive()) {
String jarName= ((IPackageFragmentRoot) element).getPath().toFile().getName();
while (jarNames.contains(jarName)) {
jarName= FatJarPackagerUtil.nextNumberedFileName(jarName);
}
jarNames.add(jarName);
}
}
String manifestRsrcClasspath= getManifestRsrcClasspath(jarNames);
ownManifest.getMainAttributes().putValue(JIJConstants.REDIRECTED_CLASS_PATH_MANIFEST_NAME, manifestRsrcClasspath);
}
public String getManifestRsrcClasspath(ArrayList<String> jarNames) {
StringBuilder result= new StringBuilder();
result.append(JIJConstants.CURRENT_DIR);
for (String jarName : jarNames) {
try {
jarName= URLEncoder.encode(jarName, "UTF-8"); //$NON-NLS-1$
} catch (UnsupportedEncodingException e) {
JavaPlugin.log(e); // does not happen
}
result.append(" ").append(jarName); //$NON-NLS-1$
}
return result.toString();
}
/**
* Hook for subclasses to add additional manifest entries.
*
* @param manifest the manifest to which the entries should be added
* @param jarPackage the JAR package specification
*/
@Override
protected void putAdditionalEntries(Manifest manifest, JarPackageData jarPackage) {
setManifestRsrcClasspath(manifest, jarPackage);
putMainClass(manifest, jarPackage);
}
private void putMainClass(Manifest manifest, JarPackageData jarPackage) {
if (jarPackage.getManifestMainClass() != null && jarPackage.getManifestMainClass().getFullyQualifiedName().length() > 0) {
manifest.getMainAttributes().put(Attributes.Name.MAIN_CLASS, JIJConstants.LOADER_MAIN_CLASS);
manifest.getMainAttributes().putValue(JIJConstants.REDIRECTED_MAIN_CLASS_MANIFEST_NAME, jarPackage.getManifestMainClass().getFullyQualifiedName());
}
}
}