source: FOIAVistA/tag/r/TOOLKIT-AWCM-XD-XIN-XPAR-XQAB-XT-XUC-XUR-ZIN-ZTED/XINDX5.m@ 636

Last change on this file since 636 was 628, checked in by George Lilly, 14 years ago

initial load of FOIAVistA 6/30/08 version

File size: 2.8 KB
Line 
1XINDX5 ;SF-ISC/RWF - CROSS REFERENCE ALL ROUTINES ;03/26/2002 09:57
2 ;;7.3;TOOLKIT;**20,27,61**;Apr 25, 1995
3 G END:$D(IND("QUIT")) I INP(8) W !,"Called Routines",! D ^XINDX52 ;Get called routines
4 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
5 D ^XINDX53:INP(7) ;Load routine file
6 ;Check called tags and routines
7 S RN="$",TXT="" W !!,"--- CROSS REFERENCING ---",!
8A S RN=$O(^UTILITY($J,RN)),L="",LABO=0 I RN="" G B
9 F 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
10 G A
11AA Q:P="" I '$D(^UTILITY($J,1,P)) D Q ;We can now check % routines
12 . I (P["&")!(P["@") Q ;External subroutine
13 . S:T["$" T=$E(T,3,99) S:P["(" P=$P(P,"(")
14 . I '$$VTAG(P) S ERR=52,ERR(1)=P D AAER(.ERR,RN,"",0) Q
15 . S X=$T(^@P) I X="" S ERR=52,ERR(1)=P D AAER(.ERR,RN,$P(XX2,","),0) Q
16 . Q:T=""
17 . I '$$VTAG(T) D AAER(37,RN,$P(XX2,","),0) Q
18 . I $$VTAG(T),$T(@T^@P)="" S E=38,E(1)="MISSING LABEL "_XX1_"^"_P D AAER(.E,RN,"",0)
19 . Q
20 I T]"",$D(^UTILITY($J,1,P)) D
21 . S:T["$$" T=$E(T,3,99) S:T["@" T=""
22 . I T]"",'$D(^UTILITY($J,1,P,"T",T)) S E=38,E(1)="MISSING LABEL (see INVOKED BY list)." D AAER(.E,P,XX1,0)
23 Q
24AAER(ERR,RTN,LAB,LABO) ;Report error. error code, routine, label, label offset
25 D ^XINDX1
26 Q
27VTAG(K) ;Check for a valid tag. works for routine name.
28 Q (K?1(1"%",1A).7NA)!(K?1.8N)
29 ;
30B D ^XINDX51
31END W:$D(IND("QUIT")) !!,"--- ",$S($D(ZTSTOP):"TASK ",1:""),"STOPPED ---" W !!,"--- END ---"
32 I IO'=IO(0) U IO(0) W !,"--- D O N E ---" U IO
33 D ^%ZISC
34 S:$D(ZTQUEUED) ZTREQ="@"
35CLEAN ;Come here from XINDX6 if queued output.
36 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
37 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
38 Q
39CRX S RTN="$" F I=0:0 S RTN=$O(^UTILITY($J,RTN)) Q:RTN="" F LOC="L","G","MK","X" D CR0
40 K VZ Q
41 ;
42CR0 N VZ S S=-1 I LOC="X",'$D(^UTILITY($J,1,"***","X",RTN_" ")) S ^UTILITY($J,1,"***","X",RTN_" ")=""
43CR1 S S=$O(^UTILITY($J,1,RTN,LOC,S)) Q:S="" ;Loop
44 S X=$G(^UTILITY($J,1,RTN,LOC,S))
45 F J=1:1:$L(X) S:$G(^UTILITY($J,1,"***",LOC,S))'[$E(X,J) ^(S)=$G(^(S))_$E(X,J) ;Pass on flags
46 F J=0:1 Q:'$D(^UTILITY($J,1,RTN,LOC,S,J)) D CR2
47 G CR1
48 ;
49CR2 S PC="" I LOC'="X" S:^UTILITY($J,1,RTN,LOC,S,J)["*" PC=PC_"*" S:^(J)["!" PC=PC_"!" S:^(J)["~" PC=PC_"~" D CR3(RTN,S,LOC) Q
50 Q:$D(VZ(S)) S S1=$S($P(S," ",2)]"":$P(S," ",2)_"^",1:"")_$P(S," ",1),VZ(S)=""
51 ;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
52 D CR3(S1,RTN,"Z"),CR3(RTN,S,LOC)
53 Q
54CR3(X1,X2,X3) ;(RTN,REF,LOC)
55 S K=0
56CR4 S ARG="" I $D(^UTILITY($J,1,"***",X3,X2,K)) S ARG=^(K) I $L(ARG)>230 S K=K+1 G CR4
57 S ^UTILITY($J,1,"***",X3,X2,K)=ARG_X1_PC_"," Q
Note: See TracBrowser for help on using the repository browser.