1 | DIFROMSR ;SFISC/DCL,TKW-RESOLVE POINTERS ON TARGET SYSTEM ;5/14/98 12:29
|
---|
2 | ;;22.0;VA FileMan;;Mar 30, 1999
|
---|
3 | ;Per VHA Directive 10-93-142, this routine should not be modified.
|
---|
4 | Q
|
---|
5 | RP(DIFRFLG,DIFRFIA,DIFRSA,DIFRMSGR) ; Resolve Pointers on Target System
|
---|
6 | ;The "FRV1" and "FRVL" structures within the
|
---|
7 | ;transport array are used.
|
---|
8 | ;FILE,FLAGS,FIAROOT,SOURCE_ARRAY,MSG_ROOT
|
---|
9 | ;*
|
---|
10 | ;FLAGS=(RESERVED FOR LATER USE)
|
---|
11 | ; (Optional)
|
---|
12 | ; None
|
---|
13 | ;*
|
---|
14 | ;FIA_ARRAY="FIA"_ARRAY_INPUT_ARRAY_ROOT
|
---|
15 | ; (Optional) - Close Input Array Reference
|
---|
16 | ; See DIFROM SERVER documentation for FIA array structure
|
---|
17 | ; definitions. If undefined SOURCE_ARRAY will be used
|
---|
18 | ; by appending "FIA" to the source array root subscript.
|
---|
19 | ;*
|
---|
20 | ;SOURCE_ARRAY=CLOSED_INPUT_ARRAY_ROOT
|
---|
21 | ; (Required) - Closed Input Array Reference where the file data
|
---|
22 | ; is temporarily stored for distribution.
|
---|
23 | ;*
|
---|
24 | ;MSG_ROOT=CLOSED ARRAY REFERENCE
|
---|
25 | ; (Optional) - Closed array reference where messages such as
|
---|
26 | ; errors will be returned. If not passed, decendents of ^TMP
|
---|
27 | ; will be used.
|
---|
28 | ;*
|
---|
29 | I '$D(DIQUIET) N DIQUIET S DIQUIET=1
|
---|
30 | I '$D(DIFM) N DIFM S DIFM=1
|
---|
31 | I $G(U)'="^"!($G(DT)'>0)!($G(DTIME)'>0)!('$D(DUZ)) D DT^DICRW
|
---|
32 | I $G(DIFRSA)']"" D ERR(6) G EXIT
|
---|
33 | S DIFRFIA=$G(DIFRFIA) S:DIFRFIA="" DIFRFIA=$NA(@DIFRSA@("FIA"))
|
---|
34 | ;
|
---|
35 | I '$D(DIFRFIA) D ERR(2) G EXIT
|
---|
36 | N DIFRFRVX,DIFRFILE
|
---|
37 | S DIFRFRVX="FRV1",DIFRFILE=0 F S DIFRFILE=$O(@DIFRSA@(DIFRFRVX,DIFRFILE)) Q:DIFRFILE'>0 D FILE
|
---|
38 | G EXIT
|
---|
39 | ;
|
---|
40 | FILE N DIFRTART,DIFRDNSC,DIFRPCE,DIFRSDA,DIFRY,DIFRPRV,DIFRPTF,DIFRPTFR,DIFRPRVL,DIFR2DD,DIFRTARL
|
---|
41 | N C,D0,DA,DIC,DIK,F,G,I,R1,R2,R3,X,Y
|
---|
42 | S DIFRTART=$NA(@DIFRSA@(DIFRFRVX,DIFRFILE))
|
---|
43 | S DIFRTARL=$NA(@DIFRSA@("FRVL",DIFRFILE))
|
---|
44 | S DIFRSDA=$$OREF^DILF($NA(@DIFRSA@("DATA",DIFRFILE))),DIFRDNSC=""
|
---|
45 | F S DIFRDNSC=$O(@DIFRTART@(DIFRDNSC)) Q:DIFRDNSC="" D
|
---|
46 | .K R1
|
---|
47 | .S R2=DIFRDNSC,C=$P(R2,","),F=1,R1=0
|
---|
48 | .F I=1:1 Q:I>C S G=$P(R2,",",F,I) Q:G="" I G'[""""!($L(G,"""")#2&($E(G)="""")&($E(G,$L(G))="""")) S F=F+$L(G,","),I=F-1,R1(R1)=G,R1=R1+1,C=C+($L(G,",")-1)
|
---|
49 | .I R1'>3 S DIFR2DD=DIFRFILE
|
---|
50 | .E D
|
---|
51 | ..S R3=""
|
---|
52 | ..F I=0:1:R1-3 S R3=R3_R1(I)_","
|
---|
53 | ..S DIFR2DD=+$P($G(@(DIFRSDA_R3_"0)")),"^",2)
|
---|
54 | ..Q
|
---|
55 | .;
|
---|
56 | .S DIFRPCE=""
|
---|
57 | .F S DIFRPCE=$O(@DIFRTART@(DIFRDNSC,DIFRPCE)) Q:DIFRPCE'>0 D
|
---|
58 | ..S DIFRPRV=$G(@DIFRTART@(DIFRDNSC,DIFRPCE)),DIFRPTF=$G(^(DIFRPCE,"F"))
|
---|
59 | ..S DIFRPRVL=$G(@DIFRTARL@(DIFRDNSC)),DIFRPTFR=$P(DIFRPTF,";",2)
|
---|
60 | ..I DIFRPRVL="" D ERR(7," (^"_DIFRPTFR_"/"_DIFRPRV_")") Q
|
---|
61 | ..I DIFRPTFR="" D ERR(8," ("_DIFRPRVL_"/"_DIFRPRV_")") Q
|
---|
62 | ..I DIFRPRV="" D ERR(9," (^"_DIFRPTFR_"/"_DIFRPRVL_")") Q
|
---|
63 | ..I '$D(@("^"_DIFRPTFR_"0)")) D ERR(10," (^"_DIFRPTFR_"/"_DIFRPRV_")") Q
|
---|
64 | ..D LOOKUP
|
---|
65 | ..I +Y'>0 D ERR(11," ("_DIC_" Entry:"_DIFRPRV_")") S Y=-1
|
---|
66 | ..S DIFRY=+Y S:DIFRPTF DIFRY=+Y_";"_DIFRPTFR
|
---|
67 | ..S $P(@DIFRPRVL,"^",DIFRPCE)=DIFRY
|
---|
68 | ..Q
|
---|
69 | ;
|
---|
70 | S DIK=@DIFRFIA@(DIFRFILE,0),DIK(0)="AB"
|
---|
71 | D IXALL^DIK:$O(@(DIK_"0)"))
|
---|
72 | ;
|
---|
73 | Q
|
---|
74 | ;
|
---|
75 | LOOKUP ; Lookup entry on pointed-to file
|
---|
76 | N DIFRS S DIFRS=$NA(@DIFRSA@("FRV1K",DIFRFILE,DIFRDNSC,DIFRPCE))
|
---|
77 | S DIC="^"_DIFRPTFR
|
---|
78 | I '$O(@DIFRS@(0)) S DIC(0)="X",X=DIFRPRV D ^DIC Q
|
---|
79 | N DIFL,DIKEY,I,DIFRVAL
|
---|
80 | S DIKEY=@DIFRS
|
---|
81 | S DIFL=+$P(@("^"_DIFRPTFR_"0)"),U,2) I 'DIFL S Y=-1 Q
|
---|
82 | F I=0:0 S I=$O(@DIFRS@(I)) Q:'I S DIFRVAL(I)=@DIFRS@(I)
|
---|
83 | S Y=$$FIND1^DIC(DIFL,",","X",.DIFRVAL,DIKEY)
|
---|
84 | S:'Y Y=-1 Q
|
---|
85 | ;
|
---|
86 | EXIT I $G(DIFRMSGR)]"" D CALLOUT^DIEFU(DIFRMSGR)
|
---|
87 | Q
|
---|
88 | ERR(X,Y) S X=$P($T(ERR+X),";",5) S:$D(Y) Y(1)=Y Q:'X D BLD^DIALOG(X,.Y) Q
|
---|
89 | ;;FIA Node Is Set To "No Data";1;9509
|
---|
90 | ;;FIA Array Does Not Exist;2;9501
|
---|
91 | ;;;3;
|
---|
92 | ;;Records Do Not Exist;4;9510
|
---|
93 | ;;FIA File Number Invalid;5;9502
|
---|
94 | ;;Source Array Root Missing;6;9533
|
---|
95 | ;;Resolved Value Data Link Missing;7;9534
|
---|
96 | ;;Pointed Too File Missing;8;9535
|
---|
97 | ;;Pointer Resolved Value Missing;9;9538
|
---|
98 | ;;Pointed Too File NOT on Target System;10;9536
|
---|
99 | ;;Unable To Find Exact Match And Resolve Pointer;11;9537
|
---|