| 1 | HLCSRPT2 ;ISC-SF/RAH-TRANS LOG ERROR LIST ;05/12/03  05:47 PM
 | 
|---|
| 2 |  ;;1.6;HEALTH LEVEL SEVEN;**50,85,107**;Oct 13, 1995
 | 
|---|
| 3 |  ;Calls to SAVEDDB^DDBR2, USAVEDDB^DDBR2, PSR^DDBR0, and WP^DDBR2 supported by IA#2540 & IA#3594
 | 
|---|
| 4 |  ;
 | 
|---|
| 5 |  Q
 | 
|---|
| 6 |  ;
 | 
|---|
| 7 | EN ; Entry point for reporting error messages.
 | 
|---|
| 8 |  ;
 | 
|---|
| 9 |  ; All NEWs below added by HL*1.6*85
 | 
|---|
| 10 |  N BLDOFF,BLDON,DY,ERRDTB,ERRDTE,HLCSCLNT,HLCSDTE,HLCSDTP
 | 
|---|
| 11 |  N HLCSEVN,HLCSEVN1,HLCSEVN2,HLCSHDR,HLCSK,HLCSLINK
 | 
|---|
| 12 |  N HLCSLNK,HLCSMID,HLCSMX,HLCSNREC,HLCSPTR,HLCSRNO,HLCSSRVR
 | 
|---|
| 13 |  N HLCSTITL,HLCSTYP,HLERR,IEN773,LAST773,LASTPDT
 | 
|---|
| 14 |  N LPIENS,NOREC,NUMERR,OLD773,OLDPDT,RVOFF,RVON,SPACE
 | 
|---|
| 15 |  N SPACE20,SPACE25,SPACE30,SPACE80,STOP,TYPEINFO,VERS22
 | 
|---|
| 16 |  ;
 | 
|---|
| 17 |  D CLEANGBL ;HL*1.6*85
 | 
|---|
| 18 |  ;
 | 
|---|
| 19 |  S (STOP,NOREC)=""
 | 
|---|
| 20 |  D SCREEN^HLCSRPT
 | 
|---|
| 21 |  S HLCSNREC=BLDON_" ===>>>  NO MATCHING RECORDS  <<<=== "_BLDOFF
 | 
|---|
| 22 |  S HLCSTITL="#773-IEN      Message-ID       Procd     Log-Link   Msg:Evn IO Sndg-Apl Rcvr-Apl" ;HL*1.6*85
 | 
|---|
| 23 |  S HLCSPTR=1,HLCSRNO=1
 | 
|---|
| 24 |  S VERS22=""
 | 
|---|
| 25 |  I 22'>+$$VERSION^XPDUTL("DI")!($$PATCH^XPDUTL("DI*21.0*32")) S VERS22="YES" ;HL*1.6*85
 | 
|---|
| 26 |  I VERS22'="YES" D
 | 
|---|
| 27 |  . S ^TMP("DDBPF1Z",$J)="D SHOWMSG^HLCSRPT2 Q"
 | 
|---|
| 28 |  . S HLCSTITL=HLCSTITL_" ERR"
 | 
|---|
| 29 |  E  S HLCSTITL=HLCSTITL_"    "
 | 
|---|
| 30 |  S ^TMP($J,"LIST","MESSAGE")="^TMP($J,""MESSAGE"",HLCSRNO)"
 | 
|---|
| 31 |  S ^TMP($J,"LIST",HLCSTITL_" ERR")="^TMP(""TLOG"",$J)" ;HL*1.6*85
 | 
|---|
| 32 |  ;
 | 
|---|
| 33 | REEN ; Internal Re-entry Point
 | 
|---|
| 34 |  S STOP=""
 | 
|---|
| 35 |  D WHATERR Q:(+$G(STOP))
 | 
|---|
| 36 |  QUIT:'$$SETUP^HLCSRPT4  ;-> HL*1.6*85
 | 
|---|
| 37 |  I TYPEINFO=2 S HLCSTITL="#773-IEN      Message-ID       Procd     Log-Link   Error-type               " ;HL*1.6*85
 | 
|---|
| 38 |  D ERRSRCH
 | 
