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

DIE0.m

Go to the documentation of this file.
  1. DIE0 ;SFISC/GFT-BRANCHING, UP-ARROWING ;27MAR2006
  1. ;;22.0;VA FileMan;**60,159**;Mar 30, 1999;Build 8
  1. ;Per VHA Directive 2004-038, this routine should not be modified.
  1. G Q^DIE1:$D(DTOUT) G:X'?1"^".E T^DIED:$P($P(DQ(DQ),U,4),";E",2),X
  1. I $D(DIE("NO^")),X=U,DIE("NO^")'["OUTOK" W !?3,"EXIT NOT ALLOWED " G X
  1. I $D(DIE("NO^")),X?1"^"1E.E,DIE("NO^")'["BACK" W !?3,"JUMPING NOT ALLOWED " G X
  1. I $L(X,"^")-1>1 S X=$E(X,2,99) G DIE0
  1. S X=$P(X,U,2),DIC(0)="E"
  1. OUT I X=""!(DP<0) S DIK=X,DC=$S($D(DQ(DQ))#2:$P(DQ(DQ),U,4),1:DQ) G OUT^DIE1
  1. I DR]"" G A:X?1"@".N S DIC("S")="D S^DIE0" S:'$D(DR(DIE1,DP)) DR(DIE1,DP)=DR
  1. S DDBK=0,DIC="^DD("_DP_"," D ^DIC I Y>0 D S
  1. E W:DDBK !?3,"JUMPING FORWARD NOT ALLOWED "
  1. K DTOUT,DIC,DDBK,DDFND,DDONE,A0,A1,A2
  1. I Y<0 S DG=DK,DH=":"_DM G X
  1. S DI=$S(DH[":":+Y,1:DH),DK=DG D ^DIE1:$D(DG)>9 K DG,DB,DE,DQ,DIFLD S DQ=0 G JMP^DIE
  1. X W:X'["?"&'$D(ZTQUEUED) $C(7),"??" G B^DIED:'$D(DB(DQ)),B^DIE1
  1. ;
  1. BR ;From ^DIED
  1. S Y=U,X=$G(X) X DQ(0,DQ) D:$D(DIEFIRE)#2 FIREREC^DIE1 G A^DIED:$D(Y)[0,A^DIED:Y=U S D=$S(+Y=Y:9999,1:DQ),X="" I 0[Y S DQ=0 G OUT
  1. D S D=D+1 I '$D(DQ(D)) G D:$D(DQ(0,D)) S DQ=9999,X=Y,DIC(0)="FO" G OUT
  1. G D:$P(DQ(D),Y,1)]"" S DQ=D G RE^DIED
  1. ;
  1. O ;From ^DIE
  1. K DQ S (DI,DV,DM)=0 I X]"",$D(@(U_$P(DC,U,3)_X_",0)"))#2 D S^DIE1,DIEC
  1. S DQ=0 G MORE^DIE
  1. ;
  1. DIEC S DIE=U_$P(DC,U,3),DIEC(DL)=DA F %=1:1 Q:'$D(DA(%)) S DIEC(DL,%)=DA(%)
  1. K DA,DB,DE,DG F %=0:1:DIEL-1 S DA="D"_%,DIEC(DL,0,%)=@DA K @DA
  1. S:$D(DIETMP)#2 DIEC(DL,"IENS")=DIIENS,DIIENS=X_","
  1. S DIEL=0,(D0,DA)=X Q
  1. ;
  1. DIEZ ;
  1. I X="" G @("A"_U_DNM)
  1. S D=0,DL=DL+1,DNM(DL)=DNM,DNM(DL,0)=DQ,DIEL=DIEL+1 D DIEC G @DGO
  1. ;
  1. A I $D(DR(DIE1,DP))>9 D OA ;Branching to "@N"
  1. E F DG=1:1 S DH=$P(DR(DIE1,DP),";",DG) G X:DH="" I DH=X S:$D(DOV) DOV=0 S DR=DR(DIE1,DP) Q
  1. S DK=DG,DI=X D ^DIE1 G JMP^DIE
  1. OA S %=0 F S %=$O(DR(DIE1,DP,%)) Q:%="" F DG=1:1 S DH=$P(DR(DIE1,DP,%),";",DG) Q:DH="" I DH=X S DR=DR(DIE1,DP,%),DOV=%,%=9999 Q
  1. S %=-1 Q
  1. ;
  1. E ;UNEDITABLE & DINUM fields
  1. I X="@" Q:DV'["I" G NO
  1. Q:X[U!(X?."?")!DV!$D(DITC)
  1. NO W:'$D(DB(DQ)) $C(7)," NO EDITING!!" K X
  1. Q Q
  1. ;
  1. ;
  1. ;
  1. S ;SCREEN fields; out= $T
  1. N DDR S (%,DDFND)=0,DDR=DR(DIE1,DP),DDBK=0,Y=+Y
  1. I $D(DIE("NO^")),DIE("NO^")["BACK" S DDBK=1
  1. D S1 I DDFND Q
  1. I 'DDONE,$D(DR(DL,DP))>9 F %=-1:0 S %=$O(DR(DIE1,DP,%)) Q:%="" S DDR=DR(DIE1,DP,%) D S1 Q:DDONE!DDFND
  1. Q
  1. S1 ;selectable?
  1. S DDONE=0 F DG=1:1 D S2 Q:DDFND!DDONE!(DH="")
  1. I DDFND S DOV=%,DR=$G(DR(DIE1,DP,%),$G(DR(DIE1,DP)))
  1. Q
  1. S2 ;parse for ;-piece
  1. S DH=$P(DDR,";",DG) Q:(DH["///"&(DIC(0)'["F"))!'DH
  1. ;list
  1. I 'DDBK,+DH=Y S DDFND=1 Q
  1. I DDBK,+DH=DIFLD,+DH'=Y S DDONE=1 Q
  1. I DDBK,+DH=Y S DDFND=1 Q
  1. Q:$P(DH,"//")'[":"
  1. ;range
  1. S A0=+$P(DH,":",1),A1=+$P(DH,":",2)
  1. I 'DDBK,Y'<A0,Y'>A1 S DDFND=1 Q
  1. F A2=A0-.000001:0 S A2=$O(^DD(DP,A2)) Q:A2>A1!'A2 S:A2=DIFLD&(A2'=Y)&DDBK DDONE=1 Q:DDONE I A2=Y,(A2'>DIFLD) S DDFND=1 Q
  1. Q