TechTalk: Copying Objects

Typography
  • Smaller Small Medium Big Bigger
  • Default Helvetica Segoe Georgia Times

The CRTDUPOBJ (Create Duplicate Object) command does not offer a replace option. If the object already exists, the command is ended and an error message is sent. Having to delete an object before each copy can be very annoying, so I created the Copy Object (CPYOBJ) command which gets around this problem.

The CPYOBJ command (2a) accepts the required parameters to run CRTDUPOBJ, with one additional parameter: REPLACE. The RE-PLACE parameter has three choices: *NO, which never replaces an existing object. If the object does not exist *NO is ignored and the object is created. If it does exist, an error message is sent and the command ends. *YES always replaces an existing object. The object is replaced and a completion message is sent. With *WARN, a warning message requiring a reply is sent using SNDUSRMSG. Either Y or N to the response sends a message to the user. For the parameter OBJTYPE I have included 10 of the most common object types. This parameter may be modified to accept others not listed. You must also include delete commands for any additional objects in program OBJ001CL.

The CPYOBJ command (Figure 2a) accepts the required parameters to run CRTDUPOBJ, with one additional parameter: REPLACE. The RE-PLACE parameter has three choices: *NO, which never replaces an existing object. If the object does not exist *NO is ignored and the object is created. If it does exist, an error message is sent and the command ends. *YES always replaces an existing object. The object is replaced and a completion message is sent. With *WARN, a warning message requiring a reply is sent using SNDUSRMSG. Either Y or N to the response sends a message to the user. For the parameter OBJTYPE I have included 10 of the most common object types. This parameter may be modified to accept others not listed. You must also include delete commands for any additional objects in program OBJ001CL.

In OBJ001CL program (2b), I receive the object and library names as a qualified parameter. It is necessary to split this variable up later in the program using CHGVAR and the substring function. This is because CRTDUPOBJ has object and library as two parameters. I check the current library with RTVJOBA (Retrieve Job Attributes) to determine if a current library is in the library list. If it is not, I default to library QGPL. I next attempt to perform CRTDUPOBJ. I monitor for escape messages such as, library not found or object not found. If the command is successful, I send a completion message. If the object already exists, I check which replace option was picked, and take the appropriate action mentioned earlier. If the *WARN option is taken, I delete the object and process the CRTDUPOBJ once again.

In OBJ001CL program (Figure 2b), I receive the object and library names as a qualified parameter. It is necessary to split this variable up later in the program using CHGVAR and the substring function. This is because CRTDUPOBJ has object and library as two parameters. I check the current library with RTVJOBA (Retrieve Job Attributes) to determine if a current library is in the library list. If it is not, I default to library QGPL. I next attempt to perform CRTDUPOBJ. I monitor for escape messages such as, library not found or object not found. If the command is successful, I send a completion message. If the object already exists, I check which replace option was picked, and take the appropriate action mentioned earlier. If the *WARN option is taken, I delete the object and process the CRTDUPOBJ once again.

-- Michael Gariola


Techtalk: Copying Objects

Figure 2A Command CPYOBJ

 CPYOBJ: CMD PROMPT('Copy Object to Another Library') PARM KWD(OBJ) TYPE(NAME1) MIN(1) PROMPT('Name of + Object') PARM KWD(OBJTYPE) TYPE(*CHAR) LEN(7) RSTD(*YES) + VALUES(*CMD *DTAARA *FILE *JOBD *MSGF + *MSGQ *OUTQ *PGM *QRYDFN *SBSD) MIN(1) + PROMPT('Object type') PARM KWD(TOLIB) TYPE(*SNAME) LEN(10) DFT(*SAME) + SPCVAL((*SAME)) PROMPT('To library') PARM KWD(NEWOBJ) TYPE(*SNAME) LEN(10) DFT(*SAME) + SPCVAL((*SAME)) PROMPT('Name of new object') PARM KWD(REPLACE) TYPE(*CHAR) LEN(5) RSTD(*YES) + DFT(*WARN) VALUES(*NO *YES *WARN) + PROMPT('Replace') NAME1: QUAL TYPE(*SNAME) LEN(10) MIN(1) QUAL TYPE(*SNAME) LEN(10) DFT(*CURLIB) + SPCVAL((*CURLIB)) PROMPT('Library') 
Techtalk: Copying Objects

