IBDEINI1 ; ; 01-AUG-2022
 ;;3.0;IB ENCOUNTER FORM IMP/EXP;;AUG 01, 2022
 ; LOADS AND INDEXES DD'S
 ;
 K DIF,DIK,D,DDF,DDT,DTO,D0,DLAYGO,DIC,DIDUZ,DIR,DA,DFR,DTN,DIX,DZ D DT^DICRW S %=1,U="^",DSEC=1
 S NO=$P("I 0^I $D(@X)#2,X[U",U,%) I %<1 K DIFQ Q
ASK I %=1,$D(DIFQ(0)) W !,"SHALL I WRITE OVER FILE SECURITY CODES" S %=2 D YN^DICN S DSEC=%=1 I %<1 K DIFQ Q
 Q:'$D(DIFQ)  S %=2 W !!,"ARE YOU SURE EVERYTHING'S OK" D YN^DICN I %-1 K DIFQ Q
 D ^IBDE2 D NOW^%DTC S DIFROM("INI")=%
 I $D(DIFKEP) F DIDIU=0:0 S DIDIU=$O(DIFKEP(DIDIU)) Q:DIDIU'>0  S DIU=DIDIU,DIU(0)=DIFKEP(DIDIU) D EN^DIU2
 D DT^DICRW K ^UTILITY(U,$J),^UTILITY("DIK",$J) D WAIT^DICD
 S DN="^IBDEI" F R=1:1:432 D @(DN_$$B36(R)) W "."
 F  S D=$O(^UTILITY(U,$J,"SBF","")) Q:D'>0  K:'DIFQ(D) ^(D) S D=$O(^(D,"")) I D>0  K ^(D) D IX
KEYSNIX ; Keys and new style indexes installer ; new in FM V22.2
 N DIFRSA S DIFRSA=$NA(^UTILITY("KX",$J)) ; Tran global for Keys and Indexes
 N DIFRFILE S DIFRFILE=0 ; Loop through files
 F  S DIFRFILE=$O(@DIFRSA@("IX",DIFRFILE)) Q:'DIFRFILE  D
 . K ^TMP("DIFROMS2",$J,"TRIG")
 . N DIFRD S DIFRD=0
 . F  S DIFRD=$O(@DIFRSA@("IX",DIFRFILE,DIFRD)) Q:'DIFRD  D DDIXIN^DIFROMSX(DIFRFILE,DIFRD,DIFRSA) ; install New Style Indexes
 . K ^TMP("DIFROMS2",$J,"TRIG")
 . S DIFRD=0
 . F  S DIFRD=$O(@DIFRSA@("KEY",DIFRFILE,DIFRD)) Q:'DIFRD  D DDKEYIN^DIFROMSY(DIFRFILE,DIFRD,DIFRSA) ; install keys
 K @DIFRSA ; kill off tran global
 ; VEN/SMH v22.2: Below I added a K D1 because it leaks from the call causing the key matching algo to fail.
DATA W "." S (D,DDF(1),DDT(0))=$O(^UTILITY(U,$J,0)) Q:D'>0
 I DIFQR(D) S DTO=0,DMRG=1,DTO(0)=^(D),Z=^(D)_"0)",D0=^(D,0),@Z=D0,DFR(1)="^UTILITY(U,$J,DDF(1),D0,",DKP=DIFQR(D)'=2 F D0=0:0 S D0=$O(^UTILITY(U,$J,DDF(1),D0)) S:D0="" D0=-1 K D1 Q:'$D(^(D0,0))  S Z=^(0) D I^DITR
 K ^UTILITY(U,$J,DDF(1)),DDF,DDT,DTO,DFR,DFN,DTN G DATA
 ;
W S Y=$P($T(@X),";",2) W !,"NOTE: This package also contains "_Y_"S",! Q:'$D(DIFQ(0))
 S %=1 W ?6,"SHALL I WRITE OVER EXISTING "_Y_"S OF THE SAME NAME" D YN^DICN I '% W !?6,"Answer YES to replace the current "_Y_"S with the incoming ones." G W
 S:%=2 DIFQ(X)=0 K:%<0 DIFQ
 Q
 ;
