[796] | 1 | TMGDBAP2 ;TMG/kst/Database API library 2 ;03/25/06; 5/2/10
|
---|
| 2 | ;;1.0;TMG-LIB;**1**;07/12/05
|
---|
| 3 |
|
---|
| 4 |
|
---|
| 5 | ;"This module holds moved functions from TMGDBAPI (moved due to size constraints)
|
---|
| 6 |
|
---|
| 7 | ConvertFDA(FDA,MarkerArray)
|
---|
| 8 | ;"Purpose: To convert all the IENS's in a FDA via ConvertIENS
|
---|
| 9 | ;"Input: FDA -- An FDA that need conversion. MUST PASS BY REFERENCE
|
---|
| 10 | ;" Expected FDA is as follows. I.e., expecting that
|
---|
| 11 | ;" there will only be ONE filenumber (the 19.01) part:
|
---|
| 12 | ;" FDA(*)
|
---|
| 13 | ;" }~19.01
|
---|
| 14 | ;" }~?+4,?+2,
|
---|
| 15 | ;" | }~.01 = DIUSER
|
---|
| 16 | ;" | }~2 = FM2
|
---|
| 17 | ;" | }~3 = 1
|
---|
| 18 | ;" |
|
---|
| 19 | ;" }~?+5,?+2,
|
---|
| 20 | ;" | }~.01 = XMMGR
|
---|
| 21 | ;" | }~2 = X2
|
---|
| 22 | ;" | }~3 = 1
|
---|
| 23 | ;" |
|
---|
| 24 | ;" }~?+6,?+2,
|
---|
| 25 | ;" }~.01 = DIEDIT
|
---|
| 26 | ;" }~2 = Edit
|
---|
| 27 | ;" }~3 = 2
|
---|
| 28 | ;" MarkerArray -- see documentation in ConvertIENS
|
---|
| 29 | ;"Output: FDA is changed
|
---|
| 30 | ;"Result: 1=OKToContinue, 0=Abort
|
---|
| 31 |
|
---|
| 32 |
|
---|
| 33 | if $data(TMGDEBUG)#10=0 new TMGDEBUG set TMGDEBUG=0
|
---|
| 34 | new cOKToCont set cOKToCont=1
|
---|
| 35 | new cAbort set cAbort=0
|
---|
| 36 | new cParentIENS set cParentIENS="ParentIENS"
|
---|
| 37 | new cRef set cRef="Ref"
|
---|
| 38 |
|
---|
| 39 |
|
---|
| 40 | ;"if $get(TMGDEBUG)>0 do DebugEntry^TMGDEBUG(.DBIndent,"ConvertFDA^TMGDBAPI")
|
---|
| 41 |
|
---|
| 42 | new result set result=1
|
---|
| 43 | if $data(FDA)=0 set result=0 goto CvFDAQ
|
---|
| 44 | new FileNum
|
---|
| 45 | new Index
|
---|
| 46 | new IENS,OldIENS
|
---|
| 47 |
|
---|
| 48 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Here is the FDA to convert")
|
---|
| 49 | ;"if TMGDEBUG do ArrayDump^TMGDEBUG("FDA")
|
---|
| 50 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Here is the MarkerArray")
|
---|
| 51 | ;"if TMGDEBUG do ArrayDump^TMGDEBUG("MarkerArray")
|
---|
| 52 |
|
---|
| 53 | set FileNum=$order(FDA(""))
|
---|
| 54 | if +FileNum=0 set result=0 goto CvFDAQ
|
---|
| 55 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Looking at filenumber ",FileNum)
|
---|
| 56 | set IENS=$order(FDA(FileNum,""))
|
---|
| 57 | for do quit:(IENS="")
|
---|
| 58 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"IENS=",IENS)
|
---|
| 59 | . if IENS="" do quit
|
---|
| 60 | . . set result=0
|
---|
| 61 | . set OldIENS=IENS
|
---|
| 62 | . if $$ConvertIENS(.IENS,.MarkerArray)=0 do quit
|
---|
| 63 | . . set IENS=""
|
---|
| 64 | . . set result=0
|
---|
| 65 | . if IENS'=OldIENS do
|
---|
| 66 | . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Converted to IENS=",IENS)
|
---|
| 67 | . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Convert FDA(FileNumber,"""_OldIENS_""") to FDA(Filenumber,"""_IENS_""")")
|
---|
| 68 | . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"$data(FDA(FileNum,OLDIENS))=",$data(FDA(FileNum,OldIENS)))
|
---|
| 69 | . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Here is FDA so far")
|
---|
| 70 | . . ;"if TMGDEBUG do ArrayDump^TMGDEBUG("FDA")
|
---|
| 71 | . . merge FDA(FileNum,IENS)=FDA(FileNum,OldIENS)
|
---|
| 72 | . . set IENS=$order(FDA(FileNum,OldIENS))
|
---|
| 73 | . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"killing FDA(FileNumber,"_OldIENS_")")
|
---|
| 74 | . . kill FDA(FileNum,OldIENS)
|
---|
| 75 | . else do
|
---|
| 76 | . . set IENS=$order(FDA(FileNum,OldIENS))
|
---|
| 77 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Resulting FDA so far")
|
---|
| 78 | . ;"if TMGDEBUG do ArrayDump^TMGDEBUG("FDA")
|
---|
| 79 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"-----------------------")
|
---|
| 80 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"End of cycle. IENS=",IENS)
|
---|
| 81 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"-----------------------")
|
---|
| 82 |
|
---|
| 83 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"After conversion, here is the FDA.")
|
---|
| 84 | ;"if TMGDEBUG do ArrayDump^TMGDEBUG("FDA")
|
---|
| 85 |
|
---|
| 86 | CvFDAQ
|
---|
| 87 | ;"if $get(TMGDEBUG)>0 do DebugExit^TMGDEBUG(.DBIndent,"ConvertFDA^TMGDBAPI")
|
---|
| 88 | quit result
|
---|
| 89 |
|
---|
| 90 |
|
---|
| 91 | ConvertIENS(IENS,MarkerArray)
|
---|
| 92 | ;"Purpose: to convert an IENS such as "?+4,?+2," into "?+4,12345,", given
|
---|
| 93 | ;" the MarkerArray that corelates "2" to #"12345"
|
---|
| 94 | ;"Input: IENS -- the IENS string to convert. MUST PASS BY REFERENCE
|
---|
| 95 | ;" MarkerArray -- a composite array composed of results returned
|
---|
| 96 | ;" by database server, like below. SHOULD PASS BY REFERENCE
|
---|
| 97 | ;" MarkerArray(*)
|
---|
| 98 | ;" }~2 = 10033
|
---|
| 99 | ;" }~0 = +
|
---|
| 100 | ;" }~4 = 12345
|
---|
| 101 | ;" }~0 = +
|
---|
| 102 | ;"Output: IENS will be changed
|
---|
| 103 | ;"Result: 1=OkToContinue, 0=Abort
|
---|
| 104 |
|
---|
| 105 | if $data(TMGDEBUG)#10=0 new TMGDEBUG set TMGDEBUG=0
|
---|
| 106 | new cOKToCont set cOKToCont=1
|
---|
| 107 | new cAbort set cAbort=0
|
---|
| 108 | new cParentIENS set cParentIENS="ParentIENS"
|
---|
| 109 |
|
---|
| 110 | ;"if $get(TMGDEBUG)>0 do DebugEntry^TMGDEBUG(.DBIndent,"ConvertIENS^TMGDBAPI")
|
---|
| 111 |
|
---|
| 112 | new result set result=1
|
---|
| 113 | new S set S=""
|
---|
| 114 |
|
---|
| 115 | if $data(IENS)#10=0 set result=0 goto CvIENSQ
|
---|
| 116 | if $data(MarkerArray)=0 set result=0 goto CvIENSQ
|
---|
| 117 |
|
---|
| 118 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Initial IENS=",IENS)
|
---|
| 119 |
|
---|
| 120 | new I set I=1
|
---|
| 121 | for do quit:(I=-1)
|
---|
| 122 | . new Part,RecMarker
|
---|
| 123 | . set Part=$piece(IENS,",",I)
|
---|
| 124 | . ;";"if $get(TMGDEBUG)>0 do DebugWrite^TMGDEBUG(.DBIndent,"Part="_Part_" --> ",0)
|
---|
| 125 | . if Part="" set I=-1 quit
|
---|
| 126 | . set RecMarker=+$translate(Part,"?+","")
|
---|
| 127 | . ;"if $get(TMGDEBUG)>0 do DebugWrite^TMGDEBUG(.DBIndent,"RecMarker="_RecMarker_" --> ",0)
|
---|
| 128 | . new tS set tS=$get(MarkerArray(RecMarker),Part)
|
---|
| 129 | . ;"if $get(TMGDEBUG)>0 do DebugWrite^TMGDEBUG(.DBIndent,"tS="_tS,1)
|
---|
| 130 | . set S=S_tS_","
|
---|
| 131 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"S so far=",S)
|
---|
| 132 | . set I=I+1
|
---|
| 133 |
|
---|
| 134 | set IENS=S
|
---|
| 135 |
|
---|
| 136 | CvIENSQ
|
---|
| 137 | ;"if $get(TMGDEBUG)>0 do DebugExit^TMGDEBUG(.DBIndent,"ConvertIENS^TMGDBAPI")
|
---|
| 138 | quit result
|
---|
| 139 |
|
---|
| 140 |
|
---|
| 141 | SetupFDA(Data,FDA,parentIENS,SrchType,MarkNum,MsgArray,Minimal,RecNum)
|
---|
| 142 | ;"Purpose: to transfer from Data format to FDA format
|
---|
| 143 | ;"Input: Data - Data array should be in format output from GetRInfo
|
---|
| 144 | ;" FDA -- SHOULD BE PASSED BY REFERENCE (to receive results)
|
---|
| 145 | ;" parentIENS -- initial IENS.. the IENS of any PARENT record, or "" if no parent record
|
---|
| 146 | ;" SrchType -- should be "?", "+", or "?+"
|
---|
| 147 | ;" MarkNum -- -- SHOULD BE PASSED BY REFERENCE. A variable to ensure
|
---|
| 148 | ;" "?X" search term always has unique number. On first call, should=0
|
---|
| 149 | ;" MsgArray -- SHOULD BE PASSED BY REFERENCE. An array that can accept
|
---|
| 150 | ;" messages back from function.
|
---|
| 151 | ;" -- One such type of message is a list of needed hackwrites.
|
---|
| 152 | ;" Format as follows:
|
---|
| 153 | ;" MsgArray(cHack,0,Entries)=2
|
---|
| 154 | ;" MsgArray(cHack,1)="^VA(;200;?+1;.01;SomeData"
|
---|
| 155 | ;" MsgArray(cHack,1,cFlags)="H"
|
---|
| 156 | ;" MsgArray(cHack,2)="^VA(;200;?+1;.02;SomeMoreData"
|
---|
| 157 | ;" MsgArray(cHack,2,cFlags)="H"
|
---|
| 158 | ;" i.e. MsgArray(cHack,0,Entries)=Number of Entries
|
---|
| 159 | ;" MsgArray(cHack,n) = Global;FileNumber;IENS;FieldNum;Data
|
---|
| 160 | ;" MsgArray(n,cFlags)=User specified Flags for field.
|
---|
| 161 | ;" -- MsgArray(cRef,SubFileNumber)=Reference to Part of Data that created this.
|
---|
| 162 | ;" MsgArray(*)
|
---|
| 163 | ;" }~cRef
|
---|
| 164 | ;" }~1234.21 = "Data(6,".07")
|
---|
| 165 | ;" }~1234.2101 = "Data(6,".07",2,".04")
|
---|
| 166 | ;" Minimal -- OPTIONAL. 1=fill only .01 fields and subfile .01 fields
|
---|
| 167 | ;" RecNum -- OPTIONAL. If FDA is to be setup such that data is put into
|
---|
| 168 | ;" a specified record number, put that number here.
|
---|
| 169 | ;" !!! Note: I believe this is used erroneously here. A record number
|
---|
| 170 | ;" is not specified in the FDA. For calls to UPDATE^DIE to a specific
|
---|
| 171 | ;" record number, the FDA should have an IENS that is like "+1,", and then
|
---|
| 172 | ;" put the desired record number into the IEN_ROOT, like TMGIEN(1)=1234
|
---|
| 173 | ;" with the "1" matching the "1" in TMGIEN(1)
|
---|
| 174 | ;"Output: FDA is changed if passed by reference.
|
---|
| 175 | ;"Returns: If should continue execution: 1=OK to continue. 0=abort.
|
---|
| 176 |
|
---|
| 177 | ;"Note: input Data array will be formated like this:
|
---|
| 178 | ;" Data(0,cFile)="1234.1" <-- "NEW PERSON" Note conversion
|
---|
| 179 | ;" Data(0,cFile,cGlobal)="^DIC(200)" <-- note, NOT "^DIC(200,"
|
---|
| 180 | ;" Data(0,cRecNum)=2 <-- only if user-specified.
|
---|
| 181 | ;" Data(0,cEntries)=1
|
---|
| 182 | ;" Data(1,".01")="MyData1"
|
---|
| 183 | ;" Data(1,".01",cMatchValue)="MyData1"
|
---|
| 184 | ;" Data(1,".02")="Bill"
|
---|
| 185 | ;" Data(1,".02",cMatchValue)="John"
|
---|
| 186 | ;" Data(1,".03")="MyData3"
|
---|
| 187 | ;" Data(1,".04")="MyData4"
|
---|
| 188 | ;" Data(1,".06")="MyData5" <-- note "NAME" was converted to ".06"
|
---|
| 189 | ;" Data(1,".07",0,cEntries)=2 <-- "ITEM" converted to ".07"
|
---|
| 190 | ;" Data(1,".07",1,".01")="SubEntry1"
|
---|
| 191 | ;" Data(1,".07",1,".02")="SE1"
|
---|
| 192 | ;" Data(1,".07",1,".03")="'Some Info'"
|
---|
| 193 | ;" Data(1,".07",2,".01")="SubEntry2"
|
---|
| 194 | ;" Data(1,".07",2,".02")="SE2"
|
---|
| 195 | ;" Data(1,".07",2,".04",0,cEntries)=1 ;"TEXT converted to .04
|
---|
| 196 | ;" Data(1,".07",2,".04",1,".01")="JD"
|
---|
| 197 | ;" Data(1,".07",2,".04",1,".02")="DOE,JOHN"
|
---|
| 198 | ;" ADDENDUM
|
---|
| 199 | ;" Data(1,".01",cFlags)=any flags specified for given field.
|
---|
| 200 | ;" only present if user specified.
|
---|
| 201 |
|
---|
| 202 | ;"Resulting FDA will look like this.
|
---|
| 203 | ;" i.e. FDA(1234,"?+1,10024,",.01)="MyData1"
|
---|
| 204 | ;" i.e. FDA(1234,"?+1,10024,",.02)="Bill"
|
---|
| 205 | ;" i.e. FDA(1234,"?+1,10024,",.03)="MyData3"
|
---|
| 206 | ;" i.e. FDA(1234,"?+1,10024,",.04)="MyData4"
|
---|
| 207 | ;" i.e. FDA(1234,"?+1,10024,",.06)="MyData5"
|
---|
| 208 | ;" i.e. FDA(1234.21,"?+2,?+1,10024,",.01)="SubEntry1"
|
---|
| 209 | ;" i.e. FDA(1234.21,"?+2,?+1,10024,",.02)="SE1"
|
---|
| 210 | ;" i.e. FDA(1234.21,"?+2,?+1,10024,",.03)="'Some Info'"
|
---|
| 211 | ;" i.e. FDA(1234.21,"?+3,?+1,10024,",.01)="SubEntry2"
|
---|
| 212 | ;" i.e. FDA(1234.21,"?+3,?+1,10024,",.02)="SE2"
|
---|
| 213 | ;" i.e. FDA(1234.21,"?+3,?+1,10024,",.03)="'Some Info'"
|
---|
| 214 | ;" i.e. FDA(1234.2101,"?+4,?+3,?+1,10024,",.01)="JD"
|
---|
| 215 | ;" i.e. FDA(1234.2101,"?+4,?+3,?+1,10024,",.02)="DOE,JOHN"
|
---|
| 216 | ;"(OR... reformat of above)
|
---|
| 217 | ;" FDA(*)
|
---|
| 218 | ;" }~1234
|
---|
| 219 | ;" }~?+1,10024
|
---|
| 220 | ;" }~.01 = MyData1
|
---|
| 221 | ;" }~.02 = Bill
|
---|
| 222 | ;" }~.03 = MyData3
|
---|
| 223 | ;" }~.04 = MyData4
|
---|
| 224 | ;" }~.06 = MyData5
|
---|
| 225 | ;" }~1234.21
|
---|
| 226 | ;" }~?+2,?+1,10024
|
---|
| 227 | ;" }~.01 = SubEntry1
|
---|
| 228 | ;" }~.02 = SE1
|
---|
| 229 | ;" }~.03 = 'Some Info'
|
---|
| 230 | ;" }~?+3,?+1,10024
|
---|
| 231 | ;" }~.01 = SubEntry2
|
---|
| 232 | ;" }~.02 = SE2
|
---|
| 233 | ;" }~.03 = 'Some Info'
|
---|
| 234 | ;" }~1234.2101
|
---|
| 235 | ;" }~?+4,?+3,?+1,10024
|
---|
| 236 | ;" }~.01 = JD
|
---|
| 237 | ;" }~.02 = DOE,JOHN
|
---|
| 238 |
|
---|
| 239 | ;"MsgArray will hold the following
|
---|
| 240 | ;" MsgArray(*)
|
---|
| 241 | ;" }~"H"
|
---|
| 242 | ;" }~"Ref"
|
---|
| 243 | ;" }~1234.21 = "Data(6,".07")
|
---|
| 244 | ;" }~1234.2101 = "Data(6,".07",2,".04")
|
---|
| 245 |
|
---|
| 246 | if $data(TMGDEBUG)#10=0 new TMGDEBUG set TMGDEBUG=0
|
---|
| 247 | new cOKToCont set cOKToCont=1
|
---|
| 248 | new cAbort set cAbort=0
|
---|
| 249 | new cFile set cFile="FILE" ;"File"
|
---|
| 250 | new cHack set cHack="H"
|
---|
| 251 | new cFlags set cFlags="FLAGS" ;"Flags"
|
---|
| 252 | new cEntries set cEntries="Entries"
|
---|
| 253 | new cNoOverwrite set cNoOverwrite="N"
|
---|
| 254 |
|
---|
| 255 | ;"if $get(TMGDEBUG)>0 do DebugEntry^TMGDEBUG(.DBIndent,"SetupFDA^TMGDBAPI")
|
---|
| 256 |
|
---|
| 257 | new result set result=cOKToCont
|
---|
| 258 | new index
|
---|
| 259 | new FieldNum
|
---|
| 260 | new FileNumber
|
---|
| 261 | new SubMarkNum set SubMarkNum=0
|
---|
| 262 | new IENS set IENS=""
|
---|
| 263 | if $get(RecNum)="" kill RecNum
|
---|
| 264 |
|
---|
| 265 | set FileNumber=$get(Data(0,cFile))
|
---|
| 266 | if +FileNumber=0 goto SFDAQ
|
---|
| 267 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"FileNumber=",FileNumber)
|
---|
| 268 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"parentIENS=",parentIENS)
|
---|
| 269 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"SrchType=",SrchType)
|
---|
| 270 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"RecNum=",$get(RecNum))
|
---|
| 271 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Here is the Data array to work with:")
|
---|
| 272 | ;"if TMGDEBUG do ArrayDump^TMGDEBUG("Data")
|
---|
| 273 |
|
---|
| 274 | set index=$order(Data(0))
|
---|
| 275 | ;"Cycle through all entries (i.e. 1, 2, 3)
|
---|
| 276 | for do quit:(index="")!(result=cAbort)
|
---|
| 277 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"index=",index)
|
---|
| 278 | . set FieldNum=$order(Data(index,""))
|
---|
| 279 | . ;"Cycle through all fields (i.e. .01, .02, ,1223)
|
---|
| 280 | . for do quit:(FieldNum="")!(result=cAbort)
|
---|
| 281 | . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"FieldNum=",FieldNum)
|
---|
| 282 | . . new NextFieldNum set NextFieldNum=$order(Data(index,FieldNum))
|
---|
| 283 | . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"NextFieldNum=",NextFieldNum)
|
---|
| 284 | . . if ($get(Data(index,FieldNum,cFlags))[cNoOverwrite)&(SrchType["?") do quit
|
---|
| 285 | . . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"m0")
|
---|
| 286 | . . . set FieldNum=NextFieldNum
|
---|
| 287 | . . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"NoOverwrite flag found, ignoring current field.")
|
---|
| 288 | . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"m1")
|
---|
| 289 | . . if (FieldNum=.01)!(IENS="") do
|
---|
| 290 | . . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"m2")
|
---|
| 291 | . . . if $data(RecNum)#10=0 do
|
---|
| 292 | . . . . set MarkNum=+$get(MarkNum)+1
|
---|
| 293 | . . . . set IENS=SrchType_MarkNum_","_$get(parentIENS)
|
---|
| 294 | . . . else do
|
---|
| 295 | . . . . set IENS=$get(RecNum)_","_$get(parentIENS)
|
---|
| 296 | . . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"IENS=",IENS)
|
---|
| 297 | . . if $get(Data(index,FieldNum,cFlags))[cHack do ;"HACK PROCESSING
|
---|
| 298 | . . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Hack Processing")
|
---|
| 299 | . . . ;"Load hacks into a message array for later processing
|
---|
| 300 | . . . new NumHacks set NumHacks=$get(MsgArray(cHack,0,cEntries))+1
|
---|
| 301 | . . . new Entry set Entry=Data(index,FieldNum)
|
---|
| 302 | . . . if $get(Data(index,FieldNum,cFlags))[cEncrypt do
|
---|
| 303 | . . . . set Entry=$$EN^XUSHSH(Entry) ;"encrypt data
|
---|
| 304 | . . . new Global set Global=$get(Data(0,cFile,cGlobal))
|
---|
| 305 | . . . if Global="" do quit
|
---|
| 306 | . . . . do ShowError^TMGDEBUG(.PriorErrorFound,"Unable to local global name for file")
|
---|
| 307 | . . . . set result=cAbort
|
---|
| 308 | . . . set MsgArray(cHack,NumHacks)=Global_";"_FileNumber_";"_IENS_";"_FieldNum_";"_Entry
|
---|
| 309 | . . . set MsgArray(cHack,NumHacks,cFlags)=Data(index,FieldNum,cFlags)
|
---|
| 310 | . . else if $data(Data(index,FieldNum,0,cEntries)) do ;"SUB-FILE PROCESSING
|
---|
| 311 | . . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Sub-file processing")
|
---|
| 312 | . . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Addition of subfile entries encountered.")
|
---|
| 313 | . . . new tempData merge tempData=Data(index,FieldNum)
|
---|
| 314 | . . . new SubFileNum set SubFileNum=$get(Data(index,FieldNum,0,cFile),0)
|
---|
| 315 | . . . set MsgArray(cRef,SubFileNum)=$name(Data(index,FieldNum))
|
---|
| 316 | . . . ;"call self recursively to handle subfile.
|
---|
| 317 | . . . new SubMarkNum set SubMarkNum=MarkNum
|
---|
| 318 | . . . set result=$$SetupFDA(.tempData,.FDA,IENS,SrchType,.SubMarkNum,.MsgArray,.Minimal)
|
---|
| 319 | . . . if SubMarkNum>MarkNum set MarkNum=SubMarkNum
|
---|
| 320 | . . else do ;"THE-USUAL-CASE PROCESSING
|
---|
| 321 | . . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Processing usual case")
|
---|
| 322 | . . . if (FieldNum=.01)!($get(Minimal)'=1) do
|
---|
| 323 | . . . . new ts set ts="Setting: FDA("_FileNumber_","""_IENS_""","_FieldNum_")="_$get(Data(index,FieldNum))
|
---|
| 324 | . . . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"ts=",ts)
|
---|
| 325 | . . . . set FDA(FileNumber,IENS,FieldNum)=$get(Data(index,FieldNum))
|
---|
| 326 | . . . if $data(Data(index,FieldNum,"WP")) do
|
---|
| 327 | . . . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Detected word-processor field")
|
---|
| 328 | . . . . merge FDA(FileNumber,IENS,FieldNum,"WP")=Data(index,FieldNum,"WP")
|
---|
| 329 | . . . . ;"if $get(TMGDEBUG)>0 do
|
---|
| 330 | . . . . ;". new ts set ts="Setting: FDA("_FileNumber_","""_IENS_""","_FieldNum_")="
|
---|
| 331 | . . . . ;". ;"NOTE: the "TMGFDA" MUST!! match the FDA name passed to UPDATE^DIE, FILE^DIE
|
---|
| 332 | . . . . ;". set ts=ts_$name(TMGFDA(FileNumber,IENS,FieldNum,"WP"))
|
---|
| 333 | . . . . ;". do DebugMsg^TMGDEBUG(.DBIndent,ts)
|
---|
| 334 | . . . . ;"NOTE: the "TMGFDA" MUST!! match the FDA name passed to UPDATE^DIE, FILE^DIE
|
---|
| 335 | . . . . set FDA(FileNumber,IENS,FieldNum)=$name(TMGFDA(FileNumber,IENS,FieldNum,"WP"))
|
---|
| 336 | . . set FieldNum=NextFieldNum
|
---|
| 337 | . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"End of field loop")
|
---|
| 338 | . set index=$order(Data(index))
|
---|
| 339 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"End of index loop")
|
---|
| 340 |
|
---|
| 341 | SFDAQ
|
---|
| 342 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Here is resulting FDA")
|
---|
| 343 | ;"if $get(TMGDEBUG)>0 do ArrayDump^TMGDEBUG("FDA") ;"zwr FDA(*)
|
---|
| 344 |
|
---|
| 345 | ;"if $get(TMGDEBUG)>0 do DebugExit^TMGDEBUG(.DBIndent,"SetupFDA^TMGDBAPI")
|
---|
| 346 | quit result
|
---|
| 347 |
|
---|
| 348 |
|
---|
| 349 |
|
---|
| 350 | OverwriteRec(RecNum,Data)
|
---|
| 351 | ;"Purpose: To stuff data from data array into record specified by RecNum.
|
---|
| 352 | ;" This function will not directly put any data into subfiles, but will
|
---|
| 353 | ;" call UploadData to handle this.
|
---|
| 354 | ;"Input: RecNum -- the record number (as returned by GetRecMatch) to put data into
|
---|
| 355 | ;" Data - Should be in format output from GetRInfo
|
---|
| 356 | ;"Output: database will be modified by changing record
|
---|
| 357 | ;"Returns: If should continue execution: 1=OK to continue. 0=abort.
|
---|
| 358 |
|
---|
| 359 | if $data(TMGDEBUG)#10=0 new TMGDEBUG set TMGDEBUG=0
|
---|
| 360 | if $data(cOKToCont)#10=0 new cOKToCont set cOKToCont=1
|
---|
| 361 | if $data(cAbort)#10=0 new cAbort set cAbort=0
|
---|
| 362 | new cParentIENS set cParentIENS="ParentIENS"
|
---|
| 363 |
|
---|
| 364 | new result set result=cOKToCont
|
---|
| 365 | new Flags
|
---|
| 366 | new FileNumber,FieldNum,SubFileNum
|
---|
| 367 | new FieldFlags
|
---|
| 368 | new tmgFDA,TMGFDA,TMGMsg
|
---|
| 369 | new index
|
---|
| 370 | new IENS set IENS=$get(Data(0,cParentIENS))
|
---|
| 371 | new FDAIndex
|
---|
| 372 | new MarkerArray
|
---|
| 373 | new MsgArray
|
---|
| 374 |
|
---|
| 375 | ;"if $get(TMGDEBUG)>0 do DebugEntry^TMGDEBUG(.DBIndent,"OverwriteRec^TMGDBAPI")
|
---|
| 376 | if $get(RecNum)=0 set result=cAbort goto OWQuit
|
---|
| 377 |
|
---|
| 378 | set FileNumber=Data(0,cFile)
|
---|
| 379 | set Flags="KE" ;"E=External format values; K=Func locks file during use.
|
---|
| 380 |
|
---|
| 381 | set IENS=$get(Data(0,cParentIENS))
|
---|
| 382 |
|
---|
| 383 | new MarkNum set MarkNum=0
|
---|
| 384 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"RecNum=",RecNum)
|
---|
| 385 |
|
---|
| 386 | ;"if $get(TMGDEBUG)>0 do ArrayDump^TMGDEBUG("Data")
|
---|
| 387 |
|
---|
| 388 | set result=$$SetupFDA(.Data,.tmgFDA,IENS,"?",.MarkNum,.MsgArray,0,RecNum)
|
---|
| 389 | if result=cAbort goto OWQuit
|
---|
| 390 | set FileNum=$get(Data(0,cFile),0) if FileNum=0 set result=cAbort goto OWQuit
|
---|
| 391 |
|
---|
| 392 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Here is master MsgArray")
|
---|
| 393 | ;"if TMGDEBUG do ArrayDump^TMGDEBUG("MsgArray")
|
---|
| 394 |
|
---|
| 395 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Here is master tmgFDA")
|
---|
| 396 | ;"if $get(TMGDEBUG)>0 do ArrayDump^TMGDEBUG("tmgFDA") ;"zwr tmgFDA(*)
|
---|
| 397 |
|
---|
| 398 | if $data(tmgFDA)=0 do goto OWPast ;"This can happen with single records with NoOverwrite flag
|
---|
| 399 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"No data to file with fileman, so skipping.")
|
---|
| 400 |
|
---|
| 401 | set FDAIndex=FileNum
|
---|
| 402 | kill TMGFDA
|
---|
| 403 | merge TMGFDA(FDAIndex)=tmgFDA(FDAIndex)
|
---|
| 404 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Processing "_FDAIndex_" part of tmgFDA")
|
---|
| 405 | ;
|
---|
| 406 | set Flags="E" ;"E=External format values
|
---|
| 407 | ;
|
---|
| 408 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Here is the TMGFDA to pass to FILE^DIE")
|
---|
| 409 | ;"if $get(TMGDEBUG)>0 do ArrayDump^TMGDEBUG("TMGFDA") ;"zwr TMGFDA(*)
|
---|
| 410 | ;
|
---|
| 411 | ;"======================================================
|
---|
| 412 | ;"Call FILE^DIE
|
---|
| 413 | ;"======================================================
|
---|
| 414 | if $data(TMGFDA)=0 set result=cAbort quit
|
---|
| 415 | ;"if $get(TMGDEBUG)>0 do DebugEntry^TMGDEBUG(.DBIndent,"TMGDBAPI::FILE^DIE")
|
---|
| 416 | do
|
---|
| 417 | . new $etrap set $etrap="do ErrTrp^TMGDBAPI"
|
---|
| 418 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Remember, FILE^DIE is for working with records that already exist.")
|
---|
| 419 | . set ^TMP("TMG",$J,"ErrorTrap")=result
|
---|
| 420 | . set ^TMP("TMG",$J,"Caller")="FILE^DIE"
|
---|
| 421 | . do FILE^DIE(Flags,"TMGFDA","TMGMsg")
|
---|
| 422 | . set result=^TMP("TMG",$J,"ErrorTrap")
|
---|
| 423 | . kill ^TMP("TMG",$J,"ErrorTrap")
|
---|
| 424 | . kill ^TMP("TMG",$J,"Caller")
|
---|
| 425 | ;"if $get(TMGDEBUG)>0 do DebugExit^TMGDEBUG(.DBIndent,"TMGDBAPI::FILE^DIE")
|
---|
| 426 | ;"======================================================
|
---|
| 427 | ;"======================================================
|
---|
| 428 | ;"
|
---|
| 429 | if $data(TMGMsg("DIERR")) do goto OWQuit
|
---|
| 430 | . do ShowDIERR^TMGDEBUG(.TMGMsg,.PriorErrorFound)
|
---|
| 431 | . set result=cAbort
|
---|
| 432 |
|
---|
| 433 | if result=cAbort goto OWQuit
|
---|
| 434 |
|
---|
| 435 | kill tmgFDA(FDAIndex)
|
---|
| 436 | set FDAIndex="" ;"I don't want to loop through rest of tmgFDA, will handle below.
|
---|
| 437 |
|
---|
| 438 | OWPast
|
---|
| 439 | set result=$$HandleHacksArray^TMGDBAPI(.MsgArray)
|
---|
| 440 | if result=cAbort do ShowError^TMGDEBUG(.PriorErrorFound,"Error in writing record") goto OWQuit
|
---|
| 441 |
|
---|
| 442 | ;"Now we handle possible subfile entries. Info regarding these is in MsgArray
|
---|
| 443 | if $data(MsgArray(cRef))'=0 do
|
---|
| 444 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Handling subfile entries.")
|
---|
| 445 | . set SubFileNum=$order(MsgArray(cRef,""))
|
---|
| 446 | . for do quit:(+SubFileNum=0)!(result=cAbort)
|
---|
| 447 | . . if +SubFileNum=0 quit
|
---|
| 448 | . . new SubData,DataP
|
---|
| 449 | . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"SubFileNum="_SubFileNum)
|
---|
| 450 | . . set DataP=MsgArray(cRef,SubFileNum)
|
---|
| 451 | . . merge SubData=@DataP
|
---|
| 452 | . . set SubData(0,cParentIENS)=RecNum_","_IENS
|
---|
| 453 | . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Sub IENS="_RecNum_","_IENS)
|
---|
| 454 | . . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"DataP="_DataP)
|
---|
| 455 | . . set result=$$UploadData^TMGDBAPI(.SubData)
|
---|
| 456 | . . set SubFileNum=$order(MsgArray(cRef,SubFileNum))
|
---|
| 457 |
|
---|
| 458 | OWQuit
|
---|
| 459 | ;"if $get(TMGDEBUG)>0 do DebugExit^TMGDEBUG(.DBIndent,"OverwriteRec^TMGDBAPI")
|
---|
| 460 | quit result
|
---|
| 461 |
|
---|
| 462 |
|
---|
| 463 | GetFileNum(FileName)
|
---|
| 464 | ;"Purpose: Convert a file name into a file number
|
---|
| 465 | ;"Input: The name of a file
|
---|
| 466 | ;"Result: The filenumber, or 0 if not found.
|
---|
| 467 |
|
---|
| 468 | ;"if $get(TMGDEBUG)>0 do DebugEntry^TMGDEBUG(.DBIndent,"GetFileNum^TMGDBAPI")
|
---|
| 469 | new result set result=0
|
---|
| 470 |
|
---|
| 471 | if $get(FileName)="" goto GtFlNumDone
|
---|
| 472 |
|
---|
| 473 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(DBIndent,"File Name='"_FileName_"'")
|
---|
| 474 |
|
---|
| 475 | if FileName=" " do goto GtFlNumDone
|
---|
| 476 | . do ShowError^TMGDEBUG(.PriorErrorFound,"No file specifier (either name or number) given!")
|
---|
| 477 | . set result=0
|
---|
| 478 |
|
---|
| 479 | set DIC=1 ;"File 1=Global file reference (the file listing info for all files)
|
---|
| 480 | set DIC(0)="M"
|
---|
| 481 | set X=FileName ;"i.e. "AGENCY"
|
---|
| 482 | do ^DIC ;"lookup filename Result comes back in Y ... i.e. "4.11^AGENCY"
|
---|
| 483 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(DBIndent,"lookup for filename '"_FileName_"' ==> "_Y)
|
---|
| 484 | set result=$piece(Y,"^",1)
|
---|
| 485 | if result=-1 set result=0
|
---|
| 486 |
|
---|
| 487 | GtFlNumDone
|
---|
| 488 | ;"if $get(TMGDEBUG)>0 do DebugExit^TMGDEBUG(.DBIndent,"GetFileNum^TMGDBAPI")
|
---|
| 489 | quit result
|
---|
| 490 |
|
---|
| 491 |
|
---|
| 492 | GetFName(FileNumber)
|
---|
| 493 | ;"Purpose: Convert a file number into a file name
|
---|
| 494 | ;"Input: The number of a file
|
---|
| 495 | ;"Result: The file name, or "" if not found.
|
---|
| 496 |
|
---|
| 497 | ;"if $get(TMGDEBUG)>0 do DebugEntry^TMGDEBUG(.DBIndent,"GetFileName^TMGDBAPI")
|
---|
| 498 | new result set result=""
|
---|
| 499 |
|
---|
| 500 | if $get(FileNumber)=0 goto GtFlNumDone
|
---|
| 501 |
|
---|
| 502 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(DBIndent,"File Number='"_FileNumber_"'")
|
---|
| 503 |
|
---|
| 504 | set result=$get(^DIC(FileNumber,0))
|
---|
| 505 | if (result="")&(FileNumber[".") do
|
---|
| 506 | . set result=$get(^DD(FileNumber,0))
|
---|
| 507 | set result=$piece(result,"^",1)
|
---|
| 508 |
|
---|
| 509 | GtFNmDone
|
---|
| 510 | ;"if $get(TMGDEBUG)>0 do DebugExit^TMGDEBUG(.DBIndent,"GetFileName^TMGDBAPI")
|
---|
| 511 | quit result
|
---|
| 512 |
|
---|
| 513 |
|
---|
| 514 | GetFldName(File,FieldNumber)
|
---|
| 515 | ;"Purpose: Convert a field number into a field name
|
---|
| 516 | ;"Input: File -- name or number of file
|
---|
| 517 | ;" FieldNumber -- the number of the field to convert
|
---|
| 518 | ;"Result: The field name, or "" if not found.
|
---|
| 519 |
|
---|
| 520 | ;"if $get(TMGDEBUG)>0 do DebugEntry^TMGDEBUG(.DBIndent,"GetFldName^TMGDBAPI")
|
---|
| 521 | new result set result=""
|
---|
| 522 | new array
|
---|
| 523 | do GetFieldInfo^TMGDBAPI(.File,.FieldNumber,"array","LABEL")
|
---|
| 524 | set result=$get(array("LABEL"))
|
---|
| 525 |
|
---|
| 526 | GFldNmDone
|
---|
| 527 | ;"if $get(TMGDEBUG)>0 do DebugExit^TMGDEBUG(.DBIndent,"GetFldName^TMGDBAPI")
|
---|
| 528 | quit result
|
---|
| 529 |
|
---|
| 530 |
|
---|
| 531 | GetFldList(File,pArray)
|
---|
| 532 | ;"Purpose: Get list of all fields for a file.
|
---|
| 533 | ;"Input: File -- File name or number to look query. May be a sub file number
|
---|
| 534 | ;" pArray -- pointer to (i.e. name of) array to put data into
|
---|
| 535 | ;" Any preexisting data in pArray will be killed.
|
---|
| 536 | ;"Output: Array will be fille with info like this:
|
---|
| 537 | ;" example: Array(.01)=""<--- shows that field .01 exists
|
---|
| 538 | ;" Array(1)="" <--- shows that field 1 exists
|
---|
| 539 | ;" Array(2)="" <--- shows that field 2 exists
|
---|
| 540 | ;"Results: 1=OK to continue. 0=error
|
---|
| 541 |
|
---|
| 542 | new result set result=1
|
---|
| 543 | new FileNumber,FileName
|
---|
| 544 | if ($get(File)="")!($get(pArray)="") set result=0 goto GFdLDone
|
---|
| 545 | kill @pArray
|
---|
| 546 |
|
---|
| 547 | if +File=File do
|
---|
| 548 | . set FileNumber=File
|
---|
| 549 | . set FileName=$$GetFName(File)
|
---|
| 550 | else do
|
---|
| 551 | . set FileName=File
|
---|
| 552 | . set FileNumber=$$GetFileNum(File)
|
---|
| 553 | if FileNumber'>0 do goto GFdLDone
|
---|
| 554 | . do ShowError^TMGDEBUG(.PriorErrorFound,"Error: Requested file, "_File_", doesn't exist.")
|
---|
| 555 | . set result=0
|
---|
| 556 |
|
---|
| 557 | new index set index=$order(^DD(FileNumber,0))
|
---|
| 558 | if +index>0 for do quit:(+index'>0)
|
---|
| 559 | . set @pArray@(index)=""
|
---|
| 560 | . set index=$order(^DD(FileNumber,index))
|
---|
| 561 |
|
---|
| 562 | GFdLDone
|
---|
| 563 | quit result
|
---|
| 564 |
|
---|
| 565 |
|
---|
| 566 | SetupFileNum(Data)
|
---|
| 567 | ;"Purpose: To Ensure that Data(0,cFile) contains valid file number
|
---|
| 568 | ;"Input: Data-- should be passed by reference, Array setup by GetRInfo
|
---|
| 569 | ;" Specifically, Data(0,cFile) should have file name OR number
|
---|
| 570 | ;"Output: Data is changed:
|
---|
| 571 | ;" Data(0,cFile)=FileNumber
|
---|
| 572 | ;" Data(0,cFile,cGlobal)=Global reference name ;i.e. "^VA(200)"
|
---|
| 573 | ;" Data(0,cFile,cGlobal,cOpen)=Open Global reference name ;i.e. "^VA(200,"
|
---|
| 574 | ;"Returns: If should continue execution: 1=OK to continue. 0=abort.
|
---|
| 575 |
|
---|
| 576 | if $data(TMGDEBUG)#10=0 new TMGDEBUG set TMGDEBUG=0
|
---|
| 577 | new cOKToCont set cOKToCont=1
|
---|
| 578 | new cAbort set cAbort=0
|
---|
| 579 | new cFile set cFile="FILE" ;"File"
|
---|
| 580 | new cGlobal set cGlobal="GLOBAL"
|
---|
| 581 | new cOpen set cOpen="OPEN"
|
---|
| 582 |
|
---|
| 583 | new result set result=cOKToCont
|
---|
| 584 | new FileNumber,FileName,File
|
---|
| 585 |
|
---|
| 586 | ;"if $get(TMGDEBUG)>0 do DebugEntry^TMGDEBUG(.DBIndent,"SetupFileNum^TMGDBAPI")
|
---|
| 587 |
|
---|
| 588 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Here is Data passed to SetupFileNum")
|
---|
| 589 | ;"if TMGDEBUG do ArrayDump^TMGDEBUG("Data") ;"zwr Data(*)
|
---|
| 590 |
|
---|
| 591 | set File=$get(Data(0,cFile)," ")
|
---|
| 592 | if +File'=0 do goto CKFileNum
|
---|
| 593 | . set FileNumber=File
|
---|
| 594 | set FileName=File
|
---|
| 595 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(DBIndent,"File Name='"_FileName_"'")
|
---|
| 596 |
|
---|
| 597 | if FileName=" " do goto SFNDone
|
---|
| 598 | . do ShowError^TMGDEBUG(.PriorErrorFound,"No file specifier (either name or number) given!")
|
---|
| 599 | . set result=cAbort ;"0=Abort
|
---|
| 600 |
|
---|
| 601 | ;"Note: I could replace this code with GetFileNum(FileName)
|
---|
| 602 | ;"----------------
|
---|
| 603 | set DIC=1 ;"File 1=Global file reference (the file listing info for all files)
|
---|
| 604 | set DIC(0)="M"
|
---|
| 605 | set X=FileName ;"i.e. "AGENCY"
|
---|
| 606 | do ^DIC ;"lookup filename Result comes back in Y ... i.e. "4.11^AGENCY"
|
---|
| 607 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(DBIndent,"lookup for filename '"_FileName_"' ==> "_Y)
|
---|
| 608 | set FileNumber=$piece(Y,"^",1)
|
---|
| 609 | ;"----------------
|
---|
| 610 |
|
---|
| 611 | CKFileNum
|
---|
| 612 | set Data(0,cFile)=FileNumber
|
---|
| 613 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(DBIndent,"Uploading to File number: "_FileNumber)
|
---|
| 614 | ;"if $data(FileName) if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(DBIndent,"('",FileName,"' file)")
|
---|
| 615 | if FileNumber=-1 do goto SFNDone
|
---|
| 616 | . do ShowError^TMGDEBUG(.PriorErrorFound,"Unable to locate file specified as #"_FileNumber_" or '"_FileName_"'.")
|
---|
| 617 | . set result=cAbort ;"0=Abort
|
---|
| 618 | if $$VFILE^DILFD(FileNumber)=0 do goto SFNDone
|
---|
| 619 | . do ShowError^TMGDEBUG(.PriorErrorFound,"Error: Requested file, #"_FileNumber_", doesn't exist.")
|
---|
| 620 | . set result=cAbort ;"0=Abort
|
---|
| 621 |
|
---|
| 622 | set Global=$get(^DIC(FileNumber,0,"GL"),"INVALID") ;"^DIC is file 1/FILE
|
---|
| 623 | set Data(0,cFile,cGlobal,cOpen)=Global
|
---|
| 624 | ;"Convert global form of ^VA(200, into ^VA(200)
|
---|
| 625 | new Len
|
---|
| 626 | set Len=$length(Global)
|
---|
| 627 | if $extract(Global,Len)="," do
|
---|
| 628 | . set $extract(Global,Len)=")"
|
---|
| 629 | if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(DBIndent,"The global file to access is: "_Global)
|
---|
| 630 | set Data(0,cFile,cGlobal)=Global
|
---|
| 631 |
|
---|
| 632 | SFNDone
|
---|
| 633 | ;"if $get(TMGDEBUG)>0 do DebugExit^TMGDEBUG(.DBIndent,"SetupFileNum^TMGDBAPI")
|
---|
| 634 |
|
---|
| 635 | quit result
|
---|
| 636 |
|
---|
| 637 |
|
---|
| 638 |
|
---|
| 639 | RecFind(Params)
|
---|
| 640 | ;"Purpose: To look through a file and find matching record
|
---|
| 641 | ;"Input -- Params(cFile)=File name or number
|
---|
| 642 | ;" Params(FieldNumber)=LookupValue
|
---|
| 643 | ;" Params(FieldNumber)=LookupValue
|
---|
| 644 | ;"
|
---|
| 645 | ;" e.g. Params(0,cFile)="PERSON CLASS"
|
---|
| 646 | ;" Params(.01)="Physicians (M.D. and D.O.)"
|
---|
| 647 | ;" Params(1)="Physician/Osteopath"
|
---|
| 648 | ;" Params(2)="Family Practice"
|
---|
| 649 | ;"
|
---|
| 650 | ;"Note: Does not support searching based on subfile data.
|
---|
| 651 | ;"Output -- (via results)
|
---|
| 652 | ;"Result -- Returns record number file, OR 0 if not found
|
---|
| 653 |
|
---|
| 654 | if $get(TMGDEBUG)>0 do DebugEntry^TMGDEBUG(.DBIndent,"RecFind^TMGDBAPI")
|
---|
| 655 |
|
---|
| 656 | if $data(cFile)=0 new cFile set cFile="FILE"
|
---|
| 657 | if $data(cEntries)=0 new cEntries set cEntries="Entries"
|
---|
| 658 | if $data(cMatchValue)=0 new cMatchValue set cMatchValue="MATCHVALUE"
|
---|
| 659 | new result set result=0
|
---|
| 660 | new Data
|
---|
| 661 | new RecNum
|
---|
| 662 | new FieldNum
|
---|
| 663 |
|
---|
| 664 | set Data(0,cFile)=$get(Params(0,cFile))
|
---|
| 665 | if Data(0,cFile)="" goto RFDone
|
---|
| 666 | if $$SetupFileNum(.Data)=0 goto RFDone
|
---|
| 667 | set Data(0,cEntries)=1
|
---|
| 668 |
|
---|
| 669 | set FieldNum=$order(Params(0))
|
---|
| 670 | for do quit:(+FieldNum=0)
|
---|
| 671 | . if +FieldNum=0 quit
|
---|
| 672 | . set Data(1,FieldNum,cMatchValue)=$get(Params(FieldNum))
|
---|
| 673 | . set FieldNum=$order(Params(FieldNum))
|
---|
| 674 |
|
---|
| 675 | if $$GetRecMatch^TMGDBAPI(.Data,.RecNum)=0 goto RFDone
|
---|
| 676 | set result=RecNum
|
---|
| 677 |
|
---|
| 678 | RFDone
|
---|
| 679 | ;"if $get(TMGDEBUG)>0 do DebugExit^TMGDEBUG(.DBIndent,"RecFind^TMGDBAPI")
|
---|
| 680 | quit result
|
---|
| 681 |
|
---|
| 682 |
|
---|
| 683 |
|
---|
| 684 | FieldCompare(TestField,dbField,Type)
|
---|
| 685 | ;"PURPOSE: To compare two fields and return a comparison code
|
---|
| 686 | ;"INPUT: TestField -- User input to be tested (in "external format"). **Don't pass by Ref**
|
---|
| 687 | ;" dbField -- data from database to be tested. **Don't pass by Ref
|
---|
| 688 | ;" Type -- (Optional) The type of data being compared:
|
---|
| 689 | ;" "NORMAL" or "" -- Simple comparison carried out (i.e. 'if A=B')
|
---|
| 690 | ;" "DATE" -- the two values are date/time values
|
---|
| 691 | ;" "SSNUM"-- the two values are social security numbers
|
---|
| 692 | ;" "SEX" -- the two values are Sex descriptors.
|
---|
| 693 | ;" "NUMBER" -- the two values are numbers
|
---|
| 694 | ;"Results:
|
---|
| 695 | ;" return value = cConflict (0) if entries conflict
|
---|
| 696 | ;" i.e. TestField="John" vs dbField="Bill"
|
---|
| 697 | ;" return value = cFullMatch (1) if entries completely match
|
---|
| 698 | ;" ie. TestField="John" vs dbField="John"
|
---|
| 699 | ;" or TestField="" vs. dbField=""
|
---|
| 700 | ;" return value = cExtraInfo (2) if entries have no conflict, but TestField has extra info.
|
---|
| 701 | ;" i.e. TestField="John" vs. dbField=""
|
---|
| 702 | ;" return value = cdbExtraInfo (3) if entries have no conflict, but dbField has extra info.
|
---|
| 703 | ;" i.e. TestField="" vs. dbField="12345"
|
---|
| 704 |
|
---|
| 705 | ;"if $get(TMGDEBUG)>0 do DebugEntry^TMGDEBUG(.DBIndent,"FieldCompare^TMGDBAPI")
|
---|
| 706 |
|
---|
| 707 | if $data(cConflict)#10=0 new cConflict set cConflict=0
|
---|
| 708 | if $data(cFullMatch)#10=0 new cFullMatch set cFullMatch=1
|
---|
| 709 | if $data(cExtraInfo)#10=0 new cExtraInfo set cExtraInfo=2
|
---|
| 710 | if $data(cdbExtraInfo)#10=0 new cdbExtraInfo set cdbExtraInfo=3
|
---|
| 711 |
|
---|
| 712 | set TestField=$get(TestField)
|
---|
| 713 | set dbField=$get(dbField)
|
---|
| 714 | set Type=$get(Type)
|
---|
| 715 |
|
---|
| 716 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"TestField=",TestField)
|
---|
| 717 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"dbField=",dbField)
|
---|
| 718 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Type=",Type)
|
---|
| 719 |
|
---|
| 720 | new result set result=cConflict
|
---|
| 721 |
|
---|
| 722 | if Type="DATE" do
|
---|
| 723 | . set TestField=$$IDATE^TIULC(TestField)
|
---|
| 724 | . set dbField=$$IDATE^TIULC(dbField)
|
---|
| 725 | else if Type="SSNUM" do
|
---|
| 726 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Processing SSNUM's")
|
---|
| 727 | . set TestField=$translate(TestField," /-","") ;"Clean delimiters
|
---|
| 728 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"TestField now=",TestField)
|
---|
| 729 | . if TestField["P" set TestField="P"
|
---|
| 730 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"TestField now=",TestField)
|
---|
| 731 | . if dbField["P" set dbField="P"
|
---|
| 732 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"dbField now=",dbField)
|
---|
| 733 | else if Type="SEX" do
|
---|
| 734 | . if (TestField="m")!(TestField="M") set TestField="MALE"
|
---|
| 735 | . if (TestField="f")!(TestField="F") set TestField="FEMALE"
|
---|
| 736 |
|
---|
| 737 | if TestField'="" do
|
---|
| 738 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"$data(dbField)=",$data(dbField))
|
---|
| 739 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"$get(dbField)='' =",($get(dbField)=""))
|
---|
| 740 | . if ($data(dbField)#10=0)!($get(dbField)="") set result=cExtraInfo
|
---|
| 741 | . else do
|
---|
| 742 | . . if Type="NUMBER" do
|
---|
| 743 | . . . if +TestField=+dbField set result=cFullMatch
|
---|
| 744 | . . else do
|
---|
| 745 | . . . if TestField=dbField set result=cFullMatch
|
---|
| 746 | else do ;"i.e. test case when TestField=""
|
---|
| 747 | . if $get(dbfield)="" set result=cFullMatch
|
---|
| 748 | . else set result=cdbExtraInfo
|
---|
| 749 |
|
---|
| 750 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"result=",result)
|
---|
| 751 | ;"if $get(TMGDEBUG)>0 do DebugExit^TMGDEBUG(.DBIndent,"FieldCompare^TMGDBAPI")
|
---|
| 752 |
|
---|
| 753 | quit result
|
---|
| 754 |
|
---|
| 755 |
|
---|
| 756 | EnsureWrite(File,Field,IENS,Value,Flags,MsgArray)
|
---|
| 757 | ;"Purpose: To provide code to that will ensure that data is written to
|
---|
| 758 | ;" the database, but it will not add duplicate records if the value
|
---|
| 759 | ;" is already there. So a FIND is done first, and added if not found.
|
---|
| 760 | ;" Note: This is primarly targeted at adding entries in a subfile.
|
---|
| 761 | ;"Input: File -- File name or number
|
---|
| 762 | ;" Field -- Field name or number
|
---|
| 763 | ;" IENS -- standard IENS string describing IEN in File, or IEN path to subfile
|
---|
| 764 | ;" Value -- The value to be filed
|
---|
| 765 | ;" Flags -- Flags to be passed
|
---|
| 766 | ;" MsgArray -- PASS BY REFERENCE. Messages to pass back out.
|
---|
| 767 | ;"Results : 1=Writen OK, 0=Already present so not written, -1=error
|
---|
| 768 |
|
---|
| 769 | new result set result=-1
|
---|
| 770 |
|
---|
| 771 |
|
---|
| 772 | quit result
|
---|
| 773 |
|
---|
| 774 |
|
---|
| 775 |
|
---|
| 776 | dbWrite(FDA,Overwrite,TMGIEN,Flags,ErrArray)
|
---|
| 777 | ;"Purpose: To provide a unified interface for writing a FDA to the database
|
---|
| 778 | ;"Input: FDA -- PASS BY REFERENCE. A standard FDA structure. (won't be changed)
|
---|
| 779 | ;" Overwrite -- specifies if records already exist in database
|
---|
| 780 | ;" if = 1, then FILE^DIE used to write into pre-existing records
|
---|
| 781 | ;" if = 0, then UPDATE^DIE used to write new records
|
---|
| 782 | ;" TMGIEN (OPTIONAL)-- an array to receive back records added (only applies if
|
---|
| 783 | ;" Overwrite=0)
|
---|
| 784 | ;" It can also be used to pass info to UPDATE^DIE recarding requested record numbers
|
---|
| 785 | ;" Flags (OPTIONAL) -- Flags to pass to UPDATE^DIE or FILE^DIE.
|
---|
| 786 | ;" default is "E". If "E" is not wanted, then pass a " "
|
---|
| 787 | ;" ErrArray (OPTIONAL) -- an OUT parameter to receive fileman "DIERR" results, if any
|
---|
| 788 | ;"Results --1 if OK, or 0 if error
|
---|
| 789 |
|
---|
| 790 | merge ^TMG("TMP","EDDIE","FDA")=FDA ;"TEMP!!
|
---|
| 791 |
|
---|
| 792 | set Overwrite=$get(Overwrite,0)
|
---|
| 793 | new TMGFDA merge TMGFDA=FDA
|
---|
| 794 | new TMGMsg
|
---|
| 795 | new TMGFlags set TMGFlags=$get(Flags,"E") ;"E=External values
|
---|
| 796 | if TMGFlags=" " set TMGFlags=""
|
---|
| 797 | if (Overwrite=1)&($get(Flags)'="") set TMGFlags=TMGFlags_"K" ;"K means filer does file locking.
|
---|
| 798 |
|
---|
| 799 | new result set result=1 ;"Default to success
|
---|
| 800 | if $data(TMGFDA)=0 set result=-1 goto DBWDone
|
---|
| 801 |
|
---|
| 802 | set ^TMP("TMG",$J,"ErrorTrap")=result
|
---|
| 803 | ;"======================================================
|
---|
| 804 | ;"======================================================
|
---|
| 805 | if Overwrite=1 do ;"i.e. FILE^DIE used to write into pre-existing records
|
---|
| 806 | . new $etrap set $etrap="do ErrTrp^TMGDBAPI"
|
---|
| 807 | . set ^TMP("TMG",$J,"Caller")="FILE^DIE"
|
---|
| 808 | . do FILE^DIE(TMGFlags,"TMGFDA","TMGMsg")
|
---|
| 809 | else if Overwrite=0 do ;"i.e. UPDATE^DIE used to write new records
|
---|
| 810 | . new $etrap set $etrap="do ErrTrp^TMGDBAPI"
|
---|
| 811 | . set ^TMP("TMG",$J,"Caller")="UPDATE^DIE"
|
---|
| 812 | . do UPDATE^DIE(TMGFlags,"TMGFDA","TMGIEN","TMGMsg")
|
---|
| 813 | ;"======================================================
|
---|
| 814 | ;"======================================================
|
---|
| 815 | set result=^TMP("TMG",$J,"ErrorTrap")
|
---|
| 816 | kill ^TMP("TMG",$J,"ErrorTrap")
|
---|
| 817 | kill ^TMP("TMG",$J,"Caller")
|
---|
| 818 |
|
---|
| 819 | if $data(TMGMsg("DIERR")) do
|
---|
| 820 | . ;"TMGDEBUG=-1 --> extra quiet mode
|
---|
| 821 | . if $get(TMGDEBUG)>-1 do ShowDIERR^TMGDEBUG(.TMGMsg,.PriorErrorFound)
|
---|
| 822 | . set result=0
|
---|
| 823 | . merge ErrArray("DIERR")=TMGMsg("DIERR")
|
---|
| 824 |
|
---|
| 825 | DBWDone
|
---|
| 826 | quit result
|
---|
| 827 |
|
---|
| 828 |
|
---|
| 829 | DelIEN(File,RecNumIEN,ErrArray)
|
---|
| 830 | ;"Purpose: To delete record# RecNumIEN from file FILE
|
---|
| 831 | ;"Input: File -- File name or number to delete from
|
---|
| 832 | ;" RecNumIEN -- the IEN to delete
|
---|
| 833 | ;" ErrArray --OPTIONAL, PASS BY REFERENCE.
|
---|
| 834 | ;" an OUT parameter to receive fileman "DIERR" results, if any
|
---|
| 835 | ;"Output: will cause deletion from database
|
---|
| 836 | ;"Results -- if error occured
|
---|
| 837 | ;" cOKToCont (i.e. 1) if no error
|
---|
| 838 | ;" cAbort (i.e. 0) if error
|
---|
| 839 |
|
---|
| 840 | new TMGFDA,result
|
---|
| 841 | set result=0
|
---|
| 842 |
|
---|
| 843 | if $get(File)="" goto DIENDone
|
---|
| 844 | if +$get(RecNumIEN)'>0 goto DIENDone
|
---|
| 845 | if +File'>0 set File=$$GetFileNum(File)
|
---|
| 846 |
|
---|
| 847 | set TMGFDA(File,+RecNumIEN_",",.01)="@"
|
---|
| 848 | set result=$$dbWrite(.TMGFDA,1,,,.ErrArray)
|
---|
| 849 |
|
---|
| 850 | DIENDone
|
---|
| 851 | quit result
|
---|
| 852 |
|
---|
| 853 |
|
---|
| 854 | WriteWP(File,RecNumIEN,Field,TMGArray)
|
---|
| 855 | ;"Purpose: To provide a shell around WP^DIE with error trap, error reporting
|
---|
| 856 | ;"Note: This does not support subfiles or multiples. Does not support appending
|
---|
| 857 | ;"Input: File: a number or name
|
---|
| 858 | ;" RecNumIEN: The record number, in File, to use
|
---|
| 859 | ;" Field: a name or number
|
---|
| 860 | ;" TMGArray: The array that contains WP data. Must be in Fileman acceptible format.
|
---|
| 861 | ;"Results -- if error occured
|
---|
| 862 | ;" cOKToCont (i.e. 1) if no error
|
---|
| 863 | ;" cAbort (i.e. 0) if error
|
---|
| 864 |
|
---|
| 865 | if $data(TMGDEBUG)#10=0 new TMGDEBUG set TMGDEBUG=0
|
---|
| 866 | if $data(cOKToCont)#10=0 new cOKToCont set cOKToCont=1
|
---|
| 867 | if $data(cAbort)#10=0 new cAbort set cAbort=0
|
---|
| 868 |
|
---|
| 869 | ;"if $get(TMGDEBUG)>0 do DebugEntry^TMGDEBUG(.DBIndent,"WriteWP^TMGDBAPI")
|
---|
| 870 |
|
---|
| 871 | new IENS
|
---|
| 872 | new TMGMsg
|
---|
| 873 | new FileNumber,FieldNumber
|
---|
| 874 | new result set result=cAbort
|
---|
| 875 | new TMGFlags set TMGFlags="K"
|
---|
| 876 |
|
---|
| 877 | set FileNumber=+$get(File)
|
---|
| 878 | if FileNumber=0 set FileNumber=$$GetFileNum(.File)
|
---|
| 879 | if FileNumber=0 do goto WWPDone
|
---|
| 880 | . do ShowError^TMGDEBUG(.PriorErrorFound,"Can't convert file '"_$get(File)_", to a number.")
|
---|
| 881 |
|
---|
| 882 | set FieldNumber=$get(Field)
|
---|
| 883 | if FieldNumber=0 set FieldNumber=$$GetNumField^TMGDBAPI(.Field)
|
---|
| 884 | if FieldNumber=0 do goto WWPDone
|
---|
| 885 | . do ShowError^TMGDEBUG(.PriorErrorFound,"Can't convert field '"_$get(Field)_", to a number.")
|
---|
| 886 |
|
---|
| 887 | if +$get(RecNumIEN)=0 do goto WWPDone
|
---|
| 888 | . do ShowError^TMGDEBUG(.PriorErrorFound,"No numeric record number supplied.")
|
---|
| 889 |
|
---|
| 890 | set IENS=RecNumIEN_","
|
---|
| 891 |
|
---|
| 892 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"FileNumber=",FileNumber)
|
---|
| 893 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"IENS='",IENS,"'")
|
---|
| 894 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"FieldNumber=",FieldNumber)
|
---|
| 895 | ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Flags=",TMGFlags)
|
---|
| 896 | ;"if $get(TMGDEBUG)>0 do ArrayDump^TMGDEBUG("TMGArray")
|
---|
| 897 |
|
---|
| 898 | do
|
---|
| 899 | . ;"======================================================
|
---|
| 900 | . ;"Call WP^DIE
|
---|
| 901 | . ;"======================================================
|
---|
| 902 | . ;"if $get(TMGDEBUG)>0 do DebugEntry^TMGDEBUG(.DBIndent,"TMGDBAPI::WP^DIE")
|
---|
| 903 | . new $etrap set $etrap="do ErrTrp^TMGDBAPI"
|
---|
| 904 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Remember, WP^DIE files WP data.")
|
---|
| 905 | . set ^TMP("TMG",$J,"ErrorTrap")=result
|
---|
| 906 | . set ^TMP("TMG",$J,"Caller")="WP^DIE"
|
---|
| 907 | . do WP^DIE(FileNumber,IENS,FieldNumber,TMGFlags,"TMGArray","TMGMsg")
|
---|
| 908 | . set result=^TMP("TMG",$J,"ErrorTrap")
|
---|
| 909 | . kill ^TMP("TMG",$J,"ErrorTrap")
|
---|
| 910 | . kill ^TMP("TMG",$J,"Caller")
|
---|
| 911 | . ;"if $get(TMGDEBUG)>0 do DebugExit^TMGDEBUG(.DBIndent,"TMGDBAPI::WP^DIE")
|
---|
| 912 | . ;"======================================================
|
---|
| 913 | . ;"======================================================
|
---|
| 914 |
|
---|
| 915 | if $data(TMGMsg("DIERR"))'=0 do goto WWPDone
|
---|
| 916 | . do ShowDIERR^TMGDEBUG(.TMGMsg,.PriorErrorFound)
|
---|
| 917 | . set result=cAbort
|
---|
| 918 |
|
---|
| 919 | set result=cOKToCont
|
---|
| 920 |
|
---|
| 921 | ;"zbreak WWPDone
|
---|
| 922 |
|
---|
| 923 | WWPDone
|
---|
| 924 | ;"if $get(TMGDEBUG)>0 do DebugExit^TMGDEBUG(.DBIndent,"WriteWP^TMGDBAPI")
|
---|
| 925 | quit result
|
---|
| 926 |
|
---|
| 927 |
|
---|
| 928 | ReadWP(File,IENS,Field,Array)
|
---|
| 929 | ;"Purpose: To provide a shell for reading a WP with error trap, error reporting
|
---|
| 930 | ;"Input: File: a number or name
|
---|
| 931 | ;" IENS: a standard IENS (i.e. "IEN,parent-IEN,grandparent-IEN,ggparent-IEN," etc.
|
---|
| 932 | ;" Note: can just pass a single IEN (without a terminal ",")
|
---|
| 933 | ;" Field: a name or number
|
---|
| 934 | ;" Array: The array to receive WP data. PASS BY REFERENCE
|
---|
| 935 | ;" returned In Fileman acceptible format.
|
---|
| 936 | ;" Array will be deleted before refilling
|
---|
| 937 | ;"Results -- if error occured
|
---|
| 938 | ;" cOKToCont (i.e. 1) if no error
|
---|
| 939 | ;" cAbort (i.e. 0) if error
|
---|
| 940 |
|
---|
| 941 | if $data(TMGDEBUG)#10=0 new TMGDEBUG set TMGDEBUG=0
|
---|
| 942 | if $data(cOKToCont)#10=0 new cOKToCont set cOKToCont=1
|
---|
| 943 | if $data(cAbort)#10=0 new cAbort set cAbort=0
|
---|
| 944 |
|
---|
| 945 | ;"if $get(TMGDEBUG)>0 do DebugEntry^TMGDEBUG(.DBIndent,"ReadWP^TMGDBAPI")
|
---|
| 946 |
|
---|
| 947 | new FileNumber,FieldNumber
|
---|
| 948 | new TMGWP,temp
|
---|
| 949 | new result set result=cOKToCont
|
---|
| 950 |
|
---|
| 951 | if $get(IENS)="" do goto RWPDone
|
---|
| 952 | . do ShowError^TMGDEBUG(.PriorErrorFound,"Valid IENS not supplied.")
|
---|
| 953 | if $extract(IENS,$length(IENS))'="," set IENS=IENS_","
|
---|
| 954 |
|
---|
| 955 | if $$SetFileFldNums^TMGDBAPI(.File,.Field,.FileNumber,.FieldNumber)=cAbort goto RWPDone
|
---|
| 956 |
|
---|
| 957 | set temp=$$GET1^DIQ(FileNumber,IENS,FieldNumber,"","TMGWP","TMGMsg")
|
---|
| 958 |
|
---|
| 959 | if $data(TMGMsg) do
|
---|
| 960 | . ;"if $get(TMGDEBUG)>0 do DebugMsg^TMGDEBUG(.DBIndent,"Here are TMGMsg entries")
|
---|
| 961 | . ;"if $get(TMGDEBUG)>0 do ArrayDump^TMGDEBUG("TMGMsg")
|
---|
| 962 | . if $data(TMGMsg("DIERR"))'=0 do quit
|
---|
| 963 | . . do ShowDIERR^TMGDEBUG(.TMGMsg,.PriorErrorFound)
|
---|
| 964 | . . set result=cAbort
|
---|
| 965 | if result=cAbort goto RWPDone
|
---|
| 966 |
|
---|
| 967 | kill Array
|
---|
| 968 | merge Array=TMGWP
|
---|
| 969 |
|
---|
| 970 | RWPDone
|
---|
| 971 | ;"if $get(TMGDEBUG)>0 do DebugExit^TMGDEBUG(.DBIndent,"ReadWP^TMGDBAPI")
|
---|
| 972 | quit result
|
---|
| 973 |
|
---|
| 974 | ShowIfError(TMGMsg,PriorErrorFound)
|
---|
| 975 | ;"Purpose: to show DIERR if preesnt in pTMGMsg
|
---|
| 976 | ;"Input: pTMGMsg -- PASS BY REFERENCE, holds message route, as set up by Fileman
|
---|
| 977 | ;" PriorErrroFound -- OPTIONAL, a variable holding if a prior error has been found
|
---|
| 978 | ;"Output: 1 if ERROR found, 0 otherwise
|
---|
| 979 |
|
---|
| 980 | new result set result=0
|
---|
| 981 | if $data(TMGMsg("DIERR"))'=0 do
|
---|
| 982 | . do ShowDIERR^TMGDEBUG(.TMGMsg,.PriorErrorFound)
|
---|
| 983 | . set result=1
|
---|
| 984 | quit result
|
---|
| 985 |
|
---|
| 986 |
|
---|
| 987 | DataImport(Info,ProgressFN)
|
---|
| 988 | ;"Purpose: to provide a generic loading utility.
|
---|
| 989 | ;" Note: this is more specific than code found in DDMP.m
|
---|
| 990 | ;"Assumptions: that all data for one record is found on one line, with a given
|
---|
| 991 | ;" number of columns for each field.
|
---|
| 992 | ;"Input: Info, an array with relevent info. PASS BY REFERENCE
|
---|
| 993 | ;" Format as follows:
|
---|
| 994 | ;" Info("HFS DIR")=<directory name in HFS to load from>
|
---|
| 995 | ;" Info("HFS FILE")=<file name in HFS to load from>
|
---|
| 996 | ;" Info("DEST FILE")=<file name or number>
|
---|
| 997 | ;" Info(x)=field# (or "IEN" if data should be used to determine record number
|
---|
| 998 | ;" Info(x,"START")=starting column
|
---|
| 999 | ;" Info(x,"END")=ending column
|
---|
| 1000 | ;" ProgressFN: optional. If not "", then this will be XECUTED after each line
|
---|
| 1001 | ;"Result: 1 if OK to continue, 0 if error
|
---|
| 1002 |
|
---|
| 1003 | ;"Note: input Data array will be formated like this:
|
---|
| 1004 | ;" Data(0,cFile)="1234.1" <-- "NEW PERSON" Note conversion
|
---|
| 1005 | ;" Data(0,cFile,cGlobal)="^DIC(200)" <-- note, NOT "^DIC(200,"
|
---|
| 1006 | ;" Data(0,cRecNum)=2 <-- only if user-specified.
|
---|
| 1007 | ;" Data(0,cEntries)=1
|
---|
| 1008 | ;" Data(1,".01")="MyData1"
|
---|
| 1009 | ;" Data(1,".01",cMatchValue)="MyData1"
|
---|
| 1010 | ;" Data(1,".02")="Bill"
|
---|
| 1011 | ;" Data(1,".02",cMatchValue)="John"
|
---|
| 1012 | ;" Data(1,".03")="MyData3"
|
---|
| 1013 | ;" Data(1,".04")="MyData4"
|
---|
| 1014 | ;" Data(1,".06")="MyData5" <-- note "NAME" was converted to ".06"
|
---|
| 1015 | ;" Data(1,".07",0,cEntries)=2 <-- "ITEM" converted to ".07"
|
---|
| 1016 | ;" Data(1,".07",1,".01")="SubEntry1"
|
---|
| 1017 | ;" Data(1,".07",1,".02")="SE1"
|
---|
| 1018 | ;" Data(1,".07",1,".03")="'Some Info'"
|
---|
| 1019 | ;" Data(1,".07",2,".01")="SubEntry2"
|
---|
| 1020 | ;" Data(1,".07",2,".02")="SE2"
|
---|
| 1021 | ;" Data(1,".07",2,".04",0,cEntries)=1 ;"TEXT converted to .04
|
---|
| 1022 | ;" Data(1,".07",2,".04",1,".01")="JD"
|
---|
| 1023 | ;" Data(1,".07",2,".04",1,".02")="DOE,JOHN"
|
---|
| 1024 | ;" ADDENDUM
|
---|
| 1025 | ;" Data(1,".01",cFlags)=any flags specified for given field.
|
---|
| 1026 | ;" only present if user specified.
|
---|
| 1027 |
|
---|
| 1028 | new cFile set cFile="FILE"
|
---|
| 1029 | new cRecNum set cRecNum="RECNUM"
|
---|
| 1030 | new result set result=1
|
---|
| 1031 |
|
---|
| 1032 | new GRef set GRef=$name(^TMP("TMG","DATAIMPORT",$J))
|
---|
| 1033 | new GRef1 set GRef1=$name(@GRef@(1)) ;"I have to use this to load file
|
---|
| 1034 | kill @GRef
|
---|
| 1035 |
|
---|
| 1036 | new result
|
---|
| 1037 | new dir set dir=$get(Info("HFS DIR"))
|
---|
| 1038 | new HFSfile set HFSfile=$get(Info("HFS FILE"))
|
---|
| 1039 | set result=$$FTG^%ZISH(dir,HFSfile,GRef1,4)
|
---|
| 1040 | if result=0 goto DIDone
|
---|
| 1041 | new file set file=$get(Info("DEST FILE"))
|
---|
| 1042 | if +file=0 set file=$$GetFileNum(file)
|
---|
| 1043 |
|
---|
| 1044 | new index
|
---|
| 1045 | set index=$order(@GRef@(""))
|
---|
| 1046 | for do quit:(+index=0)!(result=0)
|
---|
| 1047 | . new RecData,FDA
|
---|
| 1048 | . set RecData(0,cFile)=file
|
---|
| 1049 | . new line set line=$get(@GRef@(index))
|
---|
| 1050 | . new fields set fields=$order(Info(""))
|
---|
| 1051 | . new IEN set IEN=""
|
---|
| 1052 | . for do quit:(+fields=0)!(result=0)
|
---|
| 1053 | . . new fieldNum set fieldNum=$get(Info(fields)) ;"could be number or 'IEN'
|
---|
| 1054 | . . new oneField
|
---|
| 1055 | . . set oneField=$extract(line,$get(Info(fields,"START")),$get(Info(fields,"END")))
|
---|
| 1056 | . . set oneField=$$Trim^TMGSTUTL(oneField)
|
---|
| 1057 | . . if fieldNum="IEN" do
|
---|
| 1058 | . . . set RecData(0,cRecNum)=fieldNum
|
---|
| 1059 | . . . set IEN=fieldNum
|
---|
| 1060 | . . else do
|
---|
| 1061 | . . . set RecData(1,fieldNum)=oneField
|
---|
| 1062 | . . set fields=$order(Info(fields))
|
---|
| 1063 | . new MarkNum set MarkNum=0
|
---|
| 1064 | . new MsgArray
|
---|
| 1065 | . set result=$$SetupFDA(.RecData,.FDA,,"+",.MarkNum,.MsgArray,IEN)
|
---|
| 1066 | . if result=0 quit
|
---|
| 1067 | . set result=$$dbWrite(.FDA,0,," ")
|
---|
| 1068 | . if result=0 quit
|
---|
| 1069 | . if $get(ProgressFN)'="" do
|
---|
| 1070 | . . new $etrap set $etrap="w ""??Progress function -- error trapped??"",!"
|
---|
| 1071 | . . xecute ProgressFN
|
---|
| 1072 | . set index=$order(@GRef@(index))
|
---|
| 1073 |
|
---|
| 1074 | DIDone
|
---|
| 1075 | kill @GRef
|
---|
| 1076 | quit result
|
---|
| 1077 |
|
---|
| 1078 |
|
---|
| 1079 | Set1(File,IEN,Field,Value,Flag)
|
---|
| 1080 | ;"Purpose: to be the reverse of GET1^DIQ (i.e. a setter instead of a getter)
|
---|
| 1081 | ;" It will set the value for 1 field in 1 record in 1 file.
|
---|
| 1082 | ;" Note: only to be used in existing files.
|
---|
| 1083 | ;"Input: File -- the Filename or number
|
---|
| 1084 | ;" IEN -- the record number to set into
|
---|
| 1085 | ;" Field -- the field name or number
|
---|
| 1086 | ;" Value -- the value to set it to (WP not currently supported)
|
---|
| 1087 | ;" Flag -- OPTIONAL. Combinations of below:
|
---|
| 1088 | ;" 'I' -- values are in internal format
|
---|
| 1089 | ;" 'E' -- values are in external format (this is the DEFAULT)
|
---|
| 1090 | ;"Results: 1 if OKtoCont, 0 if error
|
---|
| 1091 |
|
---|
| 1092 | new FileNumber,FieldNumber
|
---|
| 1093 | new result set result=0 ;"default to error
|
---|
| 1094 |
|
---|
| 1095 | ;"new tempDebug set tempDebug=$get(TMGDEBUG)
|
---|
| 1096 | ;"set TMGDEBUG=-1 ;"Extra quiet mode
|
---|
| 1097 |
|
---|
| 1098 | if $$SetFileFldNums^TMGDBAPI(.File,.Field,.FileNumber,.FieldNumber)=0 goto S1Done
|
---|
| 1099 | if (+FileNumber=0)!(+FieldNumber=0) goto S1Done
|
---|
| 1100 | if ($get(Value)="")!(+IEN=0) goto S1Done
|
---|
| 1101 |
|
---|
| 1102 | new result set result=1 ;"default to success.
|
---|
| 1103 |
|
---|
| 1104 | new TMGFDA,FMFlag,TMGMSG
|
---|
| 1105 | set FMFlag="E"
|
---|
| 1106 | if $get(Flag)["I" set FMFlag=""
|
---|
| 1107 | set FMFlag=FMFlag_"K"
|
---|
| 1108 | set TMGFDA(FileNumber,IEN_",",FieldNumber)=Value
|
---|
| 1109 | do FILE^DIE(FMFlag,"TMGFDA","TMGMSG")
|
---|
| 1110 | if $data(TMGMSG("DIERR"))'=0 do goto S1Done
|
---|
| 1111 | . do ShowDIERR^TMGDEBUG(.TMGMSG,.PriorErrorFound)
|
---|
| 1112 |
|
---|
| 1113 | S1Done
|
---|
| 1114 | ;"set TMGDEBUG=tempDebug
|
---|
| 1115 | quit result
|
---|
| 1116 |
|
---|
| 1117 |
|
---|
| 1118 | GetValidInput(File,Field)
|
---|
| 1119 | ;"Purpose: Gets a valid input for field in file, asking user from console
|
---|
| 1120 | ;"Input: File: File number or name of file to use
|
---|
| 1121 | ;" Field: Field number or name in file.
|
---|
| 1122 | ;"Results: returns valid input, or ""
|
---|
| 1123 |
|
---|
| 1124 | new FileNum,FldNum
|
---|
| 1125 | new DIR,X,Y
|
---|
| 1126 | set Y=""
|
---|
| 1127 |
|
---|
| 1128 | set FileNum=+$get(File)
|
---|
| 1129 | if FileNum=0 set FileNum=$$GetFileNum^TMGDBAPI(.File)
|
---|
| 1130 | if FileNum=0 goto GVIDone
|
---|
| 1131 |
|
---|
| 1132 | set FldNum=$get(Field)
|
---|
| 1133 | if FldNum=0 set FldNum=$$GetNumField^TMGDBAPI(FileNum,.Field)
|
---|
| 1134 | if FldNum=0 goto GVIDone
|
---|
| 1135 |
|
---|
| 1136 | set DIR(0)=FileNum_","_FldNum
|
---|
| 1137 | do ^DIR write !
|
---|
| 1138 | GVIDone
|
---|
| 1139 | quit Y
|
---|
| 1140 |
|
---|
| 1141 |
|
---|
| 1142 | AskFIENS()
|
---|
| 1143 | ;"Purpose: Ask user to pick a file number, then pick a record
|
---|
| 1144 | ;" from that file. This supports selection of subfiles.
|
---|
| 1145 | ;"Input: none
|
---|
| 1146 | ;"Results: format-- File^IENS, or ^ if abort
|
---|
| 1147 | new result set result="^"
|
---|
| 1148 |
|
---|
| 1149 | new DIR,X,Y
|
---|
| 1150 | set DIR(0)="F"
|
---|
| 1151 | set DIR("A")="Select FILE (or SUBFILE)"
|
---|
| 1152 | set DIR("?")="Answer with FILE NUMBER or NAME, or SUBFILE NUMBER"
|
---|
| 1153 | set DIR("PRE")="D ASKSCRN^TMGDBAPI"
|
---|
| 1154 | do ^DIR
|
---|
| 1155 | set Y=+Y
|
---|
| 1156 | if Y>0 set result=Y_"^"_$$AskIENS(Y)
|
---|
| 1157 |
|
---|
| 1158 | quit result
|
---|
| 1159 |
|
---|
| 1160 | ASKSCRN
|
---|
| 1161 | ;"Purpose: an Input transform for AskFIENS
|
---|
| 1162 | ;"Input: (global) X -- the user's response in ^DIR
|
---|
| 1163 | ;" (global) DTOUT -- this will be defined if the read timed out.
|
---|
| 1164 | ;"Output: If X is changed, it will be as if user entered in new X
|
---|
| 1165 | ;" If X is killed, it will be as if user entered an illegal value.
|
---|
| 1166 |
|
---|
| 1167 | if $data(DTOUT) quit
|
---|
| 1168 | if +X=X do
|
---|
| 1169 | . if $data(^DD(X,0))=0 kill X quit
|
---|
| 1170 | . if $data(^DIC(X,0)) write " ",$piece(^DIC(X,0),"^",1)," " quit
|
---|
| 1171 | . ;"Here we deal with subfiles
|
---|
| 1172 | . new temp,i,filenum
|
---|
| 1173 | . set filenum=X
|
---|
| 1174 | . set X=""
|
---|
| 1175 | . for i=100:-1:0 do quit:(filenum=0)
|
---|
| 1176 | . . set temp(i)=filenum
|
---|
| 1177 | . . set X=X_filenum_","
|
---|
| 1178 | . . set filenum=+$get(^DD(filenum,0,"UP"))
|
---|
| 1179 | . new indent set indent=5
|
---|
| 1180 | . new indentS set $piece(indentS," ",75)=" "
|
---|
| 1181 | . write !
|
---|
| 1182 | . set i=""
|
---|
| 1183 | . for set i=$order(temp(i)) quit:(i="") do
|
---|
| 1184 | . . set filenum=+$get(temp(i)) quit:(filenum=0)
|
---|
| 1185 | . . write $extract(indentS,1,indent)
|
---|
| 1186 | . . if $data(^DIC(filenum,0)) do
|
---|
| 1187 | . . . write $piece(^DIC(filenum,0),"^",1)," (FILE #",filenum,")",!
|
---|
| 1188 | . . else write "+--SUBFILE# ",filenum,!
|
---|
| 1189 | . . set indent=indent+3
|
---|
| 1190 | else do ;"check validity of FILE NAME
|
---|
| 1191 | . if X="" quit
|
---|
| 1192 | . new filenum
|
---|
| 1193 | . set filenum=$order(^DIC("B",X,""))
|
---|
| 1194 | . if +filenum>0 set X=+filenum_"," quit
|
---|
| 1195 | . set filenum=$$GetFileNum(X)
|
---|
| 1196 | . if +filenum>0 set X=+filenum_"," quit
|
---|
| 1197 | . new DIC,Y
|
---|
| 1198 | . set DIC=1 set DIC(0)="EQM"
|
---|
| 1199 | . do ^DIC w !
|
---|
| 1200 | . if +Y>0 set X=+Y quit
|
---|
| 1201 | . set X=0
|
---|
| 1202 |
|
---|
| 1203 | if $get(X)="" set X=0
|
---|
| 1204 | quit
|
---|
| 1205 |
|
---|
| 1206 |
|
---|
| 1207 | AskIENS(FileNum,IENS)
|
---|
| 1208 | ;"Purpose: To ask user to select a record in File indicated by FileNum.
|
---|
| 1209 | ;" If FileNum is a subfile number, then the user will be asked
|
---|
| 1210 | ;" for records to drill down to desired record, and return values
|
---|
| 1211 | ;" as an IENS.
|
---|
| 1212 | ;"Input: FileNum: A file number or subfile number
|
---|
| 1213 | ;" IENS: OPTIONAL. Allows for supplying a partial IENS supplying a
|
---|
| 1214 | ;" partial path. E.g. if a full IENS to FileNum
|
---|
| 1215 | ;" would be '2,3,4455,' and if the IENS supplied is
|
---|
| 1216 | ;" '3,4455,' then only the missing IEN (in this case 2)
|
---|
| 1217 | ;" would be asked.
|
---|
| 1218 | ;"Results: Returns IENS. format: IEN in file,IEN in parentfile,IEN in grandparentfile, ... ,
|
---|
| 1219 | ;" Note: IENS will contain '?' if there is a problem,
|
---|
| 1220 | ;" or "" if FileNum is invalid
|
---|
| 1221 | new array
|
---|
| 1222 | do GetRefArray(FileNum,.array)
|
---|
| 1223 | new resultIENS set resultIENS=""
|
---|
| 1224 | set IENS=$get(IENS)
|
---|
| 1225 |
|
---|
| 1226 | new DANum set DANum=1
|
---|
| 1227 | new TMGDA,numIENS
|
---|
| 1228 | set numIENS=$length(IENS,",")
|
---|
| 1229 | new i,abort set i="",abort=0
|
---|
| 1230 | for set i=$order(array(i),-1) quit:(i="")!abort do
|
---|
| 1231 | . new DIC,X,Y,DA
|
---|
| 1232 | . new tempIEN set tempIEN=+$piece(IENS,",",numIENS-DANum)
|
---|
| 1233 | . if tempIEN'>0 do
|
---|
| 1234 | . . set DIC=$get(array(i,"GL")),DIC(0)="AEQM"
|
---|
| 1235 | . . if DIC'="" write !,"Select entry in file# ",array(i,"FILE NUM")
|
---|
| 1236 | . . do ^DIC write !
|
---|
| 1237 | . else set Y=tempIEN
|
---|
| 1238 | . if +Y'>0 set resultIENS="?,"_resultIENS,abort=1 quit
|
---|
| 1239 | . set TMGDA(DANum)=+Y,DANum=DANum+1
|
---|
| 1240 | . set resultIENS=+Y_","_resultIENS
|
---|
| 1241 |
|
---|
| 1242 | write "#: ",resultIENS,!
|
---|
| 1243 | quit resultIENS
|
---|
| 1244 |
|
---|
| 1245 |
|
---|
| 1246 | GetRefArray(FileNum,array)
|
---|
| 1247 | ;"Purpose: To return an array containing global references that can
|
---|
| 1248 | ;" be passed to ^DIC, for given file or subfile number
|
---|
| 1249 | ;"Input: FileNum: A file number or subfile number
|
---|
| 1250 | ;" array: PASS BY REFERENCE. See format below
|
---|
| 1251 | ;"Results: none, but array is filled with result. Format (example):
|
---|
| 1252 | ;" array(1,"FILE NUM")=2.011 <--- sub sub file
|
---|
| 1253 | ;" array(1,"GL")="^DPT(TMGDA(1),""DE"",TMGDA(2),""1"","
|
---|
| 1254 | ;" array(2,"FILE NUM")=2.001 <---- sub file
|
---|
| 1255 | ;" array(2,"GL")="^DPT(TMGDA(1),""DE"","
|
---|
| 1256 | ;" array(3,"FILE NUM")=2 <---- parent file
|
---|
| 1257 | ;" array(3,"GL")="^DPT("
|
---|
| 1258 | ;"Note: To use the references stored in "GL", then the IEN for
|
---|
| 1259 | ;" each step should be stored in TMGDA(x)
|
---|
| 1260 |
|
---|
| 1261 | new i
|
---|
| 1262 | for i=1:1 quit:(+$get(FileNum)=0) do
|
---|
| 1263 | . set array(i,"FILE NUM")=FileNum
|
---|
| 1264 | . if $data(^DD(FileNum,0,"UP")) do
|
---|
| 1265 | . . new parentFlNum,field
|
---|
| 1266 | . . set parentFlNum=+$get(^DD(FileNum,0,"UP"))
|
---|
| 1267 | . . if parentFlNum=0 quit ;"really should be an abort
|
---|
| 1268 | . . set field=$order(^DD(parentFlNum,"SB",FileNum,""))
|
---|
| 1269 | . . if field="" quit ;"really should be an abort
|
---|
| 1270 | . . new node set node=$piece($piece($get(^DD(parentFlNum,field,0)),"^",4),";",1)
|
---|
| 1271 | . . set array(i,"NODE IN PARENT")=node
|
---|
| 1272 | . else do
|
---|
| 1273 | . . set array(i,"GL")=$get(^DIC(FileNum,0,"GL"))
|
---|
| 1274 | . set FileNum=+$get(^DD(FileNum,0,"UP"))
|
---|
| 1275 |
|
---|
| 1276 | set i="" set i=$order(array(i),-1)
|
---|
| 1277 | set array(i,"ref")=$get(array(i,"GL"))_"TMGDA(1),"
|
---|
| 1278 | new DANum set DANum=2
|
---|
| 1279 | for set i=$order(array(i),-1) quit:(i="") do
|
---|
| 1280 | . new ref
|
---|
| 1281 | . set ref=$get(array(i+1,"ref"))_""""_$get(array(i,"NODE IN PARENT"))_""","
|
---|
| 1282 | . kill array(i+1,"ref"),array(i,"NODE IN PARENT")
|
---|
| 1283 | . set array(i,"GL")=ref
|
---|
| 1284 | . set array(i,"ref")=ref_"TMGDA("_DANum_"),"
|
---|
| 1285 | . set DANum=DANum+1
|
---|
| 1286 | kill array(1,"ref")
|
---|
| 1287 | quit
|
---|
| 1288 |
|
---|
| 1289 | FIENS2Root(FIENS)
|
---|
| 1290 | ;"Purpose: to convert a Files^IENS string into a root reference
|
---|
| 1291 | ;"Input: FIENS: format: FileNumber^StandardIENS
|
---|
| 1292 | ;"Output: A global root in open format
|
---|
| 1293 | quit
|
---|
| 1294 |
|
---|
| 1295 |
|
---|
| 1296 | GetRef(file,IENS,field)
|
---|
| 1297 | ;"Purpose: to return the global reference for a given record
|
---|
| 1298 | ;"Input: file -- File or subfile number
|
---|
| 1299 | ;" IENS -- an IEN, or an IENS for record
|
---|
| 1300 | ;" field -- OPTIONAL.
|
---|
| 1301 | ;"Results: if field is NOT supplied, or
|
---|
| 1302 | ;" OPEN global ref
|
---|
| 1303 | ;" if field IS supplied
|
---|
| 1304 | ;" CLOSED global ref@piece
|
---|
| 1305 | ;" e.g. ^TMG(22706.9,3,2,IEN,0)@1 <-- note 'IEN' placeholder
|
---|
| 1306 |
|
---|
| 1307 | ;"Note: This function really needs to be fleshed out some more...
|
---|
| 1308 | ;"Note: this only will work for normal files, or subfiles ONE (1) level deep...
|
---|
| 1309 |
|
---|
| 1310 | new ref set ref=""
|
---|
| 1311 | new parentFile set parentFile=$$IsSubFile^TMGDBAPI(file)
|
---|
| 1312 | if parentFile=0 goto GRF1 ;"handle non-subfiles separately.
|
---|
| 1313 |
|
---|
| 1314 | set fieldInParent=$piece(parentFile,"^",2)
|
---|
| 1315 | set ref=$get(^DIC(+parentFile,0,"GL"))
|
---|
| 1316 | new IENinParent set IENinParent=$piece(IENS,",",2)
|
---|
| 1317 | set ref=ref_IENinParent_","
|
---|
| 1318 | new storeLoc set storeLoc=$piece($get(^DD(+parentFile,fieldInParent,0)),"^",4)
|
---|
| 1319 | ;"Note: works only with storeLoc in Node;Piece format... not all fields follow this...
|
---|
| 1320 | set ref=ref_+storeLoc_","
|
---|
| 1321 | new IENinSubRec set IENinSubRec=$piece(IENS,",",1)
|
---|
| 1322 | if IENinSubRec="" set IENinSubRec="IEN"
|
---|
| 1323 | set ref=ref_IENinSubRec_","
|
---|
| 1324 |
|
---|
| 1325 | if $get(field)="" goto GRF2 ;"done
|
---|
| 1326 | set storeLoc=$piece($get(^DD(file,field,0)),"^",4)
|
---|
| 1327 | set ref=ref_+storeLoc_")@"_$piece(storeLoc,";",2)
|
---|
| 1328 | goto GRF2
|
---|
| 1329 |
|
---|
| 1330 | GRF1
|
---|
| 1331 | set ref=$get(^DIC(file,0,"GL"))
|
---|
| 1332 | set ref=ref_+IENS_","
|
---|
| 1333 | if $get(field)="" goto GRF2 ;"done
|
---|
| 1334 | new storeLoc set storeLoc=$piece($get(^DD(file,field,0)),"^",4)
|
---|
| 1335 | set ref=ref_+storeLoc_")@"_$piece(storeLoc,";",2)
|
---|
| 1336 | ;"Note: works only with storeLoc in Node;Piece format... not all fields follow this...
|
---|
| 1337 | GRF2
|
---|
| 1338 | quit ref
|
---|
| 1339 |
|
---|
| 1340 | TrimFDA(FDA,Quiet)
|
---|
| 1341 | ;"Purpose: To take an FDA, and compare it to data already present in the
|
---|
| 1342 | ;" record specified by the FDA. If any values already in the record
|
---|
| 1343 | ;" match those in the FDA, then those entries will be removed from the
|
---|
| 1344 | ;" FDA array.
|
---|
| 1345 | ;"Input: FDA -- PASS BY REFERENCE. A standard Fileman FDA.
|
---|
| 1346 | ;" Quiet -- OPTIONAL. If 1, then error messages will be supressed
|
---|
| 1347 | ;" (These would be messages generated on READING existing
|
---|
| 1348 | ;" data, not writing new data.)
|
---|
| 1349 | ;" default value=1
|
---|
| 1350 | ;"Output: Values from FDA may be removed.
|
---|
| 1351 | ;"Results: final IENS (i.e. '+1,3,' --> '5,3,' if prev value found)
|
---|
| 1352 | ;"Note: match will be made base on INTERNAL, or EXTERNAL forms
|
---|
| 1353 | ;"Note: Fields should be specified by numbers, NOT NAMES.
|
---|
| 1354 |
|
---|
| 1355 | new tempIENS set tempIENS=""
|
---|
| 1356 | if $data(FDA)'>0 goto TFDDone
|
---|
| 1357 | new TMGDATA,TMGMSG
|
---|
| 1358 | new file,IENS
|
---|
| 1359 | set file=$order(FDA(""))
|
---|
| 1360 | set IENS=$order(FDA(file,""))
|
---|
| 1361 | set tempIENS=IENS
|
---|
| 1362 | set Quiet=$get(Quiet,1)
|
---|
| 1363 |
|
---|
| 1364 | new fieldsS set fieldsS=""
|
---|
| 1365 | new field set field=""
|
---|
| 1366 | for set field=$order(FDA(file,IENS,field)) quit:(field="") do
|
---|
| 1367 | . set fieldsS=fieldsS_field_";"
|
---|
| 1368 |
|
---|
| 1369 | new parentFile set parentFile=$$IsSubFile^TMGDBAPI(file)
|
---|
| 1370 | if parentFile=0 goto TFD0 ;"handle non-subfiles separately.
|
---|
| 1371 |
|
---|
| 1372 | ;"e.g. FDA(22706.9001,"+1,3",.01)=1
|
---|
| 1373 | ;" FDA(22706.9001,"+1,3",.02)=2
|
---|
| 1374 | ;"Note: The .01 field is used to find a matching subrecord, which is then
|
---|
| 1375 | ;" check for preexisting data. If multiple matches for .01 are found,
|
---|
| 1376 | ;" then the process is aborted, and the FDA will NOT BE TRIMMED.
|
---|
| 1377 |
|
---|
| 1378 | set $piece(tempIENS,",",1)="" ;"leave first piece blank in IENS
|
---|
| 1379 | new value set value=$get(FDA(file,IENS,.01))
|
---|
| 1380 |
|
---|
| 1381 | ;"new i for i=1:1:$length(fieldsS,",") do ;"append 'E' to each field number
|
---|
| 1382 | ;". new field set field=$piece(fieldsS,";",i)
|
---|
| 1383 | ;". set field=field_"E"
|
---|
| 1384 | ;". set $piece(fieldsS,";",i)=field
|
---|
| 1385 | ;"
|
---|
| 1386 | ;"new TMGFIND
|
---|
| 1387 | ;"
|
---|
| 1388 | ;"I can't get this part to work... so will work around
|
---|
| 1389 | ;"do FIND^DIC(file,tempIENS,fieldsS,"BMU",value,"*",,,,"TMGFIND","TMGMSG")
|
---|
| 1390 | ;"do ShowIfDIERR^TMGDEBUG(.TMGMSG)
|
---|
| 1391 | ;"if +$get(TMGFIND(0))'=1 goto TFDDone ;"abort
|
---|
| 1392 | ;"merge TMGDATA(file,IENS)=TMGDATA("ID",1)
|
---|
| 1393 | ;"goto TFD1
|
---|
| 1394 |
|
---|
| 1395 | new ref set ref=$$GetRef(file,tempIENS,.01) ;"returns ref with 'IEN' built in...
|
---|
| 1396 | new ref2 set ref2=$$CREF^DILF($piece(ref,"IEN",1))
|
---|
| 1397 | new ref3 set ref3=$piece(ref,"@",1)
|
---|
| 1398 | new p set p=$piece(ref,"@",2)
|
---|
| 1399 | new found set found=0
|
---|
| 1400 | new IEN set IEN=0
|
---|
| 1401 | for set IEN=$order(@ref2@(IEN)) quit:(+IEN'>0)!(found>0) do
|
---|
| 1402 | . new valueFound set valueFound=$piece($get(@ref3),"^",p)
|
---|
| 1403 | . if valueFound=value set found=IEN
|
---|
| 1404 | if found=0 set tempIENS=IENS goto TFDDone
|
---|
| 1405 | set tempIENS=found_tempIENS
|
---|
| 1406 | TFD0
|
---|
| 1407 | do GETS^DIQ(file,tempIENS,fieldsS,"EI","TMGDATA","TMGMSG")
|
---|
| 1408 | if 'Quiet do ShowIfDIERR^TMGDEBUG(.TMGMSG)
|
---|
| 1409 |
|
---|
| 1410 | TFD1
|
---|
| 1411 | for set field=$order(FDA(file,IENS,field)) quit:(field="") do
|
---|
| 1412 | . new found set found=0
|
---|
| 1413 | . new FDAvalue set FDAvalue=$get(FDA(file,IENS,field))
|
---|
| 1414 | . if $get(TMGDATA(file,tempIENS,field,"I"))=FDAvalue set found=1
|
---|
| 1415 | . if $get(TMGDATA(file,tempIENS,field,"E"))=FDAvalue set found=1
|
---|
| 1416 | . if (FDAvalue="@")&($data(TMGDATA(file,tempIENS,field))=0) set found=1
|
---|
| 1417 | . if found=1 kill FDA(file,IENS,field)
|
---|
| 1418 | goto TFDDone
|
---|
| 1419 | TFDDone
|
---|
| 1420 | quit tempIENS
|
---|
| 1421 |
|
---|
| 1422 |
|
---|
| 1423 |
|
---|
| 1424 | GetPtrsOUT(File,Info)
|
---|
| 1425 | ;"Purpose: to get a list of pointers out from the file.
|
---|
| 1426 | ;"Input: File -- File Name or Number of file to investigate
|
---|
| 1427 | ;" Info -- PASS BY REFERENCE. An OUT PARAMETER. Format:
|
---|
| 1428 | ;" Info(Field#)=PointedToFileNum
|
---|
| 1429 | ;" Info(Field#,"GL")=an open global ref to pointed-to file
|
---|
| 1430 | ;"results: none
|
---|
| 1431 |
|
---|
| 1432 | if $get(File)="" goto GPODone
|
---|
| 1433 | if +File'=File set File=$$GetFileNum(File)
|
---|
| 1434 | new field set field=0
|
---|
| 1435 | new done set done=0
|
---|
| 1436 | for set field=$order(^DD(File,field)) quit:(+field'>0)!(done=1) do
|
---|
| 1437 | . new array
|
---|
| 1438 | . do FIELD^DID(File,field,"N","POINTER","array")
|
---|
| 1439 | . if $get(array("POINTER"))="" quit
|
---|
| 1440 | . if array("POINTER")[";" quit
|
---|
| 1441 | . set Info(field,"GL")=array("POINTER")
|
---|
| 1442 | . new temp set temp=$piece($get(^DD(File,field,0)),"^",2)
|
---|
| 1443 | . set temp=+$piece(temp,"P",2)
|
---|
| 1444 | . set Info(field)=temp
|
---|
| 1445 | . if $data(array) write field," " zwr array
|
---|
| 1446 | GPODone
|
---|
| 1447 | quit
|
---|
| 1448 |
|
---|