| [613] | 1 | LEX2040P ; ISL/KER - Pre/Post Install ; 04/06/2006
 | 
|---|
 | 2 |  ;;2.0;LEXICON UTILITY;**40**;Sep 23, 1996;Build 1
 | 
|---|
 | 3 |  ;
 | 
|---|
 | 4 |  ; External References
 | 
|---|
 | 5 |  ;   DBIA 10086  HOME^%ZIS
 | 
|---|
 | 6 |  ;   DBIA  2052  $$GET1^DID
 | 
|---|
 | 7 |  ;   DBIA  2055  PRD^DILFD
 | 
|---|
 | 8 |  ;   DBIA 10014  EN^DIU2
 | 
|---|
 | 9 |  ;   DBIA 10141  BMES^XPDUTL
 | 
|---|
 | 10 |  ;   DBIA 10141  MES^XPDUTL
 | 
|---|
 | 11 |  ;                      
 | 
|---|
 | 12 |  Q
 | 
|---|
 | 13 |  ;                      
 | 
|---|
 | 14 | POST ; LEX*2.0*40 Post-Install
 | 
|---|
 | 15 |  N LEXEDT,LEXCHG,LEXSCHG S LEXEDT=$G(^LEXM(0,"CREATED"))
 | 
|---|
 | 16 |  S LEXCHG=0 S:$D(^LEXM(80))!($D(^LEXM(80.1)))!($D(^LEXM(81)))!($D(^LEXM(81.2)))!($D(^LEXM(81.3))) LEXCHG=1
 | 
|---|
 | 17 |  ;
 | 
|---|
 | 18 |  ;-----------------------------
 | 
|---|
 | 19 |  ;   Save Changes
 | 
|---|
 | 20 |  D SCHG
 | 
|---|
 | 21 |  ;
 | 
|---|
 | 22 |  ;-----------------------------
 | 
|---|
 | 23 |  ;   Load Data into Files
 | 
|---|
 | 24 |  D LOAD
 | 
|---|
 | 25 |  ;
 | 
|---|
 | 26 |  ;-----------------------------
 | 
|---|
 | 27 |  ;   Data Conversion
 | 
|---|
 | 28 |  D CON
 | 
|---|
 | 29 |  ;
 | 
|---|
 | 30 |  ;-----------------------------
 | 
|---|
 | 31 |  ;   Re-Index Files - N/A for LEX*2.0*40
 | 
|---|
 | 32 |  ;   Do not use for Annual/Quarterly Updates, it disrupts the Protocol
 | 
|---|
 | 33 |  ;   D RX
 | 
|---|
 | 34 |  ;
 | 
|---|
 | 35 |  ;-----------------------------
 | 
|---|
 | 36 |  ;   Fire Protocol 
 | 
|---|
 | 37 |  D NOTIFY^LEXXGI
 | 
|---|
 | 38 |  ;
 | 
|---|
 | 39 |  ;-----------------------------
 | 
|---|
 | 40 |  ;   Send a Install Message
 | 
|---|
 | 41 |  D MSG
 | 
|---|
 | 42 |  ;
 | 
|---|
 | 43 |  ;-----------------------------
 | 
|---|
 | 44 |  ;   Clean up and Quit
 | 
|---|
 | 45 |  D KLEXM
 | 
|---|
 | 46 |  Q
 | 
|---|
 | 47 |  ;                      
 | 
|---|
 | 48 | LOAD ; Load Data from ^LEXM into IC*/LEX Files
 | 
|---|
 | 49 |  N LEXB,LEXBUILD,LEXCD,LEXIGHF,LEXLAST,LEXLREV D IMP^LEX2040
 | 
|---|
 | 50 |  S U="^",LEXB=$G(^LEXM(0,"BUILD")) Q:LEXB=""  Q:LEXBUILD=""
 | 
|---|
 | 51 |  S LEXCD=0 S LEXCD=+($$CPD^LEX2040)
 | 
|---|
 | 52 |  I LEXCD,LEXB=LEXBUILD D  G LQ
 | 
|---|
 | 53 |  . S X="Data for patch "_LEXBUILD_" has already been installed"
 | 
|---|
 | 54 |  . W:'$D(XPDNM) !!,X D:$D(XPDNM) BMES^XPDUTL(X)
 | 
|---|
 | 55 |  . S X="" W:'$D(XPDNM) ! D:$D(XPDNM) MES^XPDUTL(X)
 | 
