VistA-IHS-VA_UTILITIES-XB/XBPATSE.m

196 lines
6.0 KiB
Mathematica
Raw Normal View History

XBPATSE ; IHS/ADC/GTH - SEARCH ROUTINES FOR PATCHES ; [ 10/29/2002 7:42 AM ]
;;4.0;XB;;Jul 20, 2009;Build 2
; XB*3*9 IHS/SET/GTH XB*3*9 10/29/2002 Cache' mods.
;
; Search Routines for Patch Versions.
;
; Thanks to Ray A. Willie for the original routine.
;
MAIN ;
NEW XB,DUZ,IO,IOF,IOM,IOSL,IOBS,IOXY,IOST,DT,DTIME,POP,U,X,Y
D INIT
D:'$D(ZTQUEUED)
. D RSEL
. D:'XB("END") DEVICE
.Q
D:'XB("END") SRCH
D:'XB("END") PRT
D EXIT
Q
;
INIT ;
S (XB("END"),XB("VER"),XB("PNBR"),XB("Q"))=0,XB("NAM")=""
KILL ^TMP($J)
D:'$D(ZTQUEUED) ^XBKVAR,DT^DICRW,HOME^%ZIS
D NOW^%DTC
S Y=%
X ^DD("DD")
S XB("DT")=Y
X ^%ZOSF("UCI")
S XB("UCI")=$P(Y,","),XB("VOL")=$P(Y,",",2)
S XB("HD1")="R.P.M.S. PATCH SEARCH UTILITY Version: "_$P($T(+2),";",3)
S XB("HD2")="UCI: "_XB("UCI")_" CPU: "_XB("VOL")_" "_XB("DT")
Q
;
RSEL ;
D SCHDR
X ^%ZOSF("RSEL")
S XB("END")='$D(^UTILITY($J))
Q
;
DEVICE ;
NEW %ZIS
S %ZIS="NMQ"
D ^%ZIS
S XB("END")=POP
Q:XB("END")
S XB("IOP")=ION_";"_IOST_$S($D(IO("DOC")):";"_IO("DOC"),1:";"_IOM_";"_IOSL)
D:$D(IO("Q")) QUE
Q
;
QUE ;
NEW ZTRTN,ZTIO,ZTDESC,ZTSAVE,ZTSK
D:IO=IO(0)&($E(IOST,1,2)="C-")&($D(IO("Q"))#2)
. W !,"Cannot Queue to HOME or CHARACTER Device",!
. S XB("END")=1
.Q
Q:XB("END")
S ZTRTN="^"_$TR($P($T(+1),";")," ",""),ZTIO=XB("IOP"),ZTDESC=$P($T(+1),";",2)
F Q:$E(ZTDESC)'=" " S ZTDESC=$E(ZTDESC,2,99)
S ZTSAVE("^UTILITY($J,")=""
D ^%ZTLOAD
I '$D(ZTSK) W !,"TASK not Queued with Task Manager",! S XB("END")=1
Q:XB("END")
S %H=ZTSK("D")
D YX^%DTC
W !,"TASK Queued with Task Manager: JOB # ",ZTSK," at ",Y,!
D HOME^%ZIS
S XB("END")=1
Q
;
SRCH ;
NEW XCNP,DIF
D:'$D(ZTQUEUED) SCHDR
S XB("NSP")=""
F S XB("NSP")=$O(^DIC(9.4,"C",XB("NSP"))) Q:XB("NSP")="" D
. S XB("EIN")=0,XB("EIN")=$O(^DIC(9.4,"C",XB("NSP"),XB("EIN")))
. S XB("NAM")=$P($G(^DIC(9.4,XB("EIN"),0)),U)
. S XB("VER")=$G(^DIC(9.4,XB("EIN"),"VERSION"),0)
. S XB("ROU")=XB("NSP")
. S:$D(^UTILITY($J,XB("ROU"))) XB("ROU")=$O(^UTILITY($J,XB("ROU")),-1)
. F XB("RKT")=0:1 S XB("ROU")=$O(^UTILITY($J,XB("ROU"))) Q:$E(XB("ROU"),1,$L(XB("NSP")))'=XB("NSP") D SRCH1
. D:XB("RKT")>0 SRCH2
.Q
;S XB("NSP")="~~",XB("ROU")="";IHS/SET/GTH XB*3*9 10/29/2002
S XB("NSP")="~~",XB("ROU")=0 ;IHS/SET/GTH XB*3*9 10/29/2002
F XB("RKT")=0:1 S XB("ROU")=$O(^UTILITY($J,XB("ROU"))) Q:XB("ROU")="" D
. S XB("NAM")="",XB("VER")=0
. D SRCH1
.Q
S XB("NAM")="%",XB("VER")=0
D:XB("RKT")>0 SRCH2
Q
;
SRCH1 ;
D:'$D(ZTQUEUED)
. W:'(XB("RKT")#8) !
. W XB("ROU"),$J("",9-$L(XB("ROU")))
.Q
S XCNP=0,DIF="^TMP("_$J_",""R"","""_XB("ROU")_""",",X=XB("ROU")
X ^%ZOSF("TEST")
Q:'$T
X ^%ZOSF("LOAD")
S XB("PPC")=$TR($P($G(^TMP($J,"R",XB("ROU"),2,0)),";",5),"*","")
D:XB("PPC")]""&(XB("PPC")'=0)
. S:XB("NAM")="" XB("NAM")=$P($G(^TMP($J,"R",XB("ROU"),2,0)),";",4)
. S:XB("VER")=0 XB("VER")=$P($G(^TMP($J,"R",XB("ROU"),2,0)),";",3)
. S XB("DESC")=$S($P($P($G(^TMP($J,"R",XB("ROU"),1,0)),";",2),"-",2,3)'="":$P($P($G(^TMP($J,"R",XB("ROU"),1,0)),";",2),"-",2,3),1:$P($G(^TMP($J,"R",XB("ROU"),1,0)),";",3))
. F Q:$E(XB("DESC"))'=" " S XB("DESC")=$E(XB("DESC"),2,99)
. D:XB("VER")]""&(XB("NAM")]"")
.. F XB("J")=1:1 S XB("PNR")=$P(XB("PPC"),",",XB("J")) Q:XB("PNR")="" D:XB("PNR")?1.4N
... S ^TMP($J,"P",XB("NSP"),XB("NAM"),XB("VER"),XB("PNR"),XB("ROU"))=XB("DESC")
... S ^TMP($J,"P","P",XB("PNR"))=""
... S ^TMP($J,"P","R",XB("ROU"))=""
KILL ^TMP($J,"R",XB("ROU")),^UTILITY($J,XB("ROU"))
Q
;
SRCH2 ;
W:'$D(ZTQUEUED) !!?5,XB("RKT")," Routines Processed",!!
S (XB("PNR"),XB("ROU"))=""
F XB("PKT")=0:1 S XB("PNR")=$O(^TMP($J,"P","P",XB("PNR"))) Q:XB("PNR")=""
F XB("PRK")=0:1 S XB("ROU")=$O(^TMP($J,"P","R",XB("ROU"))) Q:XB("ROU")=""
KILL ^TMP($J,"P","P"),^TMP($J,"P","R")
S ^TMP($J,"P",XB("NSP"),XB("NAM"),XB("VER"),.01)=XB("RKT")
S ^TMP($J,"P",XB("NSP"),XB("NAM"),XB("VER"),.02)=XB("PKT")
S ^TMP($J,"P",XB("NSP"),XB("NAM"),XB("VER"),.03)=XB("PRK")
Q
;
SCHDR ;
W !,?IOM-$L(XB("HD1"))\2,XB("HD1"),!,?IOM-$L(XB("HD2"))\2,XB("HD2"),!
Q
;
PRT ;
S XB("PAGE")=0,XB("NSP")=""
D:'$D(ZTQUEUED)
. S IOP=XB("IOP")
. D ^%ZIS
.Q
U IO
D HDR
F S XB("NSP")=$O(^TMP($J,"P",XB("NSP"))) Q:XB("NSP")=""!(XB("END")) D
. S XB("NAM")=""
. F S XB("NAM")=$O(^TMP($J,"P",XB("NSP"),XB("NAM"))) Q:XB("NAM")=""!(XB("END")) D
.. D:XB("NAM")="%"
... W !!,"****",?5,"ROUTINES THAT ARE NOT IN PACKAGE FILE NAME-SPACE"
... W !?5,^TMP($J,"P",XB("NSP"),"%",0,.01)," TOTAL ROUTINE(s): "
... W ^TMP($J,"P",XB("NSP"),"%",0,.02)," PATCHE(s) in "
... W ^TMP($J,"P",XB("NSP"),"%",0,.03)," ROUTINE(s)",!
... S XB("NAM")=$O(^TMP($J,"P",XB("NSP"),XB("NAM")))
.. S XB("END")=(XB("NAM")="")
.. Q:XB("END")
.. S XB("VER")=.5
.. F S XB("VER")=$O(^TMP($J,"P",XB("NSP"),XB("NAM"),XB("VER"))) Q:XB("VER")=""!(XB("END")) D
... D:$Y+5>IOSL HDR
... Q:XB("END")
... W !!,XB("NSP"),?5,XB("NAM")," -- Version: ",XB("VER")
... D:XB("NSP")'="~~"
.... W !?5,^TMP($J,"P",XB("NSP"),XB("NAM"),XB("VER"),.01)," TOTAL ROUTINE(s): "
.... W ^TMP($J,"P",XB("NSP"),XB("NAM"),XB("VER"),.02)," PATCHE(s) in "
.... W ^TMP($J,"P",XB("NSP"),XB("NAM"),XB("VER"),.03)," ROUTINE(s)",!
... S XB("PNBR")=.5
... F S XB("PNBR")=$O(^TMP($J,"P",XB("NSP"),XB("NAM"),XB("VER"),XB("PNBR"))) Q:XB("PNBR")=""!(XB("END")) D
.... S XB("ROU")=""
.... F S XB("ROU")=$O(^TMP($J,"P",XB("NSP"),XB("NAM"),XB("VER"),XB("PNBR"),XB("ROU"))) Q:XB("ROU")=""!(XB("END")) D
..... D:$Y+5>IOSL HDR
..... Q:XB("END")
..... W !,$J(XB("PNBR"),4),?5,XB("ROU"),?14,^TMP($J,"P",XB("NSP"),XB("NAM"),XB("VER"),XB("PNBR"),XB("ROU"))
Q
;
HDR ;
NEW DIRUT,DUOUT
D:XB("PAGE")&($E(IOST,1,2)="C-")&(IO=IO(0))
. S Y=$$DIR^XBDIR("E")
. S:$D(DIRUT)!($D(DUOUT)) XB("END")=1
.Q
Q:XB("END")
HDR1 ;
D:$D(IO("S"))&('XB("PAGE"))
. S (DX,DY)=0
. X ^%ZOSF("XY")
.Q
W:$E(IOST,1,2)="C-"!(($E(IOST,1,2)'="C-")&(XB("PAGE"))) @IOF
HDR2 ;
S XB("PAGE")=XB("PAGE")+1
W !,?IOM-$L(XB("HD1"))\2,XB("HD1"),?(IOM-15),"PAGE: ",$J(XB("PAGE"),3)
W !,?IOM-$L(XB("HD2"))\2,XB("HD2")
W !,"PATCH"
W !,"NMBR",?5,"ROUTINE",?14,"ROUTINE DESCRIPTION"
W !,"==== ======== ",$$REPEAT^XLFSTR("=",IOM-19)
Q
;
EXIT ;
D ^%ZISC
KILL ^UTILITY($J),^TMP($J)
Q
;