| 1 | DICOMPX ;SFISC/GFT-EVALUATE COMPUTED FLD EXPR ;10:29 AM  22 Nov 2002
 | 
|---|
| 2 |  ;;22.0;VA FileMan;**6,76,114**;Mar 30, 1999
 | 
|---|
| 3 |  ;Per VHA Directive 10-93-142, this routine should not be modified.
 | 
|---|
| 4 | M ;
 | 
|---|
| 5 |  I '$D(J(0)) K X Q
 | 
|---|
| 6 |  S DIC("S")="I $P(^(0),U,2),$P(^DD(+$P(^(0),U,2),.01,0),U,2)'[""W"""
 | 
|---|
| 7 | MM S DICN=X,T=DLV S:X?1"#".NP X=$E(X,2,99)
 | 
|---|
| 8 | TRY S DIC="^DD("_J(T)_",",DG=$O(^DD(J(T),0,"NM",0))_" " D DICS^DICOMPY,^DIC G R:Y<0
 | 
|---|
| 9 |  F D=M:1:$L(I)+1 Q:$F(X,$E(I,1,D))-1-D  S W=$E(I,D+1)
 | 
|---|
| 10 |  I DICOMP["?",$P(Y,U,2)'=DICN W !?3,"By '"_DICN_"', do you mean the '"_$P(Y,U,2)_"' Subfield" S %=1 D YN^DICN I %-1 G R:%+1 K X Q
 | 
|---|
| 11 |  S M=D,Y=+$P(Y(0),U,2),X=$P($P(Y(0),U,4),";") I +X'=X S X=""""_X_""""
 | 
|---|
| 12 |  S (DLV,D)=DLV0+100 F %=T\100*100:1 Q:%>T  S J(DLV)=J(%),I(DLV)=I(%),DLV=DLV+1
 | 
|---|
| 13 |  S I(DLV)=X,X=I(D),J(DLV)=Y D QQ,REF S DLV0=DLV0+100 F DLV=D:1:DLV D SN
 | 
|---|
| 14 |  Q
 | 
|---|
| 15 |  ;
 | 
|---|
| 16 | REF F Y=D+1:1:DLV S V=Y#100-1,DICN=I(Y) S:DICN["""" DICN=""""_DICN_"""" S X=X_$S(T<DLV0:"I("_(T\100*100+V)_",0)",1:"D"_V)_","_DICN_","
 | 
|---|
| 17 | Q Q
 | 
|---|
| 18 |  ;
 | 
|---|
| 19 | R I X]"",$P(X,DG,1)="",X=DICN S X=$P(X,DG,2,9) G TRY
 | 
|---|
| 20 |  S T=T-1 I T'<0 G TRY:$D(J(T)) F T=T-99:1 G TRY:'$D(J(T+1))
 | 
|---|
| 21 | FILEQ S X=DICN,DIC=1 D DRW,^DIC I Y<0 K X Q
 | 
|---|
| 22 |  S X=^(0,"GL") D QQ
 | 
|---|
| 23 | Y ;
 | 
|---|
| 24 |  S DLV0=DLV0+100,I(DLV0)=^DIC(+Y,0,"GL"),J(DLV0)=+Y F DLV=DLV+100:-1:DLV0 D SN
 | 
|---|
| 25 |  Q
 | 
|---|
| 26 |  ;
 | 
|---|
| 27 | SN D SV(DLV0-100) S DG(DLV0)=DLV Q
 | 
|---|
| 28 |  ;
 | 
|---|
| 29 | SV(%X) ;also called from DICOMPY
 | 
|---|
| 30 |  S (T,DG(%X))=DG(%X)+1,%=DLV#100,K(K+2,1)=DLV0,DG(%X,T)=%,M(%,%X+%)=T Q
 | 
|---|
| 31 |  ;
 | 
|---|
| 32 | QQ F %=0:0 S %=$F(X,"""",%) G Q:%<1 S X=$E(X,1,%-1)_$E(X,%-1,999),%=%+1
 | 
|---|
| 33 |  ;
 | 
|---|
| 34 | OKFILE(Y,DICOMP) ;Called from DIR
 | 
|---|
| 35 |  ;DICOMP either does or doesn't contain "W"
 | 
|---|
| 36 |  N D,DIC,DIAC,DIFILE,%
 | 
|---|
| 37 |  D DRW I $D(^DIC(Y,0)) X DIC("S")
 | 
|---|
| 38 |  Q $T
 | 
|---|
| 39 |  ;
 | 
|---|
| 40 | DRW ;also called from DICOMPV, and DICOMPW to filter FILE names
 | 
|---|
| 41 |  S D=$S(DICOMP["W":"""WR""",1:"""RD""")
 | 
|---|
| 42 |  S DIC("S")="S DIAC="_D_",DIFILE=+Y D ^DIAC I %"
 | 
|---|
| 43 |  Q
 | 
|---|
| 44 |  ;
 | 
|---|
| 45 | P ;
 | 
|---|
| 46 |  S X=" S D0="_X_" S:'D0!'$D("_%Y_"+D0,0)) D0=-1"
 | 
|---|
| 47 |  I $D(DICOMPX(0)) S X=X_" S "_DICOMPX(0)_"0)=D0",DICOMPX(0,DICN)=""
 | 
|---|
| 48 |  D ST
 | 
|---|
| 49 |  I W=":" D
 | 
|---|
| 50 |  .S M=M+1,W="",%=$E(I,M,999) I %,+%=$P(%,")") S I=$E(I,1,M-1)_"#"_%
 | 
|---|
| 51 |  E  S I="#.01"_$E(I,M,999),M=1,W=""
 | 
|---|
| 52 |  S DLV0=DLV0+100,I(DLV0)=%Y,J(DLV0)=DICN F DLV=DLV+100:-1:DLV0 D SN
 | 
|---|
| 53 |  Q
 | 
|---|
| 54 |  ;
 | 
|---|
| 55 | ST N X D ST^DICOMP S DPS(DPS,"ST")=1,K=K+1,K(K)=X
 | 
|---|
| 56 |  Q
 | 
|---|