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

XTKERM1.m

Go to the documentation of this file.
  1. XTKERM1 ;SF/RWF - Kermit Send a file ;10/21/09 16:44
  1. ;;7.3;TOOLKIT;**122**;Apr 25, 1995;Build 4
  1. ;Per VHA Directive 2004-038, this routine should not be modified.
  1. S D BSPAR^XTKERM4,STO S XTKS("PT")="S",F1=0
  1. I '$D(ZTQUEUED) U IO(0) D
  1. . I IO=IO(0) W !,"Now start a KERMIT receive on your system.",!,"Starting [REMOTE] KERMIT send.",! H 5
  1. . E W !,"Starting a [LOCAL] KERMIT send.",!
  1. . Q
  1. U IO S XTKET=$H
  1. F XTKERR=0:0 D @("S"_XTKS("PT")) Q:XTKERR!(XTKS("PT")="")
  1. S %=$H,XTKET=%-XTKET*86400+$P(%,",",2)-$P(XTKET,",",2)
  1. I '$D(ZTQUEUED) U IO(0) D
  1. . W !,"Done with ",$S(IO=IO(0):"[REMOTE]",1:"[LOCAL]")," send, File transfer ",$S('XTKERR:"was successful.",1:"failed. ("_XTKERR_")")
  1. . W:'XTKERR !,?10,"Bytes: ",XTKS("CCNT")," Sec: ",XTKET W:XTKET>0 " cps: ",$J($S(XTKET>0:XTKS("CCNT")/XTKET,1:""),3,1)
  1. Q
  1. SS S XTKS("PN")=0 D SEND,RTO S XTKSDAT=XTKRDAT D SPAR^XTKERM4 S XTKS("PT")="F" Q
  1. SF S XTKSDAT=XTKFILE D SEND,RACK:(XTKR("PN")'=XTKS("PN")) S XTKS("PT")="D" Q
  1. SD D GDATA I 'F1 D SZ Q
  1. D SDATA Q
  1. SZ S XTKSDAT="",XTKS("PT")="Z" D SEND S XTKS("PT")="B" Q:XTKERR
  1. Q ;MARK FILE AS SENT.
  1. SB S XTKSDAT="",XTKS("PT")="B" D SEND S XTKS("PT")="" Q
  1. SEND D:XTKS("PT")'="S" BUMP D SPACK ;Fall into RACK
  1. RACK S XTKS("TRY")=XTKS("TRY")+1 I XTKS("TRY")>XTKS("MAXTRY") G ABORT
  1. D RPACK^XTKERM3 I "EY"'[XTKR("PT")!XTKERR D SPACK G RACK
  1. I XTKR("PN")'=XTKS("PN") D SPACK G RACK
  1. S:"E"=XTKR("PT") XTKERR="8 Error packet" Q
  1. Q
  1. SEQ S X=(XTKS("PN")'=XTKS("PN")) Q:'X D NAK S X=1 Q
  1. Q
  1. ABORT S:'XTKERR XTKERR="7 Aborting send operation" Q
  1. BUMP S XTKS("TRY")=0,XTKS("PN")=XTKS("PN")+1#64 Q
  1. PREV S XTKS("PN")=$S(XTKS("PN"):XTKS("PN")-1,1:63) Q
  1. NAK S XTKS("PT")="N",XTKSDAT="" D SPACK Q
  1. ACK S XTKS("PT")="Y",XTKSDAT="" D SPACK S XTKS("TRY")=0 Q
  1. SPACK G SPACK^XTKERM3
  1. RPACK G RPACK^XTKERM3
  1. SDATA ;Send the data from the file.
  1. S XTKSDAT="",XTKS("SA")=X G IDATA:'XTKMODE
  1. I X'[XTKS("QA")&(X?1.ANP) S XTKSDAT=$E(X,1,XTKS("SIZ")),I=XTKS("SIZ")+1 G SD2
  1. F I=1:1:$L(XTKS("SA")) S %1=$E(XTKS("SA"),I),%2=(%1[XTKS("QA")!(%1?1C)) Q:$L(XTKSDAT)+1+%2>XTKS("SIZ") D
  1. . S XTKSDAT=XTKSDAT_$S('%2:%1,%1[XTKS("QA"):%1_%1,1:XTKS("QA")_$C($A(%1)+64)),%2=0
  1. . Q
  1. S:'%2&(I=$L(XTKS("SA"))) I=I+1
  1. SD2 S XTKS("SA")=$E(XTKS("SA"),I,999) D SEND Q:XTKERR S X=XTKS("SA") G SDATA:X]""
  1. Q
  1. IDATA F F3=0:0 S X=$E(XTKS("SA"),1,XTKS("SIZ")),XTKS("SA")=$E(XTKS("SA"),XTKS("SIZ")+1,999) D SEND Q:XTKS("SA")=""
  1. Q
  1. Q
  1. GDATA ;Get data from global
  1. S @("F1=$O("_XTKDIC_"F1))") Q:F1'>0 S X=@(XTKDIC_"F1,0)"),XTKS("CCNT")=XTKS("CCNT")+$L(X) S:XTKMODE=2 X=X_$C(13) S:XTKMODE=3 X=X_$C(13,10) Q
  1. Q
  1. STO ;Save timeout data for startup
  1. S XTKR("TOS")=XTKR("TO"),XTKR("TO")=5,XTKS("MAXTRY")=30
  1. Q
  1. RTO ;Restore saved timeout
  1. S XTKR("TO")=XTKR("TOS"),XTKS("MAXTRY")=10 K XTKR("TOS")
  1. Q