VistA-FOIAVistA/r/VA_FILEMAN-ARJT-DI-DD-DM-DT.../DIFROMS5.m

88 lines
3.0 KiB
Mathematica

DIFROMS5 ;SCISC/DCL-DIFROM SERVER PROCESS TEMPLATES OUT ;1:40 PM 4 Sep 1998
;;22.0;VA FileMan;;Mar 30, 1999
;Per VHA Directive 10-93-142, this routine should not be modified.
Q
;
EDEOUT ;EXTENDED DATABASE ELEMENTS OUT
N DIFRDSV,DIFRF,DIFRGBL,DIFRSEC,DIFRTRT
I $G(DIFRIEN)>0 G EDE
N DIFRIENX,DIFRIENZ
S DIFRIENX=$O(@DIFRLST@(0)),DIFRIENZ=$D(@DIFRLST@(DIFRIENX,0))#2,DIFRIENX=0
F S DIFRIENX=$O(@DIFRLST@(DIFRIENX)) Q:DIFRIENX'>0 D
.I DIFRIENZ S DIFRIEN=+@DIFRLST@(DIFRIENX,0) S:DIFRIEN'>0 DIFRIEN=DIFRIENX D EDE Q
.S DIFRIEN=+@DIFRLST@(DIFRIENX) S:DIFRIEN'>0 DIFRIEN=DIFRIENX D EDE Q
Q
EDE ;
; DIFRTRT=FULL ROOT IN DIST ARRAY
; DIFRDSV=0TH NODE OF TEMPLATE
; :.401, .4, .402
; :TEMPL NAME^DATE CREATED^READ^FILENR^DUZ^WRITE^DATE LAST USED
; :.403
; :FORM NAME^READ^WRITE^DUZ^DATE CREATED^DATA LAST USED^^FILE^
; :.84
; :DIALOG NUMBER^TYPE^INTERNAL PARM^PACKAGE FILE (pointer)
; DIFRSEC=FILE SECURITY 1=EXPORT SECURITY,0=NO FILE SECURITY
; DIFRIEN=TEMPLATE'S INTERNAL ENTRY NUMBER
; :.5 (FUNCTIONS)
S DIFRTRT=$NA(@DIFRTA@(DIFRFILE,DIFRIEN))
S DIFRGBL=$$ROOT^DILFD(DIFRFILE,"",1)
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
;
; For stand alone FileMan only - KIDS will do the Merge
; v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v v
;
I $G(DIFRSTNA) S DIFRGBL=$$ROOT^DILFD(DIFRFILE,"",1) M @DIFRTRT=@DIFRGBL@(DIFRIEN)
;
; ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^
; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
I DIFRFILE=.5 Q ;no processing necessary
S DIFRDSV=$G(@DIFRTRT@(0)),DIFRF=$P(DIFRDSV,U,$S(DIFRFILE=.403:8,1:4))
I DIFRDSV="" D Q
.N DIFRERR S DIFRERR(1)=DIFRFNAM,DIFRERR(2)=DIFRIEN
.D BLD^DIALOG(9516,.DIFRERR)
.Q
I DIFRFILE=.84 G DIALOG
S DIFRSEC=DIFRFLG'["S"
I DIFRFILE=.403 G T403
Q:'$D(@DIFRTRT@(0)) K ^("RD"),^("AB") K:DIFRFILE=.401 ^(1)
S $P(@DIFRTRT@(0),U,5)="" S:'DIFRSEC ^(0)=$P(DIFRDSV,U,1,2)_U_U_DIFRF_U_U_U_U_$P(DIFRDSV,U,8,9)
Q
;
T403 ;PROCESS FORMS AND EACH BLOCK IT CONTAINES
S $P(DIFRDSV,U,4)="",$P(DIFRDSV,U,6)="" S:'DIFRSEC $P(DIFRDSV,U,2,3)=U
S @DIFRTRT@(0)=DIFRDSV
D T404
K @DIFRTRT@("AY"),@DIFRTRT@(40,"B"),^("C")
N X
S X=0
F S X=$O(@DIFRTRT@(40,X)) Q:X'>0 K @DIFRTRT@(40,X,40,"AC"),^("B")
Q
;
T404 ;PROCESS BLOCKS
; :.404
; :BLOCK NAME^
N DIFR1,DIFR2,D1,D2
S D1=0
F S D1=$O(@DIFRTRT@(40,D1)) Q:'D1 I $D(^(D1,0)) S DIFR1=+$P(^(0),U,2) D
.I $D(^DIST(.404,DIFR1,0)) D
..S $P(@DIFRTRT@(40,D1,0),U,2)=$P(^DIST(.404,DIFR1,0),U)
..M @DIFRTA@(.404,DIFR1)=^DIST(.404,DIFR1)
..K @DIFRTA@(.404,DIFR1,40,"B"),^("C"),^("D")
..Q
.S D2=0
.F S D2=$O(@DIFRTRT@(40,D1,40,D2)) Q:'D2 I $D(^(D2,0)) S DIFR2=+^(0) D
..I $D(^DIST(.404,DIFR2)) D
...S $P(@DIFRTRT@(40,D1,40,D2,0),U)=$P(^DIST(.404,DIFR2,0),U)
...M @DIFRTA@(.404,DIFR2)=^DIST(.404,DIFR2)
...K @DIFRTA@(.404,DIFR2,40,"B"),^("C"),^("D")
...Q
..Q
.Q
Q
;
DIALOG ;
Q:'$D(@DIFRTRT@(0)) K ^(4),^(3,"B")
Q:$G(DIFRF)'>0
S:DIFRF DIFRF=$P($G(^DIC(9.4,DIFRF,0)),"^"),$P(@DIFRTRT@(0),"^",4)=DIFRF
Q