%ZIS4 ;SFISC/RWF,AC - DEVICE HANDLER SPOOL SPECIFIC CODE(MSM) ;30-OCT-1997 09:28
;;8.0;KERNEL;**23,36,49,59,69**;JUL 03, 1995
;
OPEN G OPN2:$D(IO(1,IO))
S POP=0 D OP1 G NOPEN:'$D(IO(1,IO))
OPN2 I $D(%ZISHP),'$D(IOP) W !,*7," Routing to device "_$P(^%ZIS(1,%E,0),"^",1)_$S($D(^(1)):" "_$P(^(1),"^",1)_" ",1:"")
Q
NOPEN I %IS'["D",$D(%ZISHP)!(%ZISHG]"") S POP=1 Q
I '$D(IOP) W *7," [BUSY] ... RETRY" S %=2,U="^" D YN^%ZIS1 G OPEN:%=1
S POP=1 Q
Q
OP1 N X S X="OPNERR^%ZIS4",@^%ZOSF("TRAP")
L:$D(%ZISLOCK) +@%ZISLOCK:60
O IO::%ZISTO S:$T IO(1,IO)="" S:'$T POP=1 L:$D(%ZISLOCK) -@%ZISLOCK
Q
OPNERR S POP=1,IO("LASTERR")=$G(IO("ERROR")),IO("ERROR")=$ZE,$EC="" Q
;
O I $P($ZV,"Version ",2)'<3 D:%IS["L" ZIO
;D:$D(%ZISIOS) ZISLPC^%ZIS Q:'%ZISB ;No longer called in Kernel v8.
I $D(IO("S")),$D(^%ZIS(2,IO("S"),10)),^(10)]"" U IO(0) D X10^ZISX ;Open Printer port
OPAR I $D(IOP),%ZTYPE="HFS",$D(%IS("HFSIO")),$D(%IS("IOPAR")),%IS("HFSIO")]"" S IO=%IS("HFSIO"),%ZISOPAR=%IS("IOPAR")
S %A=$S(%ZISOPAR]"":%ZISOPAR,%ZTYPE["TRM":+%Z91,1:"")
S %A=%A_$S(%A["):":"",%ZTYPE["OTH"&($P(%ZTIME,"^",3)="n"):"",1:":"_%ZISTO),%A=""""_IO_""""_$E(":",%A]"")_%A
D O1 I POP W:'$D(IOP) !,?5,*7,"[Device is BUSY]" Q
I %ZTYPE="HFS" D Q:POP
. N % S %=$I
. U IO S:$ZA<0 POP=1
. U:'$D(ZTQUEUED) % I POP C:IO]"" IO K:IO]"" IO(1,IO)
. I POP,'$D(IOP),'$D(ZTQUEUED) W !,?5,*7,"[File not Found]" Q
;U IO S:'(IO=IO(0)&'$D(IO("S"))&'$D(ZTQUEUED)) $X=0,$Y=0
U IO S $X=0,$Y=0
I %ZISUPAR]"" S %A1=""""_IO_""":"_%ZISUPAR U @%A1
;U:%IS'[0 IO(0)
G OXECUTE^%ZIS6
;
O1 N X S X="OPNERR^%ZIS4",@^%ZOSF("TRAP")
L:$D(%ZISLOCK) +@%ZISLOCK:60
O @%A S:'$T&(%A?.E1":".N) POP=1 S:'POP IO(1,IO)="" L:$D(%ZISLOCK) -@%ZISLOCK
S IO("ERROR")="" Q
;
ZIO N % S (IO("ZIO"),%)=$ZDEV($I),%=$S(%?1.3N1P.E:$TR(%,"~",":"),1:%)
S:(%?1.3N1P1.3N1P.E)&'$D(IO("IP")) IO("IP")=$TR(%,"~",":") S:(%?1A.ANP1"~"1.4N)&'$D(IO("CLNM")) IO("CLNM")=$TR($$LOW^%ZIS1(%),"~",":")
Q
;
SPOOL ;%ZDA=pointer to ^XMB(3.51, %ZFN=spool file name.
I $D(ZISDA) W:'$D(IOP) !?5,*7,"You may not Spool the printing of a Spool document" G N
I $D(DUZ)[0 W:'$D(IOP) !,"Must be a valid user." G N
S ZOSFV=($P($ZV,"Version ",2)'<2)
R S %ZY=-1 D NEWDOC^ZISPL1 G N:%ZY'>0 S %ZDA=+%ZY,%ZFN=$P(%ZY(0),U,2),IO("DOC")=$P(%ZY(0),U,1) I '%ZISB!$D(IO("Q")) S:'ZOSFV IO=51 G OK
I '$P(%ZY,"^",3),%ZFN D SPL3 G N:'%ZFN,DOC
S %ZFN=-1 D SPL2 G:%ZFN<0 N S $P(^XMB(3.51,%ZDA,0),U,2)=%ZFN,^XMB(3.51,"C",%ZFN,%ZDA)=""
DOC S IO("SPOOL")=%ZDA,^XUTL("XQ",$J,"SPOOL")=%ZDA,IOF="#"
I $D(^%ZIS(1,%ZISIOS,1)),$P(^(1),"^",8),$O(^("SPL",0)) S ^XUTL("XQ",$J,"ADSPL")=%ZISIOS,ZISPLAD=%ZISIOS
OK K %ZDA,%ZFN Q
N K %ZDA,%ZFN,IO("DOC") S POP=1 Q
;
SPL2 O 2:1 G SPL5:$ZA<0,SPL5:$ZC S %ZFN=$ZA#256 S IO(1,2)="",IO(1,2,"%ZFN")=%ZFN Q
;
SPL3 Q:$D(IO(1,2))#2 O 2:%ZFN+256 G:$ZA<0 SPL5:$ZA<0,SPL5:$ZC S IO(1,2)="",IO(1,2,"%ZFN")=%ZFN Q
SPL4 E G SPL5
;U IO S %ZA=$ZA U:%IS'[0 IO(0) I %ZA<0 G SPL5
Q
SPL5 W:'$D(IOP)&'$D(ZTQUEUED) !?5,*7,"Couldn't open the spool file." S %ZFN=-1 Q
;
CLOSE N %Z1 S ZOSFV=($P($ZV,"Version ",2)'<2)
C 2 K IO(1,2)
D FILE^ZISPL1 I %ZDA'>0 K ZISPLAD Q
S %Z1=+$G(^XTV(8989.3,1,"SPL"))
S IO=2,%ZFN=$P(%ZS,"^",2) D SPL3 Q:%ZFN'>0 U IO S %ZCR=$C(13),%Y=""
G V2CL1^%ZOSV
Q ;Send error up
CL2 I %Z1<(%+1) S %=%+1,^XMBS(3.519,XS,2,%,0)="*** INCOMPLETE REPORT -- SPOOL DOCUMENT LINE LIMIT EXCEEDED ***",$P(^XMB(3.51,%ZDA,0),"^",11)=1 Q
I %2[$C(12) S %=%+1,^XMBS(3.519,XMZ,2,%,0)="|TOP|"
S %=%+1,^XMBS(3.519,XMZ,2,%,0)=%2 Q
;
HFS G HFS^%ZISF
REWMT(IO,IOPAR) ;Rewind Magtape
S X="REWERR^%ZIS4",@^%ZOSF("TRAP")
U IO W *5
Q 1
REWSDP(IO,IOPAR) ;Rewind Sequential Block Processor
S X="REWERR^%ZIS4",@^%ZOSF("TRAP")
U IO:IOPAR
Q 1
REWHFS(IO,IOPAR) ;Rewind Host File.
REW1 S X="REWERR^%ZIS4",@^%ZOSF("TRAP")
U IO:(::0)
Q 1
REWERR ;Error encountered.
Q 0