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 Dec 13, 2024@02:50:27 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",%)