35 lines
1.6 KiB
Mathematica
35 lines
1.6 KiB
Mathematica
DIT0 ;SFISC/XAK-PREPARE TO XFR ;09:21 AM Jul 19, 1988
|
|
;;22.0;VA FileMan;;Mar 30, 1999
|
|
;Per VHA Directive 10-93-142, this routine should not be modified.
|
|
K Y,DIC S DIT=DDF(1),DIC=L,DIC(0)="EQLAM",X="DATA INTO WHICH " D LK
|
|
G Q:Y<0 S DFR=+Y,DTO(1)=DIC_+Y_",",DIC(0)="EQAM",X="FROM ",DIC("S")="I Y-"_+Y D LK G Q:Y<0
|
|
S S %=2 W !," WANT TO DELETE THIS ENTRY AFTER IT'S TRANSFERRED" D YN^DICN G Q:%<0 S DH=2-% I '% D F^DIT G S
|
|
S ^UTILITY("DIT",$J,+Y)=DFR_";"_$E(DIC,2,999)
|
|
S DTO=0,(D0,DA)=+Y,DIK=DIC,DFR(1)=DIC_DA_"," K DIC D WAIT^DICD
|
|
GO D GO^DITR
|
|
S DIT=DH D KL^DIT,^DIK:DH S DA=DFR K DFR D IX1^DIK
|
|
S DH=DIT D ASK^DITP,PTS^DITP:%=1
|
|
Q G Q^DIT
|
|
;
|
|
LK S DIC("A")="TRANSFER "_X_DFL G ^DIC
|
|
;
|
|
EN ; PROGRAMMER CALL
|
|
; DIT("F") = GLOBAL ROOT OR FILE # OF FILE TO TRANSFER FROM
|
|
; DIT("T") = GLOBAL ROOT OR FILE # OF FILE TO TRANSFER TO
|
|
; DA("F") = ENTRY # IN FILE TO TRANSFER FROM
|
|
; DA("T") = ENTRY # IN FILE TO TRANSFER TO
|
|
;
|
|
I '$D(DIT("F"))!'$D(DIT("T"))!'$D(DA("F"))!'$D(DA("T")) G FIN
|
|
S DDF(1)=DIT("F"),DDT(0)=DIT("T")
|
|
I 'DDF(1) S DDF(1)=$S($D(@(DDF(1)_"0)"))#2:+$P(^(0),U,2),1:0) G FIN:'DDF(1) S DFR(1)=DIT("F")
|
|
I 'DDT(0) S DDT(0)=$S($D(@(DDT(0)_"0)"))#2:+$P(^(0),U,2),1:0) G FIN:'DDT(0) S DTO(1)=DIT("T") G C
|
|
G FIN:'$D(^DIC(+DDF(1),0,"GL")) S DFR(1)=^("GL")
|
|
G FIN:'$D(^DIC(+DDT(0),0,"GL")) S DTO(1)=^("GL")
|
|
C S DB=DA("F"),(DB1,DFR)=DA("T"),DIK=DTO(1)
|
|
I $D(DA(1)) F I=1:1 G:'$D(DA(I)) SET S DRF(I)=$P(DA(I),",",1)_",1,",DOT(I)=$P(DA(I),",",2)_",1,"
|
|
DON K DRF,DOT S DFR(1)=DFR(1)_DB_",",DTO(1)=DTO(1)_DB1_",",DKP=1,DMRG=1,DTO=0,DH=0 G GO
|
|
SET F I=I-1:-1 G:I'>0 DON S DFR(1)=DFR(1)_DRF(I),DTO(1)=DTO(1)_DOT(I)
|
|
FIN ;
|
|
K DDF,DFR,DDT,DTO
|
|
Q
|