- %INDX5 ;SF-ISC/RWF - CROSS REFERENCE ALL ROUTINES ;12/1/93 08:17 ;
- ;;7.3;TOOLKIT;;Apr 25, 1995
- G END:$D(IND("QUIT")) I INP(8) W !,"Called Routines",! D ^%INDX52 ;Get called routines
- K ARG,CCN,CH,COM,ERR,GK,GRB,I,INDDA,INDDS,L,LAB,LAB0,LC,LIN,LOC,PC,PRV,R,RTN,S,STR,TXT,V,X,Y
- D ^%INDX53:INP(7) ;Load routine file
- S RN="$" W !!,"--- CROSS REFERENCING ---",!
- A S RN=$O(^UTILITY($J,RN)),L="",LABO=0 I RN="" G B
- F I=1:1 S L=$O(^UTILITY($J,1,RN,"X",L)) Q:L="" S XX2=^(L,0),XX1=$P(L," ",2),T=$P(XX1,"+",1),P=$P(L," ",1) D AA
- G A
- AA I '$D(^UTILITY($J,1,P)),P'["%" S X=P X ^%ZOSF("TEST") I '$T S RTN=RN,LAB=$P(XX2,","),ERR=52,ERR(1)=P D ^%INDX1
- I T]"",$D(^UTILITY($J,1,P)) S:T["$" T=$E(T,3,99) I T]"",'$D(^UTILITY($J,1,P,"T",T)) S RTN=P,LAB=XX1,ERR=38 D ^%INDX1
- Q
- B D ^%INDX51
- END W:$D(IND("QUIT")) !!,"--- ",$S($D(ZTSTOP):"TASK ",1:""),"STOPPED ---" W !!,"--- END ---"
- I IO'=IO(0) U IO(0) W !,"--- D O N E ---" U IO
- D ^%ZISC
- S:$D(ZTQUEUED) ZTREQ="@"
- CLEAN ;Come here from %INDX6 if queued output.
- K %,%1,%2,%I1,%IN1,%UCN,A,ARG,C,C9,CCN,CH,COM,DA,DIC,DUOUT,ERR,ERTX,F,F1,G,GK,GRB,H,HED,HS
- K ^UTILITY($J),I,IND,INDB,INDC,INDDA,INDDS,INDF,INDFN,INDLC,INDPM,INDX,INDXDT,INDXJ,INP,IP,J,K,K1,K3,L,LAB,LABO,LBL,LC,LIN,LINE,LOC,NRO,OFF,P,PC,PGM,POP,POST,Q,R,RDTIME,RHS,ROU,RTN,S,S1,STR,SYM,TAB,TAG,TXT,TY,V,VZ,X,X1,X2,X3,Y
- Q
- CRX S RTN="$" F I=0:0 S RTN=$O(^UTILITY($J,RTN)) Q:RTN="" F LOC="L","G","MK","X" D CR0
- K VZ Q
- CR0 S S=-1 I LOC="X" K VZ I '$D(^UTILITY($J,1,"***","X",RTN_" ")) S ^UTILITY($J,1,"***","X",RTN_" ")=""
- CR1 S S=$O(^UTILITY($J,1,RTN,LOC,S)) Q:S="" S X=$G(^UTILITY($J,1,RTN,LOC,S)) S:$G(^UTILITY($J,1,"***",LOC,S))'[X ^(S)=$G(^(S))_X
- F J=0:1 Q:'$D(^UTILITY($J,1,RTN,LOC,S,J)) D CR2
- G CR1
- CR2 S PC="" I LOC'="X" S:^UTILITY($J,1,RTN,LOC,S,J)["*" PC=PC_"*" S:^(J)["!" PC=PC_"!" S:^(J)["~" PC=PC_"~" G CR3
- Q:$D(VZ(S)) S S1=$S($P(S," ",2)]"":$P(S," ",2)_"^",1:"")_$P(S," ",1),VZ(S)=""
- S X1=LOC,X2=S,X3=RTN,LOC="Z",S=RTN,RTN=S1 D CR3 S LOC=X1,S=X2,RTN=X3 K X1,X2,X3
- D CR3 Q
- CR3 S K=0
- CR4 S ARG="" I $D(^UTILITY($J,1,"***",LOC,S,K)) S ARG=^(K) I $L(ARG)>230 S K=K+1 G CR4
- S ^UTILITY($J,1,"***",LOC,S,K)=ARG_RTN_PC_"," Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HZINDX5 2177 printed Feb 19, 2025@00:09:03 Page 2
- %INDX5 ;SF-ISC/RWF - CROSS REFERENCE ALL ROUTINES ;12/1/93 08:17 ;
- +1 ;;7.3;TOOLKIT;;Apr 25, 1995
- +2 ;Get called routines
- if $DATA(IND("QUIT"))
- GOTO END
- IF INP(8)
- WRITE !,"Called Routines",!
- DO ^%INDX52
- +3 KILL ARG,CCN,CH,COM,ERR,GK,GRB,I,INDDA,INDDS,L,LAB,LAB0,LC,LIN,LOC,PC,PRV,R,RTN,S,STR,TXT,V,X,Y
- +4 ;Load routine file
- if INP(7)
- DO ^%INDX53
- +5 SET RN="$"
- WRITE !!,"--- CROSS REFERENCING ---",!
- A SET RN=$ORDER(^UTILITY($JOB,RN))
- SET L=""
- SET LABO=0
- IF RN=""
- GOTO B
- +1 FOR I=1:1
- SET L=$ORDER(^UTILITY($JOB,1,RN,"X",L))
- if L=""
- QUIT
- SET XX2=^(L,0)
- SET XX1=$PIECE(L," ",2)
- SET T=$PIECE(XX1,"+",1)
- SET P=$PIECE(L," ",1)
- DO AA
- +2 GOTO A
- AA IF '$DATA(^UTILITY($JOB,1,P))
- IF P'["%"
- SET X=P
- XECUTE ^%ZOSF("TEST")
- IF '$TEST
- SET RTN=RN
- SET LAB=$PIECE(XX2,",")
- SET ERR=52
- SET ERR(1)=P
- DO ^%INDX1
- +1 IF T]""
- IF $DATA(^UTILITY($JOB,1,P))
- if T["$"
- SET T=$EXTRACT(T,3,99)
- IF T]""
- IF '$DATA(^UTILITY($JOB,1,P,"T",T))
- SET RTN=P
- SET LAB=XX1
- SET ERR=38
- DO ^%INDX1
- +2 QUIT
- B DO ^%INDX51
- END if $DATA(IND("QUIT"))
- WRITE !!,"--- ",$SELECT($DATA(ZTSTOP):"TASK ",1:""),"STOPPED ---"
- WRITE !!,"--- END ---"
- +1 IF IO'=IO(0)
- USE IO(0)
- WRITE !,"--- D O N E ---"
- USE IO
- +2 --- END --- DO ^%ZISC
- +3 if $DATA(ZTQUEUED)
- SET ZTREQ="@"
- CLEAN ;Come here from %INDX6 if queued output.
- +1 KILL %,%1,%2,%I1,%IN1,%UCN,A,ARG,C,C9,CCN,CH,COM,DA,DIC,DUOUT,ERR,ERTX,F,F1,G,GK,GRB,H,HED,HS
- +2 KILL ^UTILITY($JOB),I,IND,INDB,INDC,INDDA,INDDS,INDF,INDFN,INDLC,INDPM,INDX,INDXDT,INDXJ,INP,IP,J,K,K1,K3,L,LAB,LABO,LBL,LC,LIN,LINE,LOC,NRO,OFF,P,PC,PGM,POP,POST,Q,R,RDTIME,RHS,ROU,RTN,S,S1,STR,SYM,TAB,TAG,TXT,TY,V,VZ,X,X1,X2,X3,Y
- +3 QUIT
- CRX SET RTN="$"
- FOR I=0:0
- SET RTN=$ORDER(^UTILITY($JOB,RTN))
- if RTN=""
- QUIT
- FOR LOC="L","G","MK","X"
- DO CR0
- +1 KILL VZ
- QUIT
- CR0 SET S=-1
- IF LOC="X"
- KILL VZ
- IF '$DATA(^UTILITY($JOB,1,"***","X",RTN_" "))
- SET ^UTILITY($JOB,1,"***","X",RTN_" ")=""
- CR1 SET S=$ORDER(^UTILITY($JOB,1,RTN,LOC,S))
- if S=""
- QUIT
- SET X=$GET(^UTILITY($JOB,1,RTN,LOC,S))
- if $GET(^UTILITY($JOB,1,"***",LOC,S))'[X
- SET ^(S)=$GET(^(S))_X
- +1 FOR J=0:1
- if '$DATA(^UTILITY($JOB,1,RTN,LOC,S,J))
- QUIT
- DO CR2
- +2 GOTO CR1
- CR2 SET PC=""
- IF LOC'="X"
- if ^UTILITY($JOB,1,RTN,LOC,S,J)["*"
- SET PC=PC_"*"
- if ^(J)["!"
- SET PC=PC_"!"
- if ^(J)["~"
- SET PC=PC_"~"
- GOTO CR3
- +1 if $DATA(VZ(S))
- QUIT
- SET S1=$SELECT($PIECE(S," ",2)]"":$PIECE(S," ",2)_"^",1:"")_$PIECE(S," ",1)
- SET VZ(S)=""
- +2 SET X1=LOC
- SET X2=S
- SET X3=RTN
- SET LOC="Z"
- SET S=RTN
- SET RTN=S1
- DO CR3
- SET LOC=X1
- SET S=X2
- SET RTN=X3
- KILL X1,X2,X3
- +3 DO CR3
- QUIT
- CR3 SET K=0
- CR4 SET ARG=""
- IF $DATA(^UTILITY($JOB,1,"***",LOC,S,K))
- SET ARG=^(K)
- IF $LENGTH(ARG)>230
- SET K=K+1
- GOTO CR4
- +1 SET ^UTILITY($JOB,1,"***",LOC,S,K)=ARG_RTN_PC_","
- QUIT