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