LEX2031P ;ISA/FJF-Pre/Post Install; 10/01/2004
;;2.0;LEXICON UTILITY;**31**;Sep 23, 1996
;
; External References
; DBIA 10086 HOME^%ZIS
; DBIA 2052 $$GET1^DID
; DBIA 2055 PRD^DILFD
; DBIA 10014 EN^DIU2
; DBIA 10141 BMES^XPDUTL
; DBIA 10141 MES^XPDUTL
;
Q
;
POST ; LEX*2.0*31 Post-Install
N LEXEDT,LEXCHG,LEXSCHG S LEXEDT=$G(^LEXM(0,"CREATED"))
S LEXCHG=0 S:$D(^LEXM(80))!($D(^LEXM(80.1)))!($D(^LEXM(81)))!($D(^LEXM(81.2)))!($D(^LEXM(81.3))) LEXCHG=1
; Save Changes
D SCHG
; Load Data into Files
D LOAD
; Data Conversion
D CON
; Re-Index Files
; Not used for Annual/Quarterly Updates
; It disrupts the Protocol
; D RX
; Notify Applications that a Change has occurred
D NOTIFY^LEXXGI
; Send a Install Message
D MSG
; Clean up and Quit
D KLEXM
Q
;
LOAD ; Load Data from ^LEXM into IC*/LEX Files
N LEXB,LEXBUILD,LEXCD,LEXIGHF,LEXLAST,LEXLREV D IMP^LEX2031
S U="^",LEXB=$G(^LEXM(0,"BUILD")) Q:LEXB="" Q:LEXBUILD=""
S LEXCD=0 S LEXCD=+($$CPD^LEX2031)
I LEXCD,LEXB=LEXBUILD D G LQ
. S X="Data for patch "_LEXBUILD_" has already been installed"
. W:'$D(XPDNM) !!,X D:$D(XPDNM) BMES^XPDUTL(X)
. S X="" W:'$D(XPDNM) ! D:$D(XPDNM) MES^XPDUTL(X)
D:'LEXCD&(LEXB=LEXBUILD) EN^LEXXGI
LQ ; Load Quit
D KLEXM
Q
;
MSG ; Send Installation Message to G.LEXICON
Q:+($G(DUZ))=0!($$NOTDEF^LEX2031($G(DUZ)))
D HOME^%ZIS N DIFROM,LEXLREV,LEXLAST,LEXBUILD,LEXIGHF
D IMP^LEX2031,SEND^LEXXST Q
;
SCHG ; Save Change File Changes
D MES^XPDUTL(" Updating Change File")
N LEXI,LEXFI,LEXFIL S LEXFI=0 F S LEXFI=$O(^LEXM(LEXFI)) Q:+LEXFI=0 D
. S LEXI=0 F S LEXI=$O(^LEXM(LEXFI,LEXI)) Q:+LEXI=0 D
. . N LEXCF,LEXIEN S LEXMUMPS=$G(^LEXM(LEXFI,LEXI)),LEXRT=$P(LEXMUMPS,"^",2)
. . S:LEXMUMPS["^LEX("!(LEXMUMPS["^LEXT(")!(LEXMUMPS["^LEXC(") LEXFIL=+($P(LEXRT,"(",2))
. . S:LEXMUMPS["^ICD9(" LEXFIL=80 S:LEXMUMPS["^ICD0(" LEXFIL=80.1 S:LEXMUMPS["^ICPT(" LEXFIL=81 S:LEXMUMPS["^DIC(81.3" LEXFIL=81.3
. . S:+LEXFIL>0 LEXSCHG(+LEXFIL,0)="" S LEXCF=+($P(LEXMUMPS,"LEXC(757.9,""AFIL"",",2))
. . S:$P(LEXCF,".",1)'="757"&("^80^80.1^81^81.3^"'[("^"_LEXCF_"^")) LEXCF=""
. . S LEXIEN=+($P(LEXMUMPS,("LEXC(757.9,""AFIL"","_+LEXCF_","),2))
. . I +LEXIEN>0&(+LEXCF)>0&("^80^80.1^81^81.3)"[LEXCF)&(+LEXFIL=757.9)&(LEXMUMPS["LEXC(757.9") D
. . . S LEXSCHG(+LEXFIL,LEXIEN)=LEXCF,LEXSCHG(757.9,"B",+LEXCF,LEXIEN)=""
. . S:$L(LEXMUMPS)&($L(LEXCF)) LEXCHGS(LEXCF)=""
Q
;
KLEXM ; Subscripted Kill of ^LEXM
N DA S DA=0 F S DA=$O(^LEXM(DA)) Q:+DA=0 K ^LEXM(DA)
K ^LEXM(0)
Q
;
PRE ; LEX*2.0*31 Pre-Install (N/A for patch 31)
Q
;
RX ; Reindex files 80, 80.1, 80.2, 81 and 81.3
N LEX,DA,DIK,TH,TM,TD
D BMES^XPDUTL(" Re-indexing NEW Versioned Text Cross-References")
;
D BMES^XPDUTL(" ICD-9 Diagnosis file #80") W !," "
S (LEX,DA)=0 F S DA=$O(^ICD9(DA)) Q:+DA=0 K ^ICD9(DA,66,"B"),^ICD9(DA,67,"B"),^ICD9(DA,68,"B") S LEX=+($G(LEX))+1 W:LEX#120=0 "."
K ^ICD9("AB"),^ICD9("ACC"),^ICD9("ACT"),^ICD9("BA"),^ICD9("D"),^ICD9("AST"),^ICD9("ADS") S DIK="^ICD9(" D IXALL^DIK
;
D MES^XPDUTL(" ICD-9 Operations/Procedure file #80.1") W !," "
S (LEX,DA)=0 F S DA=$O(^ICD0(DA)) Q:+DA=0 K ^ICD0(DA,66,"B"),^ICD0(DA,67,"B"),^ICD0(DA,68,"B") S LEX=+($G(LEX))+1 W:LEX#120=0 "."
K ^ICD0("AB"),^ICD0("ACT"),^ICD0("ADS"),^ICD0("AST"),^ICD0("BA"),^ICD0("D"),^ICD0("E") S DIK="^ICD0(" D IXALL^DIK
;
D MES^XPDUTL(" DRG file #80.2") W !," "
S (LEX,DA)=0 F S DA=$O(^ICD(DA)) Q:+DA=0 K ^ICD(DA,1,"B"),^ICD(DA,66,"B"),^ICD(DA,68,"B") S LEX=+($G(LEX))+1 W:LEX#120=0 "."
K ^ICD("ADS"),^ICD("B") S DIK="^ICD(" D IXALL^DIK
;
D MES^XPDUTL(" CPT/HCPCS Procedure/Services file #81") W !," "
S (LEX,DA)=0 F S DA=$O(^ICPT(DA)) Q:+DA=0 D
. K ^ICPT(DA,60,"B"),^ICPT(DA,61,"B"),^ICPT(DA,62,"B"),^ICPT(DA,"D","B") S LEX=+($G(LEX))+1 W:LEX#120=0 "."
K ^ICPT("ACT"),^ICPT("ADS"),^ICPT("AST"),^ICPT("B"),^ICPT("BA"),^ICPT("C"),^ICPT("D"),^ICPT("E"),^ICPT("F") S DIK="^ICPT(" D IXALL^DIK
;
D MES^XPDUTL(" CPT Modifier file #81.3") W !," "
S (LEX,DA)=0 F S DA=$O(^DIC(81.3,DA)) Q:+DA=0 D
. K ^DIC(81.3,DA,60,"B"),^DIC(81.3,DA,61,"B"),^DIC(81.3,DA,62,"B") S LEX=+($G(LEX))+1 W:LEX#120=0 "."
K ^DIC(81.3,"ACT"),^DIC(81.3,"ADS"),^DIC(81.3,"AST"),^DIC(81.3,"B"),^DIC(81.3,"BA"),^DIC(81.3,"C"),^DIC(81.3,"D"),^DIC(81.3,"M") S DIK="^DIC(81.3," D IXALL^DIK
Q
;
CON ; Conversion of data (for patch 31 only)
D BMES^XPDUTL(" Checking File 80/80.1 Input Transformations")
D AGE,SEX
D MES^XPDUTL(" ")
Q
SEX ; Sex Field
N LEXIEN,LEXSEX S LEXIEN=0 F S LEXIEN=$O(^ICD0(LEXIEN)) Q:+LEXIEN=0 D
. S LEXSEX=$P($G(^ICD0(LEXIEN,0)),"^",10) Q:LEXSEX'="T047" S $P(^ICD0(LEXIEN,0),"^",10)=""
Q
AGE ; Age High Field
N LEXIEN,LEXAGE S LEXIEN=0 F S LEXIEN=$O(^ICD9(LEXIEN)) Q:+LEXIEN=0 D
. S LEXAGE=$P($G(^ICD9(LEXIEN,0)),"^",15) Q:+LEXAGE'=124 S $P(^ICD9(LEXIEN,0),"^",15)="99"
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HLEX2031P 5092 printed Nov 22, 2024@17:14:02 Page 2
LEX2031P ;ISA/FJF-Pre/Post Install; 10/01/2004
+1 ;;2.0;LEXICON UTILITY;**31**;Sep 23, 1996
+2 ;
+3 ; External References
+4 ; DBIA 10086 HOME^%ZIS
+5 ; DBIA 2052 $$GET1^DID
+6 ; DBIA 2055 PRD^DILFD
+7 ; DBIA 10014 EN^DIU2
+8 ; DBIA 10141 BMES^XPDUTL
+9 ; DBIA 10141 MES^XPDUTL
+10 ;
+11 QUIT
+12 ;
POST ; LEX*2.0*31 Post-Install
+1 NEW LEXEDT,LEXCHG,LEXSCHG
SET LEXEDT=$GET(^LEXM(0,"CREATED"))
+2 SET LEXCHG=0
if $DATA(^LEXM(80))!($DATA(^LEXM(80.1)))!($DATA(^LEXM(81)))!($DATA(^LEXM(81.2)))!($DATA(^LEXM(81.3)))
SET LEXCHG=1
+3 ; Save Changes
+4 DO SCHG
+5 ; Load Data into Files
+6 DO LOAD
+7 ; Data Conversion
+8 DO CON
+9 ; Re-Index Files
+10 ; Not used for Annual/Quarterly Updates
+11 ; It disrupts the Protocol
+12 ; D RX
+13 ; Notify Applications that a Change has occurred
+14 DO NOTIFY^LEXXGI
+15 ; Send a Install Message
+16 DO MSG
+17 ; Clean up and Quit
+18 DO KLEXM
+19 QUIT
+20 ;
LOAD ; Load Data from ^LEXM into IC*/LEX Files
+1 NEW LEXB,LEXBUILD,LEXCD,LEXIGHF,LEXLAST,LEXLREV
DO IMP^LEX2031
+2 SET U="^"
SET LEXB=$GET(^LEXM(0,"BUILD"))
if LEXB=""
QUIT
if LEXBUILD=""
QUIT
+3 SET LEXCD=0
SET LEXCD=+($$CPD^LEX2031)
+4 IF LEXCD
IF LEXB=LEXBUILD
Begin DoDot:1
+5 SET X="Data for patch "_LEXBUILD_" has already been installed"
+6 if '$DATA(XPDNM)
WRITE !!,X
if $DATA(XPDNM)
DO BMES^XPDUTL(X)
+7 SET X=""
if '$DATA(XPDNM)
WRITE !
if $DATA(XPDNM)
DO MES^XPDUTL(X)
End DoDot:1
GOTO LQ
+8 if 'LEXCD&(LEXB=LEXBUILD)
DO EN^LEXXGI
LQ ; Load Quit
+1 DO KLEXM
+2 QUIT
+3 ;
MSG ; Send Installation Message to G.LEXICON
+1 if +($GET(DUZ))=0!($$NOTDEF^LEX2031($GET(DUZ)))
QUIT
+2 DO HOME^%ZIS
NEW DIFROM,LEXLREV,LEXLAST,LEXBUILD,LEXIGHF
+3 DO IMP^LEX2031
DO SEND^LEXXST
QUIT
+4 ;
SCHG ; Save Change File Changes
+1 DO MES^XPDUTL(" Updating Change File")
+2 NEW LEXI,LEXFI,LEXFIL
SET LEXFI=0
FOR
SET LEXFI=$ORDER(^LEXM(LEXFI))
if +LEXFI=0
QUIT
Begin DoDot:1
+3 SET LEXI=0
FOR
SET LEXI=$ORDER(^LEXM(LEXFI,LEXI))
if +LEXI=0
QUIT
Begin DoDot:2
+4 NEW LEXCF,LEXIEN
SET LEXMUMPS=$GET(^LEXM(LEXFI,LEXI))
SET LEXRT=$PIECE(LEXMUMPS,"^",2)
+5 if LEXMUMPS["^LEX("!(LEXMUMPS["^LEXT(")!(LEXMUMPS["^LEXC(")
SET LEXFIL=+($PIECE(LEXRT,"(",2))
+6 if LEXMUMPS["^ICD9("
SET LEXFIL=80
if LEXMUMPS["^ICD0("
SET LEXFIL=80.1
if LEXMUMPS["^ICPT("
SET LEXFIL=81
if LEXMUMPS["^DIC(81.3"
SET LEXFIL=81.3
+7 if +LEXFIL>0
SET LEXSCHG(+LEXFIL,0)=""
SET LEXCF=+($PIECE(LEXMUMPS,"LEXC(757.9,""AFIL"",",2))
+8 if $PIECE(LEXCF,".",1)'="757"&("^80^80.1^81^81.3^"'[("^"_LEXCF_"^"))
SET LEXCF=""
+9 SET LEXIEN=+($PIECE(LEXMUMPS,("LEXC(757.9,""AFIL"","_+LEXCF_","),2))
+10 IF +LEXIEN>0&(+LEXCF)>0&("^80^80.1^81^81.3)"[LEXCF)&(+LEXFIL=757.9)&(LEXMUMPS["LEXC(757.9")
Begin DoDot:3
+11 SET LEXSCHG(+LEXFIL,LEXIEN)=LEXCF
SET LEXSCHG(757.9,"B",+LEXCF,LEXIEN)=""
End DoDot:3
+12 if $LENGTH(LEXMUMPS)&($LENGTH(LEXCF))
SET LEXCHGS(LEXCF)=""
End DoDot:2
End DoDot:1
+13 QUIT
+14 ;
KLEXM ; Subscripted Kill of ^LEXM
+1 NEW DA
SET DA=0
FOR
SET DA=$ORDER(^LEXM(DA))
if +DA=0
QUIT
KILL ^LEXM(DA)
+2 KILL ^LEXM(0)
+3 QUIT
+4 ;
PRE ; LEX*2.0*31 Pre-Install (N/A for patch 31)
+1 QUIT
+2 ;
RX ; Reindex files 80, 80.1, 80.2, 81 and 81.3
+1 NEW LEX,DA,DIK,TH,TM,TD
+2 DO BMES^XPDUTL(" Re-indexing NEW Versioned Text Cross-References")
+3 ;
+4 DO BMES^XPDUTL(" ICD-9 Diagnosis file #80")
WRITE !," "
+5 SET (LEX,DA)=0
FOR
SET DA=$ORDER(^ICD9(DA))
if +DA=0
QUIT
KILL ^ICD9(DA,66,"B"),^ICD9(DA,67,"B"),^ICD9(DA,68,"B")
SET LEX=+($GET(LEX))+1
if LEX#120=0
WRITE "."
+6 KILL ^ICD9("AB"),^ICD9("ACC"),^ICD9("ACT"),^ICD9("BA"),^ICD9("D"),^ICD9("AST"),^ICD9("ADS")
SET DIK="^ICD9("
DO IXALL^DIK
+7 ;
+8 DO MES^XPDUTL(" ICD-9 Operations/Procedure file #80.1")
WRITE !," "
+9 SET (LEX,DA)=0
FOR
SET DA=$ORDER(^ICD0(DA))
if +DA=0
QUIT
KILL ^ICD0(DA,66,"B"),^ICD0(DA,67,"B"),^ICD0(DA,68,"B")
SET LEX=+($GET(LEX))+1
if LEX#120=0
WRITE "."
+10 KILL ^ICD0("AB"),^ICD0("ACT"),^ICD0("ADS"),^ICD0("AST"),^ICD0("BA"),^ICD0("D"),^ICD0("E")
SET DIK="^ICD0("
DO IXALL^DIK
+11 ;
+12 DO MES^XPDUTL(" DRG file #80.2")
WRITE !," "
+13 SET (LEX,DA)=0
FOR
SET DA=$ORDER(^ICD(DA))
if +DA=0
QUIT
KILL ^ICD(DA,1,"B"),^ICD(DA,66,"B"),^ICD(DA,68,"B")
SET LEX=+($GET(LEX))+1
if LEX#120=0
WRITE "."
+14 KILL ^ICD("ADS"),^ICD("B")
SET DIK="^ICD("
DO IXALL^DIK
+15 ;
+16 DO MES^XPDUTL(" CPT/HCPCS Procedure/Services file #81")
WRITE !," "
+17 SET (LEX,DA)=0
FOR
SET DA=$ORDER(^ICPT(DA))
if +DA=0
QUIT
Begin DoDot:1
+18 KILL ^ICPT(DA,60,"B"),^ICPT(DA,61,"B"),^ICPT(DA,62,"B"),^ICPT(DA,"D","B")
SET LEX=+($GET(LEX))+1
if LEX#120=0
WRITE "."
End DoDot:1
+19 KILL ^ICPT("ACT"),^ICPT("ADS"),^ICPT("AST"),^ICPT("B"),^ICPT("BA"),^ICPT("C"),^ICPT("D"),^ICPT("E"),^ICPT("F")
SET DIK="^ICPT("
DO IXALL^DIK
+20 ;
+21 DO MES^XPDUTL(" CPT Modifier file #81.3")
WRITE !," "
+22 SET (LEX,DA)=0
FOR
SET DA=$ORDER(^DIC(81.3,DA))
if +DA=0
QUIT
Begin DoDot:1
+23 KILL ^DIC(81.3,DA,60,"B"),^DIC(81.3,DA,61,"B"),^DIC(81.3,DA,62,"B")
SET LEX=+($GET(LEX))+1
if LEX#120=0
WRITE "."
End DoDot:1
+24 KILL ^DIC(81.3,"ACT"),^DIC(81.3,"ADS"),^DIC(81.3,"AST"),^DIC(81.3,"B"),^DIC(81.3,"BA"),^DIC(81.3,"C"),^DIC(81.3,"D"),^DIC(81.3,"M")
SET DIK="^DIC(81.3,"
DO IXALL^DIK
+25 QUIT
+26 ;
CON ; Conversion of data (for patch 31 only)
+1 DO BMES^XPDUTL(" Checking File 80/80.1 Input Transformations")
+2 DO AGE
DO SEX
+3 DO MES^XPDUTL(" ")
+4 QUIT
SEX ; Sex Field
+1 NEW LEXIEN,LEXSEX
SET LEXIEN=0
FOR
SET LEXIEN=$ORDER(^ICD0(LEXIEN))
if +LEXIEN=0
QUIT
Begin DoDot:1
+2 SET LEXSEX=$PIECE($GET(^ICD0(LEXIEN,0)),"^",10)
if LEXSEX'="T047"
QUIT
SET $PIECE(^ICD0(LEXIEN,0),"^",10)=""
End DoDot:1
+3 QUIT
AGE ; Age High Field
+1 NEW LEXIEN,LEXAGE
SET LEXIEN=0
FOR
SET LEXIEN=$ORDER(^ICD9(LEXIEN))
if +LEXIEN=0
QUIT
Begin DoDot:1
+2 SET LEXAGE=$PIECE($GET(^ICD9(LEXIEN,0)),"^",15)
if +LEXAGE'=124
QUIT
SET $PIECE(^ICD9(LEXIEN,0),"^",15)="99"
End DoDot:1
+3 QUIT