source: FOIAVistA/trunk/r/PATIENT_DATA_EXCHANGE-VAQ/VAQFIL16.m@ 1775

Last change on this file since 1775 was 628, checked in by George Lilly, 15 years ago

initial load of FOIAVistA 6/30/08 version

File size: 2.6 KB
Line 
1VAQFIL16 ;ALB/JRP - MESSAGE FILING;14-MAY-93
2 ;;1.5;PATIENT DATA EXCHANGE;**4,16,20**;NOV 17, 1993
3SEGMENT(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
Note: See TracBrowser for help on using the repository browser.