| 1 | LEXXII ;ISL/KER - Lexicon Status (Install Info) ;06/06/2007 | 
|---|
| 2 | ;;2.0;LEXICON UTILITY;**32,46,49,50,41**;Sep 23, 1996;Build 34 | 
|---|
| 3 | ; | 
|---|
| 4 | ; Variables NEWed or KILLed Elsewhere | 
|---|
| 5 | ;   LEXACCT  NEWed by LEXXFI sending message | 
|---|
| 6 | ;   LEXID    NEWed by LEXXFI sending message | 
|---|
| 7 | ;   LEXCRE   NEWed by LEXXGI loading data | 
|---|
| 8 | ;   LEXIGHF  NEWed by Post Install routine LEX20nnP | 
|---|
| 9 | ;   XPDA     NEWed by KIDS during Install | 
|---|
| 10 | ; | 
|---|
| 11 | ; Global Variables | 
|---|
| 12 | ;   DBIA 10096  ^%ZOSF("PROD" | 
|---|
| 13 | ;   DBIA 10096  ^%ZOSF("UCI" | 
|---|
| 14 | ;   DBIA 10060  ^VA(200 | 
|---|
| 15 | ;   ^LEXM(0 | 
|---|
| 16 | ;   ^TMP("LEX*",$J    SACC 2.3.2.5.1 | 
|---|
| 17 | ; | 
|---|
| 18 | ; External References | 
|---|
| 19 | ;   DBIA 10103  $$FMTE^XLFDT | 
|---|
| 20 | ;   DBIA 10103  $$NOW^XLFDT | 
|---|
| 21 | ;   DBIA 10103  $$FMDIFF^XLFDT | 
|---|
| 22 | ;   DBIA  2056  $$GET1^DIQ (file #200) | 
|---|
| 23 | ;   DBIA  2051  FIND^DIC | 
|---|
| 24 | ;   DBIA  2056  GETS^DIQ | 
|---|
| 25 | ; | 
|---|
| 26 | EN ; Main Entry | 
|---|
| 27 | N LEXSUB S LEXSUB=$G(LEXID) S:LEXSUB="" LEXSUB="LEXXII" K ^TMP(LEXSUB,$J) D II | 
|---|
| 28 | Q | 
|---|
| 29 | ; | 
|---|
| 30 | II ; Install Information | 
|---|
| 31 | N LEXT,LEXA,LEXACT,LEXB,LEXD,LEXE,LEXL,LEXU,LEXN,LEXP,LEXPROF,LEXDA H 2 | 
|---|
| 32 | S LEXA="",LEXACT=$G(LEXACCT),LEXPRO=$G(LEXPRO),LEXPRON=$G(LEXPRON) | 
|---|
| 33 | S:'$L(LEXPRON) LEXPRON="LEXICAL SERVICES UPDATE" S:'$L(LEXPRO) LEXPRO=$G(^LEXM(0,"PRO")) S:+LEXPRO>0 LEXPRO=$$ED(LEXPRO) | 
|---|
| 34 | S LEXT="Lexicon/ICD/CPT Installation" D TL(LEXT) | 
|---|
| 35 | S LEXT="============================" D TL(LEXT),BL | 
|---|
| 36 | S LEXD=$$ASOF,LEXA=$$UCI,LEXU=$$USR,LEXN=$P(LEXU,"^",1) | 
|---|
| 37 | S:$L($P(LEXACT,"^",1))&($L($P(LEXACT,"^",1))) LEXA=LEXACT | 
|---|
| 38 | S LEXP=$P(LEXU,"^",2),LEXN=$$PM^LEXXFI7(LEXN) | 
|---|
| 39 | S:$L(LEXD) LEXT="  As of:       "_LEXD | 
|---|
| 40 | D:$L(LEXD) TL(LEXT) | 
|---|
| 41 | S LEXT="" S:$L(LEXA) LEXT="  In Account:  "_$S($L($P(LEXA,"^",1)):"[",1:"")_$P(LEXA,"^",1)_$S($L($P(LEXA,"^",2)):"]",1:"") | 
|---|
| 42 | S:$L(LEXT)&($L($P(LEXA,"^",2))) LEXT=LEXT_"  "_$P(LEXA,"^",2) | 
|---|
| 43 | D:$L(LEXA) TL(LEXT) | 
|---|
| 44 | S LEXT="" S:$L(LEXU) LEXT="  Maint By:    " | 
|---|
| 45 | S:$L(LEXN) LEXT=LEXT_LEXN | 
|---|
| 46 | S:$L(LEXP)&($L(LEXN)) LEXT=LEXT_"   "_LEXP | 
|---|
| 47 | D:$L(LEXT)&(LEXT'["UNKNOWN") TL(LEXT) | 
|---|
| 48 | S LEXT="" S:$L($G(LEXBUILD)) LEXT="  Build:       "_$G(LEXBUILD) | 
|---|
| 49 | D:$L(LEXT) TL(LEXT) | 
|---|
| 50 | S LEXT="" S:$L($G(LEXIGHF)) LEXT="  Host File:   "_$G(LEXIGHF) | 
|---|
| 51 | S:$L(LEXT)&($L($G(LEXCRE)))&($P($G(LEXCRE),".",1)?7N) LEXT=LEXT_" (Created "_$$ED($G(LEXCRE))_")" | 
|---|
| 52 | S:'$L(LEXT)&($L($G(LEXCRE)))&($P($G(LEXCRE),".",1)?7N) LEXT="  Created:     "_$$ED($G(LEXCRE)) | 
|---|
| 53 | D:$L(LEXT) TL(LEXT) | 
|---|
| 54 | S LEXT="" I $L($G(LEXPRO))&($L($G(LEXPRON))) D | 
|---|
| 55 | . S LEXT="  Protocol:    "_LEXPRON D BL,TL(LEXT) | 
|---|
| 56 | . S LEXT="  Invoked:     "_LEXPRO D TL(LEXT) | 
|---|
| 57 | . K LEXPRO,LEXPRON,^LEXM(0,"PRO") | 
|---|
| 58 | S LEXB=$$SS($G(LEXBUILD)),LEXE=$P(LEXB,"^",2),LEXL=$P(LEXB,"^",3),LEXB=$P(LEXB,"^",1) | 
|---|
| 59 | I $P(LEXB,".",1)?7N!($P(LEXB,".",2)?7N)!($P(LEXB,".",3)[":") D | 
|---|
| 60 | . D BL | 
|---|
| 61 | . I $P(LEXB,".",1)?7N D | 
|---|
| 62 | . . S LEXT="" S LEXT="  Started:     "_$$ED($G(LEXB)) D TL(LEXT) | 
|---|
| 63 | . I $P(LEXE,".",1)?7N D | 
|---|
| 64 | . . S LEXT="" S LEXT="  Finished:    "_$$ED($G(LEXE)) D TL(LEXT) | 
|---|
| 65 | . I $L(LEXL) D | 
|---|
| 66 | . . S LEXT="" S LEXT="  Elapsed:     "_$$ED($G(LEXL)) D TL(LEXT) | 
|---|
| 67 | D BL | 
|---|
| 68 | Q | 
|---|
| 69 | ; | 
|---|
| 70 | ; Miscellaneous | 
|---|
| 71 | UCI(X) ;   UCI where Lexicon is installed | 
|---|
| 72 | N LEXU,LEXP,LEXT,Y X ^%ZOSF("UCI") S LEXU=Y,LEXP="" S:LEXU=^%ZOSF("PROD")!($P(LEXU,",",1)=^%ZOSF("PROD")) LEXP=" (Production)" | 
|---|
| 73 | S:LEXU'=^%ZOSF("PROD")&($P(LEXU,",",1)'=^%ZOSF("PROD")) LEXP=" (Test)" S X="",$P(X,"^",1)=LEXU,$P(X,"^",2)=LEXP | 
|---|
| 74 | Q X | 
|---|
| 75 | USR(LEX) ;   User/Person | 
|---|
| 76 | N LEXDUZ,LEXPH,LEXNM | 
|---|
| 77 | S LEX=+($G(DUZ)),LEXNM=$$GET1^DIQ(200,+LEX,.01) Q:'$L(LEXNM) "UNKNOWN^" | 
|---|
| 78 | S LEXDUZ=LEX S LEXPH=$$GET1^DIQ(200,+LEXDUZ,.132) S:LEXPH="" LEXPH=$$GET1^DIQ(200,+LEXDUZ,.131) | 
|---|
| 79 | S:LEXPH="" LEXPH=$$GET1^DIQ(200,+LEXDUZ,.133) S:LEXPH="" LEXPH=$$GET1^DIQ(200,+LEXDUZ,.134) | 
|---|
| 80 | S LEXDUZ=$$GET1^DIQ(200,+LEX,.01),LEX=LEXDUZ_"^"_LEXPH Q LEX | 
|---|
| 81 | SS(LEX) ;   Start/Stop Times | 
|---|
| 82 | N LEXDA,LEXOUT,LEXIENS,LEXB,LEXBUILD,LEXB,LEXE,LEXL | 
|---|
| 83 | S LEXBUILD=$G(LEX),LEXD=0 S:$L(LEXBUILD) LEXD=$$DDA(LEXBUILD) | 
|---|
| 84 | S LEXDA=+($G(XPDA)) | 
|---|
| 85 | I +LEXDA>0 D | 
|---|
| 86 | . S LEXIENS=LEXDA_"," | 
|---|
| 87 | . D GETS^DIQ(9.7,LEXIENS,"11;17","I","LEXOUT") | 
|---|
| 88 | . S LEXL=0,LEXB=$G(LEXOUT(9.7,LEXIENS,11,"I")) | 
|---|
| 89 | . S LEXE=$$NOW^XLFDT | 
|---|
| 90 | . S:+LEXB>0&(+LEXE>0) LEXL=$$EP(LEXB,LEXE) | 
|---|
| 91 | . S LEX=LEXB_"^"_LEXE S:$L(LEXL) $P(LEX,"^",3)=LEXL | 
|---|
| 92 | I +LEXDA=0 D | 
|---|
| 93 | . S LEX="" S LEXDA=+($G(LEXD)) Q:+LEXDA'>0 | 
|---|
| 94 | . S LEXL="",LEXB=$P($G(LEXD),"^",2) Q:$P(LEXB,".",1)'?7N | 
|---|
| 95 | . S LEXE=$$NOW^XLFDT | 
|---|
| 96 | . S:+LEXB>0&(+LEXE>0) LEXL=$$EP(LEXB,LEXE) | 
|---|
| 97 | . S LEX=LEXB_"^"_LEXE S:$L(LEXL) $P(LEX,"^",3)=LEXL | 
|---|
| 98 | Q LEX | 
|---|
| 99 | DDA(LEX) ;   Get Default DA of Build LEX | 
|---|
| 100 | N LEXB,LEXE,LEXOUT,LEXMSG,LEXI S LEXB=$G(LEX) Q:'$L(LEXB) "" | 
|---|
| 101 | D FIND^DIC(9.7,,"11I;17I","BP",LEXB,,"B",,,"LEXOUT","LEXMSG") | 
|---|
| 102 | S LEXI=+($O(LEXOUT("DILIST"," "),-1)) | 
|---|
| 103 | S LEXB=$G(LEXOUT("DILIST",+LEXI,0)) | 
|---|
| 104 | S LEXI=$P(LEXB,"^",1),LEXE=$P(LEXB,"^",4),LEXB=$P(LEXB,"^",3) | 
|---|
| 105 | Q:+($G(LEXI))'>0 ""  Q:+($G(LEXB))'>0 ""  S:+LEXE'>0 LEXE=$$NOW^XLFDT | 
|---|
| 106 | S LEX=LEXI_"^"_LEXB_"^"_LEXE | 
|---|
| 107 | Q LEX | 
|---|
| 108 | ASOF(LEX) ;   As of date/time | 
|---|
| 109 | S X=$$ED($$NOW^XLFDT) Q X | 
|---|
| 110 | ED(LEX) ;   External Date MM/DD/YYYY TT:TT | 
|---|
| 111 | S LEX=$$FMTE^XLFDT($G(LEX),"1Z") | 
|---|
| 112 | S:LEX["@" LEX=$P(LEX,"@",1)_"  "_$P(LEX,"@",2,299) Q LEX | 
|---|
| 113 | Q LEX | 
|---|
| 114 | EP(X,Y) ;   Elapsed Time (Begin, End) | 
|---|
| 115 | N LEXTIM,LEXBEG,LEXEND | 
|---|
| 116 | S LEXBEG=$G(X),LEXEND=$G(Y) Q:+LEXBEG'>0 ""  Q:+LEXEND'>0 "" | 
|---|
| 117 | S LEXTIM=$$FMDIFF^XLFDT(LEXEND,LEXBEG,2) Q:+LEXTIM'>0 "00:00:00" | 
|---|
| 118 | S LEXTIM=$$TIM(LEXTIM) | 
|---|
| 119 | Q LEXTIM | 
|---|
| 120 | TIM(X) ;   Format Time Elapsed | 
|---|
| 121 | N LEXD,LEXH,LEXM,LEXS,LEXT,LEXV S X=+($G(X)) Q:X'>0 "00:00:00" | 
|---|
| 122 | S LEXD=X\86400 S LEXV=LEXD*86400 S:+LEXV>0&(LEXV<X) X=X-LEXV | 
|---|
| 123 | S LEXH=X\3600 S LEXV=LEXH*3600 S:+LEXV>0&(LEXV<X) X=X-LEXV | 
|---|
| 124 | S:$L(LEXH)<2 LEXH="0"_LEXH S:$L(LEXH)<2 LEXH="0"_LEXH | 
|---|
| 125 | S LEXM=X\60 S LEXV=LEXM*60 S:+LEXV>0&(LEXV<X) X=X-LEXV | 
|---|
| 126 | S:$L(LEXM)<2 LEXM="0"_LEXM S:$L(LEXM)<2 LEXM="0"_LEXM | 
|---|
| 127 | S LEXS=X S:$L(LEXS)<2 LEXS="0"_LEXS S:$L(LEXS)<2 LEXS="0"_LEXS | 
|---|
| 128 | S LEXT="" S:+LEXD>0 LEXT=+LEXD_" day"_$S(+LEXD>1:"s",1:"")_" " | 
|---|
| 129 | S LEXT=LEXT_LEXH_":"_LEXM_":"_LEXS,X=LEXT | 
|---|
| 130 | Q X | 
|---|
| 131 | BL ;   Blank Line | 
|---|
| 132 | D TL("") Q | 
|---|
| 133 | TL(LEXX) ;   Text Line | 
|---|
| 134 | S LEXSUB=$G(LEXSUB) S:'$L(LEXSUB) LEXSUB="LEXXII" | 
|---|
| 135 | I '$D(^TMP(LEXSUB,$J,1)) S ^TMP(LEXSUB,$J,1)=" ",^TMP(LEXSUB,$J,0)=1 | 
|---|
| 136 | N LEXNX S LEXNX=$O(^TMP(LEXSUB,$J," "),-1),LEXNX=LEXNX+1 | 
|---|
| 137 | S ^TMP(LEXSUB,$J,LEXNX)=" "_$G(LEXX),^TMP(LEXSUB,$J,0)=LEXNX | 
|---|
| 138 | Q | 
|---|
| 139 | ST ;   Show Temp Array | 
|---|
| 140 | S LEXSUB=$G(LEXSUB) S:'$L(LEXSUB) LEXSUB="LEXXII" | 
|---|
| 141 | N LEXN,LEXC S LEXN="^TMP("""_LEXSUB_""","_$J_")",LEXC="^TMP("""_LEXSUB_""","_$J_"," | 
|---|
| 142 | F  S LEXN=$Q(@LEXN) Q:LEXN=""!(LEXN'[LEXC)  D | 
|---|
| 143 | . Q:LEXN[",0)"  W !,@LEXN | 
|---|
| 144 | Q | 
|---|