From 6d3d209a35ee2102d633061b3f0a2d5ad671608f Mon Sep 17 00:00:00 2001 From: zongyu Date: Sat, 18 Jul 2020 15:37:44 +0800 Subject: format a right string for java-virtuals/* Signed-off-by: zongyu --- .../org/gentoo/java/ebuilder/maven/MavenCache.java | 10 ++-- .../gentoo/java/ebuilder/maven/MavenEbuilder.java | 54 ++++++++++------------ 2 files changed, 32 insertions(+), 32 deletions(-) diff --git a/src/main/java/org/gentoo/java/ebuilder/maven/MavenCache.java b/src/main/java/org/gentoo/java/ebuilder/maven/MavenCache.java index 0443dd4..d6345bf 100644 --- a/src/main/java/org/gentoo/java/ebuilder/maven/MavenCache.java +++ b/src/main/java/org/gentoo/java/ebuilder/maven/MavenCache.java @@ -69,12 +69,16 @@ public class MavenCache { } final StringBuilder sbDependency = new StringBuilder(50); - sbDependency.append(">="); + if (cacheItem.getCategory().compareTo("java-virtuals") != 0) { + sbDependency.append(">="); + } sbDependency.append(cacheItem.getCategory()); sbDependency.append('/'); sbDependency.append(cacheItem.getPkg()); - sbDependency.append('-'); - sbDependency.append(stripExtraFromVersion(cacheItem.getVersion())); + if (cacheItem.getCategory().compareTo("java-virtuals") != 0) { + sbDependency.append('-'); + sbDependency.append(stripExtraFromVersion(cacheItem.getVersion())); + } if (cacheItem.getUseFlag() != null) { sbDependency.append('['); diff --git a/src/main/java/org/gentoo/java/ebuilder/maven/MavenEbuilder.java b/src/main/java/org/gentoo/java/ebuilder/maven/MavenEbuilder.java index 08a5f99..da3a01b 100644 --- a/src/main/java/org/gentoo/java/ebuilder/maven/MavenEbuilder.java +++ b/src/main/java/org/gentoo/java/ebuilder/maven/MavenEbuilder.java @@ -57,7 +57,7 @@ public class MavenEbuilder { */ final MavenProject mavenProject = mavenProjects.get(mavenProjects.size() - 1); - writeInherit(mavenProject, writer); + writeInherit(config, mavenProject, writer); writePackageInfo(config, mavenProject, writer); writeDependencies(config, mavenProjects, writer); @@ -244,16 +244,11 @@ public class MavenEbuilder { */ private String improveBinjarUri(final String binjarUri) { - final Matcher matcher = PATTERN_TARBALL_EXTENSION.matcher(binjarUri); - /** - * We do not know how to get the extension so assume it will be jar + * Binary file should be jars */ - if (!matcher.matches()) { - return binjarUri + " -> " + "${P}-bin.jar"; - } + return binjarUri + " -> " + "${P}-bin.jar"; - return binjarUri + " -> " + "${P}-bin" + matcher.group(1); } /** @@ -479,15 +474,19 @@ public class MavenEbuilder { mavenProjects, config.getForceMinJavaVersion())); writer.println(":*"); - if (hasCDepend) { - writer.println("\t${CDEPEND}"); - } - if (config.getDownloadUri() != null && config.getDownloadUri(). toString().matches("^.*?\\.(jar|zip)$")) { writer.println("\tapp-arch/unzip"); } + if (config.hasBinjarUri() && (hasCDepend || !compileDependencies.isEmpty())) { + writer.println("\t!binary? ("); + } + + if (hasCDepend) { + writer.println("\t${CDEPEND}"); + } + if (!compileDependencies.isEmpty()) { compileDependencies.stream().forEach((dependency) -> { writer.print('\t'); @@ -495,6 +494,10 @@ public class MavenEbuilder { }); } + if (config.hasBinjarUri() && (hasCDepend || !compileDependencies.isEmpty())) { + writer.println("\t)"); + } + if (!testDependencies.isEmpty()) { writer.println("\ttest? ("); @@ -528,10 +531,6 @@ public class MavenEbuilder { mavenProjects, config.getForceMinJavaVersion())); writer.println(":*"); - if (config.hasBinjarUri()) { - writer.println("\t!binary? ("); - } - if (hasCDepend) { writer.print("${CDEPEND}"); } @@ -544,9 +543,6 @@ public class MavenEbuilder { }); } - if (config.hasBinjarUri()) { - writer.println("\t)"); - } writer.println('"'); @@ -613,8 +609,8 @@ public class MavenEbuilder { * * @param writer ebuild writer */ - private void writeInherit(final MavenProject mavenProject, - final PrintWriter writer) { + private void writeInherit(final Config config, + final MavenProject mavenProject, final PrintWriter writer) { writer.println(); writer.print("JAVA_PKG_IUSE=\"doc source"); @@ -622,7 +618,7 @@ public class MavenEbuilder { writer.print(" test"); } - if (mavenProject.hasBinjarUri()) { + if (config.hasBinjarUri()) { writer.print(" binary"); } @@ -800,6 +796,10 @@ public class MavenEbuilder { writer.println(')'); } + if (config.hasBinjarUri()) { + writer.println("JAVA_BINJAR_FILENAME=\"${P}-bin.jar\""); + } + final String testingFramework = determineTestingFramework(mavenProject); boolean firstTestVar = true; @@ -851,7 +851,7 @@ public class MavenEbuilder { } if (config.isFromMavenCentral()) { - writeMavenUnpack(config, mavenProject, writer); + writeMavenUnpack(mavenProject, writer); } } @@ -871,8 +871,8 @@ public class MavenEbuilder { * * @param writer ebuild writer */ - private void writeMavenUnpack(final Config config, - final MavenProject mavenProject, final PrintWriter writer) { + private void writeMavenUnpack(final MavenProject mavenProject, + final PrintWriter writer) { writer.println(); writer.println("src_unpack() {"); writer.println("\tmkdir -p ${S}/${JAVA_SRC_DIR}"); @@ -883,10 +883,6 @@ public class MavenEbuilder { writer.println("\tunzip ${DISTDIR}/${P}-test.jar -d ${S}/${JAVA_TEST_SRC_DIR} || die"); } - if (config.hasBinjarUri()) { - writer.println("use binary && cp ${DISTDIR}/${P}-bin.jar ${S}/${PN}.jar || die \"failed to copy binary jar\""); - } - writer.println("}"); } } -- cgit v1.2.3-65-gdbad