| 1 | RGUT ;CAIRO/DKM - General purpose utilities;17-Sep-1998 14:14;DKM
 | 
|---|
| 2 |  ;;2.1;RUN TIME LIBRARY;;Mar 22, 1999
 | 
|---|
| 3 |  ;=================================================================
 | 
|---|
| 4 |  ; Replaces delimited arguments in string, returning result
 | 
|---|
| 5 | MSG(%RGTXT,%RGDLM) ;
 | 
|---|
| 6 |  N %RGZ1,%RGZ2
 | 
|---|
| 7 |  I $$NEWERR^%ZTER N $ET S $ET=""
 | 
|---|
| 8 |  S:$G(%RGDLM)="" %RGDLM="%"
 | 
|---|
| 9 |  S %RGZ2="",%RGTXT=$TR(%RGTXT,"~","^"),@$$TRAP^RGZOSF("M1^RGUT")
 | 
|---|
| 10 |  F  Q:%RGTXT=""  D
 | 
|---|
| 11 |  .S %RGZ2=%RGZ2_$P(%RGTXT,%RGDLM),%RGZ1=$P(%RGTXT,%RGDLM,2),%RGTXT=$P(%RGTXT,%RGDLM,3,999)
 | 
|---|
| 12 |  .I %RGZ1="" S:%RGTXT'="" %RGZ2=%RGZ2_%RGDLM
 | 
|---|
| 13 |  .E  X "S %RGZ2=%RGZ2_("_%RGZ1_")"
 | 
|---|
| 14 | M1 Q %RGZ2
 | 
|---|
| 15 |  ; Case-insensitive string comparison
 | 
|---|
| 16 |  ; Returns 0: X=Y, 1: X>Y, -1: X<Y
 | 
|---|
| 17 | STRICMP(X,Y) ;
 | 
|---|
| 18 |  S X=$$UP^XLFSTR(X),Y=$$UP^XLFSTR(Y)
 | 
|---|
| 19 |  Q $S(X=Y:0,X]]Y:1,1:-1)
 | 
|---|
| 20 |  ; Output an underline X bytes long
 | 
|---|
| 21 | UND(X) Q $$REPEAT^XLFSTR("-",$G(X,$G(IOM,80)))
 | 
|---|
| 22 |  ; Truncate a string if > Y bytes long
 | 
|---|
| 23 | TRUNC(X,Y) ;
 | 
