Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: ZOSVVXD

ZOSVVXD.m

Go to the documentation of this file.
  1. %ZOSV ;SFISC/AC - View commands & special functions. ;10/26/06 08:15
  1. ;;8.0;KERNEL;**13,65,71,94,107,118,136,215,284,425**;Jul 10, 1995;Build 18
  1. ACTJ() ; # active jobs
  1. Q $P($$JOBS^%SY,",",2)
  1. ;
  1. AVJ() ; # available jobs
  1. N Y S Y=$$JOBS^%SY Q +Y-$P(Y,",",2)
  1. ;
  1. PASSALL ;
  1. S Y=$ZC(%SPAWN,"SET TERM/PASTHRU "_$I) U $I:NOTERM Q
  1. NOPASS ;
  1. S Y=$ZC(%SPAWN,"SET TERM/NOPASTHRU "_$I) U $I:TERM="" Q
  1. ;
  1. PRGMODE ;
  1. W ! S ZTPAC=$S($D(^VA(200,+DUZ,.1))#10:$P(^(.1),"^",5),1:""),XUVOL=^%ZOSF("VOL")
  1. S X="" X ^%ZOSF("EOFF") R:ZTPAC]"" !,"PAC: ",X:60 D LC^XUS X ^%ZOSF("EON") I X'=ZTPAC W "??",*7 Q
  1. K XMB,XMTEXT,XMY S XMB="XUPROGMODE",XMB(1)=DUZ,XMB(2)=$I D ^XMB:$L($T(^XMB)) D BYE^XUSCLEAN K ZTPAC,X,XMB
  1. I '$$PROGMODE() D UCI S XUCI=Y,XQZ="PRGM^ZUA[MGR]",XUSLNT=1 D DO^%XUCI ZESCAPE
  1. E S $ECODE=",<<PROG>>,"
  1. ;
  1. PROGMODE() ;
  1. Q ($V($V($V(0)))#2=0)
  1. ;
  1. UCI ;
  1. S Y=$ZC(%UCI),Y=$P(Y,",",1)_","_$P(Y,",",4) Q
  1. ;
  1. UCICHECK(X) ;
  1. N %,%1,U,V,Y
  1. I '(X?3U!(X?3U1","3U)) Q ""
  1. S U=$ZC(%UCI),V=$P(U,",",4),U=$P(U,","),%1=$P(X,",",2),%=$P(X,",")
  1. S Y=$ZC(%SETUCI,%,%1),Y=$S(Y:%_","_$S(%1]"":%1,1:V),1:""),V=$ZC(%SETUCI,U,V)
  1. Q Y
  1. ;
  1. GETPEER() ;Get the PEER address
  1. N PEER,NL,$ET S NL="",$ET="S $EC=NL Q NL",PEER=""
  1. S PEER=$ZC(%TRNLNM,"VISTA$IP")
  1. I '$L(PEER) S PEER=$&%UCXGETPEER S PEER=$A(PEER,1)_"."_$A(PEER,2)_"."_$A(PEER,3)_"."_$A(PEER,4)
  1. Q PEER
  1. ;
  1. SHARELIC(TYPE) ;See if can share a C/S license DSM
  1. Q ;Cache only at this time.
  1. Q:$$VERSION<7.2
  1. N %,$ET S $ET="S $EC="""" Q"
  1. I TYPE S %=$$GetCSLic^%LICENSE Q
  1. I 'TYPE S %=$$ShareLic^%LICENSE
  1. S $EC=""
  1. Q
  1. PRIORITY ;
  1. Q ;Q:X>10!(X<1) S X=(X+1)\2-1,Y=$ZC(%SETPRI,X) Q ;Let VSM do it's thing.
  1. ;
  1. PRIINQ() ;
  1. Q $ZC(%GETJPI,0,"PRIB")*2+2
  1. ;
  1. BAUD S X="UNKNOWN" Q
  1. ;
  1. LGR() Q $ZR ;Last global ref.
  1. ;
  1. EC() Q $ZE ;Error code
  1. ;
  1. DOLRO ;SAVE ENTIRE SYMBOL TABLE IN LOCATION SPECIFIED BY X
  1. S Y="%" F S Y=$ZSORT(@Y) Q:Y="" D ;code from DEC
  1. . I $D(@Y)#2 S @(X_"Y)="_Y)
  1. . I $D(@Y)>9 S %X=Y_"(",%Y=X_"Y," D %XY^%RCR
  1. K %X,%Y,Y Q
  1. ;
  1. ORDER ;SAVE PARTS OF SYMBOL TABLE IN LOCATION SPECIFIED BY X
  1. S (Y,Y1)=$P(Y,"*") I $D(@Y)=0 F S Y=$ZSORT(@Y) Q:Y=""!(Y[Y1)
  1. Q:Y="" S %=$D(@Y) S:%#2 @(X_"Y)="_Y) I %>9 S %X=Y_"(",%Y=X_"Y," D %XY^%RCR
  1. F S Y=$ZSORT(@Y) Q:Y=""!(Y'[Y1) S %=$D(@Y) S:%#2 @(X_"Y)="_Y) I %>9 S %X=Y_"(",%Y=X_"Y," D %XY^%RCR
  1. K %,%X,%Y,Y,Y1
  1. Q
  1. ;
  1. PARSIZ ;
  1. S X=3 Q
  1. ;
  1. NOLOG ;
  1. S Y=0 Q
  1. ;
  1. GETENV ;Get environment Return Y='UCI^VOL/DIR^NODE^BOX LOOKUP'
  1. S Y=$P($ZU(0),",",1)_"^"_$P($ZU(0),",",2)_"^"_$P($ZC(%GETSYI),",",4)
  1. S $P(Y,"^",4)=$P(Y,"^",2)_":"_$P(Y,"^",3)
  1. Q
  1. VERSION(X) ;return DSM version, X=1 - return OS
  1. N % S %=$ZV
  1. I %[" V" Q $S($G(X):$P($ZV," V"),1:$P($ZV," V",2))
  1. Q $S($G(X):$P($ZV," ",1,2),1:$P($ZV," ",3))
  1. ;
  1. SETNM(X) ;Set name, Trap dup's, Fall into SETENV
  1. N $ETRAP S $ETRAP="S $ECODE="""" Q"
  1. SETENV ;Set environment X='PROCESS NAME^ '
  1. S %=$ZC(%SETPRN,$P(X,"^")) Q
  1. ;
  1. ;Code moved to %ZOSVKR, Comment out if needed.
  1. LOGRSRC(OPT,TYPE,STATUS) ;record resource usage in ^XTMP("KMPR"
  1. Q:'$G(^%ZTSCH("LOGRSRC")) ; quit if RUM not turned on.
  1. ; call to RUM routine.
  1. D RU^%ZOSVKR($G(OPT),$G(TYPE),$G(STATUS))
  1. Q
  1. ;
  1. SETTRM(X) ;Turn on specified terminators.
  1. U $I:TERM=X
  1. Q 1
  1. ;
  1. DEVOK ;Check Device Availability. (not complete)
  1. ;INPUT: X=Device $I, X1=IOT -- X1 needed for resources
  1. ;OUTPUT: Y=0 if available, Y=job # if owned, Y=-1 if device does not exists.
  1. S Y=0 Q:X["::" I $G(X1)="RES" G RESOK^%ZIS6
  1. S Y=$ZC(%GETDVI,X,"EXISTS")
  1. G DV1:Y D DV2 Q:Y=-1 I Y="TERM" S Y=-1 Q
  1. S Y=-2 Q
  1. DV1 S Y=$ZC(%GETDVI,X,"PID") I Y=$J!($ZC(%GETDVI,X,"SPL")) S Y=0 Q
  1. I Y,$ZC(%GETJPI,X,"MASTER_PID")=Y G DVOPN
  1. Q:Y>0 D DV2 G DVOPN:Y="TERM" S Y=$S(Y="DISK":0,Y="MAILBOX":0,Y="TAPE":0,1:-1) Q
  1. DV2 S Y=$ZC(%PARSE,X) I Y="" S Y=-1 Q
  1. I X]"" S Y=$ZC(%GETDVI,$S(Y]"":Y,1:X),"DEVCLASS") Q
  1. Q
  1. DVOPN S $ZT="DVERR",Y=0 Q:$D(%ZTIO)
  1. L:$D(%ZISLOCK) +@%ZISLOCK:60
  1. O X::$S($D(%ZISTO):%ZISTO,1:0) E S Y=999 L:$D(%ZISLOCK) -@%ZISLOCK:60 Q
  1. L:$D(%ZISLOCK) -@%ZISLOCK
  1. S Y=0 I '$D(%ZISCHK)!$S($D(%ZIS)#2:(%ZIS["T"),1:0) C X Q
  1. S:X]"" IO(1,X)="" Q
  1. DVERR I $ZE["OPENERR" S Y=-1 Q
  1. ZQ
  1. ;
  1. SID() ;Build a System ID
  1. N J1,J2,J3,T S T="~"
  1. S J1=$P($ZC(%GETSYI),",",4) ;NODE NAME
  1. S J2=$ZU(0) ;UCI
  1. S J3=$ZC(%ENVIDNM) ;Enviroment number,name
  1. ;S ^RWF("SID",$J,1)=J1,^(2)=J2,^(3)=J3
  1. Q "1~"_(+J3)_T_$P(J3,",",2)_T_J2_T
  1. ;
  1. T0 ; start RT clock
  1. ;S %ZH0=$ZH,%=$P(%ZH0,",",3) S:$E($ZV,10,12)>5.1 %=$E(%,13,23) S XRT0=+$H_","_($P(%,":")*3600+($P(%,":",2)*60)+$P(%,":",3))
  1. Q
  1. ;
  1. T1 ; store RT datum w/ZHDIF
  1. ;S %ZH1=$ZH,%=$P(%ZH1,",",3) S:$E($ZV,10,12)>5.1 %=$E(%,13,23) S XRT1=+$H_","_($P(%,":")*3600+($P(%,":",2)*60)+$P(%,":",3))
  1. ;S ^%ZRTL(3,XRTL,+XRT1,XRTN,$P(XRT1,",",2))=XRT0_"^^"_($P(%ZH1,",")-$P(%ZH0,","))_"^"_($P(%ZH1,",",7)-$P(%ZH0,",",7))_"^"_($P(%ZH1,",",8)-$P(%ZH0,",",8)) K XRT0,%ZH0,%ZH1
  1. Q
  1. ;
  1. ZHDIF ;Display dif of two $ZH's
  1. W !," CPU=",$J($P(%ZH1,",")-$P(%ZH0,","),6,2),?14," ET=",$J($P(%ZH1,",",2)-$P(%ZH0,",",2),6,1),?27," DIO=",$J($P(%ZH1,",",7)-$P(%ZH0,",",7),5),?40," BIO=",$J($P(%ZH1,",",8)-$P(%ZH0,",",8),5),! Q
  1. ;
  1. DEVOPN ;List devices opened.
  1. N %,%B,%I,%L,%X,%X1,%X2,%Y
  1. S %X1=$V($V(0)+8),%X2=$V(%X1),Y=""
  1. F %I=1:1 D D1 S %X2=$V(%X2) Q:%X2=%X1
  1. Q
  1. D1 S %X=$V(%X2+8)
  1. S %L=$V(%X+4,-1,1),%B=$V(%X+8)
  1. S %Y=""
  1. F %=1:1:%L S %Y=%Y_$C($V(%B,-1,1)) S %B=%B+1
  1. S Y=Y_%Y_"," Q
  1. ;