|---|
 | 56 |  D:'LEXCD&(LEXB=LEXBUILD) EN^LEXXGI
 | 
|---|
 | 57 | LQ ; Load Quit
 | 
|---|
 | 58 |  D KLEXM
 | 
|---|
 | 59 |  Q
 | 
|---|
 | 60 |  ;
 | 
|---|
 | 61 | MSG ; Send Installation Message to G.LEXICON
 | 
|---|
 | 62 |  Q:+($G(DUZ))=0!($$NOTDEF^LEX2040($G(DUZ)))
 | 
|---|
 | 63 |  D HOME^%ZIS N DIFROM,LEXLREV,LEXLAST,LEXBUILD,LEXIGHF
 | 
|---|
 | 64 |  D IMP^LEX2040,POST^LEXXFI Q
 | 
|---|
 | 65 |  ;
 | 
|---|
 | 66 | SCHG ; Save Change File Changes
 | 
|---|
 | 67 |  N LEXI,LEXFI,LEXFIL S LEXFI=0 F  S LEXFI=$O(^LEXM(LEXFI)) Q:+LEXFI=0  D
 | 
|---|
 | 68 |  . S LEXI=0 F  S LEXI=$O(^LEXM(LEXFI,LEXI)) Q:+LEXI=0  D
 | 
|---|
 | 69 |  . . N LEXCF,LEXIEN S LEXMUMPS=$G(^LEXM(LEXFI,LEXI)),LEXRT=$P(LEXMUMPS,"^",2)
 | 
