Skip to content

Commit

Permalink
Eclipse 4.33 (M1) JDT Patch for Groovy-Eclipse
Browse files Browse the repository at this point in the history
  • Loading branch information
eric-milles committed Jul 20, 2024
1 parent 17947d3 commit d6ac73c
Show file tree
Hide file tree
Showing 2,247 changed files with 1,329,515 additions and 39 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -72,23 +72,24 @@ public abstract class GroovyCompilerTestSuite {
protected static final long JDK8 = ClassFileConstants.JDK1_8;
protected static final long JDK9 = ClassFileConstants.JDK9;
protected static final long JDK10 = ClassFileConstants.JDK10;
protected static final long JDK11 = (55L << 16) + ClassFileConstants.MINOR_VERSION_0;
protected static final long JDK12 = (56L << 16) + ClassFileConstants.MINOR_VERSION_0;
protected static final long JDK13 = (57L << 16) + ClassFileConstants.MINOR_VERSION_0;
protected static final long JDK14 = (58L << 16) + ClassFileConstants.MINOR_VERSION_0;
protected static final long JDK15 = (59L << 16) + ClassFileConstants.MINOR_VERSION_0;
protected static final long JDK11 = ClassFileConstants.JDK11;
protected static final long JDK12 = ClassFileConstants.JDK12;
protected static final long JDK13 = ClassFileConstants.JDK13;
protected static final long JDK14 = ClassFileConstants.JDK14;
protected static final long JDK15 = ClassFileConstants.JDK15;
protected static final long JDK16 = (60L << 16) + ClassFileConstants.MINOR_VERSION_0;
protected static final long JDK17 = (61L << 16) + ClassFileConstants.MINOR_VERSION_0;
protected static final long JDK18 = (62L << 16) + ClassFileConstants.MINOR_VERSION_0;
protected static final long JDK19 = (63L << 16) + ClassFileConstants.MINOR_VERSION_0;
protected static final long JDK20 = (64L << 16) + ClassFileConstants.MINOR_VERSION_0;
protected static final long JDK21 = (65L << 16) + ClassFileConstants.MINOR_VERSION_0;
protected static final long JDK22 = (66L << 16) + ClassFileConstants.MINOR_VERSION_0;

@Parameters(name = "Java {1}")
public static Iterable<Object[]> params() {
long javaSpec = CompilerOptions.versionToJdkLevel(System.getProperty("java.specification.version"));
List<Object[]> params = new ArrayList<>();
for (long jdk : new long[] {JDK8, JDK9, JDK10, JDK11, JDK12, JDK13, JDK14, JDK15, JDK16, JDK17, JDK18, JDK19, JDK20, JDK21}) {
for (long jdk : new long[] {JDK8, JDK9, JDK10, JDK11, JDK12, JDK13, JDK14, JDK15, JDK16, JDK17, JDK18, JDK19, JDK20, JDK21, JDK22}) {
if (jdk == javaSpec || (jdk < javaSpec && (/*jdk == JDK8 || */jdk == JDK11 || jdk == JDK17 || jdk == JDK21))) { // current and LTS
params.add(new Object[] {jdk, CompilerOptions.versionFromJdkLevel(jdk)});
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2509,7 +2509,7 @@ private TypeParameter[] createTypeParametersForGenerics(GenericsType[] generics)
}

typeParameter.bounds[j - 1] = createTypeReferenceForClassNode(upperBounds[j], offset, offset + length);
typeParameter.bounds[j - 1].bits |= ASTNode.IsSuperType;
typeParameter.bounds[j - 1].bits |= ASTNode.Bit5/*IsSuperType*/;
}
}
}
Expand Down
10 changes: 6 additions & 4 deletions docs/Getting-Started-with-Groovy-Eclipse-Source-Code.md
Original file line number Diff line number Diff line change
Expand Up @@ -164,12 +164,13 @@ This minimal project set should be open in your workspace:
* org.eclipse.jdt.core
* org.eclipse.jdt.core.compiler.batch (4.27+)
* org.eclipse.jdt.core.tests.builder
* org.eclipse.jdt.core.tests.builder.mockcompiler (4.33+)
* org.eclipse.jdt.core.tests.compiler
* org.eclipse.jdt.groovy.core
* org.eclipse.jdt.groovy.core.tests.builder
* org.eclipse.jdt.groovy.core.tests.compiler

Note: Only one JDT patch should be imported (`org.eclipse.jdt.core`, `org.eclipse.jdt.core.tests.builder`, `org.eclipse.jdt.core.tests.compiler`) and it should be matched to the target platform of your workspace. For example, the patch in the `/e432` folder is for Eclipse 4.32 (2024-06).
Note: Only one JDT patch should be imported (`org.eclipse.jdt.core`, `org.eclipse.jdt.core.compiler.batch`, etc.) and it should be matched to the target platform of your workspace. For example, the patch in the `/e433` folder is for Eclipse 4.33 (2024-09).


## Test with Eclipse
Expand All @@ -187,14 +188,15 @@ For manual testing and debugging, right-click on the org.codehaus.groovy.eclipse

[Download and install Maven](https://maven.apache.org/).

From the root directory of the repository, execute the following command to build Groovy-Eclipse for Eclipse 4.32 (2024-06).
From the root directory of the repository, execute the following command to build Groovy-Eclipse for Eclipse 4.33 (2024-09).

```
mvn -Pe4.32 clean verify
mvn -Pe4.33 clean verify
```

Replace e4.32 with a different option to build it for another Eclipse version:
Replace e4.33 with a different option to build it for another Eclipse version:

* e4.32
* e4.31
* e4.30
* e4.29
Expand Down
58 changes: 30 additions & 28 deletions groovy-eclipse.setup
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,9 @@
defaultValue="2024-06"
storageURI="scope://Workspace"
label="Target Platform">
<choice
value="2024-09"
label="Eclipse 4.33 (2024-09)"/>
<choice
value="2024-06"
label="Eclipse 4.32 (2024-06)"/>
Expand All @@ -105,9 +108,6 @@
<choice
value="2023-06"
label="Eclipse 4.28 (2023-06)"/>
<choice
value="2023-03"
label="Eclipse 4.27 (2023-03)"/>
<description>Choose the compatibility level of the target platform</description>
</setupTask>
<setupTask
Expand Down Expand Up @@ -144,19 +144,27 @@
</setupTask>
<setupTask
xsi:type="setup.p2:P2Task"
filter="(| (scope.product.version.name=2024-06) (scope.product.version.name=latest) (scope.product.version.name=latest.released))">
filter="(| (scope.product.version.name=2024-09) (scope.product.version.name=latest))">
<requirement
name="org.codehaus.groovy.m2eclipse.feature.feature.group"/>
<repository
url="https://groovy.jfrog.io/artifactory/plugins-snapshot/e4.32"/>
url="https://groovy.jfrog.io/artifactory/plugins-snapshot/e4.33"/>
</setupTask>
<setupTask
xsi:type="setup.p2:P2Task"
filter="(| (scope.product.version.name=2024-06) (scope.product.version.name=latest.released))">
<requirement
name="org.codehaus.groovy.m2eclipse.feature.feature.group"/>
<repository
url="https://groovy.jfrog.io/artifactory/plugins-release/e4.32"/>
</setupTask>
<setupTask
xsi:type="setup.p2:P2Task"
filter="(scope.product.version.name=2024-03)">
<requirement
name="org.codehaus.groovy.m2eclipse.feature.feature.group"/>
<repository
url="https://groovy.jfrog.io/artifactory/plugins-snapshot/e4.31"/>
url="https://groovy.jfrog.io/artifactory/plugins-release/e4.31"/>
</setupTask>
<setupTask
xsi:type="setup.p2:P2Task"
Expand All @@ -182,14 +190,6 @@
<repository
url="https://groovy.jfrog.io/artifactory/plugins-release/e4.28"/>
</setupTask>
<setupTask
xsi:type="setup.p2:P2Task"
filter="(scope.product.version.name=2023-03)">
<requirement
name="org.codehaus.groovy.m2eclipse.feature.feature.group"/>
<repository
url="https://groovy.jfrog.io/artifactory/plugins-snapshot/e4.27"/>
</setupTask>
<setupTask
xsi:type="git:GitCloneTask"
id="git.clone.Groovy-Eclipse"
Expand Down Expand Up @@ -243,6 +243,13 @@
<sourceLocator
rootFolder="${git.clone.Groovy-Eclipse.location}/Site-org.codehaus.groovy.eclipse"/>
</setupTask>
<setupTask
xsi:type="projects:ProjectsImportTask"
filter="(eclipse.target.platform=2024-09)">
<sourceLocator
rootFolder="${git.clone.Groovy-Eclipse.location}/jdt-patch/e433"
locateNestedProjects="true"/>
</setupTask>
<setupTask
xsi:type="projects:ProjectsImportTask"
filter="(eclipse.target.platform=2024-06)">
Expand Down Expand Up @@ -278,13 +285,6 @@
rootFolder="${git.clone.Groovy-Eclipse.location}/jdt-patch/e428"
locateNestedProjects="true"/>
</setupTask>
<setupTask
xsi:type="projects:ProjectsImportTask"
filter="(eclipse.target.platform=2023-03)">
<sourceLocator
rootFolder="${git.clone.Groovy-Eclipse.location}/jdt-patch/e427"
locateNestedProjects="true"/>
</setupTask>
<setupTask
xsi:type="setup.targlets:TargletTask">
<targlet
Expand All @@ -304,6 +304,15 @@
name="org.eclipse.buildship.feature.group"/>
<requirement
name="org.eclipse.test.feature.group"/>
<repositoryList
name="2024-09">
<repository
url="https://download.eclipse.org/releases/2024-09"/>
<repository
url="https://download.eclipse.org/eclipse/updates/4.33"/>
<repository
url="https://download.eclipse.org/eclipse/updates/4.33-I-builds/I20240704-1800"/>
</repositoryList>
<repositoryList
name="2024-06">
<repository
Expand Down Expand Up @@ -339,13 +348,6 @@
<repository
url="https://download.eclipse.org/eclipse/updates/4.28"/>
</repositoryList>
<repositoryList
name="2023-03">
<repository
url="https://download.eclipse.org/releases/2023-03"/>
<repository
url="https://download.eclipse.org/eclipse/updates/4.27"/>
</repositoryList>
</targlet>
</setupTask>
<setupTask
Expand Down
1 change: 1 addition & 0 deletions ide/org.codehaus.groovy.eclipse.ant/META-INF/MANIFEST.MF
Original file line number Diff line number Diff line change
Expand Up @@ -5,4 +5,5 @@ Bundle-Name: Groovy Ant support
Bundle-Vendor: Pivotal Software, Inc.
Bundle-Version: 5.5.0.qualifier
Require-Bundle: org.eclipse.ant.core
Import-Package: org.eclipse.jdt.core
Bundle-RequiredExecutionEnvironment: JavaSE-1.8
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
/target
12 changes: 12 additions & 0 deletions jdt-patch/e433/Feature-org.codehaus.groovy.jdt.patch/.project
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8"?>
<projectDescription>
<name>Feature-org.codehaus.groovy.jdt.patch</name>
<buildSpec>
<buildCommand>
<name>org.eclipse.pde.FeatureBuilder</name>
</buildCommand>
</buildSpec>
<natures>
<nature>org.eclipse.pde.FeatureNature</nature>
</natures>
</projectDescription>
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
bin.includes = feature.properties,\
feature.xml,\
*.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,124 @@
# contains externalized strings for feature.xml
# java.io.Properties file (ISO 8859-1 with "\" escapes)
# "%foo" in feature.xml corresponds to the key "foo" in this file

providerName=Pivotal Software, Inc.

featureName=Eclipse JDT Core patch for Groovy

descriptionURL=https://github.com/groovy/groovy-eclipse/wiki

description=This JDT Core patch provides Groovy integration with the JDT and the Java compiler.

# "licenseURL" property - URL of the "Feature License"
# do not translate value - just change to point to a locale-specific HTML page
licenseURL=license.html

# "license" property - text of the "Feature Update License"
# should be plain text version of license agreement pointed to be "licenseURL"
license=\
ECLIPSE FOUNDATION SOFTWARE USER AGREEMENT\n\
March 17, 2005\n\
\n\
Usage Of Content\n\
\n\
THE ECLIPSE FOUNDATION MAKES AVAILABLE SOFTWARE, DOCUMENTATION, INFORMATION AND/OR\n\
OTHER MATERIALS FOR OPEN SOURCE PROJECTS (COLLECTIVELY "CONTENT").\n\
USE OF THE CONTENT IS GOVERNED BY THE TERMS AND CONDITIONS OF THIS\n\
AGREEMENT AND/OR THE TERMS AND CONDITIONS OF LICENSE AGREEMENTS OR\n\
NOTICES INDICATED OR REFERENCED BELOW. BY USING THE CONTENT, YOU\n\
AGREE THAT YOUR USE OF THE CONTENT IS GOVERNED BY THIS AGREEMENT\n\
AND/OR THE TERMS AND CONDITIONS OF ANY APPLICABLE LICENSE AGREEMENTS\n\
OR NOTICES INDICATED OR REFERENCED BELOW. IF YOU DO NOT AGREE TO THE\n\
TERMS AND CONDITIONS OF THIS AGREEMENT AND THE TERMS AND CONDITIONS\n\
OF ANY APPLICABLE LICENSE AGREEMENTS OR NOTICES INDICATED OR REFERENCED\n\
BELOW, THEN YOU MAY NOT USE THE CONTENT.\n\
\n\
Applicable Licenses\n\
\n\
Unless otherwise indicated, all Content made available by the Eclipse Foundation\n\
is provided to you under the terms and conditions of the Eclipse Public\n\
License Version 1.0 ("EPL"). A copy of the EPL is provided with this\n\
Content and is also available at https://www.eclipse.org/legal/epl-v10.html.\n\
For purposes of the EPL, "Program" will mean the Content.\n\
\n\
Content includes, but is not limited to, source code, object code,\n\
documentation and other files maintained in the Eclipse.org CVS\n\
repository ("Repository") in CVS modules ("Modules") and made available\n\
as downloadable archives ("Downloads").\n\
\n\
- Content may be structured and packaged into modules to facilitate delivering,\n\
extending, and upgrading the Content. Typical modules may include plug-ins ("Plug-ins"),\n\
plug-in fragments ("Fragments"), and features ("Features").\n\
- Each Plug-in or Fragment may be packaged as a sub-directory or JAR (Java? ARchive)\n\
in a directory named "plugins".\n\
- A Feature is a bundle of one or more Plug-ins and/or Fragments and associated material.\n\
Each Feature may be packaged as a sub-directory in a directory named "features".\n\
Within a Feature, files named "feature.xml" may contain a list of the names and version\n\
numbers of the Plug-ins and/or Fragments associated with that Feature.\n\
- Features may also include other Features ("Included Features"). Within a Feature, files\n\
named "feature.xml" may contain a list of the names and version numbers of Included Features.\n\
\n\
Features may also include other Features ("Included Features"). Files named\n\
"feature.xml" may contain a list of the names and version numbers of\n\
Included Features.\n\
\n\
The terms and conditions governing Plug-ins and Fragments should be\n\
contained in files named "about.html" ("Abouts"). The terms and\n\
conditions governing Features and Included Features should be contained\n\
in files named "license.html" ("Feature Licenses"). Abouts and Feature\n\
Licenses may be located in any directory of a Download or Module\n\
including, but not limited to the following locations:\n\
\n\
- The top-level (root) directory\n\
- Plug-in and Fragment directories\n\
- Inside Plug-ins and Fragments packaged as JARs\n\
- Sub-directories of the directory named "src" of certain Plug-ins\n\
- Feature directories\n\
\n\
Note: if a Feature made available by the Eclipse Foundation is installed using the\n\
Eclipse Update Manager, you must agree to a license ("Feature Update\n\
License") during the installation process. If the Feature contains\n\
Included Features, the Feature Update License should either provide you\n\
with the terms and conditions governing the Included Features or inform\n\
you where you can locate them. Feature Update Licenses may be found in\n\
the "license" property of files named "feature.properties". Such Abouts,\n\
Feature Licenses and Feature Update Licenses contain the terms and\n\
conditions (or references to such terms and conditions) that govern your\n\
use of the associated Content in that directory.\n\
\n\
THE ABOUTS, FEATURE LICENSES AND FEATURE UPDATE LICENSES MAY REFER\n\
TO THE EPL OR OTHER LICENSE AGREEMENTS, NOTICES OR TERMS AND CONDITIONS.\n\
SOME OF THESE OTHER LICENSE AGREEMENTS MAY INCLUDE (BUT ARE NOT LIMITED TO):\n\
\n\
- Common Public License Version 1.0 (available at https://www.eclipse.org/legal/cpl-v10.html)\n\
- Apache Software License 1.1 (available at https://www.apache.org/licenses/LICENSE)\n\
- Apache Software License 2.0 (available at https://www.apache.org/licenses/LICENSE-2.0)\n\
- IBM Public License 1.0 (available at http://oss.software.ibm.com/developerworks/opensource/license10.html)\n\
- Metro Link Public License 1.00 (available at http://www.opengroup.org/openmotif/supporters/metrolink/license.html)\n\
- Mozilla Public License Version 1.1 (available at https://www.mozilla.org/MPL/MPL-1.1.html)\n\
\n\
IT IS YOUR OBLIGATION TO READ AND ACCEPT ALL SUCH TERMS AND CONDITIONS PRIOR\n\
TO USE OF THE CONTENT. If no About, Feature License or Feature Update License\n\
is provided, please contact the Eclipse Foundation to determine what terms and conditions\n\
govern that particular Content.\n\
\n\
Cryptography\n\
\n\
Content may contain encryption software. The country in which you are\n\
currently may have restrictions on the import, possession, and use,\n\
and/or re-export to another country, of encryption software. BEFORE\n\
using any encryption software, please check the country's laws,\n\
regulations and policies concerning the import, possession, or use,\n\
and re-export of encryption software, to see if this is permitted.\n\
\n\
Java and all Java-based trademarks are trademarks of Sun Microsystems, Inc. in the United States, other countries, or both.\n
########### end of license property ##########################################

# "copyright" property - text of the "Feature Update Copyright"
copyright=\
Copyright (c) 2009-2024 Pivotal Software, Inc. and others.\n\
All rights reserved. This program and the accompanying materials\n\
are made available under the terms of the Eclipse Public License v1.0\n\
which accompanies this distribution, and is available at\n\
https://www.eclipse.org/legal/epl-v10.html\n\
40 changes: 40 additions & 0 deletions jdt-patch/e433/Feature-org.codehaus.groovy.jdt.patch/feature.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
<?xml version="1.0" encoding="UTF-8"?>

<feature id="org.codehaus.groovy.jdt.patch"
label="%featureName"
version="5.5.0.qualifier"
provider-name="%providerName">

<description url="%descriptionURL">
%description
</description>

<copyright>
%copyright
</copyright>

<license url="%licenseURL">
%license
</license>

<requires>
<import feature="org.eclipse.jdt" version="3.19.600.v20240704-2057" patch="true"/>
</requires>

<plugin
id="org.eclipse.jdt.core"
download-size="0"
install-size="0"
version="0.0.0"
unpack="false"
/>

<plugin
id="org.eclipse.jdt.core.compiler.batch"
download-size="0"
install-size="0"
version="0.0.0"
unpack="false"
/>

</feature>
Loading

0 comments on commit d6ac73c

Please sign in to comment.