Figure 2B CL program OBJ001CL

 OBJ001CL: + PGM PARM(&QLFNAM &OBJTYPE &TOLIB &NEWOBJ &REPLACE) DCL VAR(&QLFNAM) TYPE(*CHAR) LEN(20) DCL VAR(&OBJ) TYPE(*CHAR) LEN(10) DCL VAR(&FROMLIB) TYPE(*CHAR) LEN(10) DCL VAR(&OBJTYPE) TYPE(*CHAR) LEN(7) DCL VAR(&TOLIB) TYPE(*CHAR) LEN(10) DCL VAR(&NEWOBJ) TYPE(*CHAR) LEN(10) DCL VAR(&REPLACE) TYPE(*CHAR) LEN(5) DCL VAR(&DATA) TYPE(*CHAR) LEN(4) VALUE(*NO) DCL VAR(&MSGRPY) TYPE(*CHAR) LEN(1) DCL VAR(&MSGID) TYPE(*CHAR) LEN(7) DCL VAR(&MSGDTA) TYPE(*CHAR) LEN(100) DCL VAR(&MSGF) TYPE(*CHAR) LEN(10) DCL VAR(&MSGFLIB) TYPE(*CHAR) LEN(10) DCL VAR(&CURLIB) TYPE(*CHAR) LEN(10) CHGVAR VAR(&OBJ) VALUE(%SST(&QLFNAM 1 10)) CHGVAR VAR(&FROMLIB) VALUE(%SST(&QLFNAM 11 10)) RTVJOBA CURLIB(&CURLIB) IF COND(&CURLIB *EQ '*NONE') THEN(CHGVAR VAR(&CURLIB) VALUE(QGPL)) IF COND(&FROMLIB *EQ '*CURLIB') THEN(CHGVAR VAR(&FROMLIB) + VALUE(&CURLIB)) IF COND(&TOLIB *EQ '*SAME') THEN(CHGVAR VAR(&TOLIB) + VALUE(&FROMLIB)) IF COND(&NEWOBJ *EQ '*SAME') THEN(CHGVAR VAR(&NEWOBJ) VALUE(&OBJ)) IF COND(&OBJTYPE *EQ '*FILE') THEN(CHGVAR VAR(&DATA) VALUE(*YES)) CREATE: + CRTDUPOBJ OBJ(&OBJ) FROMLIB(&FROMLIB) OBJTYPE(&OBJTYPE) + TOLIB(&TOLIB) NEWOBJ(&NEWOBJ) DATA(&DATA) MONMSG MSGID(CPF0000) EXEC(DO) RCVMSG MSGTYPE(*ANY) MSGDTA(&MSGDTA) MSGID(&MSGID) + MSGF(&MSGF) MSGFLIB(&MSGFLIB) IF COND(&MSGID *EQ 'CPF2110' *OR &MSGID *EQ 'CPF2105' *OR + &MSGID *EQ 'CPF2182' *OR &MSGID *EQ 'CPF2189') THEN(GOTO + CMDLBL(MSG)) IF COND(&MSGID *EQ 'CPD2104') THEN(GOTO CMDLBL(DELETE)) ENDDO SNDPGMMSG MSG('Object' *BCAT &NEWOBJ *BCAT 'in' *BCAT &TOLIB + *BCAT 'type' *BCAT &OBJTYPE *BCAT 'created.') MSGTYPE(*COMP) RETURN DELETE: + IF COND(&TOLIB *EQ &FROMLIB *AND &NEWOBJ *EQ &OBJ) THEN(GOTO + CMDLBL(MSG)) IF COND(&REPLACE *EQ '*NO') THEN(GOTO CMDLBL(MSG)) IF COND(&REPLACE *EQ '*YES') THEN(GOTO CMDLBL(REPYES)) SNDUSRMSG MSG('Do you wish to delete' *BCAT &NEWOBJ *BCAT '? (Y + N).') VALUES(Y N) DFT(N) MSGTYPE(*INQ) MSGRPY(&MSGRPY) IF COND(&MSGRPY *EQ 'Y') THEN(DO) REPYES: + IF COND(&OBJTYPE *EQ '*CMD') THEN(DLTCMD CMD(&TOLIB/&NEWOBJ)) IF COND(&OBJTYPE *EQ '*DTAARA') THEN(DLTDTAARA + DTAARA(&TOLIB/&NEWOBJ)) IF COND(&OBJTYPE *EQ '*FILE') THEN(DLTF FILE(&TOLIB/&NEWOBJ)) IF COND(&OBJTYPE *EQ '*JOBD') THEN(DLTJOBD JOBD(&TOLIB/&NEWOBJ)) IF COND(&OBJTYPE *EQ '*MSGF') THEN(DLTMSGF MSGF(&TOLIB/&NEWOBJ)) IF COND(&OBJTYPE *EQ '*OUTQ') THEN(DLTOUTQ OUTQ(&TOLIB/&NEWOBJ)) IF COND(&OBJTYPE *EQ '*PGM') THEN(DLTPGM PGM(&TOLIB/&NEWOBJ)) IF COND(&OBJTYPE *EQ '*QRYDFN') THEN(DLTQRY QRY(&TOLIB/&NEWOBJ)) IF COND(&OBJTYPE *EQ '*SBSD') THEN(DLTSBSD SBSD(&TOLIB/&NEWOBJ)) GOTO CMDLBL(CREATE) ENDDO SNDPGMMSG MSG('Object' *BCAT &NEWOBJ *BCAT 'not deleted.') + MSGTYPE(*COMP) GOTO CMDLBL(END) MSG: + SNDPGMMSG MSGID(&MSGID) MSGF(&MSGFLIB/&MSGF) MSGDTA(&MSGDTA) + MSGTYPE(*ESCAPE) END: + ENDPGM 
BLOG COMMENTS POWERED BY DISQUS

LATEST COMMENTS

Support MC Press Online

$

Book Reviews

Resource Center

  •  

  • LANSA Business users want new applications now. Market and regulatory pressures require faster application updates and delivery into production. Your IBM i developers may be approaching retirement, and you see no sure way to fill their positions with experienced developers. In addition, you may be caught between maintaining your existing applications and the uncertainty of moving to something new.

  • The MC Resource Centers bring you the widest selection of white papers, trial software, and on-demand webcasts for you to choose from. >> Review the list of White Papers, Trial Software or On-Demand Webcast at the MC Press Resource Center. >> Add the items to yru Cart and complet he checkout process and submit

  • SB Profound WC 5536Join us for this hour-long webcast that will explore:

  • Fortra IT managers hoping to find new IBM i talent are discovering that the pool of experienced RPG programmers and operators or administrators with intimate knowledge of the operating system and the applications that run on it is small. This begs the question: How will you manage the platform that supports such a big part of your business? This guide offers strategies and software suggestions to help you plan IT staffing and resources and smooth the transition after your AS/400 talent retires. Read on to learn: