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

INHSYSUT.m

Go to the documentation of this file.
  1. INHSYSUT ;JPD/WOM; 23 Aug 1999 12:26;gis sys con data installation utility
  1. ;;3.01;BHL IHS Interfaces with GIS;;JUL 01, 2001
  1. ;COPYRIGHT 1991-2000 SAIC
  1. ;CHCS TOOLS_460; GEN 5; 6-OCT-1997
  1. ;COPYRIGHT 1994 SAIC
  1. Q
  1. ;
  1. MSG(%X,%FNUM,%MSG,%MULT,%PASS) ;Display message if DIC lookup failed
  1. ; Input:
  1. ; %X - Entry we tried to look up Using DIC
  1. ; %FNUM - File number
  1. ; %MULT - 0 Not a multiple
  1. ; 1 Multiple
  1. ; Output:
  1. ; %MSG - 1 - Flag We have a message
  1. N %TP,QT
  1. S %TP="File",%MULT=$G(%MULT),QT=$C(34)
  1. I %MULT S %TP="Multiple"
  1. D PG^INHSYS03(%PASS)
  1. W !!,%TP_" entry "_QT_$P(%X,U)_QT_" does not exist for "_%TP_" "_%FNUM,!,"or is a duplicate entry!",!
  1. I %MULT W "If entry is a pointer, it will have to be entered by hand",!
  1. S %MSG=1
  1. Q
  1. RQ(%RQ) ;Required fields
  1. ;output: %RQ - Required fields array
  1. N I
  1. F I=4000,4005,4006,4004,4011,4010,4012,4090.2,4020 S %RQ(I,.01)=""
  1. F I=.02,.04,.08 S %RQ(4000,I)=""
  1. Q
  1. OMT(%OMT) ;fields to omit from updating
  1. ;Output:
  1. ; %OMT - Fields to omit
  1. ; If a file/field is found in this array, it will not
  1. ; be updated in Pass 2
  1. ;
  1. N I
  1. F I=.01 S %OMT(4005.01,I)=""
  1. F I=1,.01 S %OMT(4005.02,I)=""
  1. F I=3.01,1,5,7.01,7.03,9 S %OMT(4005,I)=""
  1. F I=.03,7.02,7.04,7.05 S %OMT(4004,I)=""
  1. Q
  1. SAVE(%SAV) ;Save values from import environment
  1. ; Output:
  1. ; %SAV - File and field to save value from
  1. ; Files/fields to restore the site specific data
  1. ;
  1. ; Programmers note:
  1. ; The DEVICE field (.03) in the BACKGROUND PROCESS CONTROL (4004)
  1. ; was originally part of the %SAV array. This field was
  1. ; omitted for two reasons. First, the field should no longer be
  1. ; used by the GIS. Secondly, the field has an input transform that
  1. ; causes the ^DIE call at tag FILE^INHSYSUT to ask for user input
  1. ; if the string being stuffed is found in more than one entry.
  1. ; This file/field should not be removed from array %OMT. The value
  1. ; of this field will be NULL after running the GIS Transaction
  1. ; Mover.
  1. ;
  1. N I
  1. F I=.05 S %SAV(4000,I)=""
  1. F I=.02,5,6,7.02,7.04,7.05,1.01,1.2,1.3,1.4,1.5,1.6,1.8,1.9,1.1,1.11,1.12,1.14,10.01,10.02 S %SAV(4004,I)=""
  1. F I=3.01,1,5,7.01,7.02,7.03,9 S %SAV(4005,I)=""
  1. Q
  1. FLSV(%XRF,%OIEN,%ROOT) ;Save old file in temp global
  1. ; Input
  1. ; %XRF - File number
  1. ; %OIEN - ien of file saving
  1. ; %ROOT - Root file name
  1. N %X,%Y
  1. S %X=%ROOT_%OIEN_")",%Y="^UTILITY(""INHSYSUT"",$J,%XRF,%OIEN)"
  1. M @%Y=@%X
  1. ;S %X=%ROOT_%OIEN_",",%Y="^UTILITY(""INHSYSUT"",$J,%XRF,%OIEN,"
  1. ;D %XY^%RCR
  1. Q
  1. LIST(INSELTT) ;selectable list of parent and child transaction types
  1. ;output:
  1. ; INSELTT --> array of selected transaction types
  1. ;local:
  1. ; INPAR --> parent TT
  1. ; INCHLD --> child TT
  1. ;
  1. ;Note: Does not put TT in INSELTT if the UNIQUE IDENTIFIER is
  1. ; blank
  1. N INPAR,DWLRF,DWLB,DWL,DWLMK,DWLR,DWLMK1,INTT,I,INS,INIEN
  1. S INPAR="",I=0 F S INPAR=$O(^INRHT("B",INPAR)) Q:INPAR="" D
  1. .S INIEN=$O(^INRHT("B",INPAR,"")) Q:$P(^INRHT(INIEN,0),"^",4)=""
  1. .S I=I+1,INTT(1,I)=INPAR,INTT(1,I,0)=INIEN_"^c",INTT(2,I)="Child"
  1. .I $D(^INRHT("AC",INIEN)) S INTT(1,I,0)=INIEN_"^p",INTT(2,I)="Parent"
  1. S DWLRF="INTT",DWLB="2^5^12^60^8",DWL="HEL0,20F1WXXM-1A2"
  1. S DWL("TITLE")="D HDR^INHSYSUT"
  1. F D ^DWL Q:DWLR'="E" D EXPAND^INHSYSUT
  1. I " ^ ^^ "[(" "_DWLR_" ")!'$D(DWLMK) S INSELTT=0 Q
  1. S INS="" F I=1:1 S INS=$O(DWLMK(1,INS)) Q:'INS D
  1. .S INSELTT=I,INSELTT(DWLMK(1,INS))=INTT(1,INS,0)_"^"_$$LB^UTIL(INTT(1,INS))
  1. Q
  1. HDR ;header for list processor
  1. X DIJC("H")
  1. W $$SETXY^%ZTF(0,4),$$CENTER^INHUTIL("Transaction Type List",80)
  1. W $$SETXY^%ZTF(0,18),"Use <FIND> Key to find desired Transaction."
  1. W $$SETXY^%ZTF(0,19),"Use <SELECT> Key to pick a Transaction Type to process"
  1. X DIJC("L")
  1. Q
  1. LOCKFL(INLKFLS,INEX) ;Lock files that will be used and check for zero node
  1. ; Input: INEX - if TRUE, then this is called during
  1. ; IMPORT so only lock those files affected
  1. ; Output:
  1. ; INLKFLS - Locked files
  1. ; Returns 0 to continue 1 to quit
  1. I $D(IO)#10,$D(IO(0))#10 I IO'=IO(0) U IO(0)
  1. N %FNUM,%LFLG,%ROOT,%FILES,AA
  1. S %LFLG=0 S:'$D(INEX) INEX=0
  1. D XRF(.%FILES)
  1. F AA=1:1 S %FNUM=$P(%FILES,U,AA) Q:%FNUM="" D Q:INPOP
  1. .I INEX,'$D(^UTILITY("INHSYS",$J,%FNUM)) Q
  1. .S %ROOT=$P(^DIC(%FNUM,0,"GL"),"(")
  1. .I '$$LOCK(%ROOT,%FNUM) S (%LFLG,INPOP)=1
  1. .S INLKFLS(%ROOT)=%FNUM
  1. .S %ROOT=^DIC(%FNUM,0,"GL")_"0)"
  1. .I $D(@%ROOT)#10'=1 W *7,!,"File Corruption in the "_%FNUM_" file!" S (%LFLG,INPOP)=1
  1. I %LFLG D
  1. .W !!,"You will have to try later",!!!!
  1. .I $$CR^UTSRD(0,IOSL-1)
  1. I $D(IO)#10,$D(IO(0))#10 I IO'=IO(0) U IO
  1. Q %LFLG
  1. LOCK(%ROOT,%FILNM) ;Lock other users from this file
  1. ; %ROOT - Global file node to lock
  1. ; %FILNM - File Name
  1. N INLOK S INLOK=1
  1. L +@%ROOT:3
  1. E S INLOK=0 W *7,!,"Another terminal is editing the "_%FILNM_" file!"
  1. Q INLOK
  1. UNLK(%FILE) ;Unlock file
  1. N I F I=1:1:3 L -@%FILE
  1. Q
  1. RPRT1(%LEVEL,%FILNM,ND) ;Do report
  1. ; Input:
  1. ; %LEVEL - Level of pointer
  1. ; %FILNM - File Number
  1. ; ND - Node
  1. N I
  1. D PG^INHSYS03(1)
  1. W ! F I=1:1:%LEVEL W "."
  1. W ?%LEVEL,%FILNM,?%LEVEL+14,$P($G(^DIC(%FILNM,0)),U),?%LEVEL+42,".01",?%LEVEL+48
  1. I %FILNM'=4020 W $P(@(ND),U)
  1. E W $P($G(^INRHT($P(@(ND),U),0)),U)
  1. W !,?%LEVEL,ND
  1. Q
  1. EXPAND ;Expand logic for list processor
  1. ;
  1. N INS,DA,DIC
  1. I '$D(DWLMK) W "SELECT an item to expand on.",*7
  1. E D
  1. .S INS="" S INS=$O(DWLMK(1,INS))
  1. .S DA=+@(DWLRF_"(1,"_INS_",0)"),DIC="^INRHT("
  1. .D EN^DIQ
  1. I $$CR^UTSRD(0,IOSL-1)
  1. Q
  1. FILE(DA,%DATA,%FLDNUM,DIE,INREPRT) ;file data
  1. ; Input:
  1. ; DA - ien and "Multiple entry"
  1. ; %DATA - What to file
  1. ; %FLDNUM - Field Number
  1. ; DIE - Global to file
  1. ; INREPRT - 0 - No report
  1. ; 1 - Report
  1. N X,DG,DNM,DQ,DIEZ,D0,D1,D2,D3,D4,D5,D6,D7,INY,FILNUM
  1. ;
  1. ; Don't stuff data for fields that are site specific except
  1. ; on Pass 3
  1. S FILNUM=$P(@(DIE_"0)"),U,2) I %PASS'=3,$D(%SAV(FILNUM,%FLDNUM))!($D(%OMT(FILNUM,%FLDNUM))) Q
  1. I INREPRT=2 W ?70,DIE
  1. I DA'>0 D Q
  1. .W !,"NON-EXISTENT OR DUPLICATE ENTRY! for "_$G(DIE)_" field #"_$G(%FLDNUM)_" Data: "_$G(%DATA)_" %XNODE="_$G(%XNODE)
  1. .D FLSUMERR^INHSYS11(FILNUM,%FLDNUM,DA,$P($G(%XNODE),U),DIE)
  1. S DR="S INY=0;"_%FLDNUM_"///^S X=%DATA;S INY=1"
  1. D ^DIE
  1. I '$G(INY) D
  1. .W ?56," NO DATA FILED for ",DIE," field #",%FLDNUM," Data: ",%DATA
  1. .D FLSUMERR^INHSYS11(FILNUM,%FLDNUM,DA,%DATA,DIE)
  1. Q
  1. DATA(%B,%P,%D) ;retrieve the data from the buffer
  1. ;input:
  1. ; %B - buffer
  1. ; %P - If an integer, uparrow piece to return
  1. ; If the first character is "E", then extract data
  1. ;output:
  1. ; %D - Data
  1. S %D=""
  1. I $E(%P)="E",$D(@%B)#2 S %D=$E(@%B,+$E(%P,2,99),+$P(%P,",",2)) Q
  1. I $D(@%B)#2 S %D=$P(@%B,U,%P)
  1. Q
  1. RUT(%ROOT) ;modify global root to indirection format
  1. ;%ROOT - Global root
  1. N Y
  1. ;get last value of root,set to all but last value & concact w/ ) or ""
  1. S Y=$E(%ROOT,$L(%ROOT)),Y=$E(%ROOT,1,$L(%ROOT)-1)_$S(Y=",":")",1:"")
  1. Q Y
  1. ;
  1. UP(FN) ;goes up & up searching for the top level file number
  1. ;input:
  1. ; FN - the current sub-level file number
  1. N Y
  1. I '$D(^DD(FN,0,"UP")) S Y=FN
  1. E S Y=$$UP(^("UP"))
  1. Q Y
  1. ;
  1. PG(%PASS) ;Page check
  1. ; Input:
  1. ; %PASS - Which PASS
  1. I IOSL-5'>$Y D
  1. .I $E(IOST)="C",INCR,$$CR^UTSRD(0,IOSL-1)
  1. .D HEAD(%PASS)
  1. Q
  1. ; Input:
  1. ; %PASS - Which pass is being run
  1. W @IOF
  1. I %PASS=1 W $$CENTER^INHUTIL("Pass 1 Required Fields",80)
  1. I %PASS=2 W $$CENTER^INHUTIL("Pass 2 All Fields",80)
  1. W !!,"File Number",?14,"File Name",?42,"Field Number",?56,"Data"
  1. W !,"^Root(IEN",!
  1. Q
  1. WP(FIL,FLD) ;word process field
  1. ;input:
  1. ; FIL - file number
  1. ; FLD - field number
  1. ; Returns 0 false 1 true
  1. N Y
  1. I $P(^DD(FIL,FLD,0),U,2) S Y=$$WP(+$P(^(0),U,2),.01)
  1. Q $P(^(0),U,2)["W"
  1. ;
  1. XRF(%FILES) ;cross reference of files and fields requiring some resolution
  1. ; Output:
  1. ; %FILES(FILE#)=fields
  1. ;':' delimiter separates field # and sub-file #
  1. ;',' delimiter separates sub-file # and sub-field #
  1. ;';' delimiter separates fields
  1. ;i.e. field[:sub-file,sub-field,...][;field...] etc.
  1. ; Subnodes used at RSLV^INHSYS03
  1. S %FILES="4012^4005^4011^4000^4004^4010^4090.2^4020^4006"
  1. S %FILES(4012)=".02;10:4012.02,.01;50"
  1. S %FILES(4005)=".02;.1"
  1. S %FILES(4011)=".05;1:4011.01,.01,.11;2:4011.02,.01;100;101"
  1. S %FILES(4000)=".02;.03;.06;.09;.17"
  1. S %FILES(4004)=".07"
  1. S %FILES(4010)="1:4010.01,.01"
  1. S %FILES(4090.2)=".02"
  1. S %FILES(4020)=".01;.02"
  1. S %FILES(4006)=".03"
  1. Q