Hello Jorge,

I have been told that in the case of an exception Java type we have
to manipulate the Java exception in a different way Is it possible to
catch that Java exception error in RPG and how would you recomend to
do it?

Under the covers, the RPG program is calling the JNI API to run your Java routine. After each JNI call, it has to call a JNI routine called ExceptionCheck (or ExceptionOccurred() one of the two) to determine if the call succeeded or failed, and then it retrieves details of the exception, and ExceptionClear() to clear the exception. The code to do all of this is generated by the compiler.

When an exception occurs, the generated code then sends an *ESCAPE message to the RPG program so that your code can detect that something failed. The important parts of the exception are sent as MSGDTA in that *ESCAPE message.

The calling RPG program can use the MONITOR opcode to catch the exception, and can then retrieve the message with QMHRCVPM read the MSGDTA to find out information about the exception.

If that support isn't sufficient for your needs, your options are:

a) Change the Java routine to NOT throw an exception, but instead, return error information via parameters/return values.

-or-

b) Call the JNI routines directly instead of using RPG's support for calling Java. Then you could control the exception handling yourself.

-or-

c) File a DCR with IBM and ask them to change the way they handle exceptions to make more information available to the RPG program directly (instead of going through the message) and hope they do it. (But this would likely take a long time to happen, if they even agreed to do it.)


So I guess my question is... what's wrong with using RPG's MONITOR op-code? From your message, you already knew it was a possibility, but discounted it for some reason. What is that reason? Why not use MONITOR?


As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:
Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.