-
Notifications
You must be signed in to change notification settings - Fork 44
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Target platform #150
Comments
This is how the provisory third-party repository manifests in the target definition right now: https://github.com/simlei/core/blob/892be3b19fdb8d9cfabfea2233d5f8ea6b0d888c/org.jcryptool.target/org.jcryptool.target.target#L22-L25 Corollary Manifest.MF changes: |
Currently located under simlei.github.io/org.jcryptool.thirdparty See jcryptool#149, jcryptool#150 Project runs under Java 11 Maven build works without complaint Workspace build works, too
The thirdparty update site project has grown as planned; the JRE features are now built and delivered through it as well. See https://github.com/org.jcryptool.thirdparty There are now two update sites, at
The former update site for jaxb, https://simlei.github.io/org.jcryptool.thirdparty.java11migration.p2/site, stays online for a while even though it is now obsolete on my fork. Credit for the move to the thirdparty repo working out well goes to @grthor with a feature-based (therefore Tycho-compatible) platform-aware solution to the JRE packaging problem. The reasons to host this through github pages still stand -- quite convenient for the while being and reliable. Still, moving these p2 sites is mandatory in the future. At the same time, we should move this stuff from /simlei to /jcryptool. Impression: Build with Tycho was tested and succeeds, and packages the JREs the same way as happened in grthor/jre_bundle. Please watch this space/branch in the next days if you want to work against the release 1.0 candidate that is most advanced: J11based-UpstreamCandidate |
Everything works again, and I have good reason to believe it will work on OSX, too. @be4 , @dschadow, @grthor please verify if you have the time! It is about starting up and having Java 11 running. More info is, where the download links are. Here is a release on my fork of /core: https://github.com/simlei/core/releases/tag/v1.0-J11-1 Here are the relevant files in the JRE features for OSX:
More in #150 . In a nutshell: please extract and see if it starts. Then, verify with (Menu)Help>About>Installation Details>Configuration whether you have it running on Java 11 (the path should to java should be inside the extracted JCT "installation"). |
How come the target platform is subject to change
In the wake of Java 11 migration problems we had to add JAXB (xml binding) packages and a backend for it (glassfish)
Attempt no. 1: Eclipse orbit repositories:
f1d8715?diff=unified#diff-88c60f032be07d961c94842868be0d1aR20
However, this did not work, as Eclipse Orbit repositories host an incompatible version that uses a hardcoded, now-abandoned package namespace (something ...internal).
Therefore, we had to get the compatible, more up to date version (2.4+) from Maven. Shipping maven dependencies in OSGi is difficult to "cleanly" integrate into release engineering with Tycho and a normal Eclipse workspace development workflow. This is, because the production build goes through Tycho, the debug (day to day dev) build through Eclipse PDE. Both should be defined by a single definition to make the delivered products and the development version as identical as possible (else, mysterious bugs that get reported but cannot be reproduced). Writeups and analysis of this can be found here: here comparing five approaches and here. In a nutshell, the viable options are:
<dependency>...</dependency>
commodities, and have to carry around binaries in our source repositoryThe second approach is implemented as proof-of-concept in simlei/org.jcryptool.thirdparty and works. Resolving the JARs and packaging as target platform is done via different maven goals. Now, that #149 mandates that we ship our own JRE, and the best way seems to be as OSGi feature, this approach seems even more fitting. The JRE is of considerable size and I think we'd rather avoid putting it in our core repository (git history size would increase non-shallow repository clones with each update of the binaries).
Infrastructure
<organization>.github.io/<repository>/<file path>
versusjackfan.us.kg/<organization>/<repository>/<file path>
).Moving forward
Is this kind of infrastructure acceptable for JCrypTool?
make sure it all works with related issues in the forks (i.e. Java 11 migration #149 and Java 11: Java XML bindings #151)
test that this all does not interfere with normal development [1]
move p2-related projects to jcryptool organisation, change target definition references in the forks to the new urls, test again.
merge subproject (plugin) changes from the forks that depend on target definition changes into jcryptool-organisation repositories
Standing issues
A solution for the latter that could be considered in the future be a "JCT dev" plugin for Eclipse IDE that i.a. notifies the developer of target platform changes (checks in acceptable intervals or on common Team update actions like git pull).
The text was updated successfully, but these errors were encountered: