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

KMPRP1.m

Go to the documentation of this file.
  1. KMPRP1 ;OAK/RAK - RUM Data by Option/Protocol/RPC ;11/29/04 08:47
  1. ;;2.0;CAPACITY MANAGEMENT - RUM;**1**;May 28, 2003
  1. EN ;-- entry point.
  1. ;
  1. N %ZIS,CONT,KMPRDATE,KMPROPR,KMPROPT,OUT,POP
  1. N X,Y,ZTDESC,ZTRTN,ZTSAVE,ZTSK
  1. ;
  1. S OUT=0
  1. F D Q:OUT
  1. .D HDR^KMPDUTL4(" RUM Data by Option/Protocol/RPC ")
  1. .S KMPROPR=$$OPR I 'KMPROPR S OUT=1 Q
  1. .; select option, protocol or rpc entry
  1. .S KMPROPT=$$OPRSEL(KMPROPR) Q:'KMPROPT
  1. .; determine start date from file 8971.1
  1. .D RUMDATES^KMPRUTL(.KMPRDATE) Q:'KMPRDATE
  1. .; select output device.
  1. .S %ZIS="Q",%ZIS("A")="Device: ",%ZIS("B")="HOME"
  1. .W ! D ^%ZIS I POP W !,"No action taken." Q
  1. .; if queued.
  1. .I $D(IO("Q")) K IO("Q") D Q
  1. ..S ZTDESC="RUM Data by Option for '"_$P(KMPROPT,U,2)_"'."
  1. ..S ZTRTN="EN1^KMPRP1"
  1. ..S ZTSAVE("KMPRDATE")="",ZTSAVE("KMPROPR")="",ZTSAVE("KMPROPT")=""
  1. ..D ^%ZTLOAD W:$G(ZTSK) !,"Task #",ZTSK
  1. ..D EXIT
  1. .;
  1. .; if output to terminal display message.
  1. .W:$E(IOST,1,2)="C-" !?3,"compiling data..."
  1. .D EN1
  1. ;
  1. Q
  1. ;
  1. EN1 ;-- entry point from taskman.
  1. ;
  1. Q:'$G(KMPRDATE)
  1. Q:'$G(KMPROPR)
  1. Q:$G(KMPROPT)=""
  1. ;
  1. N ELEMENT,KMPRARRY,KMPRDAYS
  1. ;
  1. ; set elements data into ELEMENT() array.
  1. D ELEARRY^KMPRUTL("ELEMENT") Q:'$D(ELEMENT)
  1. S KMPRARRY=$NA(^TMP("KMPR OPT DATA",$J))
  1. K @KMPRARRY
  1. D DATA,PRINT,EXIT
  1. K @KMPRARRY
  1. ;
  1. Q
  1. ;
  1. DATA ;-- set data into KMPRARRY
  1. Q:'$D(ELEMENT)
  1. Q:$G(KMPRARRY)=""
  1. Q:'$G(KMPRDATE)
  1. Q:'$G(KMPROPR)
  1. Q:$G(KMPROPT)=""
  1. ;
  1. N DATE,END,I,IEN,OPTION,START
  1. ;
  1. ; start and end dates.
  1. S START=$P(KMPRDATE,U),END=$P(KMPRDATE,U,2)
  1. S DATE=START-.1,KMPRDAYS=0
  1. F S DATE=$O(^KMPR(8971.1,"B",DATE)) Q:'DATE!(DATE>END) D
  1. .S IEN=0,KMPRDAYS=KMPRDAYS+1
  1. .F S IEN=$O(^KMPR(8971.1,"B",DATE,IEN)) Q:'IEN D
  1. ..Q:'$D(^KMPR(8971.1,IEN,0)) S DATA(0)=^(0),DATA(1)=$G(^(1)),DATA(2)=$G(^(2))
  1. ..S OPTION=$$OPRCHK(KMPROPR,KMPROPT,DATA(0)) Q:OPTION=""
  1. ..F I=1:1:8 D
  1. ...S $P(@KMPRARRY@(OPTION),U,I)=$P($G(@KMPRARRY@(OPTION)),U,I)+$P(DATA(1),U,I)
  1. ...S $P(@KMPRARRY@(OPTION),U,I)=$P($G(@KMPRARRY@(OPTION)),U,I)+$P(DATA(2),U,I)
  1. ;
  1. Q
  1. ;
  1. EXIT ;
  1. S:$D(ZTQUEUED) ZTREQ="@"
  1. D ^%ZISC
  1. K KMPUDATE,KMPUNAM
  1. ;
  1. Q
  1. ;
  1. PRINT ;-- print data from KMPRARRY.
  1. Q:'$D(ELEMENT)
  1. Q:$G(KMPRARRY)=""
  1. ;
  1. U IO
  1. ;
  1. N DATA,OCCUR,I,NUMBER,PIECE,SITE
  1. ;
  1. ; facility name.
  1. S SITE=$$SITE^VASITE
  1. S SITE=$P(SITE,U,2)_" ("_$P(SITE,U,3)_")"
  1. ;
  1. I '$D(@KMPRARRY) D Q
  1. .D HDR
  1. .W !!!?28,"<<<No Data to Report>>>"
  1. .D CONTINUE^KMPDUTL4("Press RETURN to continue",2,.CONT)
  1. ;
  1. S OPTION=""
  1. F S OPTION=$O(@KMPRARRY@(OPTION)) Q:OPTION="" D
  1. .D HDR S DATA=@KMPRARRY@(OPTION),I=0,OCCUR=$P(DATA,U,8)
  1. .F S I=$O(ELEMENT(I)) Q:'I D
  1. ..W !,$P(ELEMENT(I),U) S PIECE=$P(ELEMENT(I),U,2)
  1. ..W $$REPEAT^XLFSTR(".",25-$X)
  1. ..S NUMBER=$P(DATA,U,PIECE)
  1. ..; per occurrence.
  1. ..W:OCCUR&(PIECE'=8) ?28,$J($FN(NUMBER/OCCUR,",",$S(I<3:2,1:0)),$S(I<3:14,1:11))
  1. ..W ?50,$J($FN(NUMBER,",",$S(I<3:2,1:0)),$S(I<3:18,1:15))
  1. ;
  1. D CONTINUE^KMPDUTL4("Press RETURN to continue",2,.CONT)
  1. ;
  1. Q
  1. ;
  1. HDR ;
  1. N TITLE
  1. W:$Y @IOF
  1. S TITLE="RUM Data for Option: "_$P(KMPROPT,U,2)
  1. W !?(80-$L(TITLE)\2),TITLE
  1. W !?(80-$L($G(SITE))\2),$G(SITE)
  1. W !?23,"For "_$P($G(KMPRDATE),U,3)_" to "_$P($G(KMPRDATE),U,4)
  1. W !
  1. W !?28,"per Occurrence",?50," Totals"
  1. W !
  1. ;
  1. Q
  1. ;
  1. OPR() ;-- extrinsic function - select option, protocol or rpc
  1. ;-----------------------------------------------------------------------
  1. ; Return: 1 - Option
  1. ; 2 - Protocol
  1. ; 3 - RPC
  1. ; "" - No selection made
  1. ;-----------------------------------------------------------------------
  1. N DIR,X,Y
  1. S DIR(0)="SO^1:Option;2:Protocol;3:RPC"
  1. D ^DIR
  1. Q $S(Y:Y_"^"_$G(Y(0)),1:"")
  1. ;
  1. OPRCHK(OPR,OPT,DATA) ;-- extrinsic function - check to see if option, protocol or rpc matches
  1. ;-----------------------------------------------------------------------
  1. ; OPR.... Results from $$OPR above.
  1. ; OPT.... Option, protocol or rpc name to be matched
  1. ; DATA... Zero node of file 8971.1 (RESOURCE USAGE MONITOR)
  1. ;
  1. ; Return: OptionName - match
  1. ; "" - no match
  1. ;-----------------------------------------------------------------------
  1. Q:$G(OPR)="" ""
  1. Q:'OPR!($P(OPR,U,2)="") ""
  1. Q:'$D(DATA) ""
  1. Q:(+OPR)<1!((+OPR)>3) ""
  1. N OPTION
  1. ; option - piece 4, protocol - piece 5, rpc - piece7
  1. S OPTION=$S((+OPR)=1:$P(DATA,U,4),(+OPR)=2:$P(DATA,U,5),1:$P(DATA,U,7))
  1. Q $S(OPTION="":"",OPTION'=$P(OPT,U,2):"",1:OPTION)
  1. ;
  1. OPRSEL(OPR) ;-- extrinsic function - select entry
  1. ;-----------------------------------------------------------------------
  1. ; OPT.... Results from $$OPR above.
  1. ;
  1. ; Return: IEN^Name - this will be from the Option file, Protocol file,
  1. ; or RPC file, depending on the value of OPR.
  1. ; "" - no selection made
  1. ;-----------------------------------------------------------------------
  1. Q:'$G(OPR) ""
  1. Q:OPR<1!(OPR>3) ""
  1. N DIC,X,Y
  1. ; 1 - option, 2 - protocol, 3 - rpc
  1. S DIC=$S((+OPR)=1:19,(+OPR)=2:101,1:8994)
  1. S DIC(0)="AEMQZ",DIC("A")="Select "_$P(OPR,U,2)_": "
  1. W ! D ^DIC
  1. Q $S(Y<0:"",1:+Y_"^"_Y(0,0))