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

ONCXERR.m

Go to the documentation of this file.
  1. ONCXERR ;HCIOFO/SG - HTTP AND WEB SERVICES (ERRORS) ; 6/21/04 2:35pm
  1. ;;2.2;ONCOLOGY;**1**;Jul 31, 2013;Build 8
  1. ;
  1. Q
  1. ;
  1. ;***** GENERATES THE ERROR MESSAGE
  1. ;
  1. ; ERRCODE Error code
  1. ;
  1. ; [[.]INFO] reserved
  1. ;
  1. ; [ARG1-ARG5] Optional parameters as for $$MSG^ONCXERR
  1. ;
  1. ; Return Values:
  1. ; <0 Error code^Message Text^Label+Offset^Routine
  1. ; 0 Ok (if ERRCOCE'<0)
  1. ;
  1. ERROR(ERRCODE,INFO,ARG1,ARG2,ARG3,ARG4,ARG5) ;
  1. Q:ERRCODE'<0 0
  1. N PLACE,SL
  1. S SL=$STACK(-1)-1
  1. F Q:SL'>0 D Q:'(PLACE["^ONCXERR") S SL=SL-1
  1. . S PLACE=$P($STACK(SL,"PLACE")," ")
  1. S:PLACE'[U PLACE=U
  1. Q ERRCODE_U_$$MSG(ERRCODE,,.ARG1,.ARG2,.ARG3,.ARG4,.ARG5)_U_PLACE
  1. ;
  1. ;***** RETURNS THE TEXT OF THE MESSAGE
  1. ;
  1. ; ERRCODE Error code
  1. ;
  1. ; [.TYPE] Type of the error
  1. ;
  1. ; [ARG1-ARG5] Optional parameters that substitute the |n| "windows"
  1. ; in the text of the message (for example, the |2| will
  1. ; be substituted by the value of the ARG2).
  1. ;
  1. ; NOTE: The "^" is replaced with the "~" in the resulting message.
  1. ;
  1. MSG(ERRCODE,TYPE,ARG1,ARG2,ARG3,ARG4,ARG5) ;
  1. S TYPE=6 Q:ERRCODE'<0 ""
  1. N ARG,I1,I2,MSG
  1. ;--- Get a descriptor of the message
  1. S I1=-ERRCODE,MSG=$P($T(MSGLIST+I1),";;",2)
  1. S I1=+$TR($P(MSG,U,2)," "),MSG=$P(MSG,U,3,999)
  1. S:I1>0 TYPE=I1
  1. Q:MSG?." " "Unknown error ("_ERRCODE_")"
  1. ;--- Substitute parameters
  1. S I1=2
  1. F S I1=$F(MSG,"|",I1-1) Q:'I1 D
  1. . S I2=$F(MSG,"|",I1) Q:'I2
  1. . X "S ARG=$G(ARG"_+$TR($E(MSG,I1,I2-2)," ")_")"
  1. . S $E(MSG,I1-1,I2-1)=ARG
  1. Q $TR($$TRIM^XLFSTR(MSG),U,"~")
  1. ;
  1. ;***** RETURNS TYPE OF THE MESSAGE
  1. ;
  1. ; ERRCODE Error code
  1. ;
  1. TYPE(ERRCODE) ;
  1. Q:ERRCODE'<0 0
  1. N I,TYPE S I=-ERRCODE
  1. S I=$P($T(MSGLIST+I),";;",2),TYPE=+$TR($P(I,U,2)," ")
  1. Q $S(TYPE>0:TYPE,1:6)
  1. ;
  1. ;***** LIST OF THE MESSAGES (THERE SHOULD BE NOTHING AFTER THE LIST!)
  1. ;
  1. ; The error codes are provided in the table only for clarity.
  1. ; Text of the messages are extracted using the $TEXT function and
  1. ; absolute values of the ERRCODE parameter.
  1. ;
  1. ; Message Type:
  1. ; 1 Debug 4 Warning
  1. ; 2 Information 5 Database Error
  1. ; 3 Data Quality 6 Error
  1. ;
  1. MSGLIST ; Code Type Message Text
  1. ;; -1 ^ 6 ^ Missing host name: '|1|'
  1. ;; -2 ^ 6 ^ Cannot resolve the host name: '|1|'
  1. ;; -3 ^ 6 ^ Cannot connect to host(s): '|1|'
  1. ;; -4 ^ 6 ^ Missing redirection URL
  1. ;; -5 ^ 6 ^ Too many redirections
  1. ;; -6 ^ 6 ^ Error during transaction (see Error Trap log)
  1. ;; -7 ^ 6 ^ Timeout