home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
OS/2 Shareware BBS: 10 Tools
/
10-Tools.zip
/
viscobv7.zip
/
vac22os2
/
ibmcobol
/
macros
/
iwzmmn.lx
< prev
next >
Wrap
Text File
|
1998-01-08
|
12KB
|
420 lines
/* Reinvoking as "REXX %0 %1 %2 %3 %4 %5 %6 %7 %8 %9" 2>nul
@goto runit */
/*********************************************************************/
/* Licensed Material - Property of IBM */
/* 5639-B92 , 5639-D65 (C) Copyright IBM Corp., 1997, 1998 */
/* All rights reserved. */
/* US Government Users Restricted Rights - Use, duplication or */
/* disclosure restricted by GSA ADP Schedule Contract with IBM Corp. */
/*********************************************************************/
trace off;
signal on novalue;
parse source opsys . whoami rest;
/* cobolroot is now set by iwzmIR.CMD */
if opsys = 'OS/2' then
do;
env = 'OS2ENVIRONMENT';
callit = '@Call';
call RxFuncAdd 'SysLoadFuncs','RexxUtil','SysLoadFuncs';
call SysLoadFuncs;
end;
else
do;
env = 'ENVIRONMENT';
callit = '@Rexx';
end;
tempdir = value('TMP',,env);
tempout = SysTempFileName(tempdir'\TM?????.OUT');
tempout2 = SysTempFileName(tempdir'\T2?????.OUT');
xx = Get_MVSINFO();
if xx <> 0 then
exit 16;
call Set_MVSINFO_Vars;
if tracemod = '*' |,
wordpos(translate(substr(whoami,lastpos('\',whoami)+1)),tracemod) > 0 then
do;
if trace > 3 then trace results;
if trace > 4 then trace ?;
end;
parse arg the_input_args;
call traceit 1 'Entry' '!'the_input_args'!';
'extract doctype into doctypeq';
if translate(doctypeq) <> 'SHL' then
do;
call traceit 1 'Error exit';
exit 16;
end;
parse upper arg request rest;
if rest = '' then
rest = '0';
parse var rest waitsec rest2;
select;
when request = 'START' then
do;
'extract global.iwzmmn into iwzmmnq';
if rc = 0 then
do;
if iwzmmnq = 'iwzmMN' then
do;
'msg MVS Job Status Monitor was already started';
'alarm';
call traceit 1 'Error exit';
exit 0;
end;
end;
'set global.iwzmmn iwzmMN';
if waitsec = 0 then
do;
'set font.l white/white';
'set font.c white/white';
'set font.background white/white'
'set focus.top 0';
'set focus.bottom 0';
'macro iwzmsys.lx';
'set action.button1down macro iwzmmn.lx mark';
'set action.button1double mult !macro iwzmmn.lx mark!macro iwzmsya.lx list!';
'set font.highlight pink/white';
end;
'set browse on';
'extract classes into classes';
'set classes' classes 'MVSSTAT';
'extract protect into protect';
'set protect' protect 'MVSSTAT';
'extract highlight into highlight';
'highlight' highlight 'MVSSTAT';
'set focus.row 2';
'set autocount 0';
'set autotime 0';
'set timeout -1';
'set synonym.quit macro iwzmmn stop';
'set synonym.qquit macro iwzmmn stop';
'bottom';
if opsys = 'OS/2' then
do;
'set global.iwzmmnc iwzmMN' rest;
'insert iwzmMN' rest;
end;
else
do;
'set global.iwzmmnc REXX iwzmMN.CMD' rest;
'insert REXX iwzmMN.CMD' rest;
end;
'cmd run';
end;
when request = 'STOP' then
do;
'set global.iwzmmn OFF';
'lxn qquit';
end;
when request = 'HIGHLIGHT' then
do;
xx = SysSleep(1);
'bottom';
'prev';
'extract content into line';
if opsys = 'OS/2' then
do;
if substr(line,1,1) = '[' & substr(line,3,1) = ':' then
do;
'delete';
'bottom';
end;
end;
else
do;
line = strip(line,'T');
if length(line) > 0 then
do;
if substr(line,2,1) = ':' & substr(line,length(line),1) = '>' then
do;
'delete';
'bottom';
end;
end;
end;
'bottom';
'extract elements into numlines';
do ii = 1 to 1000; /* prevent endless loop */
'extract element into linenum';
if linenum <= 1 then
leave;
'extract content into line';
if substr(line,1,10) = '----------' then
leave;
'prev';
end;
found = 0;
do ii = 1 to 1000; /* prevent endless loop */
'extract element into linenum';
if linenum >= numlines then
leave;
'extract content into line';
if substr(line,3,1) = '/' & substr(line,6,1) = '/' &,
substr(line,12,1) = ':' & substr(line,15,1) = ':' then
do;
if found = 0 then
do;
found = linenum;
'mark set @@mon@@';
end;
if pos('ON OUTPUT QUEUE',line) > 0 then
'set class MVSSTAT';
end;
'next';
end;
if found = 0 then
do;
'bottom';
'mark set @@mon@@';
end;
'top';
do ii = 1 to 10;
'extract content into line';
if substr(line,3,1) = '/' & substr(line,6,1) = '/' &,
substr(line,12,1) = ':' & substr(line,15,1) = ':' then
leave;
'delete';
if substr(line,1,10) = '----------' then
leave;
end;
'msg Job status complete';
'set font.l black/white';
'check';
'set changes 0';
'mark find @@mon@@';
'focus';
end;
when request = 'MARK' then
do;
'primitive setcursor';
'extract content into line';
'block clear';
if substr(line,3,1) = '/' & substr(line,6,1) = '/' &,
substr(line,12,1) = ':' & substr(line,15,1) = ':' then
do;
if pos('ON OUTPUT QUEUE',line) > 0 then
do;
'begin';
'block mark character';
'end';
'block mark character';
'begin';
end;
end;
'msg ';
end;
when request = 'STARTS' then
do;
'set browse on';
'set font.c white/white';
'set font.background white/white'
'set focus.top 0';
'set focus.bottom 0';
'set autocount 0';
'set autotime 0';
'set timeout -1';
'set synonym.quit macro iwzmmn stops';
'set synonym.qquit macro iwzmmn stops';
end;
when request = 'STOPS' then
'lxn qquit';
when request = 'CLEANS' then
do;
xx = SysSleep(2);
'top';
do ii = 1 to 8;
'extract content into line';
lines = strip(line,'L');
if substr(lines,1,13) = 'Accessing MVS' then
leave;
'delete';
if opsys = 'OS/2' then
do;
if substr(line,1,1) = '[' & substr(line,3,1) = ':' then
leave;
end;
else
do;
line = strip(line,'T');
if length(line) > 0 then
do;
if substr(line,2,1) = ':' & substr(line,length(line),1) = '>' then
leave;
end;
end;
end;
'bottom';
'extract content into line';
if opsys = 'OS/2' then
do;
if substr(line,1,1) = '[' & substr(line,3,1) = ':' then
'delete';
end;
else
do;
line = strip(line,'T');
if length(line) > 0 then
do;
if substr(line,2,1) = ':' & substr(line,length(line),1) = '>' then
'delete';
end;
end;
'macro out.lxl';
end;
otherwise
do;
'msg Unknown request:' request;
'alarm';
call traceit 1 'Error exit';
exit 16;
end;
end;
call traceit 1 'Normal exit';
exit 0;
Get_MVSINFO:
Procedure expose env cobolroot mvsinfo. whoami tempdir trace
rtn = 0
null = '0000'x
crlf = '0D0A'x
mvsinfo. = ''
mvsinfoQ = translate('iwzm_MVSINFO.DAT_YALE');
oldq = rxqueue('Set',mvsinfoQ) /* switch to mvsinfo queue */
if queued() = 0 then do /* if Q is missing we'll */
qname = rxqueue('Create',mvsinfoQ) /* create it and put a bad */
if qname = mvsinfoQ then push 'Sven' /* timestamp on it, else */
else x=rxqueue('Delete',qname) /* it was in use (we hope) */
end /* so we'll assume we can */
parse pull mvsstuff; push mvsstuff /* get/replace Q contents */
parse value mvsstuff with ts (null) . cobolroot (null) mvsstuff /* get */
/* timestamp and cobolroot */
if ts <> 'Sven' then do;
mvsinfo = cobolroot'\MACROS\MVSINFO.DAT'
bad_mvsinfo = ' **' whoami '****'crlf' **error*' mvsinfo,
'is unavailable, missing or empty **'
x=SysFileTree(mvsinfo,'ts','F') /* get MVSINFO.DAT's timestamp */
if ts.0 <> 1 then do
say bad_mvsinfo
return 12;
end
parse var ts.1 v0 v1 v2 .
timestamp ='mvsinfo.dat.timestamp' v0 v1 v2
end;
else
timestamp = 'Yale'
if timestamp <> ts then do /* timestamps match? */
pull mvsstuff /* no, remove bad contents */
rtn = "iwzmIR.CMD"() /* ask for new stuff */
if rtn = 0 then do
parse pull mvsstuff; push mvsstuff /* get/replace Q contents */
/* remove timestamp and */
/* cobolroot */
parse value mvsstuff with . (null) . cobolroot ( null) mvsstuff
end
end
qname = rxqueue('Set',oldq) /* restore normal queue */
do while (mvsstuff<>'') & (rtn=0) /* mvsinfo. structure */
parse value mvsstuff with key val (null) mvsstuff
if mvsinfo.key = '' then do /* e.g. mvsinfo.TYPE='' */
mvsinfo.KEYS = mvsinfo.KEYS key /* no substitution for KEYS */
mvsinfo.key.1 = val /* e.g. mvsinfo.TYPE.1=val */
mvsinfo.key = 1 /* e.g. mvsinfo.TYPE=1 */
end
else do
x = mvsinfo.key + 1 /* e.g. mvsinfo.TYPE+1 */
mvsinfo.key.x = val /* e.g. mvsinfo.TYPE.2=val */
mvsinfo.key = x /* e.g. mvsinfo.TYPE=2 */
end
end
return rtn
Set_MVSINFO_Vars:
parse var mvsinfo.CLOSECMD.1 closecmd;
parse var mvsinfo.CLOSEFILE.1 closefile;
parse var mvsinfo.FILESYS.1 filesys accessmon testaccess;
parse var mvsinfo.FSSTARTCMD.1 fsstartcmd;
parse var mvsinfo.FSSTOPCMD.1 fsstopcmd;
parse var mvsinfo.HEADER.1 header;
parse var mvsinfo.JOBLOG.1 joblog;
parse var mvsinfo.MAXCMD.1 maxcmd;
parse var mvsinfo.LANGUAGE.1 language;
parse var mvsinfo.MOUNTCMD.1 mountcmd;
parse var mvsinfo.MVSCOMM.1 mvscomm;
parse var mvsinfo.iwzmEDT.1 iwzmedt;
parse var mvsinfo.NFS.1 nfs;
parse var mvsinfo.NULLSTDIN.1 nullstdin;
parse var mvsinfo.OUTSHOW.1 outshow;
parse var mvsinfo.PROTSAVE.1 protsave tempmult;
parse var mvsinfo.PWD.1 pwd pwdasis pwdt pwde;
parse var mvsinfo.READTIMEOUT.1 readtimeout;
parse var mvsinfo.REXECCMD.1 rexeccmd;
parse var mvsinfo.SDU.1 sdu;
parse var mvsinfo.SIGYCLST.1 sigyclst;
parse var mvsinfo.SYSPROC.1 sysproc;
parse var mvsinfo.SYSTEM.1 system;
parse var mvsinfo.TEMPDRIVE.1 tempdrive;
parse var mvsinfo.TEMPDATA.1 tempdata;
parse var mvsinfo.TESTFILE.1 testfile;
parse var mvsinfo.TRACE.1 trace tracekeep;
parse var mvsinfo.TRACECMD.1 tracecmd;
parse var mvsinfo.TRACEMOD.1 tracemod;
parse var mvsinfo.UMOUNTCMD.1 umountcmd;
parse var mvsinfo.USERID.1 userid;
parse var mvsinfo.WORKSYS.1 worksys;
parse var mvsinfo.WRITETIMEOUT.1 writetimeout;
parse var mvsinfo.DRIVE numdrive;
if numdrive = '' then
numdrive = 0;
do ii = 1 to numdrive;
parse var mvsinfo.DRIVE.ii,
drive.ii highqual.ii trans.ii mapping.ii sidefile.ii;
end;
parse var mvsinfo.TYPE numtype;
if numtype = '' then
numtype = 0;
do ii = 1 to numtype;
parse var mvsinfo.TYPE.ii type.ii ext.ii;
end;
return
/* */
Traceit:
parse arg iwz_trc_level iwz_trc_message;
if iwz_trc_level > trace then
return;
if pwd <> '********' & pwd <> '++++++++' & pwd <> '========' then
do;
do forever;
if pos(pwd,iwz_trc_message) = 0 then
leave;
parse var iwz_trc_message iwz_trc_message1 (pwd) iwz_trc_message2;
iwz_trc_message = iwz_trc_message1||'********'||iwz_trc_message2
end;
end
iwz_trc_message = date('O') time('L') whoami':' iwz_trc_message;
xx = lineout(tempdir'\iwzmTRC.TRC',iwz_trc_message);
xx = stream(tempdir'\iwzmTRC.TRC','C','CLOSE');
if tracecmd <> '' then
interpret tracecmd;
return;
/* */
sayit:
parse arg iwz_sayit_arg;
if trace > 2 then
call traceit 3 '--->' iwz_sayit_arg;
say iwz_sayit_arg;
return;
/*
:runit
@rexx %0 %1 %2 %3 %4 %5 %6 %7 %8 %9
@rem */