OPT ;OPTION
RTN ;ROUTINE DOCUMENTATION NOTE
FUN ;FUNCTION
BUL ;BULLETIN
KEY ;SECURITY KEY
HEL ;HELP FRAME
DIP ;PRINT TEMPLATE
DIE ;INPUT TEMPLATE
DIB ;SORT TEMPLATE
DIS ;FORM
REM ;REMOTE PROCEDURE
 ;
SBF ;FILE AND SUB FILE NUMBERS
IX W "." S DIK="A" F %=0:0 S DIK=$O(^DD(D,DIK)) Q:DIK=""  K ^(DIK)
 S DA(1)=D,DIK="^DD("_D_"," D IXALL^DIK
 I $D(^DIC(D,"%",0)) S DIK="^DIC(D,""%""," G IXALL^DIK
 Q
B36(X) Q $$N(X\(36*36)#36+1)_$$N(X\36#36+1)_$$N(X#36+1)
N(%) Q $E("0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ",%)
 
--- Routine Detail   --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HIBDEINI1   2685     printed  Sep 23, 2025@20:26:30                                                                                                                                                                                                    Page 2
IBDEINI1  ; ; 01-AUG-2022
 +1       ;;3.0;IB ENCOUNTER FORM IMP/EXP;;AUG 01, 2022
 +2       ; LOADS AND INDEXES DD'S
 +3       ;
 +4        KILL DIF,DIK,D,DDF,DDT,DTO,D0,DLAYGO,DIC,DIDUZ,DIR,DA,DFR,DTN,DIX,DZ
           DO DT^DICRW
           SET %=1
           SET U="^"
           SET DSEC=1
 +5        SET NO=$PIECE("I 0^I $D(@X)#2,X[U",U,%)
           IF %<1
               KILL DIFQ
               QUIT 
ASK        IF %=1
               IF $DATA(DIFQ(0))
                   WRITE !,"SHALL I WRITE OVER FILE SECURITY CODES"
                   SET %=2
                   DO YN^DICN
                   SET DSEC=%=1
                   IF %<1
                       KILL DIFQ
                       QUIT 
 +1        if '$DATA(DIFQ)
               QUIT 
           SET %=2
           WRITE !!,"ARE YOU SURE EVERYTHING'S OK"
           DO YN^DICN
           IF %-1
               KILL DIFQ
               QUIT 
 +2        DO ^IBDE2
           DO NOW^%DTC
           SET DIFROM("INI")=%
 +3        IF $DATA(DIFKEP)
               FOR DIDIU=0:0
                   SET DIDIU=$ORDER(DIFKEP(DIDIU))
                   if DIDIU'>0
                       QUIT 
                   SET DIU=DIDIU
                   SET DIU(0)=DIFKEP(DIDIU)
                   DO EN^DIU2
 +4        DO DT^DICRW
           KILL ^UTILITY(U,$JOB),^UTILITY("DIK",$JOB)
           DO WAIT^DICD
 +5        SET DN="^IBDEI"
           FOR R=1:1:432
               DO @(DN_$$B36(R))
               WRITE "."
 +6        FOR 
               SET D=$ORDER(^UTILITY(U,$JOB,"SBF",""))
               if D'>0
                   QUIT 
               if 'DIFQ(D)
                   KILL ^(D)
               SET D=$ORDER(^(D,""))
               IF D>0
                   KILL ^(D)
                   DO IX
KEYSNIX   ; Keys and new style indexes installer ; new in FM V22.2
 +1       ; Tran global for Keys and Indexes
           NEW DIFRSA
           SET DIFRSA=$NAME(^UTILITY("KX",$JOB))
 +2       ; Loop through files
           NEW DIFRFILE
           SET DIFRFILE=0
 +3        FOR 
               SET DIFRFILE=$ORDER(@DIFRSA@("IX",DIFRFILE))
               if 'DIFRFILE
                   QUIT 
               Begin DoDot:1
 +4                KILL ^TMP("DIFROMS2",$JOB,"TRIG")
 +5                NEW DIFRD
                   SET DIFRD=0
 +6       ; install New Style Indexes
                   FOR 
                       SET DIFRD=$ORDER(@DIFRSA@("IX",DIFRFILE,DIFRD))
                       if 'DIFRD
                           QUIT 
                       DO DDIXIN^DIFROMSX(DIFRFILE,DIFRD,DIFRSA)
 +7                KILL ^TMP("DIFROMS2",$JOB,"TRIG")
 +8                SET DIFRD=0
 +9       ; install keys
                   FOR 
                       SET DIFRD=$ORDER(@DIFRSA@("KEY",DIFRFILE,DIFRD))
                       if 'DIFRD
                           QUIT 
                       DO DDKEYIN^DIFROMSY(DIFRFILE,DIFRD,DIFRSA)
               End DoDot:1
 +10      ; kill off tran global
           KILL @DIFRSA
 +11      ; VEN/SMH v22.2: Below I added a K D1 because it leaks from the call causing the key matching algo to fail.
DATA       WRITE "."
           SET (D,DDF(1),DDT(0))=$ORDER(^UTILITY(U,$JOB,0))
           if D'>0
               QUIT 
 +1        IF DIFQR(D)
               SET DTO=0
               SET DMRG=1
               SET DTO(0)=^(D)
               SET Z=^(D)_"0)"
               SET D0=^(D,0)
               SET @Z=D0
               SET DFR(1)="^UTILITY(U,$J,DDF(1),D0,"
               SET DKP=DIFQR(D)'=2
               FOR D0=0:0
                   SET D0=$ORDER(^UTILITY(U,$JOB,DDF(1),D0))
                   if D0=""
                       SET D0=-1
                   KILL D1
                   if '$DATA(^(D0,0))
                       QUIT 
                   SET Z=^(0)
                   DO I^DITR
 +2        KILL ^UTILITY(U,$JOB,DDF(1)),DDF,DDT,DTO,DFR,DFN,DTN
           GOTO DATA
 +3       ;
W          SET Y=$PIECE($TEXT(@X),";",2)
           WRITE !,"NOTE: This package also contains "_Y_"S",!
           if '$DATA(DIFQ(0))
               QUIT 
 +1        SET %=1
           WRITE ?6,"SHALL I WRITE OVER EXISTING "_Y_"S OF THE SAME NAME"
           DO YN^DICN
           IF '%
               WRITE !?6,"Answer YES to replace the current "_Y_"S with the incoming ones."
               GOTO W
 +2        if %=2
               SET DIFQ(X)=0
           if %<0
               KILL DIFQ
 +3        QUIT 
 +4       ;
OPT       ;OPTION
RTN       ;ROUTINE DOCUMENTATION NOTE
FUN       ;FUNCTION
BUL       ;BULLETIN
KEY       ;SECURITY KEY
HEL       ;HELP FRAME
DIP       ;PRINT TEMPLATE
DIE       ;INPUT TEMPLATE
DIB       ;SORT TEMPLATE
DIS       ;FORM
REM       ;REMOTE PROCEDURE
 +1       ;
SBF       ;FILE AND SUB FILE NUMBERS
IX         WRITE "."
           SET DIK="A"
           FOR %=0:0
               SET DIK=$ORDER(^DD(D,DIK))
               if DIK=""
                   QUIT 
               KILL ^(DIK)
 +1        SET DA(1)=D
           SET DIK="^DD("_D_","
           DO IXALL^DIK
 +2        IF $DATA(^DIC(D,"%",0))
               SET DIK="^DIC(D,""%"","
               GOTO IXALL^DIK
 +3        QUIT 
B36(X)     QUIT $$N(X\(36*36)#36+1)_$$N(X\36#36+1)_$$N(X#36+1)
N(%)       QUIT $EXTRACT("0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ",%)