|---|
| 39 |  I ERRDTE[9999999 S ERRDTE=$$NOW^XLFDT
 | 
|---|
| 40 |  I +$G(STOP) D EXIT Q
 | 
|---|
| 41 |  I +$G(NOREC) W !!,HLCSNREC,!! S DIR(0)="E" D ^DIR K DIR,X,Y D EXIT Q
 | 
|---|
| 42 |  D DISPLAY^HLCSRPT ;HL*1.6*85
 | 
|---|
| 43 |  D CLEANGBL ;HL*1.6*85
 | 
|---|
| 44 |  D EXIT
 | 
|---|
| 45 |  S STOP=1
 | 
|---|
| 46 |  Q
 | 
|---|
| 47 |  ;
 | 
|---|
| 48 | CLEANGBL ; New subroutine added by HL*1.6*85 to clean up globals
 | 
|---|
| 49 |  N GBL
 | 
|---|
| 50 |  F GBL="LIST","MESSAGE" KILL ^TMP($J,GBL)
 | 
|---|
| 51 |  F GBL="DDBPF1Z","DDBLST","TLOG","TMPLOG" KILL ^TMP(GBL,$J)
 | 
|---|
| 52 |  QUIT
 | 
|---|
| 53 |  ;
 | 
|---|
| 54 | WHATERR ; Ask for one error code; with default of all
 | 
|---|
| 55 |  W @IOF,! S HLCSHDR="Error Type Selection" D HLCSBAR
 | 
|---|
| 56 |  S X="",HLCSER="ALL"
 | 
|---|
| 57 |  S DIR(0)="PAO^771.7:AEO",DIR("A")="Select Error Type:  ALL//"
 | 
|---|
| 58 |  D ^DIR S:($D(DTOUT)!($D(DUOUT))) STOP=1
 | 
|---|
| 59 |  I +$G(STOP) K DIR,X,Y Q
 | 
|---|
| 60 |  I X="" K DIR,X,Y Q
 | 
|---|
| 61 |  I Y=-1 W !,X_" NOT VALID " K DIR,X,Y G WHATERR
 | 
|---|
| 62 |  S HLCSTER1=$P(Y,U,1),HLCSTER2=$P(Y,U,2) K DIR,X,Y
 | 
|---|
| 63 |  S HLCSER=1
 | 
|---|
| 64 |  Q
 | 
|---|
| 65 |  ;
 | 
|---|
| 66 | ERRSRCH ; Find and report the 'errored' messages (Multiple HL*1.6*85 changes start here)
 | 
|---|
| 67 |  ; ERRDTB,ERRDTE,NUMERR -- req
 | 
|---|
| 68 |  N NEXT,CT
 | 
|---|
| 69 |  W !!,"PLEASE WAIT, THIS CAN TAKE AWHILE..."
 | 
|---|
| 70 |  ;
 | 
|---|
| 71 |  ;HL*1.6*85 - LOADERR loads all errors, using the user-supplied 
 | 
|---|
| 72 |  ;            parameters, and places them in ^TMP.  Below, the code
 | 
|---|
| 73 |  ;            now loops thru ^TMP instead of ^HLMA (which happened
 | 
|---|
| 74 |  ;            in LOADERR.)
 | 
|---|
| 75 |  D LOADERR^HLCSRPT4
 | 
|---|
| 76 |  ;
 | 
|---|
| 77 |  ; Looping starts here...
 | 
|---|
| 78 |  S HLCSI=0,HLCSST=0,HLCSLN=0
 | 
|---|
| 79 |  F  S HLCSI=$O(^TMP("ERRLST",$J,HLCSI)) Q:HLCSI'>0  D
 | 
|---|
| 80 |  .  S HLCSN=HLCSI,HLCSJ=0
 | 
|---|
| 81 |  .  F  S HLCSJ=$O(^TMP("ERRLST",$J,HLCSI,HLCSJ)) Q:HLCSJ'>0  D
 | 
|---|
| 82 |  .. ;HL*1.6*85 changes end here, until noted otherwise below.
 | 
|---|
| 83 |  ..
 | 
|---|
| 84 |  .. I '$D(^HLMA(HLCSJ,0)) Q
 | 
|---|
| 85 |  .. S HLCSX=^HLMA(HLCSJ,0),HLCSDTE=$P(HLCSX,U,1)
 | 
|---|
| 86 |  .. I $D(^HLMA(HLCSJ,"S")) S HLCSDTP=$P(^HLMA(HLCSJ,"S"),U,1)
 | 
|---|
| 87 |  .. E  S HLCSDTP=""
 | 
|---|
| 88 |  .. I $D(^HLMA(HLCSJ,"P")) S HLCSY=^HLMA(HLCSJ,"P")
 | 
|---|
| 89 |  .. E  S HLCSY=""
 | 
|---|
| 90 |  .. I HLCSER=1,(HLCSTER1'=$P(HLCSY,U,4)) Q
 | 
|---|
| 91 |  .. S HLCSER1=$P(HLCSY,U,4),HLCSER2=HLCSER1
 | 
|---|
| 92 |  .. I HLCSER1'="",($D(^HL(771.7,HLCSER1,0))) S HLCSER1=$P(^HL(771.7,HLCSER1,0),U,1)
 | 
|---|
| 93 |  .. S HLCSERMS=$P(HLCSY,U,3)
 | 
|---|
| 94 |  .. S HLCSLINK=$P(HLCSX,U,7) S HLCSLNK="          "
 | 
|---|
| 95 |  .. I HLCSLINK'="",($D(^HLCS(870,HLCSLINK,0))) S HLCSLNK=$P(^HLCS(870,HLCSLINK,0),U,1)
 | 
|---|
| 96 |  .. S HLCSEVN1=$P(HLCSX,U,13) I HLCSEVN1'="",($D(^HL(771.2,HLCSEVN1,0))) S HLCSEVN1=$P(^HL(771.2,HLCSEVN1,0),U,1)
 | 
|---|
| 97 |  .. S HLCSEVN2=$P(HLCSX,U,14) I HLCSEVN2'="",($D(^HL(779.001,HLCSEVN2,0))) S HLCSEVN2=$P(^HL(779.001,HLCSEVN2,0),U,1)
 | 
|---|
| 98 |  .. I HLCSEVN1="" S HLCSEVN1=$$MSGEVN^HLCSRPT5(HLCSJ,2) ;HL*1.6*85
 | 
|---|
| 99 |  .. I HLCSEVN2="" S HLCSEVN2=$$MSGEVN^HLCSRPT5(HLCSJ,2) ;HL*1.6*85
 | 
|---|
| 100 |  .. I $L(HLCSEVN1)<3 S HLCSEVN1=HLCSEVN1_"   ",HLCSEVN1=$E(HLCSEVN1,1,3)
 | 
|---|
| 101 |  .. I $L(HLCSEVN2)<3 S HLCSEVN2=HLCSEVN2_"   ",HLCSEVN2=$E(HLCSEVN2,1,3)
 | 
|---|
| 102 |  .. S HLCSEVN=HLCSEVN1_":"_HLCSEVN2
 | 
|---|
| 103 |  .. D ERRRPT^HLCSRPT5 ;HL*1.6*85 - Code overrun moved
 | 
|---|
| 104 |  .. Q
 | 
|---|
| 105 |  .Q
 | 
|---|
| 106 |  KILL ^TMP("ERRLST",$J) ;HL*1.6*85
 | 
|---|
| 107 |  D TMPLOG^HLCSRPT4 ;HL*1.6*85 Reset ^TMP("TMPLOG",$J) to ^TMP("TLOG",$J)
 | 
|---|
| 108 |  I '$D(^TMP("TLOG",$J,1)) S NOREC=1 Q
 | 
|---|
| 109 |  ;HL*1.6*85 - HLCSTITL already set above ;S HLCSTITL="IEN Record #   MESSAGE ID #         Log Link   Msg:Evn IO Sndg Apl Rcvr Apl"
 | 
|---|
| 110 |  I '$D(VERS22) S HLCSTITL=HLCSTITL_" ERR"
 | 
|---|
| 111 |  E  S HLCSTITL=HLCSTITL_"    "
 | 
|---|
| 112 |  D TEST
 | 
|---|
| 113 |  Q
 | 
|---|
| 114 |  ;
 | 
|---|
| 115 | SHOWMSG ; Enable switching to specific message (used by PF1Z).
 | 
|---|
| 116 |  ; If FM version 22 installed, uses VERS22 code, instead.
 | 
|---|
| 117 |  W @IOF
 | 
|---|
| 118 |  S DIR(0)="F:AE",DIR("A")="Enter Record Number: "
 | 
|---|
| 119 |  D ^DIR Q:$D(DIRUT)
 | 
|---|
| 120 |  I Y=-1!(X="") Q
 | 
|---|
| 121 |  S HLCSRNO=X I '$D(^HLMA(HLCSRNO,0)) D  Q
 | 
|---|
| 122 |  . W !!,BLDON,"  ==>  NO SUCH RECORD NUMBER <== ",BLDOFF H 3
 | 
|---|
| 123 |  S HLCSPTR=$P(^HLMA(HLCSRNO,0),"^",1)
 | 
|---|
| 124 |  S XXY=HLCSRNO,XXZ=HLCSPTR D VERS22(XXY,XXZ)
 | 
|---|
| 125 |  D SWITCH
 | 
|---|
| 126 |  Q
 | 
|---|
| 127 | SWITCH ; Non-standard Fileman Browser calls covered by IA# 2540.
 | 
|---|
| 128 |  N DDBLN,DDBZ,DIC,DIR,X,Y,DIRUT,DIROUT,DUOUT,DILN
 | 
|---|
| 129 |  S DILN=DDBRSA(DDBRSA,"DDBSRL")-2
 | 
|---|
| 130 |  S:$G(DDBLST)="" DDBLST="^TMP(""DDBLST"",$J)" S DDBLN=$S($D(@DDBLST@("A",DDBSA)):^(DDBSA),1:$O(@DDBLST@(" "),-1)+1)
 | 
|---|
| 131 |  I $D(@DDBLST) D
 | 
|---|
| 132 |  .I $O(@DDBLST@(" "),-1)=1,$G(@DDBLST@(1,"DDBSA"))=DDBSA Q
 | 
|---|
| 133 |  .S DDBZ=$G(@DDBLST@("A",DDBSA),0)
 | 
|---|
| 134 |  .S Y=2
 | 
|---|
| 135 |  .D SAVEDDB^DDBR2(DDBLST,DDBLN),USAVEDDB^DDBR2(DDBLST,+Y)
 | 
|---|
| 136 |  .S DIROUT=1
 | 
|---|
| 137 |  N DDBLNA
 | 
|---|
| 138 |  I $G(DDBLNA,-1)=-1 G PS
 | 
|---|
| 139 |  I $G(DDBLNA(6))=DDBSA G PS  ;if current doc re-selected
 | 
|---|
| 140 |  I $G(DDBLNA(6))]"",$D(@DDBLST@("APSA",DDBSA)) G PS  ;on list
 | 
|---|
| 141 |  D:DDBLNA>0 SAVEDDB^DDBR2(DDBLST,DDBLN),WP^DDBR2(.DDBLNA)
 | 
|---|
| 142 | PS D PSR^DDBR0(1)
 | 
|---|
| 143 |  Q
 | 
|---|
| 144 |  ;
 | 
|---|
| 145 | VERS22(XXY,XXZ) ; this is modified code from SHOWMSG^HLCSRPT1.
 | 
|---|
| 146 |  ; Each node, ^tmp($j,"message",record_ien), invokes this code
 | 
|---|
| 147 |  ; to compile a 'virtual w-p document' when a message is browsed.
 | 
|---|
| 148 |  I $D(^HLMA(XXY,"MSH",0)) D
 | 
|---|
| 149 |  .S ^TMP($J,"MESSAGE",XXY,0)=^HLMA(XXY,"MSH",0)
 | 
|---|
| 150 |  .S YY1=$P(^HLMA(XXY,"MSH",0),U,3),YY2=$P(^HLMA(XXY,"MSH",0),U,4)
 | 
|---|
| 151 |  E  S ^TMP($J,"MESSAGE",XXY,0)="^^1^1" S (YY1,YY2)=1
 | 
|---|
| 152 |  S XLINE=^HLMA(XXY,0)
 | 
|---|
| 153 |  S LINE="Record #: "_XXY_"                    ",LINE=$E(LINE,1,30)
 | 
|---|
| 154 |  S LINE=LINE_"Message #: "_$P(XLINE,U,2)
 | 
|---|
| 155 |  S ^TMP($J,"MESSAGE",XXY,1,0)=LINE
 | 
|---|
| 156 |  S DTE=$P(XLINE,U,1) I $P($G(^HL(772,DTE,0)),U,1)'="" S DTE=$P(^HL(772,DTE,0),U,1),DTE=$E(DTE,4,7)_$E(DTE,2,3)_"."_$P(DTE,".",2)_"      "
 | 
|---|
| 157 |  I $D(^HLMA(XXY,"S")),$P(^HLMA(XXY,"S"),U,1)'="" S DTP=$P(^HLMA(XXY,"S"),U,1) S DTP=$E(DTP,4,7)_$E(DTP,2,3)_"."_$P(DTP,".",2)
 | 
|---|
| 158 |  E  S DTP=" "
 | 
|---|
| 159 |  S LINE="D/T Entered: "_DTE,LINE=$E(LINE,1,30)_"D/T Processed: "_DTP
 | 
|---|
| 160 |  S ^TMP($J,"MESSAGE",XXY,2,0)=LINE K DTE,DTP
 | 
|---|
| 161 |  S LINE="Logical Link: " I $P(XLINE,U,7)'="",($G(^HLCS(870,$P(XLINE,U,7),0))) S LINE=LINE_$P(^HLCS(870,$P(XLINE,U,7),0),U,1)
 | 
|---|
| 162 |  S LINE=LINE_"                ",LINE=$E(LINE,1,30)
 | 
|---|
| 163 |  S LINE=LINE_"Ack To MSG#: " I $P(XLINE,U,6)'="",$G(^HLMA($P(XLINE,U,6),0)) S LINE=LINE_$P(^HLMA($P(XLINE,U,6),0),U,2)
 | 
|---|
| 164 |  S ^TMP($J,"MESSAGE",XXY,3,0)=LINE
 | 
|---|
| 165 |  S DTS="" I $P($G(^HLMA(XXY,"P")),U,2)'="" S DTS=$P(^HLMA(XXY,"P"),U,2),DTS=$E(DTS,4,7)_$E(DTS,2,3)_"."_$P(DTS,".",2)
 | 
|---|
| 166 |  S LINE="D/T STATUS: "_DTS_"                 ",LINE=$E(LINE,1,30),LINE=LINE_"STATUS: "
 | 
|---|
| 167 |  I $P(^HLMA(XXY,"P"),U,2)'="",($G(^HL(771.6,+$P(^HLMA(XXY,"P"),U,1),0))) S LINE=LINE_$P(^HL(771.6,+$P(^HLMA(XXY,"P"),U,1),0),U,1)
 | 
|---|
| 168 |  S ^TMP($J,"MESSAGE",XXY,4,0)=LINE K DTS
 | 
|---|
| 169 |  S LINE="ERR MSG: " I $P(^HLMA(XXY,"P"),U,3)'="" S LINE=LINE_$E($P(^HLMA(XXY,"P"),U,3),1,20)
 | 
|---|
| 170 |  S LINE=LINE_"                      ",LINE=$E(LINE,1,30)_"ERR TYPE: "
 | 
|---|
| 171 |  I $P(^HLMA(XXY,"P"),U,4)'="",($D(^HL(771.7,+$P(^HLMA(XXY,"P"),U,4),0))) S LINE=LINE_$P(^HL(771.7,+$P(^HLMA(XXY,"P"),U,4),0),U,1)
 | 
|---|
| 172 |  S ^TMP($J,"MESSAGE",XXY,5,0)=LINE
 | 
|---|
| 173 |  S LINE="Sending Appl: " I $P(XLINE,U,11)'="",($D(^HL(771,$P(XLINE,U,11),0))) S LINE=LINE_$P(^HL(771,$P(XLINE,U,11),0),U,1)
 | 
|---|
| 174 |  S ^TMP($J,"MESSAGE",XXY,6,0)=LINE
 | 
|---|
| 175 |  S LINE="Receiving Appl: " I $P(XLINE,U,12)'="",($D(^HL(771,$P(XLINE,U,12),0))) S LINE=LINE_$P(^HL(771,$P(XLINE,U,12),0),U,1)
 | 
|---|
| 176 |  S ^TMP($J,"MESSAGE",XXY,7,0)=LINE
 | 
|---|
| 177 |  S LINE="Message Type: " I $P(XLINE,U,13)'="",($D(^HL(771.2,$P(XLINE,U,13),0))) S LINE=LINE_$P(^HL(771.2,$P(XLINE,U,13),0),U,1)
 | 
|---|
| 178 |  S LINE=LINE_"                    ",LINE=$E(LINE,1,30)_"Event Type: "
 | 
|---|
| 179 |  I $P(XLINE,U,14)'="",($D(^HL(779.001,$P(XLINE,U,14),0))) S LINE=LINE_$P(^HL(779.001,$P(XLINE,U,14),0),U,1)
 | 
|---|
| 180 |  S ^TMP($J,"MESSAGE",XXY,8,0)=LINE K LINE,XLINE
 | 
|---|
| 181 |  S ^TMP($J,"MESSAGE",XXY,9,0)="MESSAGE HEADER: "
 | 
|---|
| 182 |  S LN2=10
 | 
|---|
| 183 |  I $D(^HLMA(XXY,"MSH",0)) D
 | 
|---|
| 184 |  .S LN1=.5
 | 
|---|
| 185 |  .F  S LN1=$O(^HLMA(XXY,"MSH",LN1)) Q:LN1=""  D
 | 
|---|
| 186 |  .. S ^TMP($J,"MESSAGE",XXY,LN2,0)=^HLMA(XXY,"MSH",LN1,0)
 | 
|---|
| 187 |  .. ;HL*1.6*107 start: to fix the multiple lines per segment
 | 
|---|
| 188 |  .. ;S LN2=LN2+1,LN1=LN1+1
 | 
|---|
| 189 |  .. S LN2=LN2+1
 | 
|---|
| 190 |  .. ;HL*1.6*107 end
 | 
|---|
| 191 |  E  S ^TMP($J,"MESSAGE",XXY,LN2,0)=" No Header in MSG Admin File (#773)" S LN2=LN2+1
 | 
|---|
| 192 |  S LN1=.5
 | 
|---|
| 193 |  S ^TMP($J,"MESSAGE",XXY,LN2,0)="MESSAGE TEXT: ",LN2=LN2+1
 | 
|---|
| 194 |  I $D(^HL(772,XXZ,"IN",0)) D
 | 
|---|
| 195 |  .F  S LN1=$O(^HL(772,XXZ,"IN",LN1)) Q:(LN1="")  D
 | 
|---|
| 196 |  .. S ^TMP($J,"MESSAGE",XXY,LN2,0)=^HL(772,XXZ,"IN",LN1,0)
 | 
|---|
| 197 |  .. ;HL*1.6*107 start: to fix the multiple lines per segment
 | 
|---|
| 198 |  .. ;S LN2=LN2+1,LN1=LN1+1
 | 
|---|
| 199 |  .. S LN2=LN2+1
 | 
|---|
| 200 |  .. ;HL*1.6*107 end
 | 
|---|
| 201 |  ..Q
 | 
|---|
| 202 |  E  S ^TMP($J,"MESSAGE",XXY,LN2,0)=" No Message in MSG Text File (#772)" S LN2=LN2+1
 | 
|---|
| 203 |  S (YY1,YY2)=LN2-1
 | 
|---|
| 204 |  S Y1Y2=YY1_"^"_YY2
 | 
|---|
| 205 |  S $P(^TMP($J,"MESSAGE",XXY,0),U,3,4)=Y1Y2
 | 
|---|
| 206 |  K LN1,LN2,Y1Y2,YY1,YY2
 | 
|---|
| 207 |  Q
 | 
|---|
| 208 |  ;
 | 
|---|
| 209 | EXIT ;
 | 
|---|
| 210 |  K I,J
 | 
|---|
| 211 |  K HLCSER,HLCSER1,HLCSER2,HLCSI,HLCSJ,HLCSLN,HLCSN
 | 
|---|
| 212 |  K HLCSST,HLCSTER1,HLCSTER2,HLCSERMS,HLCSX,HLCSY
 | 
|---|
| 213 |  K ^TMP($J,"LIST",HLCSTITL_" ERR") ;HL*1.6*85
 | 
|---|
| 214 |  I VERS22'="YES" S ^TMP("DDBPF1Z",$J)="D SHOWMSG^HLCSRPT Q"
 | 
|---|
| 215 |  Q
 | 
|---|
| 216 |  ;
 | 
|---|
| 217 | HLCSBAR ; Center Title on Top Line of Screen
 | 
|---|
| 218 |  W RVON,?(80-$L(HLCSHDR)\2),HLCSHDR,$E(SPACE,$X,77),RVOFF,!
 | 
|---|
| 219 |  Q
 | 
|---|
| 220 |  ;
 | 
|---|
| 221 | TEST ;
 | 
|---|
| 222 |  S HLCSJ=$O(^TMP("TLOG",$J,0))
 | 
|---|
| 223 |  S HLCSJ=+$P(HLCSJ," ",1)
 | 
|---|
| 224 |  S ^TMP($J,"MESSAGE",HLCSJ,0)="^^1^1"
 | 
|---|
| 225 |  S ^TMP($J,"MESSAGE",HLCSJ,1,0)=" HEADER: "
 | 
|---|
| 226 |  S HLCSRNO=HLCSJ
 | 
|---|
| 227 |  Q
 | 
|---|
| 228 |  ;
 | 
|---|