|---|
 | 70 |  . . S:LEXMUMPS["^LEX("!(LEXMUMPS["^LEXT(")!(LEXMUMPS["^LEXC(") LEXFIL=+($P(LEXRT,"(",2))
 | 
|---|
 | 71 |  . . S:LEXMUMPS["^ICD9(" LEXFIL=80 S:LEXMUMPS["^ICD0(" LEXFIL=80.1 S:LEXMUMPS["^ICPT(" LEXFIL=81 S:LEXMUMPS["^DIC(81.3" LEXFIL=81.3
 | 
|---|
 | 72 |  . . S:+LEXFIL>0 LEXSCHG(+LEXFIL,0)="" S LEXCF=+($P(LEXMUMPS,"LEXC(757.9,""AFIL"",",2))
 | 
|---|
 | 73 |  . . S:$P(LEXCF,".",1)'="757"&("^80^80.1^81^81.3^"'[("^"_LEXCF_"^")) LEXCF=""
 | 
|---|
 | 74 |  . . S LEXIEN=+($P(LEXMUMPS,("LEXC(757.9,""AFIL"","_+LEXCF_","),2))
 | 
|---|
 | 75 |  . . I +LEXIEN>0&(+LEXCF)>0&("^80^80.1^81^81.3)"[LEXCF)&(+LEXFIL=757.9)&(LEXMUMPS["LEXC(757.9") D
 | 
|---|
 | 76 |  . . . S LEXSCHG(+LEXFIL,LEXIEN)=LEXCF,LEXSCHG(757.9,"B",+LEXCF,LEXIEN)=""
 | 
|---|
 | 77 |  . . S:$L(LEXMUMPS)&($L(LEXCF)) LEXCHGS(LEXCF)=""
 | 
|---|
 | 78 |  Q
 | 
|---|
 | 79 |  ;
 | 
|---|
 | 80 | KLEXM ; Subscripted Kill of ^LEXM
 | 
|---|
 | 81 |  N DA S DA=0 F  S DA=$O(^LEXM(DA)) Q:+DA=0  K ^LEXM(DA)
 | 
|---|
 | 82 |  K ^LEXM(0)
 | 
|---|
 | 83 |  Q
 | 
|---|
 | 84 |  ;
 | 
|---|
 | 85 | PRE ; LEX*2.0*40 Pre-Install   (N/A for patch 40)
 | 
|---|
 | 86 |  Q
 | 
|---|
 | 87 |  ;
 | 
|---|
 | 88 | RX ; Reindex files            (N/A for patch 40)
 | 
|---|
 | 89 |  Q
 | 
|---|
 | 90 |  N LEX,DA,DIK,TH,TM,TD
 | 
|---|
 | 91 |  D BMES^XPDUTL(" Re-indexing NEW Versioned Text Cross-References")
 | 
|---|
 | 92 |  ;
 | 
|---|
 | 93 |  D BMES^XPDUTL("   ICD-9 Diagnosis file                 #80") W !,"   "
 | 
|---|
 | 94 |  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 "."
 | 
|---|
 | 95 |  K ^ICD9("AB"),^ICD9("ACC"),^ICD9("ACT"),^ICD9("BA"),^ICD9("D"),^ICD9("AST"),^ICD9("ADS") S DIK="^ICD9(" D IXALL^DIK
 | 
|---|
 | 96 |  ;
 | 
|---|
 | 97 |  D MES^XPDUTL("   ICD-9 Operations/Procedure file      #80.1") W !,"   "
 | 
|---|
 | 98 |  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 "."
 | 
|---|
 | 99 |  K ^ICD0("AB"),^ICD0("ACT"),^ICD0("ADS"),^ICD0("AST"),^ICD0("BA"),^ICD0("D"),^ICD0("E") S DIK="^ICD0(" D IXALL^DIK
 | 
|---|
 | 100 |  ;
 | 
|---|
 | 101 |  D MES^XPDUTL("   DRG file                             #80.2") W !,"   "
 | 
|---|
 | 102 |  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 "."
 | 
|---|
 | 103 |  K ^ICD("ADS"),^ICD("B") S DIK="^ICD(" D IXALL^DIK
 | 
|---|
 | 104 |  ;
 | 
|---|
 | 105 |  D MES^XPDUTL("   CPT/HCPCS Procedure/Services file    #81") W !,"   "
 | 
|---|
 | 106 |  S (LEX,DA)=0 F  S DA=$O(^ICPT(DA)) Q:+DA=0  D
 | 
|---|
 | 107 |  . 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 "."
 | 
|---|
 | 108 |  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
 | 
|---|
 | 109 |  ;
 | 
|---|
 | 110 |  D MES^XPDUTL("   CPT Modifier file                    #81.3") W !,"   "
 | 
|---|
 | 111 |  S (LEX,DA)=0 F  S DA=$O(^DIC(81.3,DA)) Q:+DA=0  D
 | 
|---|
 | 112 |  . 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 "."
 | 
|---|
 | 113 |  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
 | 
|---|
 | 114 |  Q
 | 
|---|
 | 115 |  ;
 | 
|---|
 | 116 | CON ; Conversion of data       (Add LEXVDT to screens)
 | 
|---|
 | 117 |  N IEN,DA,DIK
 | 
|---|
 | 118 |  S ^LEX(757.3,1,1)="I $$SC^LEXU(Y,""BEH/DIS;999/64/66/73/74/77/82/169/170/171;ICD/CPT/CPC"",+($G(LEXVDT)))"
 | 
|---|
 | 119 |  S ^LEX(757.3,2,1)="I $L($$ICDONE^LEXU(+Y,+($G(LEXVDT))))!($L($$CPTONE^LEXU(+Y,+($G(LEXVDT)))))!($L($$CPCONE^LEXU(+Y,+($G(LEXVDT)))))"
 | 
|---|
 | 120 |  S ^LEX(757.3,3,1)="I $$SC^LEXU(Y,""BEH/DIS;999/64/66/73/74/77/82/169/170/171;ICD/CPT/CPC/DS4"",+($G(LEXVDT)))"
 | 
|---|
 | 121 |  S ^LEX(757.3,4,1)="I $$SO^LEXU(Y,""NAN/OMA"",+($G(LEXVDT)))"
 | 
|---|
 | 122 |  S ^LEX(757.3,5,1)="I $$SC^LEXU(Y,""BEH/DIS;999/64/66/73/74/77/82/169/170/171;ICD/CPT/CPC/DS4"",+($G(LEXVDT)))"
 | 
|---|
 | 123 |  S ^LEX(757.3,6,1)="I $$SO^LEXU(Y,""NAN/OMA"",+($G(LEXVDT)))"
 | 
|---|
 | 124 |  S ^LEX(757.3,8,1)="I $L($$ICDONE^LEXU(+Y,+($G(LEXVDT))))"
 | 
|---|
 | 125 |  S ^LEX(757.3,9,1)="I $L($$CPTONE^LEXU(+Y,+($G(LEXVDT))))!($L($$CPCONE^LEXU(+Y,+($G(LEXVDT)))))"
 | 
|---|
 | 126 |  S ^LEX(757.3,10,1)="I $$SO^LEXU(Y,""DS4"",+($G(LEXVDT)))"
 | 
|---|
 | 127 |  K ^LEX(757.3,"APPS"),^LEX(757.3,"AS"),^LEX(757.3,"B"),^LEX(757.3,"C"),^LEX(757.3,"D")
 | 
|---|
 | 128 |  S IEN=0 F  S IEN=$O(^LEX(757.3,IEN)) Q:+IEN'>0  S DA=+IEN,DIK="^LEX(757.3," D IX1^DIK
 | 
|---|
 | 129 |  S NEW="I $$SC^LEXU(Y,""BEH/DIS;999/64/66/73/74/77/82/169/170/171;ICD/CPT/CPC"",+($G(LEXVDT)))"
 | 
|---|
 | 130 |  S OLD="I $$SC^LEXU(Y,""BEH/DIS;999/64/66/73/74/77/82/169/170/171;ICD/CPT/CPC"")" D SW
 | 
|---|
 | 131 |  S NEW="I $L($$ICDONE^LEXU(+Y,+($G(LEXVDT))))!($L($$CPTONE^LEXU(+Y,+($G(LEXVDT)))))!($L($$CPCONE^LEXU(+Y,+($G(LEXVDT)))))"
 | 
|---|
 | 132 |  S OLD="I $L($$ICDONE^LEXU(+Y))!($L($$CPTONE^LEXU(+Y)))!($L($$CPCONE^LEXU(+Y)))" D SW
 | 
|---|
 | 133 |  S NEW="I $$SC^LEXU(Y,""BEH/DIS;999/64/66/73/74/77/82/169/170/171;ICD/CPT/CPC/DS4"",+($G(LEXVDT)))"
 | 
|---|
 | 134 |  S OLD="I $$SC^LEXU(Y,""BEH/DIS;999/64/66/73/74/77/82/169/170/171;ICD/CPT/CPC/DS4"")" D SW
 | 
|---|
 | 135 |  S NEW="I $$SO^LEXU(Y,""NAN/OMA"",+($G(LEXVDT)))"
 | 
|---|
 | 136 |  S OLD="I $$SO^LEXU(Y,""NAN/OMA"")" D SW
 | 
|---|
 | 137 |  S NEW="I $$SC^LEXU(Y,""BEH/DIS;999/64/66/73/74/77/82/169/170/171;ICD/CPT/CPC/DS4"",+($G(LEXVDT)))"
 | 
|---|
 | 138 |  S OLD="I $$SC^LEXU(Y,""BEH/DIS;999/64/66/73/74/77/82/169/170/171;ICD/CPT/CPC/DS4"")" D SW
 | 
|---|
 | 139 |  S NEW="I $$SO^LEXU(Y,""NAN/OMA"",+($G(LEXVDT)))"
 | 
|---|
 | 140 |  S OLD="I $$SO^LEXU(Y,""NAN/OMA"")" D SW
 | 
|---|
 | 141 |  S NEW="I $L($$ICDONE^LEXU(+Y,+($G(LEXVDT))))"
 | 
|---|
 | 142 |  S OLD="I $L($$ICDONE^LEXU(+Y))" D SW
 | 
|---|
 | 143 |  S NEW="I $L($$CPTONE^LEXU(+Y,+($G(LEXVDT))))!($L($$CPCONE^LEXU(+Y,+($G(LEXVDT)))))"
 | 
|---|
 | 144 |  S OLD="I $L($$CPTONE^LEXU(+Y))!($L($$CPCONE^LEXU(+Y)))" D SW
 | 
|---|
 | 145 |  S NEW="I $$SO^LEXU(Y,""DS4"",+($G(LEXVDT)))"
 | 
|---|
 | 146 |  S OLD="I $$SO^LEXU(Y,""DS4"")" D SW
 | 
|---|
 | 147 |  Q
 | 
|---|
 | 148 | SW ; Swap
 | 
|---|
 | 149 |  N IEN S IEN=0 F  S IEN=$O(^LEXT(757.2,IEN)) Q:+IEN=0  D
 | 
|---|
 | 150 |  . I $G(^LEXT(757.2,IEN,6))=OLD S ^LEXT(757.2,IEN,6)=NEW
 | 
|---|
 | 151 |  . N USR S USR=0 F  S USR=$O(^LEXT(757.2,IEN,200,USR)) Q:+USR=0  D
 | 
|---|
 | 152 |  . . I $G(^LEXT(757.2,IEN,200,USR,1))=OLD S ^LEXT(757.2,IEN,200,USR,1)=NEW
 | 
|---|
 | 153 |  Q
 | 
|---|