On 27 Sep 2013 03:01, Jane Taubman wrote:
I have a custom menu program RPGLE (5250) which calls other RPG
programs using QCMDEXEC <ed: QCMDEXC> with the CALL command.

However when you look on WRKACTJOB they all show with the name
of the menu program, so you get pages of people in MEZ008. You can
of course see what program they are in using the display Call stack,
but it would help if the program they called was shown.

I seem to remember it's something to do with "invocation levels",
but I can't find anything with a Google search as I suspect I am
remembering it wrong.

Please could someone point me in the right direction.


Nothing directly to do with invocation levels, per se, nor Request Processors. It is instead, the effect provided by whatever system interface decides to update the job "Function". For example, a visited menu updates the function to identify the MNU-name [as effected by the MN\Menu component of the OS], a CL command-line CL command request invocation updates the CMD-name [as effected by the CA\Command-Analyzer component of the OS], etc. Including... The PGM-name appears whenever a CL CALL command invokes a program [likely also, _as effected by_ the CA\Command-Analyzer component of the OS], but *only* as an /effective/ command-line program-call; i.e. a CALL coded in a CLP or a CALL invoked within QCMDEXC will *not* effect that same update to the job "Function".

However, there is a /simple/ resolution; "simple" being a relative term :-) Change from using the QCMDEXC API to using the more robust QCAPCMD API. The latter API offers more function, including the capability to perform the CL request as an effective Command Line invocation. Thus the same component that recognizes the command-request as a command-line invocation will perform its normal function of updating the job's "Function" to reflect the PGM-name. Note specifically, the /Type of Command Processing/ of x'00000002' in the following documentation; both its functions and its potential caveats or limits, although all are probably typically acceptable or positive effects:

http://pic.dhe.ibm.com/infocenter/iseries/v6r1m0/topic/apis/qcapcmd.htm
_i Process Commands (QCAPCMD) API i_
"...

Type of command processing. The type of command processing to be performed by the system. The following processes can occur:

0 Command running. The processing for this type is the same as that performed by the QCMDEXC API. Commands processed must have a value of *EXEC on the ALLOW parameter of the Create Command (CRTCMD) or the Change Command (CHGCMD) command.
1 Command syntax check. The processing for this type is the same as that performed by the QCMDCHK API.
2 Command line running. This processing is like that provided by the QCMDEXC API but with the following additions:

* Limited user checking is performed.
* Prompting for missing required parameters is performed.
* If the System/36™ environment is active and the commands are System/36 commands, the System/36 environment runs the commands.

This type processes commands with entry codes of Job: I (value of *INTERACT on the ALLOW parameter of the CRTCMD or CHGCMD command). While this type is meant to implement an interactive command line, it can be used in batch. When used in a batch job, the entry code for the command must be Job: B. Limited user checking and System/36 environment processing is done while prompting options are ignored.
..."

FWiW: To effect a quick test, compare the difference between the two invocations; having chosen a MYLIBRNAME/MYPGM_NAME that either goes into a wait state or which can be stopped in debug via a serviced job, long enough to review the effect in Work With Active Jobs:

call qsys/qcmdexc ('call MYLIBRNAME/MYPGM_NAME' 26)
/* effects PGM-QCMDEXC from a menu or command-entry */

call qsys/qcapcmd ('call MYLIBRNAME/MYPGM_NAME' x'0000001A'
x'00000002F0F0F000000000000000000000000000' x'00000014'
'CPOP0100' ' ' x'00000000' x'00000000' x'0000000000000000')
/* effects PGM-MYPGM_NAME irrespective whence */


As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:

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.