Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: VAQCON7

VAQCON7.m

Go to the documentation of this file.
  1. VAQCON7 ;ALB/JRP - MESSAGE CONSTRUCTION;13-APR-93
  1. ;;1.5;PATIENT DATA EXCHANGE;;NOV 17, 1993
  1. DATA(TRANPTR,SEGABB,DATARR,MESSNUM,ARRAY,OFFSET) ;CONSTRUCT DATA BLOCK
  1. ;INPUT : TRANPTR - Pointer to VAQ - TRANSACTION file
  1. ; SEGABB - Segment abbreviation for segment
  1. ; DATARR - Location of Extraction Array (full global reference)
  1. ; MESSNUM - Message number to place block into
  1. ; (if 0, block will be placed in ARRAY)
  1. ; ARRAY - Array to store block in (full global reference)
  1. ; OFFSET - Where to begin placing information (defaults to 0)
  1. ;OUTPUT : N - Number of lines in block
  1. ; -1^Error_Text - Error
  1. ;NOTES : If MESSNUM=0, then the block will be placed into
  1. ; ARRAY(LineNumber)=Line_of_info
  1. ; If MESSNUM>0 then the block will be placed into
  1. ; ^XMB(3.9,MESSNUM,2,LineNumber,0)=Line_of_info
  1. ;
  1. ;CHECK INPUT
  1. S TRANPTR=+$G(TRANPTR)
  1. Q:(('TRANPTR)!('$D(^VAT(394.61,TRANPTR)))) "-1^Did not pass a valid pointer to VAQ - TRANSACTION file"
  1. Q:($G(SEGABB)="") "-1^Did not pass segment abbreviation"
  1. Q:($G(DATARR)="") "-1^Did not pass location of Extraction Array"
  1. S MESSNUM=+$G(MESSNUM)
  1. I (('MESSNUM)&($G(ARRAY)="")) Q "-1^Did not pass message number of reference to array"
  1. I (MESSNUM) Q:('$D(^XMB(3.9,MESSNUM))) "-1^Valid message number not passed"
  1. S OFFSET=+$G(OFFSET)
  1. ;DECLARE VARIABLES
  1. N TMP,LINE,ID,FILE,FIELD,SEQ,NCRYPTON,X
  1. S LINE=OFFSET
  1. ;DETERMINE IF ENCRYPTION WAS TURNED ON
  1. S NCRYPTON=$$TRANENC^VAQUTL3(TRANPTR,0)
  1. ;LINE 1
  1. S TMP="$DATA"
  1. S:('MESSNUM) @ARRAY@(LINE)=TMP
  1. S:(MESSNUM) X=$$ADDLINE^VAQCON1(TMP,MESSNUM,LINE)
  1. S LINE=LINE+1
  1. ;LINE 2
  1. S TMP=SEGABB
  1. S:('MESSNUM) @ARRAY@(LINE)=TMP
  1. S:(MESSNUM) X=$$ADDLINE^VAQCON1(TMP,MESSNUM,LINE)
  1. S LINE=LINE+1
  1. ;LOOP THROUGH EACH FILE
  1. S FILE=""
  1. F S FILE=$O(@DATARR@("VALUE",FILE)) Q:(FILE="") D
  1. .;LOOP THROUGH EACH FIELD
  1. .S FIELD=""
  1. .F S FIELD=$O(@DATARR@("VALUE",FILE,FIELD)) Q:(FIELD="") D
  1. ..;COUNT NUMBER OF VALUES (IF MORE THAN ONE)
  1. ..S SEQ=1
  1. ..I (+$O(@DATARR@("VALUE",FILE,FIELD,0))) D
  1. ...S SEQ=0
  1. ...S X=""
  1. ...F S X=$O(@DATARR@("VALUE",FILE,FIELD,X)) Q:(X="") S SEQ=SEQ+1
  1. ..;STORE NON-REPEATED INFO
  1. ..;DETERMINE IF FIELD WAS ENCRYPTED
  1. ..S X=0
  1. ..S:(NCRYPTON) X=+$$NCRPFLD^VAQUTL2(FILE,FIELD)
  1. ..S TMP=X_"^"_FILE_"^"_FIELD_"^"_SEQ
  1. ..S:('MESSNUM) @ARRAY@(LINE)=TMP
  1. ..S:(MESSNUM) X=$$ADDLINE^VAQCON1(TMP,MESSNUM,LINE)
  1. ..S LINE=LINE+1
  1. ..;LOOP THROUGH EACH VALUE
  1. ..S SEQ=""
  1. ..F S SEQ=$O(@DATARR@("VALUE",FILE,FIELD,SEQ)) Q:(SEQ="") D
  1. ...S TMP=$G(@DATARR@("VALUE",FILE,FIELD,SEQ))
  1. ...S:('MESSNUM) @ARRAY@(LINE)=TMP
  1. ...S:(MESSNUM) X=$$ADDLINE^VAQCON1(TMP,MESSNUM,LINE)
  1. ...S LINE=LINE+1
  1. ...S TMP=$G(@DATARR@("ID",FILE,FIELD,SEQ))
  1. ...S:('MESSNUM) @ARRAY@(LINE)=TMP
  1. ...S:(MESSNUM) X=$$ADDLINE^VAQCON1(TMP,MESSNUM,LINE)
  1. ...S LINE=LINE+1
  1. ;LINE Z
  1. S TMP="$$DATA"
  1. S:('MESSNUM) @ARRAY@(LINE)=TMP
  1. S:(MESSNUM) X=$$ADDLINE^VAQCON1(TMP,MESSNUM,LINE)
  1. S LINE=LINE+1
  1. Q (LINE-OFFSET)