From 2f6176657f1039ff8122bfd2d94d86bbbdea9aa1 Mon Sep 17 00:00:00 2001 From: CentOS Sources Date: May 16 2023 06:21:20 +0000 Subject: import ecj-4.20-10.el8 --- diff --git a/.ecj.metadata b/.ecj.metadata index 8b1aa93..3927a92 100644 --- a/.ecj.metadata +++ b/.ecj.metadata @@ -1,2 +1 @@ -8750b8effb40f0fbab79fd529ba82088e7b59931 SOURCES/ecjsrc-4.11RC1.jar -fa5c42a17e84d7d635022d3d346d20f63c09bb15 SOURCES/java10api.jar +93617e44d5b7fd7c301ad128d64367b64db2fa34 SOURCES/ecjsrc-4.20.jar diff --git a/.gitignore b/.gitignore index 0d202e8..b4615e3 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1 @@ -SOURCES/ecjsrc-4.11RC1.jar -SOURCES/java10api.jar +SOURCES/ecjsrc-4.20.jar diff --git a/SOURCES/0001-Always-generate-bytecode-debuginfo.patch b/SOURCES/0001-Always-generate-bytecode-debuginfo.patch new file mode 100644 index 0000000..6bc2c92 --- /dev/null +++ b/SOURCES/0001-Always-generate-bytecode-debuginfo.patch @@ -0,0 +1,47 @@ +From e7ff390ef777bd818ccc6e6f8f3a56f36020abfe Mon Sep 17 00:00:00 2001 +From: Mat Booth +Date: Wed, 15 Sep 2021 10:21:53 +0100 +Subject: [PATCH 1/2] Always generate bytecode debuginfo + +When ecj is used to build RPMs +--- + .../jdt/internal/compiler/batch/Main.java | 23 +++++++++++++++++++ + 1 file changed, 23 insertions(+) + +diff --git a/org/eclipse/jdt/internal/compiler/batch/Main.java b/org/eclipse/jdt/internal/compiler/batch/Main.java +index f77372d..73a0d24 100644 +--- a/org/eclipse/jdt/internal/compiler/batch/Main.java ++++ b/org/eclipse/jdt/internal/compiler/batch/Main.java +@@ -3109,6 +3109,29 @@ public void configure(String[] argv) { + this.options.put(CompilerOptions.OPTION_Process_Annotations, CompilerOptions.ENABLED); + } + ++ { ++ // If we're building an RPM, force full debugging info to ++ // be generated, no matter what options have been passed ++ // by Ant. This is something of a kludge, but it is far ++ // better than the alternative, which is having class ++ // files with debug info mysteriously missing. ++ ++ String RpmPackageName = System.getenv("RPM_PACKAGE_NAME"); ++ String RpmArch = System.getenv("RPM_ARCH"); ++ String RpmBuildRoot = System.getenv("RPM_BUILD_ROOT"); ++ if (RpmPackageName != null && RpmArch != null && RpmBuildRoot != null) { ++ this.options.put( ++ CompilerOptions.OPTION_LocalVariableAttribute, ++ CompilerOptions.GENERATE); ++ this.options.put( ++ CompilerOptions.OPTION_LineNumberAttribute, ++ CompilerOptions.GENERATE); ++ this.options.put( ++ CompilerOptions.OPTION_SourceFileAttribute, ++ CompilerOptions.GENERATE); ++ } ++ } ++ + this.logger.logCommandLineArguments(newCommandLineArgs); + this.logger.logOptions(this.options); + +-- +2.31.1 + diff --git a/SOURCES/MANIFEST.MF b/SOURCES/MANIFEST.MF index 9f73431..09a02a7 100644 --- a/SOURCES/MANIFEST.MF +++ b/SOURCES/MANIFEST.MF @@ -1,29 +1,27 @@ Manifest-Version: 1.0 -Bundle-SymbolicName: org.eclipse.jdt.core.compiler.batch -Export-Package: org.eclipse.jdt.core,org.eclipse.jdt.core.compiler,org - .eclipse.jdt.internal.antadapter;x-internal:=true,org.eclipse.jdt.int - ernal.compiler;x-internal:=true,org.eclipse.jdt.internal.compiler.apt - .dispatch;x-internal:=true,org.eclipse.jdt.internal.compiler.apt.mode - l;x-internal:=true,org.eclipse.jdt.internal.compiler.apt.util;x-inter - nal:=true,org.eclipse.jdt.internal.compiler.ast;x-internal:=true,org. - eclipse.jdt.internal.compiler.batch;x-internal:=true,org.eclipse.jdt. - internal.compiler.classfmt;x-internal:=true,org.eclipse.jdt.internal. - compiler.codegen;x-internal:=true,org.eclipse.jdt.internal.compiler.e - nv;x-internal:=true,org.eclipse.jdt.internal.compiler.flow;x-internal - :=true,org.eclipse.jdt.internal.compiler.impl;x-internal:=true,org.ec - lipse.jdt.internal.compiler.lookup;x-internal:=true,org.eclipse.jdt.i - nternal.compiler.parser;x-internal:=true,org.eclipse.jdt.internal.com - piler.parser.diagnose;x-internal:=true,org.eclipse.jdt.internal.compi - ler.problem;x-internal:=true,org.eclipse.jdt.internal.compiler.util;x - -internal:=true,org.eclipse.jdt.internal.compiler.tool;x-internal:=tr - ue +Created-By: Maven Archiver 3.5.0 +Build-Jdk-Spec: 11 +Main-Class: org.eclipse.jdt.internal.compiler.batch.Main +Bundle-ManifestVersion: 2 Bundle-Name: Eclipse Compiler for Java(TM) -Bundle-Version: 3.17.0.v20190227-1706 +Bundle-SymbolicName: org.eclipse.jdt.core.compiler.batch +Bundle-Version: 3.27.0.v20210823-1758 Bundle-ClassPath: . -Built-By: genie.releng -Bundle-ManifestVersion: 2 Bundle-Vendor: Eclipse.org -Created-By: Apache Maven 3.5.4 -Build-Jdk: 1.8.0_192 -Main-Class: org.eclipse.jdt.internal.compiler.batch.Main +Export-Package: org.eclipse.jdt.core,org.eclipse.jdt.core.compiler,org.e + clipse.jdt.internal.antadapter;x-internal:=true,org.eclipse.jdt.interna + l.compiler;x-internal:=true,org.eclipse.jdt.internal.compiler.apt.dispa + tch;x-internal:=true,org.eclipse.jdt.internal.compiler.apt.model;x-inte + rnal:=true,org.eclipse.jdt.internal.compiler.apt.util;x-internal:=true, + org.eclipse.jdt.internal.compiler.ast;x-internal:=true,org.eclipse.jdt. + internal.compiler.batch;x-internal:=true,org.eclipse.jdt.internal.compi + ler.classfmt;x-internal:=true,org.eclipse.jdt.internal.compiler.codegen + ;x-internal:=true,org.eclipse.jdt.internal.compiler.env;x-internal:=tru + e,org.eclipse.jdt.internal.compiler.flow;x-internal:=true,org.eclipse.j + dt.internal.compiler.impl;x-internal:=true,org.eclipse.jdt.internal.com + piler.lookup;x-internal:=true,org.eclipse.jdt.internal.compiler.parser; + x-internal:=true,org.eclipse.jdt.internal.compiler.parser.diagnose;x-in + ternal:=true,org.eclipse.jdt.internal.compiler.problem;x-internal:=true + ,org.eclipse.jdt.internal.compiler.util;x-internal:=true,org.eclipse.jd + t.internal.compiler.tool;x-internal:=true diff --git a/SOURCES/ecj-3.27.0.pom b/SOURCES/ecj-3.27.0.pom new file mode 100644 index 0000000..24b3ab0 --- /dev/null +++ b/SOURCES/ecj-3.27.0.pom @@ -0,0 +1,47 @@ + + + + 4.0.0 + org.eclipse.jdt + ecj + 3.27.0 + Eclipse Compiler for Java(TM) + Eclipse Compiler for Java(TM) + http://www.eclipse.org/jdt + + + Eclipse Public License - v 2.0 + https://www.eclipse.org/legal/epl-2.0/ + repo + + + + Eclipse Foundation + http://www.eclipse.org/ + + + Bugzilla + https://bugs.eclipse.org/ + + + scm:git:https://git.eclipse.org/r/jdt/eclipse.jdt.core.git + https://git.eclipse.org/c/jdt/eclipse.jdt.core.git + + + + https://projects.eclipse.org/projects/eclipse.jdt/who + + + diff --git a/SOURCES/ecj-4.11.pom b/SOURCES/ecj-4.11.pom deleted file mode 100644 index de7c43d..0000000 --- a/SOURCES/ecj-4.11.pom +++ /dev/null @@ -1,44 +0,0 @@ - - - - 4.0.0 - org.eclipse.jdt.core.compiler - ecj - 4.11 - jar - Eclipse ECJ - Eclipse JDT Core Batch Compiler - http://www.eclipse.org/jdt/ - - UTF-8 - UTF-8 - 1.8 - 1.8 - - - - - org.apache.ant - ant - 1.9.4 - true - - - - - - - org.apache.maven.plugins - maven-javadoc-plugin - 2.10.3 - - -Xdoclint:none - - - - - - diff --git a/SOURCES/ecj-rpmdebuginfo.patch b/SOURCES/ecj-rpmdebuginfo.patch deleted file mode 100644 index e2727a1..0000000 --- a/SOURCES/ecj-rpmdebuginfo.patch +++ /dev/null @@ -1,39 +0,0 @@ -### Eclipse Workspace Patch 1.0 -#P org.eclipse.jdt.core -Index: batch/org/eclipse/jdt/internal/compiler/batch/Main.java -=================================================================== -RCS file: /cvsroot/eclipse/org.eclipse.jdt.core/batch/org/eclipse/jdt/internal/compiler/batch/Main.java,v -retrieving revision 1.327 -diff -u -r1.327 Main.java ---- batch/org/eclipse/jdt/internal/compiler/batch/Main.java 21 Apr 2008 15:00:59 -0000 1.327 -+++ batch/org/eclipse/jdt/internal/compiler/batch/Main.java 20 Nov 2008 19:26:57 -0000 -@@ -2609,6 +2609,29 @@ - this.options.put(CompilerOptions.OPTION_Process_Annotations, CompilerOptions.ENABLED); - } - -+ { -+ // If we're building an RPM, force full debugging info to -+ // be generated, no matter what options have been passed -+ // by Ant. This is something of a kludge, but it is far -+ // better than the alternative, which is having class -+ // files with debug info mysteriously missing. -+ -+ String RpmPackageName = System.getenv("RPM_PACKAGE_NAME"); -+ String RpmArch = System.getenv("RPM_ARCH"); -+ String RpmBuildRoot = System.getenv("RPM_BUILD_ROOT"); -+ if (RpmPackageName != null && RpmArch != null && RpmBuildRoot != null) { -+ this.options.put( -+ CompilerOptions.OPTION_LocalVariableAttribute, -+ CompilerOptions.GENERATE); -+ this.options.put( -+ CompilerOptions.OPTION_LineNumberAttribute, -+ CompilerOptions.GENERATE); -+ this.options.put( -+ CompilerOptions.OPTION_SourceFileAttribute, -+ CompilerOptions.GENERATE); -+ } -+ } -+ - this.logger.logCommandLineArguments(newCommandLineArgs); - this.logger.logOptions(this.options); - diff --git a/SOURCES/ecj.sh.in b/SOURCES/ecj.sh.in deleted file mode 100644 index d8a40e9..0000000 --- a/SOURCES/ecj.sh.in +++ /dev/null @@ -1,4 +0,0 @@ -#!/bin/sh - -CLASSPATH=$(build-classpath ecj):${CLASSPATH=.} \ -java org.eclipse.jdt.internal.compiler.batch.Main "$@" diff --git a/SOURCES/javaAPI.patch b/SOURCES/javaAPI.patch deleted file mode 100644 index 74da3a9..0000000 --- a/SOURCES/javaAPI.patch +++ /dev/null @@ -1,26 +0,0 @@ ---- build.xml.orig 2018-03-20 15:15:57.063810672 +0000 -+++ build.xml 2018-03-20 15:16:26.018700633 +0000 -@@ -15,16 +15,20 @@ - - - -+ -+ -+ -+ - - - - - -- -- -+ - - - diff --git a/SPECS/ecj.spec b/SPECS/ecj.spec index ed183ed..50484b8 100644 --- a/SPECS/ecj.spec +++ b/SPECS/ecj.spec @@ -1,73 +1,64 @@ Epoch: 1 -%global qualifier S-4.11RC1-201903010040 +%global eclipse_ver 4.20 +%global bundle_ver 3.27.0 +%global jar_ver %{eclipse_ver} +%global drop R-%{jar_ver}-202106111600 Summary: Eclipse Compiler for Java -Name: ecj -Version: 4.11 -Release: 0.1%{?dist} -URL: http://www.eclipse.org +Name: ecj +Version: %{eclipse_ver} +Release: 10%{?dist} +URL: https://www.eclipse.org License: EPL-2.0 -Source0: http://download.eclipse.org/eclipse/downloads/drops4/%{qualifier}/ecjsrc-%{version}RC1.jar -Source1: ecj.sh.in -Source3: https://repo1.maven.org/maven2/org/eclipse/jdt/core/compiler/ecj/%{version}/ecj-%{version}.pom -# Extracted from https://www.eclipse.org/downloads/download.php?file=/eclipse/downloads/drops4/%%{qualifier}/ecj-%%{version}.jar -Source4: MANIFEST.MF -# Java API stubs for newer JDKs -Source5: java10api.jar +Source0: https://download.eclipse.org/eclipse/downloads/drops4/%{drop}/ecjsrc-%{jar_ver}.jar +Source1: https://repo1.maven.org/maven2/org/eclipse/jdt/ecj/%{bundle_ver}/ecj-%{bundle_ver}.pom +# The ecj build does not generate a proper manifest, so use the one from the binary distribution +# Extracted from: https://download.eclipse.org/eclipse/downloads/drops4/%%{drop}/ecj-%%{jar_ver}.jar +Source2: MANIFEST.MF # Always generate debug info when building RPMs (Andrew Haley) -Patch0: %{name}-rpmdebuginfo.patch - -# Include java API stubs in build -Patch1: javaAPI.patch +Patch0: 0001-Always-generate-bytecode-debuginfo.patch BuildArch: noarch BuildRequires: ant BuildRequires: javapackages-local +BuildRequires: java-17-openjdk-devel + +Requires: java-headless >= 1:1.8.0 +Requires: javapackages-tools %description ECJ is the Java bytecode compiler of the Eclipse Platform. It is also known as the JDT Core batch compiler. %prep -%setup -q -c -%patch0 -p1 -%patch1 +%autosetup -p1 -c -n %{name}-%{eclipse_ver} -sed -i -e 's|debuglevel=\"lines,source\"|debug=\"yes\"|g' build.xml +# Specify encoding +sed -i -e '/compilerarg/s/Xlint:none/Xlint:none -encoding cp1252/' build.xml -cp %{SOURCE3} pom.xml +cp %{SOURCE1} pom.xml mkdir -p scripts/binary/META-INF/ -cp %{SOURCE4} scripts/binary/META-INF/MANIFEST.MF - -# JDTCompilerAdapter isn't used by the batch compiler -rm -f org/eclipse/jdt/core/JDTCompilerAdapter.java - -# No dep on ant needed -%pom_remove_dep org.apache.ant:ant +cp %{SOURCE2} scripts/binary/META-INF/MANIFEST.MF +rm ./META-INF/ECLIPSE_.{SF,RSA} -# Symlinks and aliases -%mvn_file :ecj ecj jdtcore -%mvn_alias org.eclipse.jdt.core.compiler:ecj \ - org.eclipse.tycho:org.eclipse.jdt.core org.eclipse.tycho:org.eclipse.jdt.compiler.apt \ - org.eclipse.jdt:core org.eclipse.jdt:ecj - -# Make Java API stubs available for other packages -%mvn_artifact "org.eclipse:java10api:jar:10" %{SOURCE5} -%mvn_alias "org.eclipse:java10api:jar:10" "org.eclipse:java9api:jar:9" +# Aliases +%mvn_alias org.eclipse.jdt:ecj org.eclipse.jdt:core org.eclipse.jdt.core.compiler:ecj \ + org.eclipse.tycho:org.eclipse.jdt.core org.eclipse.tycho:org.eclipse.jdt.compiler.apt %build -ant -Djavaapi=%{SOURCE5} +export JAVA_HOME=/usr/lib/jvm/java-17-openjdk +ant %install %mvn_artifact pom.xml ecj.jar %mvn_install # Install the ecj wrapper script -install -p -D -m0755 %{SOURCE1} $RPM_BUILD_ROOT%{_bindir}/ecj +%jpackage_script org.eclipse.jdt.internal.compiler.batch.Main '' '' ecj ecj true # Install manpage mkdir -p $RPM_BUILD_ROOT%{_mandir}/man1 @@ -79,6 +70,88 @@ install -m 644 -p ecj.1 $RPM_BUILD_ROOT%{_mandir}/man1/ecj.1 %{_mandir}/man1/ecj* %changelog +* Wed Feb 15 2023 Coty Sutherland - 1:4.20-10 +- Drop unnecessary javax16.api.jar (again) +- Add dependency on javapackages-tools since the ecj binary requires it to run + +* Wed Feb 15 2023 Coty Sutherland - 1:4.20-9 +- Trigger CI tests again + +* Wed Feb 15 2023 Coty Sutherland - 1:4.20-8 +- Update BuildRequires to use java-17 + +* Tue Feb 14 2023 Hui Wang - 1:4.20-7 +- Fix JAVA_HOME + +* Tue Feb 14 2023 Hui Wang - 1:4.20-6 +- Add requires java-11-openjdk and java-11-openjdk-headless + +* Tue Feb 07 2023 Hui Wang - 1:4.20-5 +- Add javax16api.jar back + +* Sat Feb 04 2023 Hui Wang - 1:4.20-4 +- Remove javax16api.jar which is not necessary in RHEL-8 + +* Thu Feb 02 2023 Hui Wang - 1:4.20-3 +- Add tmt gating plan + +* Wed Feb 01 2023 Hui Wang - 1:4.20-2 +- Add gating.yaml + +* Thu Jan 19 2023 Hui Wang - 1:4.20-1 +- Update to 4.20 + +* Wed Aug 25 2021 Stefan Bluhm - 1:4.19-3 +- Added RHEL8 build. + +* Wed Jul 21 2021 Fedora Release Engineering - 1:4.19-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_35_Mass_Rebuild + +* Wed Mar 10 2021 Mat Booth - 1:4.19-1 +- Update to latest upstream release + +* Mon Mar 01 2021 Mat Booth - 1:4.18-3 +- Allow building against Java 11 + +* Tue Jan 26 2021 Fedora Release Engineering - 1:4.18-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild + +* Tue Jan 12 2021 Alexander Kurtakov 1:4.18-1 +- Update to latest upstream release. + +* Thu Oct 29 2020 Mat Booth - 1:4.17-1 +- Update to latest upstream release + +* Mon Jul 27 2020 Fedora Release Engineering - 1:4.16-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild + +* Fri Jul 10 2020 Jiri Vanek - 1:4.16-3 +- Rebuilt for JDK-11, see https://fedoraproject.org/wiki/Changes/Java11 + +* Fri Jun 19 2020 Mat Booth - 1:4.16-2 +- Restore compiler adaptor + +* Thu Jun 18 2020 Mat Booth - 1:4.16-1 +- Update to latest upstream release + +* Fri Mar 20 2020 Mat Booth - 1:4.15-1 +- Update to latest upstream release + +* Tue Jan 28 2020 Fedora Release Engineering - 1:4.14-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild + +* Mon Dec 16 2019 Mat Booth - 1:4.14-2 +- Remove upstream code-signatures + +* Fri Dec 13 2019 Mat Booth - 1:4.14-1 +- Update to latest upstream version + +* Wed Jul 24 2019 Fedora Release Engineering - 1:4.12-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild + +* Sat Jun 29 2019 Mat Booth - 1:4.12-1 +- Update to latest upstream release + * Thu Mar 07 2019 Mat Booth - 1:4.11-0.1 - Update to latest release candidate of 4.11