[ https://issues.apache.org/jira/browse/GROOVY-11571?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17936033#comment-17936033 ]
ASF GitHub Bot commented on GROOVY-11571: ----------------------------------------- eric-milles commented on code in PR #2154: URL: https://github.com/apache/groovy/pull/2154#discussion_r1997659214 ########## build-logic/src/main/groovy/org/apache/groovy/gradle/JarJarTask.groovy: ########## @@ -169,16 +168,9 @@ class JarJarTask extends DefaultTask { it.into(outputFile.parentFile) it.rename { outputFile.name } } - project.ant.jar(destfile: outputFile, update: true, index: true, manifest: manifestFile, modificationtime: tstamp) { - manifest { - // because we don't want to use JDK 1.8.0_91, we don't care and it will - // introduce cache misses - attribute(name: 'Created-By', value: 'Gradle') Review Comment: This should be all set now. I can promote it from draft or you can do some investigation. Just let me know. > Performance problem in Eclipse RCP/OSGi/Equinox environment > ----------------------------------------------------------- > > Key: GROOVY-11571 > URL: https://issues.apache.org/jira/browse/GROOVY-11571 > Project: Groovy > Issue Type: Bug > Components: groovy-runtime > Affects Versions: 4.0.25 > Environment: Eclipse RCP 4.25 > Reporter: Torsten Witte > Assignee: Paul King > Priority: Major > Fix For: 4.0.26 > > > We have an Eclipse RCP application that includes Groovy (4.0.25) so that > users can customise it via Groovy scripts (groovy, groovy-datetime, > groovy-dateutil, groovy-json, groovy-templates, groovy-xml, groovy-yaml). > Unfortunately, we have noticed that the compilation of each individual script > takes several seconds (e.g. 3 seconds and more for a tiny script). > We have discovered that it will be faster if we remove some Groovy libs (e.g. > groovy-yaml), but that is not an option because we need the dependencies. > Then we have noticed that the scripts compile in a few milliseconds if the > application has been started with the Eclipse "-clean" parameter > ("osgi.clean"). > The scripts can therefore be compiled much faster! > However, the "-clean" parameter slows down the start of the application, as > the OSGi configuration has to be recreated each time, and that is also not an > option for us. > It seems that Eclipse/OSGi/Equinox holds some wiring information in its > configuration folder which slow down the Groovy compile times (more precise: > the class loading). > When drilling down into the problem, we got as far as buddy class loading, > where the time is lost. > The reason is in the {{MANIFEST.MF}} of the {{groovy_<version>.jar}}: > {noformat} > Eclipse-BuddyPolicy: dependent > {noformat} > Setting the value to "global" fixes the problem and the scripts are always > compiled in a few milliseconds, whether starting the application with or > without the "-clean" parameter. > {noformat} > Eclipse-BuddyPolicy: global > {noformat} > The documentation of the [Buddy Class > Loading|https://wiki.eclipse.org/Context_Class_Loader_Enhancements#Buddy_Policy_2] > says: > bq. dependent - Consults all bundles that directly or indirectly depend on > the bundle. An indirect dependency can be introduced by bundles that use > Require-Bundle with the visibility directive set to reexport. Note that this > casts a rather wide net and may introduce performance problems as the number > of bundles increase. > We use Require-Bundle in our {{MANIFEST.MF}} but without visibility reexport: > {noformat} > Require-Bundle: [...], > groovy;bundle-version="4.0.25", > groovy-datetime;bundle-version="4.0.25", > groovy-dateutil;bundle-version="4.0.25", > groovy-json;bundle-version="4.0.25", > groovy-templates;bundle-version="4.0.25", > groovy-xml;bundle-version="4.0.25", > groovy-yaml;bundle-version="4.0.25", > [...] > {noformat} > Are there reasons why the entry "Eclipse-BuddyPolicy" in the {{MANIFEST.MF}} > of the {{groovy_<version>.jar}} is set to "dependent"? > Is it possible to set the value to "global" in further releases? > (Another problem with the Eclipse-BuddyPolicy is described in GROOVY-6491) -- This message was sent by Atlassian Jira (v8.20.10#820010)