PGM /*---------------------------------------------------------*/ /* TESTMBRDCL : メンバー記述の検索 */ /*---------------------------------------------------------*/ DCL VAR(&MSG) TYPE(*CHAR) LEN(132) DCL VAR(&MSGID) TYPE(*CHAR) LEN(7) DCL VAR(&MSGF) TYPE(*CHAR) LEN(10) DCL VAR(&MSGFLIB) TYPE(*CHAR) LEN(10) DCL VAR(&MSGDTA) TYPE(*CHAR) LEN(132) DCL VAR(&TYPE) TYPE(*CHAR) LEN(1) DCL VAR(&RCVVAR) TYPE(*CHAR) LEN(1024) DCL VAR(&RCVLEN) TYPE(*CHAR) LEN(4) + VALUE(X'00000400') DCL VAR(&APIERR) TYPE(*CHAR) LEN(116) + VALUE(X'000074') /* 2 進数 */ DCL VAR(&NULL4) TYPE(*CHAR) LEN(4) + VALUE(X'00000000') MONMSG MSGID(CPF0000) EXEC(GOTO CMDLBL(ERROR)) RTVJOBA TYPE(&TYPE) CALL PGM(QUSRMBRD) PARM(&RCVVAR &RCVLEN + 'MBRD0100' 'QRPGLESRC PGMRLIB ' + 'AAI006 ' '0' &APIERR) IF COND(%SST(&APIERR 5 4) *NE &NULL4) THEN(DO) GOTO APIERR ENDDO SNDPGMMSG MSG('SRCTYPE = ' *CAT %SST(&RCVVAR 49 + 10)) TOMSGQ(*TOPGMQ) MSGTYPE(*DIAG) RETURN APIERR: CHGVAR VAR(&MSGID) VALUE(%SST(&APIERR 9 7)) CHGVAR VAR(&MSGF) VALUE('QCPFMSG ') CHGVAR VAR(&MSGDTA) VALUE(%SST(&APIERR 17 100)) RTVMSG MSGID(&MSGID) MSGF(QCPFMSG) MSGDTA(&MSGDTA) + MSG(&MSG) GOTO SNDMSG ERROR: RCVMSG MSGTYPE(*LAST) RMV(*NO) MSG(&MSG) SNDMSG: IF COND(&TYPE *EQ '0') THEN(DO) SNDPGMMSG MSG(&MSG) TOMSGQ(*SYSOPR) MSGTYPE(*COMP) ENDDO ELSE CMD(DO) SNDPGMMSG MSG(&MSG) TOMSGQ(*TOPGMQ) MSGTYPE(*DIAG) ENDDO ENDPGM