1 | VAQFIL16 ;ALB/JRP - MESSAGE FILING;14-MAY-93
|
---|
2 | ;;1.5;PATIENT DATA EXCHANGE;**4,16,20**;NOV 17, 1993
|
---|
3 | SEGMENT(MESSNUM,PARSARR,TRANPTR) ;FILE SEGMENT BLOCK
|
---|
4 | ;INPUT : MESSNUM - Message number in transmission (not XMZ)
|
---|
5 | ; (defaults to 1)
|
---|
6 | ; PARSARR - Parsing array (full global reference)
|
---|
7 | ; TRANPTR - Pointer to VAQ - TRANSACTION file
|
---|
8 | ; (As defined by MailMan)
|
---|
9 | ; XMFROM, XMREC,XMZ
|
---|
10 | ;OUTPUT : 0 - Success
|
---|
11 | ; -1^Error_Text - Error
|
---|
12 | ;NOTES : It is the responsibility of the calling program to correct
|
---|
13 | ; the transaction being updated if an error occurs.
|
---|
14 | ;
|
---|
15 | N VAQCSEG
|
---|
16 | ;CHECK INPUT
|
---|
17 | S:($G(MESSNUM)="") MESSNUM=1
|
---|
18 | Q:($G(PARSARR)="") "-1^Did not pass reference to parsing array"
|
---|
19 | Q:('$D(@PARSARR@(MESSNUM))) "-1^Did not pass valid message number"
|
---|
20 | Q:('$D(@PARSARR@(MESSNUM,"PATIENT",1))) "-1^Message did not contain a patient block"
|
---|
21 | S TRANPTR=+$G(TRANPTR)
|
---|
22 | Q:(('TRANPTR)!('$D(^VAT(394.61,TRANPTR)))) "-1^Did not pass a valid transaction"
|
---|
23 | ;DECLARE VARIABLES
|
---|
24 | N TMP,ERR,SEGMENT,OFFSET,TMPARR,TIMLIM,OCCLIM
|
---|
25 | S TMPARR="^TMP(""VAQ-TMP"","_$J_")"
|
---|
26 | K @TMPARR
|
---|
27 | ;MAKE SURE IT'S A SEGMENT BLOCK
|
---|
28 | S TMP=$G(@PARSARR@(MESSNUM,"SEGMENT",1,1))
|
---|
29 | S:(TMP=" ") TMP=""
|
---|
30 | Q:((TMP="")!(TMP'="$SEGMENT")) "-1^Not a segment block"
|
---|
31 | ;DETERMINE SEGMENTS ALREADY IN TRANSACTION
|
---|
32 | S TMP=""
|
---|
33 | F S TMP=$O(^VAT(394.61,TRANPTR,"SEG","B",TMP)) Q:(TMP="") D
|
---|
34 | .S SEGMENT=$P($G(^VAT(394.71,TMP,0)),"^",1)
|
---|
35 | ;FILE SEGMENTS
|
---|
36 | S OFFSET=1
|
---|
37 | S TMP=""
|
---|
38 | F S OFFSET=$O(@PARSARR@(MESSNUM,"SEGMENT",1,OFFSET)) Q:(OFFSET="") D Q:((TMP="$$SEGMENT")!(OFFSET=""))
|
---|
39 | .S TMP=$G(@PARSARR@(MESSNUM,"SEGMENT",1,OFFSET))
|
---|
40 | .Q:(TMP="$$SEGMENT")
|
---|
41 | .S:(TMP=" ") TMP=""
|
---|
42 | .Q:(TMP="")
|
---|
43 | .;CONVERT ABBREVIATION TO POINTER
|
---|
44 | .S SEGMENT=+$O(^VAT(394.71,"C",TMP,""))
|
---|
45 | .Q:('SEGMENT)
|
---|
46 | .Q:($P($G(^VAT(394.71,SEGMENT,0)),"^",1)="")
|
---|
47 | .S VAQCSEG=SEGMENT,SEGMENT="`"_SEGMENT
|
---|
48 | .;S VAQCSEG=$P(^VAT(394.71,SEGMENT,0),"^"),SEGMENT="`"_SEGMENT
|
---|
49 | .;GET TIME LIMIT
|
---|
50 | .S OFFSET=$O(@PARSARR@(MESSNUM,"SEGMENT",1,OFFSET)) Q:(OFFSET="")
|
---|
51 | .S TMP=$G(@PARSARR@(MESSNUM,"SEGMENT",1,OFFSET))
|
---|
52 | .Q:(TMP="$$SEGMENT")
|
---|
53 | .S:(TMP=" ") TMP=""
|
---|
54 | .;LIMITS NOT PASSED (BACK UP A LINE)
|
---|
55 | .I (TMP'="") I (+$O(^VAT(394.71,"C",TMP,""))) S OFFSET=OFFSET-1 Q
|
---|
56 | .S TIMLIM=TMP
|
---|
57 | .;GET OCCURRENCE LIMIT (NEXT LINE IN MESSAGE)
|
---|
58 | .S OFFSET=$O(@PARSARR@(MESSNUM,"SEGMENT",1,OFFSET)) Q:(OFFSET="")
|
---|
59 | .S TMP=$G(@PARSARR@(MESSNUM,"SEGMENT",1,OFFSET))
|
---|
60 | .Q:(TMP="$$SEGMENT")
|
---|
61 | .S:(TMP=" ") TMP=""
|
---|
62 | .S OCCLIM=TMP
|
---|
63 | .;FILE NAME, TIME AND OCCURRENCE LIMITS
|
---|
64 | .S ERR=$$FILESEG^VAQFILE2(394.61,TRANPTR,80,VAQCSEG,TIMLIM,OCCLIM)
|
---|
65 | I (TMP'="$$SEGMENT") K @TMPARR Q "-1^Not a valid segment block"
|
---|
66 | ;DON'T DELETE SEGMENTS
|
---|
67 | K @TMPARR Q 0
|
---|