| 1 | ORWCV ; SLC/KCM - Background Cover Sheet Load; ;11/2/06  15:07
 | 
|---|
| 2 |  ;;3.0;ORDER ENTRY/RESULTS REPORTING;**10,85,109,132,209,214,195,215,260**;Dec 17, 1997;Build 26
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 |  ; DBIA 4011    Access ^XWB(8994)
 | 
|---|
| 5 |  ; DBIA 4313    Direct R/W permission to capacity mgmt global ^KMPTMP("KMPDT")
 | 
|---|
| 6 |  ; DBIA 10061   Reference to ^UTILITY
 | 
|---|
| 7 |  ; 
 | 
|---|
| 8 | START(VAL,DFN,IP,HWND,LOC,NODO,NEWREM) ; start cover sheet build in background
 | 
|---|
| 9 |  N ZTIO,ZTRTN,ZTDTH,ZTSAVE,ZTDESC,SECT,BACK,X,I,ORLIST,STR,FILE,NODE,ORHTIME,ORX
 | 
|---|
| 10 |  ; Capacity planning timing code uses ORHTIME
 | 
|---|
| 11 |  S ORHTIME=$H
 | 
|---|
| 12 |  S LOC=$G(LOC),NODO=";"_$G(NODO),NEWREM=+$G(NEWREM)
 | 
|---|
| 13 |  D GETLST^XPAR(.ORX,"SYS^PKG","ORWOR COVER RETRIEVAL NEW","Q")
 | 
|---|
| 14 |  S I=0 F  S I=$O(ORX(I)) Q:'I  I $D(^ORD(101.24,+ORX(I),0)) S SECT(+$P(^(0),"^",2))=$P(ORX(I),"^",2)
 | 
|---|
| 15 |  D GETLST^XPAR(.ORLIST,"ALL","ORWCV1 COVERSHEET LIST")
 | 
|---|
| 16 |  S (VAL,BACK,STR,FILE)=""
 | 
|---|
| 17 |  F  S I=$O(ORLIST(I)) Q:'I  I $D(^ORD(101.24,$P(ORLIST(I),"^",2),0))  S X0=^(0) D
 | 
|---|
| 18 |  . Q:$P(X0,"^",8)'="C"
 | 
|---|
| 19 |  . S X=$P(X0,"^",2)
 | 
