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

ZTLOAD1.m

Go to the documentation of this file.
  1. %ZTLOAD1 ;SEA/RDS-TaskMan: P I: Queue ;09/23/08 10:06
  1. ;;8.0;KERNEL;**112,118,127,162,275,363,409,415,425,446**;Jul 10, 1995;Build 44
  1. ;Per VHA Directive 2004-038, this routine should not be modified.
  1. ;
  1. GET ;get task data
  1. N %X,%Y,X,Y,X1,ZT,ZTC1,ZTC2,ZTA1,ZTA4,ZTA5,ZTINC,ZTGOT,ZTC34P
  1. K %ZTLOAD
  1. I ("^"[$G(ZTRTN))!($L($G(ZTRTN),"^")>2) D REJECT^%ZTLOAD2("Bad Routine") G EXIT
  1. S U="^" I ZTRTN'[U S ZTRTN=U_ZTRTN
  1. S ZTC1=+$G(DUZ),ZTC2=""
  1. I ZTC1>0 S ZTC2=$P($G(^VA(200,ZTC1,0)),U)
  1. ;Check Date/Time
  1. 1 I $D(ZTDTH)[0 S ZTDTH=""
  1. I ZTDTH?7N.".".N S ZTDTH=$$FMTH^%ZTLOAD7(ZTDTH)
  1. I $P($G(XQY0),U,18) D RESTRCT^%ZTLOAD2
  1. I ZTDTH'="@",ZTDTH'?1.5N1","1.5N D ASK^%ZTLOAD2 I ZTDTH'>0 D REJECT^%ZTLOAD2("Bad Date/Time") G EXIT
  1. ;
  1. S ZTA1="R",ZTA4="",ZTA5=""
  1. I ZTRTN="ZTSK^XQ1" D OPTION^%ZTLOAD2 I ZTA1="" D REJECT^%ZTLOAD2("Bad Option") G EXIT
  1. I ZTA1="R" D
  1. . S ZTSAVE("XQY")="",ZTSAVE("XQY0")="",ZTA4=$G(XQY),ZTA5=$P($G(XQY0),U)
  1. ;
  1. D GETENV^%ZOSV S ZTC34P=Y
  1. ;Description
  1. 2 I $D(ZTDESC)[0 S ZTDESC="No Description (%ZTLOAD)"
  1. ;
  1. I $G(ZTKIL)]"" D ZTKIL^%ZTLOAD2
  1. S:$G(ZTUCI)["," ZTUCI=$P(ZTUCI,",") S:$G(ZTCPU)["," ZTCPU=$P(ZTCPU,",",2)
  1. DEVICE ;get device data
  1. I $D(ZTIO)#2,$G(ION)=$P(ZTIO,";"),$G(IOT)="SPL" D SPOOL^%ZTLOAD2
  1. ;If no ZTIO, build from symbol table
  1. I $D(ZTIO)[0 S ZTIO=$G(ION) I $L(ZTIO) D
  1. . S:$G(IOST)]"" $P(ZTIO,";",2)=IOST
  1. . I $G(IO("DOC"))]"" S ZTIO=ZTIO_";"_IO("DOC")
  1. . E I $G(IOM)]"" S ZTIO=ZTIO_";"_IOM I $G(IOSL)]"" S ZTIO=ZTIO_";"_IOSL
  1. . Q
  1. ;
  1. I $E(ZTIO,1)="`" S $P(ZTIO,";")=$P(^%ZIS(1,+$E(ZTIO,2,99),0),"^") ;Convert `IEN format
  1. S ZTIO(1)=$S($G(ZTIO(1))'="D":"Q",1:"DIRECT")
  1. I $L(ZTIO) D ;Skip if no device
  1. . ;IO("HFSIO") and IOPAR are how %ZIS reports the user selected file name and parameters
  1. . S:'$D(ZTIO("H")) ZTIO("H")=$G(IO("HFSIO"))
  1. . S:'$D(ZTIO("P")) ZTIO("P")=$G(IOPAR)
  1. . I $G(IO("P"))]"",ZTIO'[";/" S ZTIO=ZTIO_";/"_IO("P")
  1. . I $$NOQ^%ZISUTL($P(ZTIO,";")) D BADDEV^%ZTLOAD2("Restricted Device")
  1. . I $E(ZTIO,1,9)="P-MESSAGE" S ZTSAVE("^TMP(""XM-MESS"",$J,")=""
  1. . Q
  1. ;
  1. I $D(%ZTLOAD("ERROR")) G EXIT
  1. ;
  1. ;See that ^%ZTSK(-1) is set
  1. I $D(^%ZTSK(-1))[0 S ^%ZTSK(-1)=$S($P($G(^%ZTSK(0)),U,3):$P(^(0),U,3),1:1000)
  1. RECORD ;build record
  1. S ZTINC=$G(^%ZOSF("$INC"),1) ;Set to 1 if this system has $INCREMENT, otherwise 0.
  1. S ZTGOT=0
  1. I 'ZTINC D ;For System that don't have $INC (GT.M, DTM, MSM)
  1. . ;Find a free entry, Claim it and Lock it.
  1. . L +^%ZTSK(-1):0 S ZTSK=^%ZTSK(-1) ;This is just a starting point
  1. . F S ZTSK=ZTSK+1 I '$D(^%ZTSK(ZTSK)) D Q:ZTGOT
  1. . . L +^%ZTSK(ZTSK):$G(DILOCKTM,3) Q:'$T ;Can we lock it
  1. . . I $D(^%ZTSK(ZTSK)) L -^%ZTSK(ZTSK) ;Already claimed
  1. . . S ^%ZTSK(ZTSK,.1)=0,^%ZTSK(-1)=ZTSK,ZTGOT=1 ;Claim it
  1. . . Q
  1. . L -^%ZTSK(-1) ;
  1. . Q
  1. I ZTINC D ;For DSM and OpenM. Faster over network(DDP)
  1. . S ZTSK=$INCREMENT(^%ZTSK(-1))
  1. . L +^%ZTSK(ZTSK):$G(DILOCKTM,3) S ZTGOT=$T ;p446
  1. I 'ZTGOT!($D(^%ZTSK(ZTSK,0))) L -^%ZTSK(ZTSK) G RECORD
  1. TSTART ;
  1. S ^%ZTSK(ZTSK,0)=ZTRTN_U_ZTC1_U_$G(ZTUCI)_U_$H_U_ZTDTH_U_ZTA1_U_ZTA4_U_ZTA5_U_ZTC2_U_$P(ZTC34P,U,1,2)_U_"ZTDESC"_U_$G(ZTCPU)_U_$G(ZTPRI)
  1. S ^%ZTSK(ZTSK,.1)=0,^%ZTSK(ZTSK,.03)=ZTDESC
  1. S ^%ZTSK(ZTSK,.2)=ZTIO_"^^^^"_ZTIO(1)_U_$G(ZTIO("H")) S:$D(ZTSYNC) $P(^%ZTSK(ZTSK,.2),U,7)=ZTSYNC
  1. I $G(ZTIO("P"))]"" S ^%ZTSK(ZTSK,.25)=ZTIO("P")
  1. ;
  1. D ZTSAVE
  1. ;
  1. SCHED ;schedule task and quit
  1. S ZTSTAT=$S(ZTDTH'="@":1,1:"K")_"^"_$H,$P(ZTSTAT,U,8)=$G(ZTKIL)
  1. S ^%ZTSK(ZTSK,.1)=ZTSTAT
  1. I ZTDTH'="@" L +^%ZTSCH("SCHQ"):$G(DILOCKTM,3) S ZT=$$H3(ZTDTH),^%ZTSK(ZTSK,.04)=ZT,^%ZTSCH(ZT,ZTSK)="" L -^%ZTSCH("SCHQ")
  1. L -^%ZTSK(ZTSK) S ZTSK("D")=ZTDTH
  1. TCOMMIT ;
  1. EXIT ;Clean up
  1. I $E($G(ZTIO),1,9)="P-MESSAGE" K ^TMP("XM-MESS",$J) ;Clean up the Global
  1. K X1,ZT,ZT1,ZTDTH,ZTKIL,ZTSAVE,ZTSTAT,ZTIO
  1. Q
  1. ;
  1. ZTSAVE ;save variables
  1. N ZTIO
  1. K %H,%T,ZTA1,ZTA4,ZTA5,ZTC1,ZTC2,ZTC34P,ZTCPU,ZTDESC,ZTIO,ZTNOGO,ZTPRI,ZTRTN,ZTUCI,ZTSYNC
  1. S ZTSAVE("DUZ(")=""
  1. S ZT1="" F S ZT1=$O(ZTSAVE(ZT1)) Q:ZT1="" D EVAL
  1. K ^%ZTSK(ZTSK,.3,"DUZ(","NEWCODE")
  1. K ^%ZTSK(ZTSK,.3,"ZTSK"),^("ZTSAVE"),^("ZTDTH")
  1. K ^%ZTSK(ZTSK,.3,"XQNOGO")
  1. Q
  1. ;
  1. EVAL ;ZTSAVE--evaluate expression
  1. I ZT1="*" S X="^%ZTSK(ZTSK,.3," D DOLRO^%ZOSV Q
  1. I ZT1["*",$P(ZT1,"*")'["(" S X="^%ZTSK(ZTSK,.3,",Y=ZT1 D ORDER^%ZOSV Q
  1. I $S($E(ZT1)="""":1,+ZT1'=ZT1:0,1:ZT1]0),$D(ZTSAVE(ZT1))#2 S @("^%ZTSK(ZTSK,"_ZT1_")=ZTSAVE(ZT1)") Q
  1. I $S(ZT1'["(":1,1:$E(ZT1,$L(ZT1))=")"),$S($D(@ZT1)#2:1,1:ZTSAVE(ZT1)]"") S ^%ZTSK(ZTSK,.3,ZT1)=$S(ZTSAVE(ZT1)]"":ZTSAVE(ZT1),1:@ZT1) Q
  1. I $E(ZT1)="^",ZT1["(" S %X=ZT1,%Y="^%ZTSK(ZTSK,.3,ZT1," D %XY^%RCR Q
  1. I ZT1["(" S %X=ZT1,%Y="^%ZTSK(ZTSK,.3,ZT1," D %XY^%RCR
  1. ;I ZT1["(" M ^%ZTSK(ZTSK,.3,ZT1)=@$P(ZT1,"(")
  1. Q
  1. ;
  1. H3(%) ;Convert $H to seconds.
  1. Q 86400*%+$P(%,",",2)
  1. H0(%) ;Covert from seconds to $H
  1. Q (%\86400)_","_(%#86400)