- %ZOSV ;ISF/STAFF - View commands & special functions (GT.M). ;09/15/08 14:45
- ;;8.0;KERNEL;**275,425,499**;Jul 10, 1995;Build 24
- ; for GT.M for VMS, version 4.3
- ;
- ACTJ() ; # active jobs
- ;Keep active count in global
- Q $G(^XUTL("XUSYS","CNT"))
- ;Long way that would work
- ;N %IMAGE S %IMAGE=$ZGETJPI($J,"IMAGNAME")
- ;N Y S Y=0
- ;N %PID S %PID=0
- ;F S %PID=$ZPID(%PID) Q:'%PID I $ZGETJPI(%PID,"IMAGNAME")=%IMAGE S Y=Y+1
- ;Q Y
- ;
- AVJ() ; # available jobs, Limit is in the OS.
- N V,J
- S V=^%ZOSF("VOL"),J=$O(^XTV(8989.3,1,4,"B",V,0)),J=$P($G(^XTV(8989.3,1,4,J,0),"^^1000"),"^",3)
- Q J-$$ACTJ ;Use signon Max
- ;
- PASSALL ;
- U $I:(PASTHRU) Q
- NOPASS ;
- U $I:(NOPASTHRU) Q
- ;
- GETPEER() ;Get the IP address of a connection peer
- N PEER
- S PEER=$ZTRNLNM("VISTA$IP")
- I $G(^XTV(8989.3,1,"PEER"))[PEER S PEER="" ;p499
- Q $S($L(PEER):PEER,$L($G(IO("GTM-IP"))):IO("GTM-IP"),1:"")
- ;
- PRGMODE ;
- N X,XUCI,XUSLNT
- W ! S ZTPAC=$P($G(^VA(200,+DUZ,.1)),"^",5),XUVOL=^%ZOSF("VOL")
- S X="" X ^%ZOSF("EOFF") R:ZTPAC]"" !,"PAC: ",X:60 D LC^XUS X ^%ZOSF("EON") I X'=ZTPAC W "??",$C(7) Q
- N XMB,XMTEXT,XMY S XMB="XUPROGMODE",XMB(1)=DUZ,XMB(2)=$I D ^XMB:$L($T(^XMB)) D BYE^XUSCLEAN K ZTPAC,X,XMB
- D UCI S XUCI=Y D PRGM^ZUA
- F BREAK
- HALT
- ;
- PROGMODE() ; In Application mode
- Q 0 ; This was used to control UCI switching, has no meaning in GT.M
- ;
- UCI ;
- S Y="VAH,"_^%ZOSF("VOL") Q
- ;
- UCICHECK(X) ;
- Q 1
- ;
- TEMP() ; Return path to temp directory
- ;N %TEMP S %TEMP=$P($$RTNDIR," "),%TEMP=$P(%TEMP,"/",1,$L(%TEMP,"/")-2)_"/t/"
- Q $G(^%ZOSF("TMP"),$G(^XTV(8989.3,1,"DEV"),"USER$:[TEMP]"))
- ;
- JOBPAR ;is job X valid on system, return UCI in Y.
- N $ES,$ET,J S $ET="Q:$ES>0 S Y="""" G JOBPX^%ZOSV"
- S Y=""
- S J=$ZGETJPI(X,"PRI")
- I $L(J) S Y=$P(^%ZOSF("PROD"),",")
- JOBPX S $EC=""
- Q
- ;
- SHARELIC(TYPE) ;Used by Cache implementations
- Q
- ;
- PRIORITY ;The VA has this disabled in general.
- Q
- ;
- PRIINQ() ;
- N PRI S PRI=$ZGETJPI($J,"PRI")
- Q $S(PRI=0:1,PRI=1:3,PRI=2:5,PRI=3:7,PRI=4:9,1:10)
- ;
- BAUD S X="UNKNOWN" Q
- ;
- LGR() Q $R ; Last global reference ($REFERENCE)
- ;
- EC() ; Error Code: returning $ZS in format more like $ZE from DSM
- N %ZE
- I $ZS="" Q ""
- S %ZE=$P($ZS,",",2)_","_$P($ZS,",",4)_","_$P($ZS,",")_",-"_$P($ZS,",",3)
- Q %ZE
- ;
- DOLRO ;SAVE ENTIRE SYMBOL TABLE IN LOCATION SPECIFIED BY X
- ;S Y="%" F S Y=$O(@Y) Q:Y="" D
- ;. I $D(@Y)#2 S @(X_"Y)="_Y)
- ;. I $D(@Y)>9 S %X=Y_"(",%Y=X_"Y," D %XY^%RCR
- S Y="%" F M:$D(@Y) @(X_"Y)="_Y) S Y=$O(@Y) Q:Y=""
- Q
- ;
- ORDER ;SAVE PART OF SYMBOL TABLE IN LOCATION SPECIFIED BY X
- N %
- S (Y,%)=$P(Y,"*",1) ;I $D(@Y)=0 F S Y=$O(@Y) Q:Y=""!(Y[Y1)
- Q:Y=""
- ;S %=$D(@Y) S:%#2 @(X_"Y)="_Y) I %>9 S %X=Y_"(",%Y=X_"Y," D %XY^%RCR
- ;F S Y=$O(@Y) Q:Y=""!(Y'[Y1) S %=$D(@Y) S:%#2 @(X_"Y)="_Y) I %>9 S %X=Y_"(",%Y=X_"Y," D %XY^%RCR
- F M:$D(@Y) @(X_"Y)="_Y) S Y=$O(@Y) Q:Y=""!(Y'[%)
- Q
- ;
- PARSIZ ;
- S X=3 Q
- ;
- NOLOG ;
- S Y=0 Q
- ;
- GETENV ;Get environment Return Y='UCI^VOL^NODE^BOX LOOKUP'
- N %V,%HOST S %HOST=$ZGETSYI("NODENAME"),%V=^%ZOSF("PROD")
- S Y=$TR(%V,",","^")_"^"_%HOST_"^"_$P(%V,",",2)_":"_%HOST
- Q
- ;
- VERSION(X) ;return OS version, X=1 - return OS
- Q $S($G(X):$P($ZV," V"),1:+$P($ZV," V",2))
- ;
- OS() ;
- Q "VMS"
- ;
- RTNDIR() ;primary routine source directory
- ;Assume dat1$:[gtm.o]/src=(dat1$:[gtm.r]),gtm$dist
- N % S %=$P($ZRO,",")
- I %["/SRC" S %=$P($P($P(%,"(",2),")",1),",")
- Q %
- ;
- SETNM(X) ;Set name, Trap dup's, Fall into SETENV
- N $ETRAP S $ETRAP="S $ECODE="""" Q"
- ;
- SETENV ;Set environment X='PROCESS NAME^ '
- ;workaround for GT.M
- S ^XUTL("XUSYS",$J,0)=$H,^("NM")=X,^("PID")=$$FUNC^%DH($J)
- Q
- ;
- SID() ;System ID
- N J1,T S T="~"
- S J1(1)=$ZROUTINES
- S J1(2)=$ZGBLDIR
- Q "1~"_J1(1)_T_J1(2)
- ;
- PRI() ;Check if a mixed OS enviroment.
- ;Default return 1 unless we are on the secondary OS.
- ;Only Cache on a VMS/Linux mix is supported now.
- Q 1
- ;
- T0 ; start RT clock
- Q
- ;
- T1 ; store RT datum, Obsolete
- Q
- ;
- ;Code moved to %ZOSVKR, Comment out if needed.
- LOGRSRC(OPT,TYPE,STATUS) ;record resource usage in ^XTMP("KMPR"
- Q:'$G(^%ZTSCH("LOGRSRC")) ; quit if RUM not turned on.
- ; call to RUM routine.
- D RU^%ZOSVKR($G(OPT),$G(TYPE),$G(STATUS))
- Q
- ;
- SETTRM(X) ;Turn on specified terminators.
- U $I:TERM=X
- Q 1
- ;
- DEVOK ;
- ;INPUT: X=Device $I, X1=IOT -- X1 needed for resources
- ;OUTPUT: Y=0 if available, Y=job # if owned
- ; Y=-1 if device does not exists.
- ; return Y=0 if not owned, Y=$J of owning job, Y=999 if dev cycling
- ;
- S Y=0,X1=$G(X1) Q:(X1="HFS")!(X1="MT")!(X1="CHAN")
- I X1="RES" G RESOK^%ZIS6
- S Y=0
- Q ;Let ZIS deal with it.
- ;
- Q
- LPC(X) ;ZCRC(X)
- N R,I
- S R=$ZBITSTR(8,0)
- F I=1:1:$L(X) S R=$ZBITXOR(R,$C(0)_$E(X,I))
- Q $A(R,2)