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

ZUONT.m

Go to the documentation of this file.
  1. ZU ;SF/RWF - For Cache and Open M! ;06/13/2006
  1. ;;8.0;KERNEL;**34,94,118,162,170,225,419**;Jul 10, 1995;Build 5
  1. ;TIE ALL TERMINALS EXCEPT CONSOLE TO THIS ROUTINE!
  1. EN N $ES,$ETRAP S $ETRAP="D ERR^ZU Q:$QUIT -9 Q"
  1. D:+$G(^%ZTSCH("LOGRSRC")) LOGRSRC^%ZOSV("$LOGIN$")
  1. ;The next line keeps sign-on users from taking the last slot
  1. ;It can be commented out if not needed.
  1. I $$AVJ^%ZOSV()<3 W $C(7),!!,"** TROUBLE ** - NO AVALIABLE JOBS ** CALL IRM NOW! **" G HALT
  1. ;Only call ShareLic for Telnet connections.
  1. I ($I["|TNT|")!($I["TNA") D SHARELIC^%ZOSV(0)
  1. G ^XUS
  1. ;
  1. ;
  1. ERR ;Come here on error
  1. ; Try and handle stack overflow errors specifically
  1. I $ZE["STACK" S $ET="Q:$ST>"_($ST-8)_" D ERR2^ZU" Q
  1. ERR2 ;
  1. S $ET="D UNWIND^ZU" L ;Backup trap (419)
  1. Q:$ECODE["<PROG>"
  1. ;
  1. D ^%ZTER K %ZT ; Capture symbol table first!
  1. ;
  1. I $G(IO)]"",$D(IO(1,IO)),$E($G(IOST))="P" D
  1. . U IO
  1. . W @$S($D(IOF):IOF,1:"#")
  1. I $G(IO(0))]"" D
  1. . U IO(0)
  1. . W !!,"RECORDING THAT AN ERROR OCCURRED ---"
  1. . W !!?15,"Sorry 'bout that"
  1. . W !,*7
  1. . W !?10,"$STACK=",$STACK," $ECODE=",$ECODE
  1. . W !?10,"$ZERROR=",$ZERROR
  1. ;
  1. I $G(DUZ)'>0 G HALT
  1. X ^%ZOSF("PROGMODE") Q:Y
  1. S $ET="D HALT^ZU" ;419
  1. I $ZE'["<INTERRUPT>" S XUERF="" G ^XUSCLEAN ;419
  1. CTRLC I $D(IO)=11 U IO(0) W !,"--Interrupt Acknowledged",!
  1. D KILL1^XUSCLEAN ;Clean up symbol table
  1. S $ECODE=",U55,"
  1. Q
  1. ;
  1. UNWIND ;Unwind the stack
  1. Q:$ESTACK>1 G CTRLC2:$ECODE["U55"
  1. S $ECODE=""
  1. Q
  1. ;
  1. CTRLC2 S $ECODE="" G:$G(^XUTL("XQ",$J,"T"))<2 ^XUSCLEAN
  1. S ^XUTL("XQ",$J,"T")=1,XQY=^(1),XQY0=$P(XQY,"^",2,99)
  1. G:$P(XQY0,"^",4)'="M" HALT
  1. S XQPSM=$P(XQY,"^",1),XQY=+XQPSM,XQPSM=$P(XQPSM,XQY,2,3)
  1. G:'XQY ^XUSCLEAN
  1. S $ECODE="",$ETRAP="D ERR^ZU"
  1. G M1^XQ
  1. ;
  1. HALT S $ECODE="" I $D(^XUTL("XQ",$J)) D BYE^XUSCLEAN
  1. D:+$G(^%ZTSCH("LOGRSRC")) LOGRSRC^%ZOSV("$LOGOUT$")
  1. HALT
  1. ;