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

LEX2049P.m

Go to the documentation of this file.
  1. LEX2049P ; ISL/OI - Post Install LEX*2.0*49 ; 02/22/2007
  1. ;;2.0;LEXICON UTILITY;**49**;Sep 23, 1996;Build 3
  1. ;
  1. ; Global Variables
  1. ; ^%ZOSF("DEL"
  1. ; ^%ZOSF("TEST"
  1. ; ^LEXC
  1. ; ^LEXM(0
  1. ; ^LEXT(757.2
  1. ; ^ORD(101
  1. ; ^TMP("LEXCNT"
  1. ; ^TMP("LEXCS"
  1. ; ^TMP("LEXI"
  1. ; ^TMP("LEXINS"
  1. ; ^TMP("LEXKID"
  1. ; ^TMP("LEXMSG"
  1. ;
  1. ; External References
  1. ; HOME^%ZIS
  1. ; $$GET1^DID
  1. ; ^DIK
  1. ; ^DIM
  1. ; $$GET1^DIQ
  1. ; EN^DIU2
  1. ; $$DT^XLFDT
  1. ; $$FMTE^XLFDT
  1. ; $$NOW^XLFDT
  1. ; BMES^XPDUTL
  1. ; MES^XPDUTL
  1. ; EN^XQOR
  1. ; $$DTIME^XUP
  1. ;
  1. POST ; Post-Install Main Entry Point
  1. N CNT,DA,DIK,DIU,ERR,EXEC,FI,FIX,FNAME,I,INST,LEX,LEXBEG,LEXBUILD,LEXCHG,LEXEDT,LEXELP,LEXEND
  1. N LEXFC,LEXI,LEXID,LEXMOD,LEXMUL,LEXNM,LEXO,LEXP,LEXPOST,LEXSCHG,LEXSHORT,LEXSUB,LEXTCS,LEXTND
  1. N NAME,OK,PN,PNO,ROK,RTN,SSIEN,STR,T,TAG,TXT,TY,X,Y,ZTQUEUED,ZTREQ S LEXPOST="",LEXSHORT="",(LEXID,LEXSUB)="LEXKID" D MSG1
  1. S LEXCHG=1,LEXEDT=$$NOW^XLFDT,LEXSCHG("0")="1"
  1. S LEXSCHG("81",0)="",LEXSCHG("81.1",0)="",LEXSCHG("81.2",0)="",LEXSCHG("81.3",0)=""
  1. S LEXSCHG("B","81")="",LEXSCHG("B","81.1")="",LEXSCHG("B","81.2")="",LEXSCHG("B","81.3")=""
  1. S LEXSCHG("C","CPT","81")="",LEXSCHG("C","CPT","81.1")="",LEXSCHG("C","CPT","81.2")="",LEXSCHG("C","CPT","81.3")=""
  1. S LEXSCHG("80",0)="",LEXSCHG("80.1",0)=""
  1. S LEXSCHG("B","80")="",LEXSCHG("B","80.1")=""
  1. S LEXSCHG("C","ICD","80")="",LEXSCHG("C","ICD","80.1")=""
  1. S LEXSCHG("757",0)="",LEXSCHG("757.001",0)="",LEXSCHG("757.01",0)="",LEXSCHG("757.02",0)="",LEXSCHG("757.1",0)=""
  1. S LEXSCHG("B","757")="",LEXSCHG("B","757.001")="",LEXSCHG("B","757.01")="",LEXSCHG("B","757.02")="",LEXSCHG("B","757.1")=""
  1. S LEXSCHG("C","LEX","757")="",LEXSCHG("C","LEX","757.001")="",LEXSCHG("C","LEX","757.01")="",LEXSCHG("C","LEX","757.02")="",LEXSCHG("C","LEX","757.1")=""
  1. S LEXSCHG("D","PRO")="",LEXSHORT=""
  1. D DDUZ,CHGF,RTN,INST,NOTIFY,MSG2,KALL^LEXXGI2
  1. Q
  1. INST ; Installed Patches
  1. N INST,STR D BL
  1. S INST=$$PROK("PXRMCSD",9) S STR=" PXRM*2.0*9 "_$S(INST>0:"Installed",1:"Not Installed") D BM(STR),TL(STR)
  1. S INST=$$PROK("ICDUPDT",28) S STR=" ICD*18.0*28 "_$S(INST>0:"Installed",1:"Not Installed") D M(STR),TL(STR)
  1. S INST=$$PROK("ICPTAU",34) S STR=" ICPT*6.0*34 "_$S(INST>0:"Installed",1:"Not Installed") D M(STR),TL(STR)
  1. S INST=$$PROK("LEXXGI",49) S STR=" LEX*2.0*49 "_$S(INST>0:"Installed",1:"Not Installed") D M(STR),TL(STR)
  1. Q
  1. NOTIFY ; Notify by Protocol - LEXICAL SERVICES UPDATE
  1. N LEXP,X,STR
  1. S STR="ERROR: Array of files not found" D:'$D(LEXSCHG) BM(STR),BL,TL(STR) Q:'$D(LEXSCHG)
  1. S LEXP=+($O(^ORD(101,"B","LEXICAL SERVICES UPDATE",0)))
  1. S STR="ERROR: LEXICAL SERVICES UPDATE protocol not found" D:$G(LEXP)'>0 BM(STR),BL,TL(STR) Q:LEXP=0
  1. S X=LEXP_";ORD(101," D EN^XQOR
  1. S STR="ERROR: LEXICAL SERVICES UPDATE protocol not invoked" D:$D(LEXSCHG) BM(STR),BL,TL(STR) Q:$D(LEXSCHG)
  1. S ^LEXM(0,"PRO")=$$NOW^XLFDT,X="Protocol 'LEXICAL SERVICES UPDATE' was invoked"
  1. W:'$D(XPDNM) !!,X D:$D(XPDNM) BM(X)
  1. S (STR,X)="Subscribing applications were notified",STR=" "_STR D BL,TL(STR)
  1. W:'$D(XPDNM) !,X D:$D(XPDNM) M(X)
  1. Q
  1. CHGF ; Change File
  1. D M(" "),RI("Removing Change Files (757.9-757.91)","Remedy 175985") N FI,FNAME,ERR,ROK,STR
  1. S FI=757.91,FNAME=$$GET1^DID(FI,"","","NAME","","ERR") I $L(FNAME) D
  1. . N DIU,ERR S DIU="^LEXC("_FI_",",DIU(0)="D" D EN^DIU2 K:'$L($$GET1^DID(FI,"","","NAME","","ERR")) ^LEXC(FI)
  1. S FI=757.903,FNAME=$$GET1^DID(FI,"","","NAME","","ERR") I $L(FNAME) D
  1. . N DIU,ERR S DIU="^LEXC("_FI_",",DIU(0)="D" D EN^DIU2 K:'$L($$GET1^DID(FI,"","","NAME","","ERR")) ^LEXC(FI)
  1. S FI=757.9,FNAME=$$GET1^DID(FI,"","","NAME","","ERR") I $L(FNAME) D
  1. . N DIU,ERR S DIU="^LEXC("_FI_",",DIU(0)="D" D EN^DIU2 K:'$L($$GET1^DID(FI,"","","NAME","","ERR")) ^LEXC(FI)
  1. S FI=757.901,FNAME=$$GET1^DID(FI,"","","NAME","","ERR") I $L(FNAME) D
  1. . N DIU,ERR S DIU="^LEXC("_FI_",",DIU(0)="D" D EN^DIU2 K:'$L($$GET1^DID(FI,"","","NAME","","ERR")) ^LEXC(FI)
  1. S FI=757.902,FNAME=$$GET1^DID(FI,"","","NAME","","ERR") I $L(FNAME) D
  1. . N DIU,ERR S DIU="^LEXC("_FI_",",DIU(0)="D" D EN^DIU2 K:'$L($$GET1^DID(FI,"","","NAME","","ERR")) ^LEXC(FI)
  1. I '$D(^LEXC) S STR="Removed Change Files (757.9-757.91) (Remedy 175985)" D BL,TL(STR) Q
  1. Q
  1. RTN ; Routines
  1. D M(" "),BL D DRTN,MRTN
  1. Q
  1. DRTN ; Delete Routines
  1. N EXEC,ROK,RTN,STR,X
  1. S X=$G(^%ZOSF("DEL")) Q:'$L(X) D ^DIM Q:'$D(X) Q:'$L(X) S EXEC=X
  1. F RTN="LEXCHGF","LEXCHGF2","LEXNDX7","LEXXST5" D
  1. . S ROK=+($$ROK(RTN)) I +ROK'>0 S STR=" "_RTN,STR=STR_$J(" ",(17-$L(STR)))_"Deleted" D M(STR),TL(STR) Q
  1. . S X=RTN X EXEC
  1. . S ROK=+($$ROK(RTN)) I +ROK'>0 S STR=" "_RTN,STR=STR_$J(" ",(17-$L(STR)))_"Deleted" D M(STR),TL(STR) Q
  1. . S STR=" "_RTN D M(STR),TL(STR)
  1. Q
  1. MRTN ; Modified Routines
  1. N CNT,EXEC,FIX,I,RTN,PN,PNO,STR,TXT,TY S CNT=0 F I=1:1 D Q:'$L(TXT)
  1. . S TXT="" S EXEC="S TXT=$T(MRN+"_I_"^LEX2049P)" X EXEC
  1. . S TXT=$P(TXT,";;",2,299) Q:TXT=""
  1. . S RTN=$P(TXT,";",1) S:'$L(RTN) TXT="" Q:'$L(TXT) Q:+($$ROK(RTN))=0
  1. . S PN=$P(TXT,";",2),TY=$P(TXT,";",3),FIX=$P(TXT,";",4)
  1. . S PNO=$$PROK(RTN,PN)
  1. . S STR=" "_RTN S:+PNO>0 STR=STR_$J(" ",(17-$L(STR)))_TY S:+PNO>0 STR=STR_$J(" ",(29-$L(STR)))_FIX
  1. . D M(STR),TL(STR)
  1. Q
  1. MRN ; Modified Routine Names
  1. ;;LEXXFI;49;Modified;Removed references to file #757.9
  1. ;;LEXXFI7;49;Modified;Removed references to file #757.9
  1. ;;LEXXST;49;Modified;Removed references to file #757.9
  1. ;;LEXXGI;49;Modified;Fix LEXICAL SERVICES UPDATE Protocol
  1. ;;LEXXGI2;49;Modified;Fix LEXICAL SERVICES UPDATE Protocol
  1. ;;LEXXII;49;Modified;Fix Install Message (Protocol)
  1. ;;ICDUPDT;28;Modified;Fix ICD CODE UPDATE EVENT Protocol
  1. ;;ICPTAU;34;Modified;Fix ICPT CODE UPDATE EVENT Protocol
  1. ;;PXRMCSD;9;Modified;Fix ICD/CPT Reminder Dialogs Message
  1. ;;PXRMCSTX;9;Modified;Fix ICD/CPT Reminder Taxonomies Message
  1. ;;
  1. DDUZ ; Delete Exported DUZ if broken Pointer
  1. N STR S STR="Removing broken Pointer in file #757.2"
  1. D M(" "),RI(STR,"ROF LEX*2.0*46") S STR=STR_" (ROF LEX*2.0*46)" Q:$L($$GET1^DIQ(200,("1118,"),.01))
  1. D BL,TL(STR) N DA,DIK,NAME,SSIEN S SSIEN=0 F S SSIEN=$O(^LEXT(757.2,SSIEN)) Q:+SSIEN'>0 D
  1. . Q:'$D(^LEXT(757.2,SSIEN,200)) Q:$O(^LEXT(757.2,SSIEN,200,0))'>0 Q:'$D(^LEXT(757.2,SSIEN,200,1118))
  1. . N DA,DIK,NAME S NAME=$P($G(^LEXT(757.2,SSIEN,0)),"^",1) D:$L(NAME) CI((" "_NAME))
  1. . S DA(1)=SSIEN,DA=1118,DIK="^LEXT(757.2,"_SSIEN_",200," D ^DIK
  1. Q
  1. ROK(X) ; Routine OK
  1. S X=$G(X) Q:'$L(X) 0 Q:$L(X)>8 0 X ^%ZOSF("TEST") Q:$T 1 Q 0
  1. PROK(X,Y) ; Routine and Patch # OK (in UCI)
  1. N LEX,LEXI,LEXO S X=$G(X),Y=$G(Y) Q:'$L(X) 0 Q:Y'=""&(+Y=0)
  1. S Y=+Y,LEX=$$ROK(X) Q:'LEX 0 Q:+Y=0 1 S LEXO=0,LEX=$T(@("+2^"_X)),LEX=$P($P(LEX,"**",2),"**",1)
  1. F LEXI=1:1:$L(LEX,",") S:+($P(LEX,",",LEXI))=Y LEXO=1 Q:LEXO=1
  1. S X=LEXO
  1. Q X
  1. LL(T,X) ; Line Label
  1. N RTN,TAG,ROK,EXEC,OK S TAG=$G(T),RTN=$G(X) Q:'$L(RTN) 0 S ROK=$$ROK(RTN) Q:+ROK'>0 0 S:'$L(TAG)&($L(RTN)) TAG=RTN
  1. S OK=0,EXEC="S OK=$L($T("_TAG_"^"_RTN_")) S OK=$S(OK>0:1,1:0)" X EXEC S X=+($G(OK))
  1. Q X
  1. MSG1 ; Send Installation Message to G.LEXICON
  1. K ^TMP("LEXCS",$J),^TMP("LEXCNT",$J),^TMP("LEXI",$J),^TMP("LEXMSG",$J)
  1. K ^TMP("LEXINS",$J),^TMP("LEXKID",$J) S:$D(ZTQUEUED) ZTREQ="@"
  1. N LEXBEG,LEXELP,LEXEND,LEXFC,LEXMOD,LEXMUL,LEXTCS,LEXTND,LEXID,ZTQUEUED
  1. S LEXID="LEXKID",LEXMUL=1,(LEXTND,LEXTCS,LEXMOD,LEXFC,ZTQUEUED)=0
  1. D HDR^LEXXFI,EN^LEXXII K ^LEXM(0,"PRO")
  1. Q
  1. MSG2 ; Send Installation (part 2)
  1. N LEXSHORT,ZTQUEUED,LEXBUILD S ZTQUEUED=0,LEXSHORT=1,LEXBUILD="LEX*2.0*49"
  1. D MAIL^LEXXFI,KILL^LEXXFI
  1. Q
  1. ENV(X) ; Environment check
  1. N LEXNM D HOME^%ZIS S U="^",DT=$$DT^XLFDT,LEXNM=$$GET1^DIQ(200,+($G(DUZ)),.01),DTIME=$$DTIME^XUP(+($G(DUZ))) Q:+($G(DUZ))'>0!('$L(LEXNM)) 0
  1. Q 1
  1. ED(LEX) ; External Date MM/DD/YYYY TT:TT
  1. N XPDNM S LEX=$$FMTE^XLFDT($G(LEX),"1Z") S:LEX["@" LEX=$P(LEX,"@",1)_" "_$P(LEX,"@",2,299)
  1. Q LEX
  1. RI(X,Y) ; Reference - Indented
  1. N I S X=$G(X),Y=$G(Y) Q:'$L(X)
  1. I $L(Y) S X=" "_X F Q:$L(X)>54 S X=X_" "
  1. S X=X_" "_Y S:$E(X,1)'=" " X=" "_X D MES^XPDUTL(X) Q
  1. CI(X) ; Comment Text - Indented
  1. N I S X=$G(X) Q:'$L(X) S X=" "_X D MES^XPDUTL(X)
  1. Q
  1. BL ; Blank Line
  1. D TL("") Q
  1. TL(LEXX) ; Text Line
  1. S LEXSUB=$G(LEXSUB) S:'$L(LEXSUB) LEXSUB="LEXXII"
  1. I '$D(^TMP(LEXSUB,$J,1)) S ^TMP(LEXSUB,$J,1)=" ",^TMP(LEXSUB,$J,0)=1
  1. N LEXNX S LEXNX=$O(^TMP(LEXSUB,$J," "),-1),LEXNX=LEXNX+1
  1. S ^TMP(LEXSUB,$J,LEXNX)=" "_$G(LEXX),^TMP(LEXSUB,$J,0)=LEXNX
  1. Q
  1. BM(X) ; Blank and Line
  1. D BMES^XPDUTL($G(X))
  1. Q
  1. M(X) ; Line
  1. D MES^XPDUTL($G(X))
  1. Q