- XBPATSE ; IHS/ADC/GTH - SEARCH ROUTINES FOR PATCHES ; [ 10/29/2002 7:42 AM ]
- ;;3.0;IHS/VA UTILITIES;**9**;FEB 07, 1997
- ; 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
- ;
- XBPATSE ; IHS/ADC/GTH - SEARCH ROUTINES FOR PATCHES ; [ 10/29/2002 7:42 AM ]
- +1 ;;3.0;IHS/VA UTILITIES;**9**;FEB 07, 1997
- +2 ; XB*3*9 IHS/SET/GTH XB*3*9 10/29/2002 Cache' mods.
- +3 ;
- +4 ; Search Routines for Patch Versions.
- +5 ;
- +6 ; Thanks to Ray A. Willie for the original routine.
- +7 ;
- MAIN ;
- +1 NEW XB,DUZ,IO,IOF,IOM,IOSL,IOBS,IOXY,IOST,DT,DTIME,POP,U,X,Y
- +2 DO INIT
- +3 IF '$DATA(ZTQUEUED)
- Begin DoDot:1
- +4 DO RSEL
- +5 IF 'XB("END")
- DO DEVICE
- +6 QUIT
- End DoDot:1
- +7 IF 'XB("END")
- DO SRCH
- +8 IF 'XB("END")
- DO PRT
- +9 DO EXIT
- +10 QUIT
- +11 ;
- INIT ;
- +1 SET (XB("END"),XB("VER"),XB("PNBR"),XB("Q"))=0
- SET XB("NAM")=""
- +2 KILL ^TMP($JOB)
- +3 IF '$DATA(ZTQUEUED)
- DO ^XBKVAR
- DO DT^DICRW
- DO HOME^%ZIS
- +4 DO NOW^%DTC
- +5 SET Y=%
- +6 XECUTE ^DD("DD")
- +7 SET XB("DT")=Y
- +8 XECUTE ^%ZOSF("UCI")
- +9 SET XB("UCI")=$PIECE(Y,",")
- SET XB("VOL")=$PIECE(Y,",",2)
- +10 SET XB("HD1")="R.P.M.S. PATCH SEARCH UTILITY Version: "_$PIECE($TEXT(+2),";",3)
- +11 SET XB("HD2")="UCI: "_XB("UCI")_" CPU: "_XB("VOL")_" "_XB("DT")
- +12 QUIT
- +13 ;
- RSEL ;
- +1 DO SCHDR
- +2 XECUTE ^%ZOSF("RSEL")
- +3 SET XB("END")='$DATA(^UTILITY($JOB))
- +4 QUIT
- +5 ;
- DEVICE ;
- +1 NEW %ZIS
- +2 SET %ZIS="NMQ"
- +3 DO ^%ZIS
- +4 SET XB("END")=POP
- +5 IF XB("END")
- QUIT
- +6 SET XB("IOP")=ION_";"_IOST_$SELECT($DATA(IO("DOC")):";"_IO("DOC"),1:";"_IOM_";"_IOSL)
- +7 IF $DATA(IO("Q"))
- DO QUE
- +8 QUIT
- +9 ;
- QUE ;
- +1 NEW ZTRTN,ZTIO,ZTDESC,ZTSAVE,ZTSK
- +2 IF IO=IO(0)&($EXTRACT(IOST,1,2)="C-")&($DATA(IO("Q"))#2)
- Begin DoDot:1
- +3 WRITE !,"Cannot Queue to HOME or CHARACTER Device",!
- +4 SET XB("END")=1
- +5 QUIT
- End DoDot:1
- +6 IF XB("END")
- QUIT
- +7 SET ZTRTN="^"_$TRANSLATE($PIECE($TEXT(+1),";")," ","")
- SET ZTIO=XB("IOP")
- SET ZTDESC=$PIECE($TEXT(+1),";",2)
- +8 FOR
- IF $EXTRACT(ZTDESC)'=" "
- QUIT
- SET ZTDESC=$EXTRACT(ZTDESC,2,99)
- +9 SET ZTSAVE("^UTILITY($J,")=""
- +10 DO ^%ZTLOAD
- +11 IF '$DATA(ZTSK)
- WRITE !,"TASK not Queued with Task Manager",!
- SET XB("END")=1
- +12 IF XB("END")
- QUIT
- +13 SET %H=ZTSK("D")
- +14 DO YX^%DTC
- +15 WRITE !,"TASK Queued with Task Manager: JOB # ",ZTSK," at ",Y,!
- +16 DO HOME^%ZIS
- +17 SET XB("END")=1
- +18 QUIT
- +19 ;
- SRCH ;
- +1 NEW XCNP,DIF
- +2 IF '$DATA(ZTQUEUED)
- DO SCHDR
- +3 SET XB("NSP")=""
- +4 FOR
- SET XB("NSP")=$ORDER(^DIC(9.4,"C",XB("NSP")))
- IF XB("NSP")=""
- QUIT
- Begin DoDot:1
- +5 SET XB("EIN")=0
- SET XB("EIN")=$ORDER(^DIC(9.4,"C",XB("NSP"),XB("EIN")))
- +6 SET XB("NAM")=$PIECE($GET(^DIC(9.4,XB("EIN"),0)),U)
- +7 SET XB("VER")=$GET(^DIC(9.4,XB("EIN"),"VERSION"),0)
- +8 SET XB("ROU")=XB("NSP")
- +9 IF $DATA(^UTILITY($JOB,XB("ROU")))
- SET XB("ROU")=$ORDER(^UTILITY($JOB,XB("ROU")),-1)
- +10 FOR XB("RKT")=0:1
- SET XB("ROU")=$ORDER(^UTILITY($JOB,XB("ROU")))
- IF $EXTRACT(XB("ROU"),1,$LENGTH(XB("NSP")))'=XB("NSP")
- QUIT
- DO SRCH1
- +11 IF XB("RKT")>0
- DO SRCH2
- +12 QUIT
- End DoDot:1
- +13 ;S XB("NSP")="~~",XB("ROU")="";IHS/SET/GTH XB*3*9 10/29/2002
- +14 ;IHS/SET/GTH XB*3*9 10/29/2002
- SET XB("NSP")="~~"
- SET XB("ROU")=0
- +15 FOR XB("RKT")=0:1
- SET XB("ROU")=$ORDER(^UTILITY($JOB,XB("ROU")))
- IF XB("ROU")=""
- QUIT
- Begin DoDot:1
- +16 SET XB("NAM")=""
- SET XB("VER")=0
- +17 DO SRCH1
- +18 QUIT
- End DoDot:1
- +19 SET XB("NAM")="%"
- SET XB("VER")=0
- +20 IF XB("RKT")>0
- DO SRCH2
- +21 QUIT
- +22 ;
- SRCH1 ;
- +1 IF '$DATA(ZTQUEUED)
- Begin DoDot:1
- +2 IF '(XB("RKT")#8)
- WRITE !
- +3 WRITE XB("ROU"),$JUSTIFY("",9-$LENGTH(XB("ROU")))
- +4 QUIT
- End DoDot:1
- +5 SET XCNP=0
- SET DIF="^TMP("_$JOB_",""R"","""_XB("ROU")_""","
- SET X=XB("ROU")
- +6 XECUTE ^%ZOSF("TEST")
- +7 IF '$TEST
- QUIT
- +8 XECUTE ^%ZOSF("LOAD")
- +9 SET XB("PPC")=$TRANSLATE($PIECE($GET(^TMP($JOB,"R",XB("ROU"),2,0)),";",5),"*","")
- +10 IF XB("PPC")]""&(XB("PPC")'=0)
- Begin DoDot:1
- +11 IF XB("NAM")=""
- SET XB("NAM")=$PIECE($GET(^TMP($JOB,"R",XB("ROU"),2,0)),";",4)
- +12 IF XB("VER")=0
- SET XB("VER")=$PIECE($GET(^TMP($JOB,"R",XB("ROU"),2,0)),";",3)
- +13 SET XB("DESC")=$SELECT($PIECE($PIECE($GET(^TMP($JOB,"R",XB("ROU"),1,0)),";",2),"-",2,3)'="":$PIECE($PIECE($GET(^TMP($JOB,"R",XB("ROU"),1,0)),";",2),"-",2,3),1:$PIECE($GET(^TMP($JOB,"R",XB("ROU"),1,0)),";",3))
- +14 FOR
- IF $EXTRACT(XB("DESC"))'=" "
- QUIT
- SET XB("DESC")=$EXTRACT(XB("DESC"),2,99)
- +15 IF XB("VER")]""&(XB("NAM")]"")
- Begin DoDot:2
- +16 FOR XB("J")=1:1
- SET XB("PNR")=$PIECE(XB("PPC"),",",XB("J"))
- IF XB("PNR")=""
- QUIT
- IF XB("PNR")?1.4N
- Begin DoDot:3
- +17 SET ^TMP($JOB,"P",XB("NSP"),XB("NAM"),XB("VER"),XB("PNR"),XB("ROU"))=XB("DESC")
- +18 SET ^TMP($JOB,"P","P",XB("PNR"))=""
- +19 SET ^TMP($JOB,"P","R",XB("ROU"))=""
- End DoDot:3
- End DoDot:2
- End DoDot:1
- +20 KILL ^TMP($JOB,"R",XB("ROU")),^UTILITY($JOB,XB("ROU"))
- +21 QUIT
- +22 ;
- SRCH2 ;
- +1 IF '$DATA(ZTQUEUED)
- WRITE !!?5,XB("RKT")," Routines Processed",!!
- +2 SET (XB("PNR"),XB("ROU"))=""
- +3 FOR XB("PKT")=0:1
- SET XB("PNR")=$ORDER(^TMP($JOB,"P","P",XB("PNR")))
- IF XB("PNR")=""
- QUIT
- +4 FOR XB("PRK")=0:1
- SET XB("ROU")=$ORDER(^TMP($JOB,"P","R",XB("ROU")))
- IF XB("ROU")=""
- QUIT
- +5 KILL ^TMP($JOB,"P","P"),^TMP($JOB,"P","R")
- +6 SET ^TMP($JOB,"P",XB("NSP"),XB("NAM"),XB("VER"),.01)=XB("RKT")
- +7 SET ^TMP($JOB,"P",XB("NSP"),XB("NAM"),XB("VER"),.02)=XB("PKT")
- +8 SET ^TMP($JOB,"P",XB("NSP"),XB("NAM"),XB("VER"),.03)=XB("PRK")
- +9 QUIT
- +10 ;
- SCHDR ;
- +1 WRITE !,?IOM-$LENGTH(XB("HD1"))\2,XB("HD1"),!,?IOM-$LENGTH(XB("HD2"))\2,XB("HD2"),!
- +2 QUIT
- +3 ;
- PRT ;
- +1 SET XB("PAGE")=0
- SET XB("NSP")=""
- +2 IF '$DATA(ZTQUEUED)
- Begin DoDot:1
- +3 SET IOP=XB("IOP")
- +4 DO ^%ZIS
- +5 QUIT
- End DoDot:1
- +6 USE IO
- +7 DO HDR
- +8 FOR
- SET XB("NSP")=$ORDER(^TMP($JOB,"P",XB("NSP")))
- IF XB("NSP")=""!(XB("END"))
- QUIT
- Begin DoDot:1
- +9 SET XB("NAM")=""
- +10 FOR
- SET XB("NAM")=$ORDER(^TMP($JOB,"P",XB("NSP"),XB("NAM")))
- IF XB("NAM")=""!(XB("END"))
- QUIT
- Begin DoDot:2
- +11 IF XB("NAM")="%"
- Begin DoDot:3
- +12 WRITE !!,"****",?5,"ROUTINES THAT ARE NOT IN PACKAGE FILE NAME-SPACE"
- +13 WRITE !?5,^TMP($JOB,"P",XB("NSP"),"%",0,.01)," TOTAL ROUTINE(s): "
- +14 WRITE ^TMP($JOB,"P",XB("NSP"),"%",0,.02)," PATCHE(s) in "
- +15 WRITE ^TMP($JOB,"P",XB("NSP"),"%",0,.03)," ROUTINE(s)",!
- +16 SET XB("NAM")=$ORDER(^TMP($JOB,"P",XB("NSP"),XB("NAM")))
- End DoDot:3
- +17 SET XB("END")=(XB("NAM")="")
- +18 IF XB("END")
- QUIT
- +19 SET XB("VER")=.5
- +20 FOR
- SET XB("VER")=$ORDER(^TMP($JOB,"P",XB("NSP"),XB("NAM"),XB("VER")))
- IF XB("VER")=""!(XB("END"))
- QUIT
- Begin DoDot:3
- +21 IF $Y+5>IOSL
- DO HDR
- +22 IF XB("END")
- QUIT
- +23 WRITE !!,XB("NSP"),?5,XB("NAM")," -- Version: ",XB("VER")
- +24 IF XB("NSP")'="~~"
- Begin DoDot:4
- +25 WRITE !?5,^TMP($JOB,"P",XB("NSP"),XB("NAM"),XB("VER"),.01)," TOTAL ROUTINE(s): "
- +26 WRITE ^TMP($JOB,"P",XB("NSP"),XB("NAM"),XB("VER"),.02)," PATCHE(s) in "
- +27 WRITE ^TMP($JOB,"P",XB("NSP"),XB("NAM"),XB("VER"),.03)," ROUTINE(s)",!
- End DoDot:4
- +28 SET XB("PNBR")=.5
- +29 FOR
- SET XB("PNBR")=$ORDER(^TMP($JOB,"P",XB("NSP"),XB("NAM"),XB("VER"),XB("PNBR")))
- IF XB("PNBR")=""!(XB("END"))
- QUIT
- Begin DoDot:4
- +30 SET XB("ROU")=""
- +31 FOR
- SET XB("ROU")=$ORDER(^TMP($JOB,"P",XB("NSP"),XB("NAM"),XB("VER"),XB("PNBR"),XB("ROU")))
- IF XB("ROU")=""!(XB("END"))
- QUIT
- Begin DoDot:5
- +32 IF $Y+5>IOSL
- DO HDR
- +33 IF XB("END")
- QUIT
- +34 WRITE !,$JUSTIFY(XB("PNBR"),4),?5,XB("ROU"),?14,^TMP($JOB,"P",XB("NSP"),XB("NAM"),XB("VER"),XB("PNBR"),XB("ROU"))
- End DoDot:5
- End DoDot:4
- End DoDot:3
- End DoDot:2
- End DoDot:1
- +35 QUIT
- +36 ;
- HDR ;
- +1 NEW DIRUT,DUOUT
- +2 IF XB("PAGE")&($EXTRACT(IOST,1,2)="C-")&(IO=IO(0))
- Begin DoDot:1
- +3 SET Y=$$DIR^XBDIR("E")
- +4 IF $DATA(DIRUT)!($DATA(DUOUT))
- SET XB("END")=1
- +5 QUIT
- End DoDot:1
- +6 IF XB("END")
- QUIT
- HDR1 ;
- +1 IF $DATA(IO("S"))&('XB("PAGE"))
- Begin DoDot:1
- +2 SET (DX,DY)=0
- +3 XECUTE ^%ZOSF("XY")
- +4 QUIT
- End DoDot:1
- +5 IF $EXTRACT(IOST,1,2)="C-"!(($EXTRACT(IOST,1,2)'="C-")&(XB("PAGE")))
- WRITE @IOF
- HDR2 ;
- +1 SET XB("PAGE")=XB("PAGE")+1
- +2 WRITE !,?IOM-$LENGTH(XB("HD1"))\2,XB("HD1"),?(IOM-15),"PAGE: ",$JUSTIFY(XB("PAGE"),3)
- +3 WRITE !,?IOM-$LENGTH(XB("HD2"))\2,XB("HD2")
- +4 WRITE !,"PATCH"
- +5 WRITE !,"NMBR",?5,"ROUTINE",?14,"ROUTINE DESCRIPTION"
- +6 WRITE !,"==== ======== ",$$REPEAT^XLFSTR("=",IOM-19)
- +7 QUIT
- +8 ;
- EXIT ;
- +1 DO ^%ZISC
- +2 KILL ^UTILITY($JOB),^TMP($JOB)
- +3 QUIT
- +4 ;