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 |
|
---|