| 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 | 
|---|