Dave,

You might try the MONITOR op code.  Check for the status after the call.  If 
the call fails retrieve the error information.

Having said that I use the QCAPCMD API to run commands.  I've included the code 
below for the wrapper module I use.  You might be able to use it as is or as a 
guide to write your own.

HTH.

h nomain                                                                        
                
 
*-----------------------------------------------------------------------------------------
 
 *    Program  . . :  PRCCMD           Author . . :  Rick Chevalier             
                
 *    Date . . . . :   1/19/2000                                                
                
 *    Purpose  . . :  Process or run a command.                                 
                
 
*-----------------------------------------------------------------------------------------
 
 *    Modifications:                               Date/Prgrmmr                 
                
 
*-----------------------------------------------------------------------------------------
 
 *      None to this point.                                                     
                
 
*-----------------------------------------------------------------------------------------
 
                                                                                
                
 * Required Parameter Group:                                                    
                
 *  1  Source command string                     Input   Char(*)                
                
                                                                                
                
 * Optional Parameter Group:                                                    
                
 *  2  Processing type                           Input   Char(1)                
                
 *        '0' - Never prompt the command                                        
                
 *        '1' - Always prompt the command                                       
                
 *   Dft  '2' - Prompt the command if selective prompting characters are 
present in the command 
 *        '3' - Show help                                                       
                
                                                                                
                
 
*-----------------------------------------------------------------------------------------
 
 * Internal procedure prototypes                                                
                
 
*---------------------------------------------------------------------------------------------
 
 * Prototype for process command procedure (PrcCmd)                             
                
d PrcCmd          pr              *                                             
                
d                            32702                                         
Command              
d                                1    options(*nopass: *omit)              
Prompt type          
                                                                                
                
 
*-----------------------------------------------------------------------------------------
 
 * External procedure prototypes.                                               
                
 
*-----------------------------------------------------------------------------------------
 
 * Send program message.                                                        
                
dsndpgmmsg        pr             4                                              
                
d##_msgid                        7                                              
                
d##_msgf                        20                                              
                
d##_msgdta@                       *   const                                     
                
d##_msgtyp                      10    options(*nopass)                     
Defaults to *DIAG    
                                                                                
                
 
*-----------------------------------------------------------------------------------------
 
 * Process command (QCAPCMD) API.  Check or run a CL command.                   
                
 
*-----------------------------------------------------------------------------------------
 
pprccmd           b                   export                                    
                
dprccmd           pi              *                                             
                
d##_cmd                      32702                                              
                
d##_pmttyp                       1    options(*nopass: *omit)              
Default = 2          
                                                                                
                
 *  1  Length of source command string           Input   Binary(4)              
                
 *  2  Options control block                                         Input   
Char(*)            
 *  3  Options control block length                                  Input   
Binary(4)          
 *  4  Options control block format                                  Input   
Char(8)            
 *  5  Changed command string                                        Output  
Char(*)            
 *  6  Length available for changed command string                   Input   
Binary(4)          
 *  7  Length of changed command string available to return          Output  
Binary(4)          
 *  8  Error code                                                    I/O     
Char(*)            
                                                                                
                
d##_cmdlen        s              9b 0                                           
                
d##_ocb           ds                                                            
                
d  ##_typprc                     9b 0 inz(2)                               Type 
of processing   
d  ##_dbcs                       1    inz('0')                             DBCS 
data handling   
d  ##_pmtact                     1                                         
Prompter action      
d  ##_cmdstx                     1    inz('0')                             
Command syntax       
d  ##_msgkey                     4    inz(*blanks)                         Msg 
retrieve key     
d  ##_reserve                    9    inz(x'000000000000000000')           
Reserved             
d##_ocblen        s              9b 0 inz(20)                                   
                
d##_ocbfmt        s              8    inz('CPOP0100')                           
                
d##_chgcmd        s          32702                                              
                
d##_chglen        s              9b 0                                           
                
d##_chgavl        s              9b 0 inz(32702)                                
                
