[613] | 1 | SCUTBK1 ;ALB/MJK - Scheduling Broker Utilities ;[ 03/08/95 3:41 PM ]
|
---|
| 2 | ;;5.3;Scheduling;**41,297,498**;AUG 13, 1993;Build 23
|
---|
| 3 | ;
|
---|
| 4 | Q
|
---|
| 5 | ;
|
---|
| 6 | DIKC(SCOK,SC) ; -- broker callback to kill a file entry
|
---|
| 7 | ;
|
---|
| 8 | N DIK,DA
|
---|
| 9 | D CHK^SCUTBK
|
---|
| 10 | ;
|
---|
| 11 | ; -- array parsing
|
---|
| 12 | S DIK=$G(SC("ROOT"))
|
---|
| 13 | S DA=+$G(SC("IEN"))
|
---|
| 14 | ;
|
---|
| 15 | IF DIK]"",$D(@(DIK_DA_",0)")) D
|
---|
| 16 | . D ^DIK
|
---|
| 17 | . S SCOK=1
|
---|
| 18 | ELSE D
|
---|
| 19 | . S SCOK=0
|
---|
| 20 | Q
|
---|
| 21 | ;
|
---|
| 22 | LOCKC(SCOK,SC) ; -- broker callback to lock/unlock a node
|
---|
| 23 | ;
|
---|
| 24 | N SCNODE
|
---|
| 25 | D CHK^SCUTBK
|
---|
| 26 | ;
|
---|
| 27 | ; -- array parsing
|
---|
| 28 | S SCNODE=$G(SC("NODE"))
|
---|
| 29 | I SCNODE[",)" S SCOK=1 Q
|
---|
| 30 | ;
|
---|
| 31 | IF SCNODE]"" D
|
---|
| 32 | . IF $G(SC("LOCKMODE")) D
|
---|
| 33 | . . L @("+"_SCNODE_":"_$G(SC("TIMEOUT"),5))
|
---|
| 34 | . . S SCOK=$T
|
---|
| 35 | . ELSE D
|
---|
| 36 | . . L @("-"_SCNODE)
|
---|
| 37 | . . S SCOK=1
|
---|
| 38 | ELSE D
|
---|
| 39 | . S SCOK=0
|
---|
| 40 | Q
|
---|
| 41 | ;
|
---|
| 42 | FILENOC(SCFLNO,SCNAME) ; -- broker callback to get File #
|
---|
| 43 | ;
|
---|
| 44 | D CHK^SCUTBK
|
---|
| 45 | S SCFLNO=+$O(^DIC("B",SCNAME,""))
|
---|
| 46 | Q
|
---|
| 47 | ;
|
---|
| 48 | NODEC(SCNODE,SCROOT) ; -- broker callback to get global node value
|
---|
| 49 | ;
|
---|
| 50 | D CHK^SCUTBK
|
---|
| 51 | ;S SCNODE=$G(@SCROOT)
|
---|
| 52 | IF $D(@SCROOT)=0!($D(@SCROOT)=10) D
|
---|
| 53 | . S SCNODE="{{"_$D(@SCROOT)_"}}"
|
---|
| 54 | IF $D(@SCROOT)=1!($D(@SCROOT)=11) D
|
---|
| 55 | . S SCNODE=$G(@SCROOT)
|
---|
| 56 | Q
|
---|
| 57 | ;
|
---|
| 58 | GLCNT(SCOK,SC) ; -- extrinsic call to invoke broker to return number of
|
---|
| 59 | ; global nodes found at cross reference
|
---|
| 60 | N SCNODE,SCTEAM,SCXREF,SCFRST
|
---|
| 61 | D CHK^SCUTBK
|
---|
| 62 | ;
|
---|
| 63 | S (SCFRST,SCOK)=""
|
---|
| 64 | S SCNODE=$G(SC("ROOT"))
|
---|
| 65 | S SCXREF=$G(SC("XREF"))
|
---|
| 66 | S SCVAL=$G(SC("VALUE"))
|
---|
| 67 | ;
|
---|
| 68 | S:SCXREF="" SCXREF="B"
|
---|
| 69 | S I="",X=0
|
---|
| 70 | F S I=$O(@SCNODE@(SCXREF,SCVAL,I)) Q:I="" D
|
---|
| 71 | . S X=X+1
|
---|
| 72 | S SCOK=$G(X)
|
---|
| 73 | Q
|
---|
| 74 | ;
|
---|
| 75 | IFNODE(SCNODE,SCROOT) ; -- extrinsic call to check if node exists.
|
---|
| 76 | ; passes in full node reference.
|
---|
| 77 | N X
|
---|
| 78 | D CHK^SCUTBK
|
---|
| 79 | ;
|
---|
| 80 | IF $D(@SCROOT)=0!($D(@SCROOT)=10) D
|
---|
| 81 | . S SCNODE="{{"_$D(@SCROOT)_"}}"
|
---|
| 82 | IF $D(@SCROOT)=1!($D(@SCROOT)=11) D
|
---|
| 83 | . S SCNODE=$G(@SCROOT)
|
---|
| 84 | Q
|
---|
| 85 | ;
|
---|
| 86 | PRTP(SCACTV,SC) ;
|
---|
| 87 | ;
|
---|
| 88 | N SCRTN,SCERRX,SCOK,SCIEN,SCKDT
|
---|
| 89 | D TMP^SCUTBK
|
---|
| 90 | D CHK^SCUTBK
|
---|
| 91 | ;
|
---|
| 92 | I $G(SC("IEN"))=0 D G PRTPQ
|
---|
| 93 | . S SCACTV=0
|
---|
| 94 | S SCIEN=SC("IEN")
|
---|
| 95 | ;
|
---|
| 96 | S SCKDT=""
|
---|
| 97 | S SCKDT("BEGIN")=$G(SC("BEGIN"),DT)
|
---|
| 98 | S SCKDT("END")=$G(SC("END"),DT)
|
---|
| 99 | S SCKDT("INCL")=$G(SC("INCL"),0)
|
---|
| 100 | ;
|
---|
| 101 | S SCOK=$$PRTP^SCAPMC8(SCIEN,"SCKDT","SCRTN","SCERRX")
|
---|
| 102 | S SCACTV=$S(SCOK:$G(SCRTN(1),"0"),1:"0")
|
---|
| 103 | PRTPQ Q
|
---|