MAGXCVL ;WOIFO/SEB,MLH - Image File Conversion Utilities & Misc. options ; 15 Jul 2004 10:54 AM
;;3.0;IMAGING;**17,25,31**;Mar 31, 2005
;; +---------------------------------------------------------------+
;; | Property of the US Government. |
;; | No permission to copy or redistribute this software is given. |
;; | Use of unreleased versions of this software requires the user |
;; | to execute a written test agreement with the VistA Imaging |
;; | Development Office of the Department of Veterans Affairs, |
;; | telephone (301) 734-0100. |
;; | |
;; | The Food and Drug Administration classifies this software as |
;; | a medical device. As such, it may not be changed in any way. |
;; | Modifications to this software may result in an adulterated |
;; | medical device under 21CFR820, the use of which is considered |
;; | to be a violation of US Federal Statutes. |
;; +---------------------------------------------------------------+
;;
Q
;
; Entry point for the File Setup option (MAG IMAGE INDEX FILE SETUP)
EN N FNAME,COUNT,MAGDATA,MAGFLD,MAGID,CT,DR,DIE,DA,%ZIS
N IX ; --------- scratch subscript var
;
S COUNT=0
EN1 ; get the name of the conversion file
K DIR S DIR(0)="FOU^3:60"
S DIR("A")="Please enter the filename of the conversion file"
S DIR("?",1)="Enter a filename (including the path) of a text file"
S DIR("?")="containing mapping data."
D ^DIR
I $G(Y)]"",'$D(DUOUT),'$D(DTOUT)
E S COUNT=-1 G DONE
S %ZIS="",%ZIS("HFSNAME")=Y,%ZIS("HFSMODE")="R",IOP="HFS"
S X="ERR^"_$T(+0),@^%ZOSF("TRAP")
D ^%ZIS I POP=1 W !,"Invalid filename. Please try again." G EN1
U IO(0)
CLEAR ; confirm it's OK to clear before proceeding
K DIR S DIR(0)="YU"
S DIR("A")="Clear mapping file",DIR("B")="NO"
D ^DIR
I $D(DUOUT)!$D(DTOUT) G CLOSE
I Y K ^XTMP("MAG30P25","MAPPING") W " File cleared!"
U IO(0) W !
F CT=1:1 U IO(0) W:CT#10=0 "." U IO R MAGDATA:DTIME Q:$E(MAGDATA,1,7)="$$EOF$$" D
. S MAGDATA=$TR(MAGDATA,$C(9),U),MAGDATA=$TR(MAGDATA,$C(34),"")
. I $E(MAGDATA,1,2)="ID"!(MAGDATA="") Q
. I $E(MAGDATA,1,7)="Field #" S MAGFLD=$P($E(MAGDATA,8,$L(MAGDATA)),"-") Q
. I MAGFLD="" Q
. ; To prevent mismatching of IEN keys, do not overwrite the values in the
. ; MAG DESCRIPTIVE CATEGORIES File (#2005.81). Instead, we will later
. ; load the values from that (merged-into) file into the mapping file.
. I MAGFLD=100 Q
. S MAGID=$P(MAGDATA,U)
. I MAGFLD=6!(MAGFLD=8)!(MAGFLD=10) S MAGID=$P(MAGDATA,U,2)
. I MAGID="" Q
. S ^XTMP("MAG30P25","MAPPING",MAGFLD,MAGID)=$P(MAGDATA,U,2,999)
. I MAGFLD=16 D DIE(MAGFLD,MAGID,MAGDATA)
. Q
U IO(0) W !,"Mapping text file load complete.",!
;
; Here is where we will load FROM the MAG DESCRIPTIVE CATEGORIES File
; (#2005.81) INTO the mapping file. (We used to do it the other way around.)
W !,"Loading values from MAG DESCRIPTIVE CATEGORIES..."
S IX=0
F S IX=$O(^MAG(2005.81,IX)) Q:'IX S MAGDATA=$G(^(IX,2)) I MAGDATA]"" D
. S ^XTMP("MAG30P25","MAPPING",100,IX)=$P($G(^MAG(2005.81,IX,0)),U)_U_MAGDATA
. Q
W "done.",!
;
; Now, re-apply local edits from the audit subtree.
W !,"Re-applying local edits..."
S AUDIX=0
F S AUDIX=$O(^XTMP("MAG30P25","MAPEDITAUD",AUDIX)) Q:'AUDIX S AUDDTA=$G(^(AUDIX,0)) I AUDDTA]"" D
. S ^XTMP("MAG30P25","MAPPING",$P(AUDDTA,U,3),$P(AUDDTA,U,4))=$P(AUDDTA,U,5,999)
. Q
W "done.",!
G CLOSE
;
DIE(MAGFLD,MAGID,MAGDATA) ;
; File mapping data for field 16 into file #2005.03 (Parent Data File)
; or mapping data for field 100 into file #2005.81 (MAG Descriptive Categories)
; Called from CLEAR and from END^MAGXCVE
N DR ; --- FileMan field string
N DIE ; -- FileMan file number
N DA ; --- FileMan internal entry number
N I ; ---- scratch index
;
F I=3:1:8 S $P(MAGDATA,U,I)=$S($P(MAGDATA,U,I)="":"@",1:$P($P(MAGDATA,U,I),"-"))
S DR="40////"_$P(MAGDATA,U,3)_";41////"_$P(MAGDATA,U,4)
S DR=DR_";42////"_$P(MAGDATA,U,5)_";43////"_$P(MAGDATA,U,6)
S DR=DR_";44////"_$P(MAGDATA,U,7)_";45////"_$P(MAGDATA,U,8)
S DIE=$S(MAGFLD=16:2005.03,MAGFLD=100:2005.81),DA=MAGID U IO D ^DIE
Q
;
; Reached when an error (including end-of-file) occurs.
ERR ;
U IO(0) X "W !,$ZE,!"
CLOSE ; normal file close logic
D ^%ZISC
DONE S COUNT=COUNT+1
I COUNT=1 W !,"Done importing conversion values."
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HMAGXCVL 4501 printed Dec 13, 2024@02:10:44 Page 2
MAGXCVL ;WOIFO/SEB,MLH - Image File Conversion Utilities & Misc. options ; 15 Jul 2004 10:54 AM
+1 ;;3.0;IMAGING;**17,25,31**;Mar 31, 2005
+2 ;; +---------------------------------------------------------------+
+3 ;; | Property of the US Government. |
+4 ;; | No permission to copy or redistribute this software is given. |
+5 ;; | Use of unreleased versions of this software requires the user |
+6 ;; | to execute a written test agreement with the VistA Imaging |
+7 ;; | Development Office of the Department of Veterans Affairs, |
+8 ;; | telephone (301) 734-0100. |
+9 ;; | |
+10 ;; | The Food and Drug Administration classifies this software as |
+11 ;; | a medical device. As such, it may not be changed in any way. |
+12 ;; | Modifications to this software may result in an adulterated |
+13 ;; | medical device under 21CFR820, the use of which is considered |
+14 ;; | to be a violation of US Federal Statutes. |
+15 ;; +---------------------------------------------------------------+
+16 ;;
+17 QUIT
+18 ;
+19 ; Entry point for the File Setup option (MAG IMAGE INDEX FILE SETUP)
EN NEW FNAME,COUNT,MAGDATA,MAGFLD,MAGID,CT,DR,DIE,DA,%ZIS
+1 ; --------- scratch subscript var
NEW IX
+2 ;
+3 SET COUNT=0
EN1 ; get the name of the conversion file
+1 KILL DIR
SET DIR(0)="FOU^3:60"
+2 SET DIR("A")="Please enter the filename of the conversion file"
+3 SET DIR("?",1)="Enter a filename (including the path) of a text file"
+4 SET DIR("?")="containing mapping data."
+5 DO ^DIR
+6 IF $GET(Y)]""
IF '$DATA(DUOUT)
IF '$DATA(DTOUT)
+7 IF '$TEST
SET COUNT=-1
GOTO DONE
+8 SET %ZIS=""
SET %ZIS("HFSNAME")=Y
SET %ZIS("HFSMODE")="R"
SET IOP="HFS"
+9 SET X="ERR^"_$TEXT(+0)
SET @^%ZOSF("TRAP")
+10 DO ^%ZIS
IF POP=1
WRITE !,"Invalid filename. Please try again."
GOTO EN1
+11 USE IO(0)
CLEAR ; confirm it's OK to clear before proceeding
+1 KILL DIR
SET DIR(0)="YU"
+2 SET DIR("A")="Clear mapping file"
SET DIR("B")="NO"
+3 DO ^DIR
+4 IF $DATA(DUOUT)!$DATA(DTOUT)
GOTO CLOSE
+5 IF Y
KILL ^XTMP("MAG30P25","MAPPING")
WRITE " File cleared!"
+6 USE IO(0)
WRITE !
+7 FOR CT=1:1
USE IO(0)
if CT#10=0
WRITE "."
USE IO
READ MAGDATA:DTIME
if $EXTRACT(MAGDATA,1,7)="$$EOF$$"
QUIT
Begin DoDot:1
+8 SET MAGDATA=$TRANSLATE(MAGDATA,$CHAR(9),U)
SET MAGDATA=$TRANSLATE(MAGDATA,$CHAR(34),"")
+9 IF $EXTRACT(MAGDATA,1,2)="ID"!(MAGDATA="")
QUIT
+10 IF $EXTRACT(MAGDATA,1,7)="Field #"
SET MAGFLD=$PIECE($EXTRACT(MAGDATA,8,$LENGTH(MAGDATA)),"-")
QUIT
+11 IF MAGFLD=""
QUIT
+12 ; To prevent mismatching of IEN keys, do not overwrite the values in the
+13 ; MAG DESCRIPTIVE CATEGORIES File (#2005.81). Instead, we will later
+14 ; load the values from that (merged-into) file into the mapping file.
+15 IF MAGFLD=100
QUIT
+16 SET MAGID=$PIECE(MAGDATA,U)
+17 IF MAGFLD=6!(MAGFLD=8)!(MAGFLD=10)
SET MAGID=$PIECE(MAGDATA,U,2)
+18 IF MAGID=""
QUIT
+19 SET ^XTMP("MAG30P25","MAPPING",MAGFLD,MAGID)=$PIECE(MAGDATA,U,2,999)
+20 IF MAGFLD=16
DO DIE(MAGFLD,MAGID,MAGDATA)
+21 QUIT
End DoDot:1
+22 USE IO(0)
WRITE !,"Mapping text file load complete.",!
+23 ;
+24 ; Here is where we will load FROM the MAG DESCRIPTIVE CATEGORIES File
+25 ; (#2005.81) INTO the mapping file. (We used to do it the other way around.)
+26 WRITE !,"Loading values from MAG DESCRIPTIVE CATEGORIES..."
+27 SET IX=0
+28 FOR
SET IX=$ORDER(^MAG(2005.81,IX))
if 'IX
QUIT
SET MAGDATA=$GET(^(IX,2))
IF MAGDATA]""
Begin DoDot:1
+29 SET ^XTMP("MAG30P25","MAPPING",100,IX)=$PIECE($GET(^MAG(2005.81,IX,0)),U)_U_MAGDATA
+30 QUIT
End DoDot:1
+31 WRITE "done.",!
+32 ;
+33 ; Now, re-apply local edits from the audit subtree.
+34 WRITE !,"Re-applying local edits..."
+35 SET AUDIX=0
+36 FOR
SET AUDIX=$ORDER(^XTMP("MAG30P25","MAPEDITAUD",AUDIX))
if 'AUDIX
QUIT
SET AUDDTA=$GET(^(AUDIX,0))
IF AUDDTA]""
Begin DoDot:1
+37 SET ^XTMP("MAG30P25","MAPPING",$PIECE(AUDDTA,U,3),$PIECE(AUDDTA,U,4))=$PIECE(AUDDTA,U,5,999)
+38 QUIT
End DoDot:1
+39 WRITE "done.",!
+40 GOTO CLOSE
+41 ;
DIE(MAGFLD,MAGID,MAGDATA) ;
+1 ; File mapping data for field 16 into file #2005.03 (Parent Data File)
+2 ; or mapping data for field 100 into file #2005.81 (MAG Descriptive Categories)
+3 ; Called from CLEAR and from END^MAGXCVE
+4 ; --- FileMan field string
NEW DR
+5 ; -- FileMan file number
NEW DIE
+6 ; --- FileMan internal entry number
NEW DA
+7 ; ---- scratch index
NEW I
+8 ;
+9 FOR I=3:1:8
SET $PIECE(MAGDATA,U,I)=$SELECT($PIECE(MAGDATA,U,I)="":"@",1:$PIECE($PIECE(MAGDATA,U,I),"-"))
+10 SET DR="40////"_$PIECE(MAGDATA,U,3)_";41////"_$PIECE(MAGDATA,U,4)
+11 SET DR=DR_";42////"_$PIECE(MAGDATA,U,5)_";43////"_$PIECE(MAGDATA,U,6)
+12 SET DR=DR_";44////"_$PIECE(MAGDATA,U,7)_";45////"_$PIECE(MAGDATA,U,8)
+13 SET DIE=$SELECT(MAGFLD=16:2005.03,MAGFLD=100:2005.81)
SET DA=MAGID
USE IO
DO ^DIE
+14 QUIT
+15 ;
+16 ; Reached when an error (including end-of-file) occurs.
ERR ;
+1 USE IO(0)
XECUTE "W !,$ZE,!"
CLOSE ; normal file close logic
+1 DO ^%ZISC
DONE SET COUNT=COUNT+1
+1 IF COUNT=1
WRITE !,"Done importing conversion values."
+2 QUIT