d##_error         ds                                                            
                
d  ##_erbp                1      4B 0 inz(128)                             
Bytes provided       
d  ##_erba                5      8B 0                                      
Bytes available      
d  ##_erexid              9     15                                         
Exception ID         
d  ##_erexdta            17    116                                         
Exception data       
                                                                                
                
d##_msgf          s             20    inz('QCPFMSG   *LIBL     ')               
                
                                                                                
                
 * Parameter list for API call.                                                 
                
c     qcapcmd       plist                                                       
                
c                   parm                    ##_cmd                              
                
c                   parm                    ##_cmdlen                           
                
c                   parm                    ##_ocb                              
                
c                   parm                    ##_ocblen                           
                
c                   parm                    ##_ocbfmt                           
                
c                   parm                    ##_chgcmd                           
                
c                   parm                    ##_chglen                           
                
c                   parm                    ##_chgavl                           
                
c                   parm                    ##_error                            
                
                                                                                
                
 * Determine the length of the command string to process.                       
                
c                   eval      ##_cmdlen = %len(%trim(##_cmd))                   
                
                                                                                
                
 * Determine the length of the command string to process.                       
                
c                   if        (%parms = 2 and %addr(##_pmttyp) = *null) or      
                
c                             %parms = 1                                        
                
c                   eval      ##_pmtact = '2'                                   
                
c                   else                                                        
                
c                   eval      ##_pmtact = ##_pmttyp                             
                
c                   endif                                                       
                
                                                                                
                
 * Process command.                                                             
                
c                   call      'QCAPCMD'     qcapcmd                             
                
                                                                                
                
 * If no error return address of attribute information.                         
                
c                   if        ##_erexid = *blanks                               
                
c                   return    %addr(##_chgcmd)                                  
                
                                                                                
                
 * Send error message to job log and return null address.                       
                
c                   else                                                        
                
c                   callp     sndpgmmsg(##_erexid: ##_msgf:                     
                
c                                       %addr(##_erexdta))                      
                
c                   return    *null                                             
                
c                   endif                                                       
                
                                                                                
                
pprccmd           e                                                             
                

Rick Chevalier
AmeriCredit AITS

(817) 525-7178
rick.chevalier@xxxxxxxxxxxxxxx

 -----Original Message-----
From:   rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx]  
On Behalf Of David & Eileen Keck
Sent:   Sunday, January 04, 2004 6:12 PM
To:     rpg400-l@xxxxxxxxxxxx
Subject:        Error Handling for QCMDEXC

What's a good way to retrieve the full message or message data associated
with a failed call to QCMDEXC ?

In the code below at the point labeled ZZZ I would like to have access to
the full error message in effect at that time.  However, by definition, the
exception data in the program status data structure is only available when
the status is 9999.  In the code below, when commitment control is already
active before the call to this program, the new attempt to start commitment
control correctly generates a CPF8351 (commit control already active),
however it yields a status code = 00202 "Called program or procedure
failed".  So the exception data is blank (even though the PSDS has the
desired message ID of CPF8351).
        Thanks - Dave K.


C     *INZSR        BegSR

 *                  start commitment control
C                   eval      cmdStr = 'STRCMTCTL  LCKLVL *CHG'
C                   eval      cmdLen = %len( cmdStr )
C* the procedure 'command' is a prototyped call to QCMDEXC
C                   callp(e)  command(cmdStr : cmdLen)
C                   if        %error
C* CPF8351 indicates commitment control is already active
C                   if        psds_MsgID = 'CPF8351'
C                   rolbk
C                   else
C*    ZZZ    Friendly error handler goes here
C                   endif
C                   endif

note: the procedure "command" is defined as follows ...
D Command         PR                  ExtPgm('QCMDEXC')
D  CmdStr                    32702    const options(*varsize)
D  CmdLen                       15p 5 const

 * Program Status Data Structure
D psds          esds                  extname(PSDS) prefix(psds_)





As an Amazon Associate we earn from qualifying purchases.

This thread ...


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.