| 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 | 
|---|