Abstract: The FIPA module belonging to JADE 4.5.4 requires the GlassFish CORBA ORB libraries for its compilation. Before migrating from JADE 4.5.4 r6867 to Java OpenJDK-17, it is necessary to check the behavior of FIPA with higher versions of Java.
To-Do List:
- (1) Achieve FIPA module compliance with the Java Platform Module System1 (JPMS) specifications.
- (2) Separate the FIPA module from JADE and study the particular compilation requirements with Oracle Java2 JDK-11 through JDK-17 LTS and higher. Further study, how to compile with OpenJDK3 versions from openJDK-11 to OpenJDK-18.
- (3) Modify the FIPA Objects that prevent compiling with higher versions. Document the changes and check their integration with the JADE platform.
- (4) Analyze the javax used by FIPA.
- (5) Analyze GlassFish CORBA used by FIPA.
- (6) Prepare as a GitHub repository for download and evaluation.
Section 1: Identification
- Responsible for the proposal: FJAC
- Proposal date: January, 2022.
- Results location: GitHub
Section 2: Update
- OpenJDK-11 to OpenJDK-18 compiler are used.
- FIPA implementation made by JADE in 2002 is used.
2.1. Description of the proposal:
- It is proposed to temporarily extract the FIPA module from the core of the JADE platform development. Since, with the current version of Java JDK-18 or higher, it is no longer possible to compile JADE. This is caused because the CORBA libraries have been removed from the core of the Java SE Standard releases and the Java JDK development release versions 17 and higher.
- Once the FIPA separation of the JADE core has been carried out, it will be possible to know the scope of the necessary changes in the FIPA module; know which are the necessary libraries of GlassFish of CORBA ORB to achieve optimal stability; and allow later integration of the FIPA module with JADE compiled with OpenJDK-17 or higher.
2.2. Target platform
-
Java SE 17, OpenJDK-17 or higher, Java JDK-17 or higher. This implies that it can be used in Desktop or Server environments, with different architectures and operating systems.
-
The final objective is its integration in JADE 4.5.4, and to wait for a future revision of JADE.
23. What does the update proposal need?
- Access to the code of the FIPA module of the JADE Platform. Found at: https://jade.tilab.com/svn/jade/trunk/
- A development environment. Eclipse 2021-12 has been used.
- A detailed compilation of the errors offered by the OpenJDK-17/ Java JDK-17 compiler; its progressive correction; the incorporation of the Java Platform Module System to allow later integration of this FIPA module with the JADE platform.
2.4. Why this proposal?
- Because the evolution of the Java compiler has removed the CORBA libraries from the Java core.
- Because it is not possible to compile the JADE Platform on top of Java OpenJDK-17. The only way is to add the GlassFish CORBA ORB libraries to the CLASSPATH. Requiring, in turn, the distribution of JADE with these specific libraries.
2.5. Underlying technology or technologies:
- OpenJDK-9 to OpenJDK18.
- Oracle Java JDK-9 through Oracle Java JDK-18.
- GlassFish CORBA ORB 2.4
2.6. Package name for API proposal?
- File: org-fipa-2002.jar
- Package: FIPA
2.7. Dependencies on specific operating systems
- Those corresponding to the version and architecture of the Java compiler.
2.8. Security issues due to the current security model
- They have not been analyzed.
2.9. Internationalization or localization problems?
- They have not been implemented.
2.10. Any need for revision as a result of this work?
- It has not been planned. Awaiting review.
2.11. Schedule for the development of this proposal
- Start: January 2022
- End: July 2022
Section 3: Contributions
3.1. Documents, proposals or implementations that describe the technology.
3.2. Starting point of the work.
- FIPA module implemented by TILAB, within the development of JADE.
Section 4: Additional Information (Optional)
4.1. Additional information to include in the Improvement Proposal
- Other relevant documents include the following FIPA documents, which can be found at http://www.fipa.org
- [FIPA00003] FIPA Agent Communication Language Specification (http://www.fipa.org/fipa00003/),
- [FIPA00007] FIPA Content Languages Specification (http://www.fipa.org/fipa00007/),
- [FIPA00008] FIPA SL Content Language Specification (http://www.fipa.org/fipa00008/),
- [FIPA00009] FIPA CCL Content Language Specification (http://www.fipa.org/fipa00009/),
- [FIPA00010] FIPA KIF Content Language Specification (http://www.fipa.org/fipa00010/),
- [FIPA00011] FIPA RDF Content Language Specification (http://www.fipa.org/fipa00011/),
- [FIPA00067] FIPA Message Transport Service Specification (http://www.fipa.org/fipa00067/),
- [FIPA00068] FIPA ACL Message Representation Library Specification (http://www.fipa.org/fipa00068/),
- [FIPA00069] FIPA ACL Message Representation in Bit-efficient Encoding Specification (http://www.fipa.org/fipa00069/),
- [FIPA00070] FIPA ACL Message Representation in String Specification (http://www.fipa.org/fipa00070 /),
- [FIPA00071] FIPA ACL Message Representation in XML Specification (http://www.fipa.org/fipa00071/),
- [FIPA00072] FIPA Agent Message Transport Envelope Representation Library Specification (http://www.fipa.org/fipa00072/),
- [FIPA00073] FIPA Agent Message Transport Envelope Representation in String Specification (http://www.fipa.org/fipa00073/),
- [FIPA00074] FIPA Agent Message Transport Protocol Library Specification (http://www.fipa.org/fipa00074/),
- [FIPA00075] FIPA Agent Message Transport Protocol for IIOP Specification (http://www.fipa.org/fipa00075/),
- [FIPA00076] FIPA Agent Message Transport Protocol for WAP Specification (http://www.fipa.org/fipa00076/).
References
-
Significant Changes in JDK 17 Release. Notes for additional descriptions of the new features and enhancements, and API specification in JDK 17. Updates in Java SE 17 and JDK 17: https://docs.oracle.com/en/java/javase/17/migrate/significant-changes-jdk-release.html ↩
-
ORACLE Java 17 is the latest long-term support (LTS) release under Java’s six-month release cadence and is the result of extensive collaboration between Oracle engineers and other members of the worldwide Java developer community via the OpenJDK Community and the Java Community Process (JCP). Verificada con la versioón jdk-17.0.3.1 (junio, 2022). https://www.oracle.com/news/announcement/oracle-releases-java-17-2021-09-14/. ↩
-
OpenJDK 17 is the open-source reference implementation of version 17 of the Java SE Platform, as specified by by JSR 390 in the Java Community Process. JDK 17 reached General Availability on 14 September 2021. URL for OpenJDK-11 is: https://openjdk.java.net/projects/jdk/11/. URL for OpenJDK-17 is: https://openjdk.java.net/projects/jdk/17/. ↩
License: GNU Lesser General Public License v2.1
Author: FIPA-Telecom Italia
Updated: 2022-06-18
- To-Do List:
- Section 1: Identification
- Section 2: Update
- 2.1. Description of the proposal:
- 2.2. Target platform
- 23. What does the update proposal need?
- 2.4. Why this proposal?
- 2.5. Underlying technology or technologies:
- 2.6. Package name for API proposal?
- 2.7. Dependencies on specific operating systems
- 2.8. Security issues due to the current security model
- 2.9. Internationalization or localization problems?
- 2.10. Any need for revision as a result of this work?
- 2.11. Schedule for the development of this proposal
- Section 3: Contributions
- Section 4: Additional Information (Optional)
- References