|---|
| 24 |  Q $S($L(X)'>Y:X,1:$E(X,1,Y-3)_"...")
 | 
|---|
| 25 |  ; Formatting for singular/plural
 | 
|---|
| 26 | SNGPLR(RGNUM,RGSNG,RGPLR) ;
 | 
|---|
| 27 |  N RGZ
 | 
|---|
| 28 |  S RGZ=RGSNG?.E1L.E,RGPLR=$G(RGPLR,RGSNG_$S(RGZ:"s",1:"S"))
 | 
|---|
| 29 |  Q $S('RGNUM:$S(RGZ:"no ",1:"NO ")_RGPLR,RGNUM=1:"1 "_RGSNG,1:RGNUM_" "_RGPLR)
 | 
|---|
| 30 |  ; Convert code to external form from set of codes
 | 
|---|
| 31 | SET(RGCODE,RGSET) ;
 | 
|---|
| 32 |  N RGZ,RGZ1
 | 
|---|
| 33 |  F RGZ=1:1:$L(RGSET,";") D  Q:RGZ1'=""
 | 
|---|
| 34 |  .S RGZ1=$P(RGSET,";",RGZ),RGZ1=$S($P(RGZ1,":")=RGCODE:$P(RGZ1,":",2),1:"")
 | 
|---|
| 35 |  Q RGZ1
 | 
|---|
| 36 |  ; Replace each occurrence of RGOLD in RGSTR with RGNEW
 | 
|---|
| 37 | SUBST(RGSTR,RGOLD,RGNEW) ;
 | 
|---|
| 38 |  N RGP,RGL1,RGL2
 | 
|---|
| 39 |  S RGNEW=$G(RGNEW),RGP=0,RGL1=$L(RGOLD),RGL2=$L(RGNEW)
 | 
|---|
| 40 |  F  S RGP=$F(RGSTR,RGOLD,RGP) Q:'RGP  D
 | 
|---|
| 41 |  .S RGSTR=$E(RGSTR,1,RGP-RGL1-1)_RGNEW_$E(RGSTR,RGP,9999)
 | 
|---|
| 42 |  .S RGP=RGP-RGL1+RGL2
 | 
|---|
| 43 |  Q RGSTR
 | 
|---|
| 44 |  ; Trim leading (Y=-1)/trailing (Y=1)/leading & trailing (Y=0) spaces
 | 
|---|
| 45 | TRIM(X,Y) ;
 | 
|---|
| 46 |  N RGZ1,RGZ2
 | 
|---|
| 47 |  S Y=+$G(Y),RGZ1=1,RGZ2=$L(X)
 | 
|---|
| 48 |  I Y'>0 F RGZ1=1:1 Q:$A(X,RGZ1)'=32
 | 
|---|
| 49 |  I Y'<0 F RGZ2=RGZ2:-1 Q:$A(X,RGZ2)'=32
 | 
|---|
| 50 |  Q $E(X,RGZ1,RGZ2)
 | 
|---|
| 51 |  ; Format a number with commas
 | 
|---|
| 52 | FMTNUM(RGNUM) ;
 | 
|---|
| 53 |  N RGZ,RGZ1,RGZ2
 | 
|---|
| 54 |  S:RGNUM<0 RGNUM=-RGNUM,RGZ2="-"
 | 
|---|
| 55 |  F RGZ=$L(RGNUM):-3:1 S RGZ1=$E(RGNUM,RGZ-2,RGZ)_$S($D(RGZ1):","_RGZ1,1:"")
 | 
|---|
| 56 |  Q $G(RGZ2)_$G(RGZ1)
 | 
|---|
| 57 |  ; Convert X to base Y padded to length L
 | 
|---|
| 58 | BASE(X,Y,L) ;
 | 
|---|
| 59 |  Q:(Y<2)!(Y>62) ""
 | 
|---|
| 60 |  N RGZ,RGZ1
 | 
|---|
| 61 |  S RGZ1="",X=$S(X<0:-X,1:X)
 | 
|---|
| 62 |  F  S RGZ=X#Y,X=X\Y,RGZ1=$C($S(RGZ<10:RGZ+48,RGZ<36:RGZ+55,1:RGZ+61))_RGZ1 Q:'X
 | 
|---|
| 63 |  Q $S('$G(L):RGZ1,1:$$REPEAT^XLFSTR(0,L-$L(RGZ1))_$E(RGZ1,1,L))
 | 
|---|
| 64 |  ; Convert a string to its SOUNDEX equivalent
 | 
|---|
| 65 | SOUNDEX(RGVALUE) ;
 | 
|---|
| 66 |  N RGCODE,RGSOUND,RGPREV,RGCHAR,RGPOS,RGTRANS
 | 
|---|
| 67 |  S RGCODE="01230129022455012623019202"
 | 
|---|
| 68 |  S RGSOUND=$C($A(RGVALUE)-(RGVALUE?1L.E*32))
 | 
|---|
| 69 |  S RGPREV=$E(RGCODE,$A(RGVALUE)-64)
 | 
|---|
| 70 |  F RGPOS=2:1 S RGCHAR=$E(RGVALUE,RGPOS) Q:","[RGCHAR  D  Q:$L(RGSOUND)=4
 | 
|---|
| 71 |  .Q:RGCHAR'?1A
 | 
|---|
| 72 |  .S RGTRANS=$E(RGCODE,$A(RGCHAR)-$S(RGCHAR?1U:64,1:96))
 | 
|---|
| 73 |  .Q:RGTRANS=RGPREV!(RGTRANS=9)
 | 
|---|
| 74 |  .S RGPREV=RGTRANS
 | 
|---|
| 75 |  .S:RGTRANS'=0 RGSOUND=RGSOUND_RGTRANS
 | 
|---|
| 76 |  Q $E(RGSOUND_"000",1,4)
 | 
|---|
| 77 |  ; Display formatted title
 | 
|---|
| 78 | TITLE(RGTTL,RGVER,RGFN) ;
 | 
|---|
| 79 |  I '$D(IOM) N IOM,IOF S IOM=80,IOF="#"
 | 
|---|
| 80 |  S RGVER=$G(RGVER,"1.0")
 | 
|---|
| 81 |  S:RGVER RGVER="Version "_RGVER
 | 
|---|
| 82 |  U $G(IO,$I)
 | 
|---|
| 83 |  W @IOF,$S(IO=IO(0):$C(27,91,55,109),1:""),*13,$$^RGCVTDT(+$H_","),?(IOM-$L(RGTTL)\2),RGTTL,?(IOM-$L(RGVER)),RGVER,!,$S(IO=IO(0):$C(27,91,109),1:$$UND),!
 | 
|---|
| 84 |  W:$D(RGFN) ?(IOM-$L(RGFN)\2),RGFN,!
 | 
|---|
| 85 |  Q
 | 
|---|
| 86 |  ; Create a unique 8.3 filename
 | 
|---|
| 87 | UFN(Y) N X
 | 
|---|
| 88 |  S Y=$E($G(Y),1,3),X=$$BASE($R(100)_$J_$TR($H,","),36,$S($L(Y):8,1:11))_Y
 | 
|---|
| 89 |  Q $E(X,1,8)_"."_$E(X,9,11)
 | 
|---|
| 90 |  ; Return formatted SSN
 | 
|---|
| 91 | SSN(X) Q $S(X="":X,1:$E(X,1,3)_"-"_$E(X,4,5)_"-"_$E(X,6,12))
 | 
|---|
| 92 |  ; Performs security check on patient access
 | 
|---|
| 93 | DGSEC(Y) N DIC
 | 
|---|
| 94 |  S DIC(0)="E"
 | 
|---|
| 95 |  D ^DGSEC
 | 
|---|
| 96 |  Q $S(Y<1:0,1:Y)
 | 
|---|
| 97 |  ; Displays spinning icon to indicate progress
 | 
|---|
| 98 | WORKING(RGST,RGP,RGS) ;
 | 
|---|
| 99 |  Q:'$D(IO(0))!$D(ZTQUEUED) 0
 | 
|---|
| 100 |  N RGZ
 | 
|---|
| 101 |  S RGZ(0)=$I,RGS=$G(RGS,"|/-\"),RGST=+$G(RGST)
 | 
|---|
| 102 |  S RGST=$S(RGST<0:0,1:RGST#$L(RGS)+1)
 | 
|---|
| 103 |  U IO(0)
 | 
|---|
| 104 |  W:'$G(RGP) *8,$S(RGST:$E(RGS,RGST),1:" ")
 | 
|---|
| 105 |  R *RGZ:0
 | 
|---|
| 106 |  U RGZ(0)
 | 
|---|
| 107 |  Q RGZ=94
 | 
|---|
| 108 |  ; Ask for Y/N response
 | 
|---|
| 109 | ASK(RGP,RGD,RGZ) ;
 | 
|---|
| 110 |  S RGD=$G(RGD,"N")
 | 
|---|
| 111 |  S RGZ=$$GETCH(RGP_"? ","YN")
 | 
|---|
| 112 |  S:RGZ="" RGZ=$E(RGD)
 | 
|---|
| 113 |  W !
 | 
|---|
| 114 |  Q $S(RGZ[U:"",1:RGZ="Y")
 | 
|---|
| 115 |  ; Pause for user response
 | 
|---|
| 116 | PAUSE(RGP,RGX,RGY) ;
 | 
|---|
| 117 |  Q $$GETCH($G(RGP,"Press RETURN or ENTER to continue..."),U,.RGX,.RGY)
 | 
|---|
| 118 |  ; Single character read
 | 
|---|
| 119 | GETCH(RGP,RGV,RGX,RGY,RGT,RGD) ;
 | 
|---|
| 120 |  N RGZ,RGC
 | 
|---|
| 121 |  W:$D(RGX)!$D(RGY) $$XY($G(RGX,$X),$G(RGY,$Y))
 | 
|---|
| 122 |  W $G(RGP)
 | 
|---|
| 123 |  S RGT=$G(RGT,$G(DTIME,999999999999)),RGD=$G(RGD,U),RGC=""
 | 
|---|
| 124 |  S:$D(RGV) RGV=$$UP^XLFSTR(RGV)_U
 | 
|---|
| 125 |  F  D  Q:'$L(RGZ)
 | 
|---|
| 126 |  .R RGZ#1:RGT
 | 
|---|
| 127 |  .E  S RGC=RGD Q
 | 
|---|
| 128 |  .W *8
 | 
|---|
| 129 |  .Q:'$L(RGZ)
 | 
|---|
| 130 |  .S RGZ=$$UP^XLFSTR(RGZ)
 | 
|---|
| 131 |  .I $D(RGV) D
 | 
|---|
| 132 |  ..I RGV[RGZ S RGC=RGZ
 | 
|---|
| 133 |  ..E  W *7,*32,*8 S RGC=""
 | 
|---|
| 134 |  .E  S RGC=RGZ
 | 
|---|
| 135 |  W !
 | 
|---|
| 136 |  Q RGC
 | 
|---|
| 137 |  ; Position cursor
 | 
|---|
| 138 | XY(DX,DY) ;
 | 
|---|
| 139 |  D:$G(IOXY)="" HOME^%ZIS
 | 
|---|
| 140 |  S DX=$S(+$G(DX)>0:+DX,1:0),DY=$S(+$G(DY)>0:+DY,1:0),$X=0
 | 
|---|
| 141 |  X IOXY
 | 
|---|
| 142 |  S $X=DX,$Y=DY
 | 
|---|
| 143 |  Q ""
 | 
|---|
| 144 |  ; Parameterized calls to date routines
 | 
|---|
| 145 | %DT(RGD,RGX) ;
 | 
|---|
| 146 |  N %D,%P,%C,%H,%I,%X,%Y,RGZ
 | 
|---|
| 147 |  D DT^DILF($G(RGX),RGD,.RGZ)
 | 
|---|
| 148 |  W:$D(RGZ(0)) RGZ(0),!
 | 
|---|
| 149 |  Q $G(RGZ,-1)
 | 
|---|
| 150 | %DTC(X1,X2) ;
 | 
|---|
| 151 |  N X3
 | 
|---|
| 152 |  S X2=$$%DTF(X1)+X2,X1=X1\1,X3=X2\1,X2=X2-X3
 | 
|---|
| 153 |  S:X2<0 X3=X3-1,X2=X2+1
 | 
|---|
| 154 |  Q $$FMADD^XLFDT(X1,X3)+$J($$%DTT(X2),0,6)
 | 
|---|
| 155 | %DTD(X1,X2) ;
 | 
|---|
| 156 |  Q $$FMDIFF^XLFDT(X1\1,X2\1)+($$%DTF(X1)-$$%DTF(X2))
 | 
|---|
| 157 | %DTF(X) S X=X#1*100
 | 
|---|
| 158 |  Q X\1*3600+(X*100#100\1*60)+(X*10000#100)/86400
 | 
|---|
| 159 | %DTT(X) S X=X*86400
 | 
|---|
| 160 |  Q X\3600*100+(X#3600/3600*60)/10000
 | 
|---|
| 161 |  ; THE FOLLOWING ENTRY POINTS WILL BE PHASED OUT IN FAVOR OF
 | 
|---|
| 162 |  ; THEIR EQUIVALENTS WITHIN KERNEL
 | 
|---|
| 163 |  ; Normalize global root
 | 
|---|
| 164 | GBL(RGGBL) ;
 | 
|---|
| 165 |  Q $$CREF^DILF(RGGBL)
 | 
|---|
| 166 |  ; Convert lower to upper case
 | 
|---|
| 167 | UPCASE(X) Q $TR(X,"abcdefghijklmnopqrstuvwxyz","ABCDEFGHIJKLMNOPQRSTUVWXYZ")
 | 
|---|
| 168 |  ; Convert upper to lower case
 | 
|---|
| 169 | LOCASE(X) Q $TR(X,"ABCDEFGHIJKLMNOPQRSTUVWXYZ","abcdefghijklmnopqrstuvwxyz")
 | 
|---|
| 170 |  ; Return a string of X repeated Y times
 | 
|---|
| 171 | RPT(X,Y) Q $$REPEAT^XLFSTR(X,Y)
 | 
|---|
| 172 | %DTDW(X) Q $$DOW^XLFDT(X)
 | 
|---|
| 173 | %DTDOW(X) ;
 | 
|---|
| 174 |  Q $$DOW^XLFDT(X,1)
 | 
|---|
| 175 | %DTNOW() Q $$NOW^XLFDT
 | 
|---|
| 176 | %DTH(X) Q $$FMTH^XLFDT(X)
 | 
|---|
| 177 | %DTYX(X) Q $$HTFM^XLFDT(X)
 | 
|---|