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

SCUTBK1.m

Go to the documentation of this file.
  1. SCUTBK1 ;ALB/MJK - Scheduling Broker Utilities ;[ 03/08/95 3:41 PM ]
  1. ;;5.3;Scheduling;**41,297,498,1015**;AUG 13, 1993;Build 21
  1. ;
  1. Q
  1. ;
  1. DIKC(SCOK,SC) ; -- broker callback to kill a file entry
  1. ;
  1. N DIK,DA
  1. D CHK^SCUTBK
  1. ;
  1. ; -- array parsing
  1. S DIK=$G(SC("ROOT"))
  1. S DA=+$G(SC("IEN"))
  1. ;
  1. IF DIK]"",$D(@(DIK_DA_",0)")) D
  1. . D ^DIK
  1. . S SCOK=1
  1. ELSE D
  1. . S SCOK=0
  1. Q
  1. ;
  1. LOCKC(SCOK,SC) ; -- broker callback to lock/unlock a node
  1. ;
  1. N SCNODE
  1. D CHK^SCUTBK
  1. ;
  1. ; -- array parsing
  1. S SCNODE=$G(SC("NODE"))
  1. I SCNODE[",)" S SCOK=1 Q
  1. ;
  1. IF SCNODE]"" D
  1. . IF $G(SC("LOCKMODE")) D
  1. . . L @("+"_SCNODE_":"_$G(SC("TIMEOUT"),5))
  1. . . S SCOK=$T
  1. . ELSE D
  1. . . L @("-"_SCNODE)
  1. . . S SCOK=1
  1. ELSE D
  1. . S SCOK=0
  1. Q
  1. ;
  1. FILENOC(SCFLNO,SCNAME) ; -- broker callback to get File #
  1. ;
  1. D CHK^SCUTBK
  1. S SCFLNO=+$O(^DIC("B",SCNAME,""))
  1. Q
  1. ;
  1. NODEC(SCNODE,SCROOT) ; -- broker callback to get global node value
  1. ;
  1. D CHK^SCUTBK
  1. ;S SCNODE=$G(@SCROOT)
  1. IF $D(@SCROOT)=0!($D(@SCROOT)=10) D
  1. . S SCNODE="{{"_$D(@SCROOT)_"}}"
  1. IF $D(@SCROOT)=1!($D(@SCROOT)=11) D
  1. . S SCNODE=$G(@SCROOT)
  1. Q
  1. ;
  1. GLCNT(SCOK,SC) ; -- extrinsic call to invoke broker to return number of
  1. ; global nodes found at cross reference
  1. N SCNODE,SCTEAM,SCXREF,SCFRST
  1. D CHK^SCUTBK
  1. ;
  1. S (SCFRST,SCOK)=""
  1. S SCNODE=$G(SC("ROOT"))
  1. S SCXREF=$G(SC("XREF"))
  1. S SCVAL=$G(SC("VALUE"))
  1. ;
  1. S:SCXREF="" SCXREF="B"
  1. S I="",X=0
  1. F S I=$O(@SCNODE@(SCXREF,SCVAL,I)) Q:I="" D
  1. . S X=X+1
  1. S SCOK=$G(X)
  1. Q
  1. ;
  1. IFNODE(SCNODE,SCROOT) ; -- extrinsic call to check if node exists.
  1. ; passes in full node reference.
  1. N X
  1. D CHK^SCUTBK
  1. ;
  1. IF $D(@SCROOT)=0!($D(@SCROOT)=10) D
  1. . S SCNODE="{{"_$D(@SCROOT)_"}}"
  1. IF $D(@SCROOT)=1!($D(@SCROOT)=11) D
  1. . S SCNODE=$G(@SCROOT)
  1. Q
  1. ;
  1. PRTP(SCACTV,SC) ;
  1. ;
  1. N SCRTN,SCERRX,SCOK,SCIEN,SCKDT
  1. D TMP^SCUTBK
  1. D CHK^SCUTBK
  1. ;
  1. I $G(SC("IEN"))=0 D G PRTPQ
  1. . S SCACTV=0
  1. S SCIEN=SC("IEN")
  1. ;
  1. S SCKDT=""
  1. S SCKDT("BEGIN")=$G(SC("BEGIN"),DT)
  1. S SCKDT("END")=$G(SC("END"),DT)
  1. S SCKDT("INCL")=$G(SC("INCL"),0)
  1. ;
  1. S SCOK=$$PRTP^SCAPMC8(SCIEN,"SCKDT","SCRTN","SCERRX")
  1. S SCACTV=$S(SCOK:$G(SCRTN(1),"0"),1:"0")
  1. PRTPQ Q