|---|
| 20 |  . I NODO[(";"_X_";") Q                                  ; if in NODO, dont do section
 | 
|---|
| 21 |  . S STR=STR_X_";"
 | 
|---|
| 22 |  . I '$G(SECT(X)) S VAL=VAL_X_";"                        ; load section in foreground
 | 
|---|
| 23 |  . E  S BACK=BACK_X_";",FILE=FILE_$P(ORLIST(I),"^",2)_";"  ; load section in background
 | 
|---|
| 24 |  Q:BACK=""
 | 
|---|
| 25 |  S ZTIO="ORW THREAD RESOURCE",ZTRTN="BUILD^ORWCV",ZTDTH=$H
 | 
|---|
| 26 |  S (ZTSAVE("DFN"),ZTSAVE("IP"),ZTSAVE("HWND"),ZTSAVE("NEWREM"),ZTSAVE("LOC"),ZTSAVE("BACK"),ZTSAVE("FILE"))=""
 | 
|---|
| 27 |  S ZTDESC="CPRS GUI Background Data Retrieval"
 | 
|---|
| 28 |  D ^%ZTLOAD I '$D(ZTSK) S VAL=STR Q
 | 
|---|
| 29 |  S NODE="ORWCV "_IP_"-"_HWND_"-"_DFN
 | 
|---|
| 30 |  K ^XTMP(NODE)
 | 
|---|
| 31 |  S ^XTMP(NODE,0)=$$FMADD^XLFDT(DT,1)_U_DT_U_"Background CPRS "_ZTSK
 | 
|---|
| 32 |  ; Start capacity planning timing clock - will be stopped in POLL code
 | 
|---|
| 33 |  I +$G(^KMPTMP("KMPD-CPRS")) S ^KMPTMP("KMPDT","ORWCV",NODE)=$G(ORHTIME)_"^^"_$G(DUZ)_"^"_$G(IO("CLNM"))
 | 
|---|
| 34 |  Q
 | 
|---|
| 35 | BUILD ; called in background by task manager, expects DFN, JobID
 | 
|---|
| 36 |  N NODE,IFLE,ORFNUM,ID,ENT,RTN,INODE,PARAM1,PARAM2,DETAIL,X0,X2
 | 
|---|
| 37 |  S NODE="ORWCV "_IP_"-"_HWND_"-"_DFN
 | 
|---|
| 38 |  I $D(ZTQUEUED) S ZTREQ="@"
 | 
|---|
| 39 |  I $G(^XTMP(NODE,"STOP")) K ^XTMP(NODE) Q  ; client no longer polling
 | 
|---|
| 40 |  I '$D(^XTMP(NODE,0)) Q                    ; XTMP node has been purged
 | 
|---|
| 41 |  L +^XTMP(NODE)
 | 
|---|
| 42 |  S ^XTMP(NODE,"DFN")=DFN
 | 
|---|
| 43 |  ;N $ETRAP,$ESTACK
 | 
|---|
| 44 |  ;S $ETRAP="D ERR^ORWCV Q"
 | 
|---|
| 45 |  I $L($G(FILE),";")>0 F IFLE=1:1:$L(FILE,";") S ORFNUM=$P(FILE,";",IFLE)  Q:'$D(^ORD(101.24,+ORFNUM,0))  S X0=^(0),X2=$G(^(2)) D
 | 
|---|
| 46 |  . S ID=$P(X0,"^",2),ENT=$P(X0,"^",6),RTN=$P(X0,"^",5),PARAM1=$P(X2,"^"),PARAM2=$P(X2,"^",2),INODE=$P(X2,"^",5),DETAIL=""
 | 
|---|
| 47 |  . I $P(X0,"^",18) S DETAIL=$P($G(^ORD(101.24,+$P(X0,"^",18),0)),"^",13),DETAIL=$P($G(^XWB(8994,+DETAIL,0)),"^")  ;DBIA 4011
 | 
|---|
| 48 |  . I '$L(INODE) Q
 | 
|---|
| 49 |  . I '$L(ENT) S LST(IFLE)="0^ERROR: Missing ENTRY POINT field in file 101.24 for "_$P(X0,"^")_", IFN="_+ORFNUM D LST2XTMP(INODE) Q
 | 
|---|
| 50 |  . I '$L(RTN) S LST(IFLE)="0^ERROR: Missing ROUTINE field in file 101.24 for "_$P(X0,"^")_", IFN="_+ORFNUM D LST2XTMP(INODE) Q
 | 
|---|
| 51 |  . I '$L($T(@(ENT_"^"_RTN))) S LST(IFLE)="0^ERROR: "_ENT_"~"_RTN_" does not exist. See file 101.24 entry: "_$P(X0,"^")_", IFN="_+ORFNUM D LST2XTMP(INODE) Q
 | 
|---|
| 52 |  . I ID=50 D:$L($T(STRT3^AWCMCPR1)) STRT3^AWCMCPR1 D  D:$L($T(END^AWCMCPR1)) END^AWCMCPR1 Q  ;Special case for reminders
 | 
|---|
| 53 |  .. I $G(NEWREM) D APPL^ORQQPXRM(.LST,DFN,LOC) I 1
 | 
|---|
| 54 |  .. E  D @(ENT_"^"_RTN_"(.LST,DFN)")
 | 
|---|
| 55 |  .. D LST2XTMP(INODE)
 | 
|---|
| 56 |  . I $L(PARAM1),$L(PARAM2) D @(ENT_"^"_RTN_"(.LST,DFN,PARAM1,PARAM2)"),LST2XTMP(INODE) Q
 | 
|---|
| 57 |  . I $L(PARAM1) D @(ENT_"^"_RTN_"(.LST,DFN,PARAM1)"),LST2XTMP(INODE) Q
 | 
|---|
| 58 |  . D @(ENT_"^"_RTN_"(.LST,DFN)"),LST2XTMP(INODE)
 | 
|---|
| 59 |  S ^XTMP(NODE,"DONE")=1
 | 
|---|
| 60 |  I $G(^XTMP(NODE,"STOP")) K ^XTMP(NODE)
 | 
|---|
| 61 |  L -^XTMP(NODE)
 | 
|---|
| 62 |  Q
 | 
|---|
| 63 | ERR ;Error trap
 | 
|---|
| 64 |  S $ETRAP="D UNWIND^ORWCV Q"
 | 
|---|
| 65 |  I $D(NODE) D
 | 
|---|
| 66 |  . I $D(INODE) S LST(0)="",LST(1)="0^ERROR DURING COVER SHEET BUILD:"_$ZERROR D LST2XTMP(INODE)
 | 
|---|
| 67 |  . S ^XTMP(NODE,"DONE")=1
 | 
|---|
| 68 |  . L -^XTMP(NODE)
 | 
|---|
| 69 |  D @^%ZOSF("ERRTN") ;file error
 | 
|---|
| 70 |  S $ECODE=",UOR70 error during Cover Sheet build,"
 | 
|---|
| 71 |  Q
 | 
|---|
| 72 | UNWIND ;Unwind Error stack
 | 
|---|
| 73 |  Q:$ESTACK>1  ;pop the stack
 | 
|---|
| 74 |  ;add additional code here, if needed
 | 
|---|
| 75 |  Q
 | 
|---|
| 76 | LST2XTMP(ID) ; put the list in ^XTMP(NODE,ID)
 | 
|---|
| 77 |  I $G(^XTMP(NODE,"STOP")) Q
 | 
|---|
| 78 |  N I
 | 
|---|
| 79 |  I $L($G(DETAIL)) S I=0 F  S I=$O(LST(I)) Q:'I  S $P(LST(I),"^",12)=DETAIL
 | 
|---|
| 80 |  K ^XTMP(NODE,ID) M ^XTMP(NODE,ID)=LST S ^XTMP(NODE,ID)=1 K LST
 | 
|---|
| 81 |  Q
 | 
|---|
| 82 | POLL(LST,DFN,IP,HWND) ; poll for completed cover sheet parts
 | 
|---|
| 83 |  N I,ILST,ID,NODE,DONE
 | 
|---|
| 84 |  S NODE="ORWCV "_IP_"-"_HWND_"-"_DFN,ILST=0,DONE=0
 | 
|---|
| 85 |  I '$D(^XTMP(NODE,"DFN")) Q
 | 
|---|
| 86 |  I ^XTMP(NODE,"DFN")'=DFN S LST(1)="~DONE=1" Q
 | 
|---|
| 87 |  I $G(^XTMP(NODE,"DONE")) S ILST=ILST+1,LST(ILST)="~DONE=1",DONE=1
 | 
|---|
| 88 |  F ID="PROB","CWAD","MEDS","RMND","LABS","VITL","VSIT" D
 | 
|---|
| 89 |  . I '$G(^XTMP(NODE,ID)) Q
 | 
|---|
| 90 |  . S ILST=ILST+1,LST(ILST)="~"_ID
 | 
|---|
| 91 |  . S I=0 F  S I=$O(^XTMP(NODE,ID,I)) Q:'I  S ILST=ILST+1,LST(ILST)="i"_^(I)
 | 
|---|
| 92 |  . K ^XTMP(NODE,ID)
 | 
|---|
| 93 |  ; Stop capacity planning timing clock - was started in START code
 | 
|---|
| 94 |  I DONE K ^XTMP(NODE) I +$G(^KMPTMP("KMPD-CPRS")) S $P(^KMPTMP("KMPDT","ORWCV",NODE),"^",2)=$H
 | 
|---|
| 95 |  Q
 | 
|---|
| 96 | STOP(OK,DFN,IP,HWND) ; stop cover sheet data retrieval
 | 
|---|
| 97 |  S NODE="ORWCV "_IP_"-"_HWND_"-"_DFN,ILST=0,DONE=0
 | 
|---|
| 98 |  S ^XTMP(NODE,"STOP")=1,OK=1
 | 
|---|
| 99 |  L +^XTMP(NODE)
 | 
|---|
| 100 |  I $G(^XTMP(NODE,"DONE")) K ^XTMP(NODE)
 | 
|---|
| 101 |  L -^XTMP(NODE)
 | 
|---|
| 102 |  Q
 | 
|---|
| 103 | CLEAN ; clean up ^XTMP nodes
 | 
|---|
| 104 |  S X="ORWCV"
 | 
|---|
| 105 |  F  S X=$O(^XTMP(X)) Q:$E(X,1,5)'="ORWCV"  W !,X K ^XTMP(X)
 | 
|---|
| 106 |  Q
 | 
|---|
| 107 | LAB(LST,DFN) ; return labs for patient
 | 
|---|
| 108 |  D:$L($T(STRT2^AWCMCPR1)) STRT2^AWCMCPR1
 | 
|---|
| 109 |  D LIST^ORQOR1(.LST,DFN,"LAB",4,"T-"_$$RNGLAB(DFN),"T","AW",1)
 | 
|---|
| 110 |  D:$L($T(END^AWCMCPR1)) END^AWCMCPR1
 | 
|---|
| 111 |  Q
 | 
|---|
| 112 |  ;
 | 
|---|
| 113 | VST1(ORVISIT,DFN,BEG,END,SKIP) ;
 | 
|---|
| 114 |  N ERR,ERRMSG
 | 
|---|
| 115 |  S ERR=0 ; kludge to return errors
 | 
|---|
| 116 |  D VST(.ORVISIT,DFN,.BEG,.END,$G(SKIP),.ERR,.ERRMSG)
 | 
|---|
| 117 |  I ERR K ORVISIT S ORVISIT(1)=ERRMSG
 | 
|---|
| 118 |  Q
 | 
|---|
| 119 |  ;
 | 
|---|
| 120 | TEST ;D VST(.ZZZ,76,2950101,3050401,777,1,1)
 | 
|---|
| 121 |  Q
 | 
|---|
| 122 | VST(ORVISIT,DFN,BEG,END,SKIP,ERR,ERRMSG) ; return appts/admissions for patient
 | 
|---|
| 123 |  N CHECKERR,VAERR,VASD,BDT,COUNT,DTM,EDT,LOC,NOW,ORQUERY,ORLST,STI,STS,TODAY,I,J,K,XI,XE,X
 | 
|---|
| 124 |  S CHECKERR=($G(ERR)=0) ; kludge to check for errors
 | 
|---|
| 125 |  S NOW=$$NOW^XLFDT(),TODAY=$P(NOW,".",1)
 | 
|---|
| 126 |  I '$G(BEG) S BEG=$$X2FM($$RNGVBEG)
 | 
|---|
| 127 |  I '$G(END) S END=$$X2FM($$RNGVEND)+0.2359
 | 
|---|
| 128 |  S COUNT=0
 | 
|---|
| 129 |  K ^TMP("ORVSTLIST",$J)
 | 
|---|
| 130 |  S VAERR=0
 | 
|---|
| 131 |  I END>NOW D   Q:VAERR  ; get future encounters, past cancels/no-shows from VADPT
 | 
|---|
| 132 |  . S VASD("F")=BEG
 | 
|---|
| 133 |  . S VASD("T")=END
 | 
|---|
| 134 |  . S VASD("W")="123456789"
 | 
|---|
| 135 |  . D SDA^ORQRY01(.ERR,.ERRMSG)
 | 
|---|
| 136 |  . I CHECKERR,ERR K ^UTILITY("VASD",$J) S ORVISIT(1)=ERRMSG Q  ;IA 10061
 | 
|---|
| 137 |  . S I=0 F  S I=$O(^UTILITY("VASD",$J,I)) Q:'I  D
 | 
|---|
| 138 |  . . S XI=^UTILITY("VASD",$J,I,"I"),XE=^("E")
 | 
|---|
| 139 |  . . S DTM=$P(XI,U),IEN=$P(XI,U,2),STI=$P(XI,U,3)
 | 
|---|
| 140 |  . . S LOC=$P(XE,U,2),STS=$P(XE,U,3)
 | 
|---|
| 141 |  . . I DTM<TODAY,(STI=""!(STI["I")!(STI="NT")) Q  ; no prior kept appts
 | 
|---|
| 142 |  . . S ^TMP("ORVSTLIST",$J,DTM,"A",1)="A;"_DTM_";"_IEN_U_DTM_U_LOC_U_STS
 | 
|---|
| 143 |  . K ^UTILITY("VASD",$J)
 | 
|---|
| 144 |  I BEG'>NOW D  ;past encounters from ACRP Toolkit - set in CALLBACK
 | 
|---|
| 145 |  . S BDT=BEG
 | 
|---|
| 146 |  . S EDT=$S(END<NOW:END,1:NOW)
 | 
|---|
| 147 |  . D OPEN^SDQ(.ORQUERY)
 | 
|---|
| 148 |  . I '$$ERRCHK^SDQUT() D INDEX^SDQ(.ORQUERY,"PATIENT/DATE","SET")
 | 
|---|
| 149 |  . I '$$ERRCHK^SDQUT() D PAT^SDQ(.ORQUERY,DFN,"SET")
 | 
|---|
| 150 |  . I '$$ERRCHK^SDQUT() D DATE^SDQ(.ORQUERY,BDT,EDT,"SET")
 | 
|---|
| 151 |  . I '$$ERRCHK^SDQUT() D
 | 
|---|
| 152 |  . . S ORLST=$NA(^TMP("ORVSTLIST",$J))
 | 
|---|
| 153 |  . . D SCANCB^SDQ(.ORQUERY,"D CALLBACK^ORWCV(Y,Y0,.ORLST,.ORSTOP)","SET")
 | 
|---|
| 154 |  . I '$$ERRCHK^SDQUT() D ACTIVE^SDQ(.ORQUERY,"TRUE","SET")
 | 
|---|
| 155 |  . I '$$ERRCHK^SDQUT() D SCAN^SDQ(.ORQUERY,"FORWARD")
 | 
|---|
| 156 |  . D CLOSE^SDQ(.ORQUERY)
 | 
|---|
| 157 |  ;
 | 
|---|
| 158 |  I '$G(SKIP) D
 | 
|---|
| 159 |  . N TIM,MOV,X0,Y,MTIM,XTYP,XLOC,HLOC,EARLY,DONE                ; admits
 | 
|---|
| 160 |  . S EARLY=$$X2FM($$RNGVBEG),DONE=0
 | 
|---|
| 161 |  . S TIM="" F  S TIM=$O(^DGPM("ATID1",DFN,TIM)) Q:TIM'>0  D  Q:DONE
 | 
|---|
| 162 |  . . S MOV=0  F  S MOV=$O(^DGPM("ATID1",DFN,TIM,MOV)) Q:MOV'>0  D  Q:DONE
 | 
|---|
| 163 |  . . . S X0=^DGPM(MOV,0),MTIM=$P(X0,U)
 | 
|---|
| 164 |  . . . I MTIM<EARLY S DONE=1 Q
 | 
|---|
| 165 |  . . . S XTYP=$P($G(^DG(405.1,+$P(X0,U,4),0)),U,1)
 | 
|---|
| 166 |  . . . S XLOC=$P($G(^DIC(42,+$P(X0,U,6),0)),U,1),HLOC=+$G(^(44))
 | 
|---|
| 167 |  . . . S ^TMP("ORVSTLIST",$J,MTIM,"I",1)="I;"_MTIM_";"_HLOC_U_MTIM_U_"Inpatient Stay"_U_XLOC_U_XTYP
 | 
|---|
| 168 |  ;
 | 
|---|
| 169 |  S COUNT=0
 | 
|---|
| 170 |  S I=0 F  S I=$O(^TMP("ORVSTLIST",$J,I)) Q:'I  D
 | 
|---|
| 171 |  . S J="" F  S J=$O(^TMP("ORVSTLIST",$J,I,J)) Q:J=""  D
 | 
|---|
| 172 |  . . S K=0 F  S K=$O(^TMP("ORVSTLIST",$J,I,J,K)) Q:'K  D
 | 
|---|
| 173 |  . . . S COUNT=COUNT+1
 | 
|---|
| 174 |  . . . S ORVISIT(COUNT)=^TMP("ORVSTLIST",$J,I,J,K)
 | 
|---|
| 175 |  K ^TMP("ORVSTLIST",$J)
 | 
|---|
| 176 |  Q
 | 
|---|
| 177 | CALLBACK(IEN,NODE0,ARRAY,STOP) ; called back from ACRP Toolkit for encounters
 | 
|---|
| 178 |  ;
 | 
|---|
| 179 |  ; IEN and NODE0 relate to Outpatient Encounter File
 | 
|---|
| 180 |  ; set STOP to 1 if need to quit
 | 
|---|
| 181 |  ;
 | 
|---|
| 182 |  N COUNT,DTM,LOC,OOS,TYPE,XSTAT,XLOC
 | 
|---|
| 183 |  S DTM=+NODE0,COUNT=1
 | 
|---|
| 184 |  S LOC=$P(NODE0,"^",4)
 | 
|---|
| 185 |  S XLOC=$P($G(^SC(+LOC,0)),U),OOS=$G(^("OOS"))
 | 
|---|
| 186 |  I OOS Q              ; ignore OOS locations
 | 
|---|
| 187 |  I $P(NODE0,"^",6) Q  ; not parent encounter
 | 
|---|
| 188 |  S XSTAT=$P($G(^SD(409.63,+$P(NODE0,"^",12),0)),"^")
 | 
|---|
| 189 |  S TYPE=$S($P(NODE0,"^",8)=1:"A",1:"V")
 | 
|---|
| 190 |  I TYPE="V",$D(@ARRAY@(DTM,"V")) S COUNT=$O(@ARRAY@(DTM,"V","A"),-1)+1 ; same d/t
 | 
|---|
| 191 |  S @ARRAY@(DTM,TYPE,COUNT)=TYPE_";"_DTM_";"_LOC_U_DTM_U_XLOC_U_XSTAT
 | 
|---|
| 192 |  Q
 | 
|---|
| 193 | DTLVST(RPT,DFN,IEN,APPTINFO) ; return progress notes / discharge summary
 | 
|---|
| 194 |  N VISIT
 | 
|---|
| 195 |  I $P(APPTINFO,";")="A" D  Q
 | 
|---|
| 196 |  . S VISIT=$$APPT2VST^PXAPI(DFN,$P(APPTINFO,";",2),$P(APPTINFO,";",3))
 | 
|---|
| 197 |  . I VISIT=0 S VISIT=+$$GETENC^PXAPI(DFN,$P(APPTINFO,";",2),$P(APPTINFO,";",3))
 | 
|---|
| 198 |  . D DETNOTE^ORQQVS(.RPT,DFN,VISIT)
 | 
|---|
| 199 |  I $P(APPTINFO,";")="V" D  Q
 | 
|---|
| 200 |  . S VISIT=+$$GETENC^PXAPI(DFN,$P(APPTINFO,";",2),$P(APPTINFO,";",3))
 | 
|---|
| 201 |  . D DETNOTE^ORQQVS(.RPT,DFN,VISIT)
 | 
|---|
| 202 |  I $P(APPTINFO,";")="I" D  Q
 | 
|---|
| 203 |  . S VISIT=+$$GETENC^PXAPI(DFN,$P(APPTINFO,";",2),$P(APPTINFO,";",3))
 | 
|---|
| 204 |  . D DETSUM^ORQQVS(.RPT,DFN,VISIT)
 | 
|---|
| 205 |  . K ^TMP("PXKENC",$J)
 | 
|---|
| 206 |  Q
 | 
|---|
| 207 | X2FM(X) ; return FM date given relative date
 | 
|---|
| 208 |  N %DT S %DT="TS" D ^%DT
 | 
|---|
| 209 |  Q Y
 | 
|---|
| 210 | RNGLAB(DFN) ; return days back for patient
 | 
|---|
| 211 |  N INPT,PAR
 | 
|---|
| 212 |  S INPT=0 I $L($G(^DPT(DFN,.1))) S INPT=1
 | 
|---|
| 213 |  S PAR="ORQQLR DATE RANGE "_$S(INPT:"INPT",1:"OUTPT")
 | 
|---|
| 214 |  Q $$GET^XPAR("ALL",PAR,1,"I")
 | 
|---|
| 215 |  ;
 | 
|---|
| 216 | RNGVBEG() ; return start date for encounters
 | 
|---|
| 217 |  Q $$GET^XPAR("ALL","ORQQCSDR CS RANGE START",1,"I")
 | 
|---|
| 218 |  ;
 | 
|---|
| 219 | RNGVEND() ; return stop date for encounters
 | 
|---|
| 220 |  Q $$GET^XPAR("ALL","ORQQCSDR CS RANGE STOP",1,"I")
 | 
|---|
| 221 |  ;
 | 
|---|
| 222 | RANGES(REC,DFN) ; return ranges given a patient
 | 
|---|
| 223 |  N REC
 | 
|---|
| 224 |  S REC=$$RNGLAB(DFN)_U_$$RNGVBEG_U_$$RNGVEND
 | 
|---|
| 225 |  Q
 | 
|---|