forked from patrickTingen/DataDigger
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDataDigger.i
475 lines (381 loc) · 17.5 KB
/
DataDigger.i
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
&ANALYZE-SUSPEND _VERSION-NUMBER AB_v10r12
&ANALYZE-RESUME
&ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _DEFINITIONS Include
/*------------------------------------------------------------------------
Name : DataDigger.i
Desc : Definitions / forward defs for DataDigger programs
----------------------------------------------------------------------*/
/* This .W file was created with the Progress AppBuilder. */
/*----------------------------------------------------------------------*/
/* *************************** Definitions ************************** */
&GLOBAL-DEFINE version {version.i}
&GLOBAL-DEFINE edition Pure Gold
&GLOBAL-DEFINE build {build.i}
&GLOBAL-DEFINE QUERYSEP CHR(1, SESSION:CPINTERNAL, "UTF-8")
&GLOBAL-DEFINE timerStart PUBLISH "DD:Timer" ("start", ENTRY(1,PROGRAM-NAME(1)," ")).
&GLOBAL-DEFINE timerStop FINALLY: PUBLISH "DD:Timer" ("stop" , ENTRY(1,PROGRAM-NAME(1)," ")). END FINALLY.
&GLOBAL-DEFINE timerStop2 PUBLISH "DD:Timer" ("stop" , ENTRY(1,PROGRAM-NAME(1)," ")).
/* Constant values for update channels */
&GLOBAL-DEFINE CHECK-MANUAL 0
&GLOBAL-DEFINE CHECK-STABLE 1
&GLOBAL-DEFINE CHECK-BETA 2
/* Constant for collecting statistics
* changed from https://goo.gl/24deK3 to is.gd because google has ended the service
* get analytics for the is.gd link by adding a - (minus) to it
*/
&GLOBAL-DEFINE PINGBACKURL https://is.gd/DataDigger
&GLOBAL-DEFINE PINGBACKSTATS https://is.gd/stats.php?url=DataDigger
/* https://is.gd/DataDigger- */
/* Table scan is not available for pre-v11 */
&IF PROVERSION >= '11' &THEN
&GLOBAL-DEFINE TABLE-SCAN TABLE-SCAN
&ENDIF
DEFINE VARIABLE gcThisProcedure AS CHARACTER NO-UNDO.
/* TT for field data to link DataDiggers to each other */
DEFINE TEMP-TABLE ttLinkInfo NO-UNDO RCODE-INFORMATION
FIELD cField AS CHARACTER
FIELD cValue AS CHARACTER
INDEX idxPrim IS PRIMARY cField
.
/* TT for the tables of a db */
DEFINE TEMP-TABLE ttTable NO-UNDO RCODE-INFORMATION
FIELD cDatabase AS CHARACTER LABEL "DB" FORMAT "X(12)"
FIELD cTableName AS CHARACTER LABEL "Table" FORMAT "X(32)"
FIELD cCrc AS CHARACTER LABEL "CRC"
FIELD cCacheId AS CHARACTER LABEL "CacheId"
FIELD lShowInList AS LOGICAL LABEL "" /* for getTablesWithField */
FIELD cTableDesc AS CHARACTER LABEL "Desc"
FIELD cFields AS CHARACTER LABEL "Fields"
FIELD lHidden AS LOGICAL LABEL ""
FIELD lFrozen AS LOGICAL LABEL ""
FIELD iNumQueries AS INTEGER LABEL "#" FORMAT "zzzzz"
FIELD tLastUsed AS DATETIME LABEL "Last Used" FORMAT "99/99/9999 HH:MM:SS"
FIELD lCached AS LOGICAL LABEL "" /* for preCaching */
FIELD iFileNumber AS INTEGER LABEL "_File-Number"
FIELD cCategory AS CHARACTER LABEL "Category"
FIELD lFavourite AS LOGICAL LABEL "" /* favourite table */
FIELD cFavourites AS CHARACTER LABEL "" /* favourite groups */
INDEX idxPrim IS PRIMARY cDatabase cTableName
INDEX idxSec cTableName
.
DEFINE TEMP-TABLE ttTableXml NO-UNDO XML-NODE-NAME "ttTable" LIKE ttTable RCODE-INFORMATION .
/* TT for the saved queries of a table */
DEFINE TEMP-TABLE ttQuery NO-UNDO RCODE-INFORMATION
FIELD cDatabase AS CHARACTER
FIELD cTable AS CHARACTER
FIELD iQueryNr AS INTEGER
FIELD cQueryTxt AS CHARACTER
INDEX idxQueryPrim IS PRIMARY iQueryNr
INDEX idxTable cDatabase cTable
.
/* TT for the fields of a table */
DEFINE TEMP-TABLE ttField NO-UNDO RCODE-INFORMATION
FIELD cTableCacheId AS CHARACTER /* unique name for db / table / table-crc */
FIELD cDatabase AS CHARACTER
FIELD cTableName AS CHARACTER
FIELD cFieldName AS CHARACTER LABEL "Name" FORMAT "X(40)"
FIELD cFullName AS CHARACTER LABEL "Name" FORMAT "X(40)" /* fieldname incl extent */
FIELD cXmlNodeName AS CHARACTER LABEL "Xml Name" FORMAT "X(40)" /* name for usage in XML */
FIELD iOrder AS DECIMAL LABEL "Order" FORMAT ">>>>>9" /* user defined order */
FIELD lShow AS LOGICAL LABEL "" /* toggle box */
FIELD cDataType AS CHARACTER LABEL "Type" FORMAT "X(16)"
FIELD cInitial AS CHARACTER LABEL "Initial" /* initial value from dict */
FIELD cFormat AS CHARACTER LABEL "Format" FORMAT "X(80)" /* user defined format */
FIELD cFormatOrg AS CHARACTER LABEL "Format" /* original format */
FIELD iWidth AS INTEGER LABEL "Width" /* SQL width */
FIELD cLabel AS CHARACTER LABEL "Label" FORMAT "X(50)"
FIELD iOrderOrg AS DECIMAL /* original order */
FIELD iExtent AS INTEGER LABEL "Extent" FORMAT ">>>>9"
FIELD lPrimary AS LOGICAL LABEL "Prim" /* part of prim index? */
FIELD lMandatory AS LOGICAL LABEL "Man" /* mandatory? */
FIELD lUniqueIdx AS LOGICAL LABEL "Uni" /* part of unique index? */
FIELD cColLabel AS CHARACTER LABEL "Column Label" FORMAT "x(24)"
FIELD iDecimals AS INTEGER LABEL "Decimals" FORMAT ">>9"
FIELD iFieldRpos AS INTEGER LABEL "R-pos" FORMAT ">>>>9"
FIELD cValExp AS CHARACTER LABEL "Val Expr" FORMAT "x(80)"
FIELD cValMsg AS CHARACTER LABEL "Val Message" FORMAT "x(80)"
FIELD cHelp AS CHARACTER LABEL "Help msg" FORMAT "x(80)"
FIELD cDesc AS CHARACTER LABEL "Description" FORMAT "x(80)"
FIELD cViewAs AS CHARACTER LABEL "View-As" FORMAT "x(40)"
/* These fields must be moved to ttColumn */
FIELD cFilterValue AS CHARACTER
FIELD cNewValue AS CHARACTER LABEL "New value" FORMAT "x(256)"
FIELD cOldValue AS CHARACTER LABEL "Old value" FORMAT "x(256)"
FIELD hColumn AS HANDLE
INDEX idxPrim IS PRIMARY cTableCacheId
INDEX idxName cFieldName
INDEX idxOrder iOrder /* for fields browse */
INDEX idxSec cTableCacheId cFieldName iOrder
.
/* TT for the fields of a table with extent fields extracted
*
* Relations: [ttTable] -< [ttField] -< [ttColumn]
* For non-extents the relation between ttField and ttColumn
* will be 1:1. For extent fields it will be 1:n
*/
DEFINE TEMP-TABLE ttColumn NO-UNDO RCODE-INFORMATION
FIELD cTableCacheId AS CHARACTER /* unique name for db / table / table-crc */
FIELD cDatabase AS CHARACTER
FIELD cTableName AS CHARACTER
FIELD cFieldName AS CHARACTER LABEL "Name" FORMAT "X(40)"
FIELD iExtent AS INTEGER LABEL "Extent" FORMAT ">>>>9"
FIELD cFullName AS CHARACTER LABEL "Name" FORMAT "X(40)" /* fieldname incl extent */
FIELD cFilterValue AS CHARACTER /* for setting shadow color */
FIELD cNewValue AS CHARACTER LABEL "New value" FORMAT "X(256)" /* for wEdit */
FIELD cOldValue AS CHARACTER LABEL "Old value" FORMAT "X(256)" /* for wEdit */
FIELD lShow AS LOGICAL /* for wEdit */
FIELD iOrder AS DECIMAL LABEL "Order" FORMAT ">>>>>9" /* user defined order */
FIELD cLabel AS CHARACTER LABEL "Label" FORMAT "X(50)"
FIELD iColumnNr AS INTEGER /* order in the databrowse */
FIELD hColumn AS HANDLE /* handle to the column in the databrowse */
FIELD hFilter AS HANDLE /* handle to the filter on top of the databrowse */
INDEX idxPrim IS PRIMARY cTableCacheId
INDEX idxField cFieldName
INDEX idxFull cFullName
INDEX idxColNr iColumnNr
INDEX idxSort cTableCacheId cFieldName iColumnNr
INDEX idxTable cDatabase cTablename
.
/* TTs Used for preCaching */
DEFINE TEMP-TABLE ttFieldCache NO-UNDO LIKE ttField RCODE-INFORMATION
INDEX idxTable IS PRIMARY cTableName
.
DEFINE TEMP-TABLE ttColumnCache NO-UNDO LIKE ttColumn RCODE-INFORMATION
.
DEFINE DATASET dsFields FOR ttField, ttColumn.
DEFINE DATASET dsFieldCache FOR ttFieldCache, ttColumnCache.
/* TT for the indexfields of a table */
DEFINE TEMP-TABLE ttIndex NO-UNDO RCODE-INFORMATION
FIELD cIndexName AS CHARACTER LABEL "Name" FORMAT "x(20)"
FIELD cIndexFlags AS CHARACTER LABEL "Flags" FORMAT "x(14)"
FIELD cIndexFields AS CHARACTER LABEL "Fields" FORMAT "x(160)"
FIELD cFieldList AS CHARACTER LABEL "Field List" FORMAT "x(80)"
FIELD lIndexActive AS LOGICAL
.
/* TT for counting windowLocks (WindowsUpdateLock) */
DEFINE TEMP-TABLE ttWindowLock NO-UNDO RCODE-INFORMATION
FIELD hWindow AS HANDLE
FIELD iLockCounter AS INTEGER
INDEX idxPrim IS PRIMARY hWindow
.
/* TT for filters on top of data browse */
DEFINE TEMP-TABLE ttFilter NO-UNDO RCODE-INFORMATION
FIELD cFieldName AS CHARACTER
FIELD hFilter AS HANDLE
FIELD hColumn AS HANDLE
FIELD hBrowse AS HANDLE
FIELD lVisible AS LOGICAL
FIELD lModified AS LOGICAL
INDEX idxBrowse hBrowse
INDEX idxField cFieldName
INDEX idxFilter hFilter
.
/* TT for filter on database tables */
DEFINE TEMP-TABLE ttTableFilter NO-UNDO RCODE-INFORMATION
FIELD lModified AS LOGICAL
FIELD cTableNameShow AS CHARACTER
FIELD cTableNameHide AS CHARACTER
FIELD cTableFieldShow AS CHARACTER
FIELD cTableFieldHide AS CHARACTER
FIELD lShowNormal AS LOGICAL INITIAL TRUE
FIELD lShowSchema AS LOGICAL
FIELD lShowVst AS LOGICAL
FIELD lShowSql AS LOGICAL
FIELD lShowOther AS LOGICAL
FIELD lShowHidden AS LOGICAL
FIELD lShowFrozen AS LOGICAL
.
/* TT For currently connected databases */
DEFINE TEMP-TABLE ttDatabase NO-UNDO RCODE-INFORMATION
FIELD cLogicalName AS CHARACTER COLUMN-LABEL "Logical Name" FORMAT "x(20)"
FIELD cSection AS CHARACTER COLUMN-LABEL "Section" FORMAT "x(20)"
FIELD cCacheStamp AS CHARACTER COLUMN-LABEL "CacheStamp" FORMAT "x(24)"
INDEX idxPrim IS PRIMARY UNIQUE cLogicalName
.
/* TT for favourites */
DEFINE TEMP-TABLE ttConnection NO-UNDO RCODE-INFORMATION
FIELD iConnectionNr AS INTEGER
FIELD cLogicalName AS CHARACTER COLUMN-LABEL "Logical Name" FORMAT "x(20)"
FIELD cDescription AS CHARACTER COLUMN-LABEL "Description" FORMAT "x(28)"
FIELD cDatabaseName AS CHARACTER COLUMN-LABEL "Database" FORMAT "x(20)"
FIELD cParameters AS CHARACTER
FIELD lConnected AS LOGICAL COLUMN-LABEL "Con"
FIELD cSection AS CHARACTER COLUMN-LABEL "Section" FORMAT "x(20)"
INDEX idxPrim IS PRIMARY UNIQUE iConnectionNr
.
/* TT for Query Tester */
DEFINE TEMP-TABLE ttTestQuery NO-UNDO RCODE-INFORMATION
FIELD iId AS INTEGER LABEL "Seq" COLUMN-LABEL "Seq" FORMAT ">,>>9"
FIELD cProgName AS CHARACTER
FIELD cQueryTxt AS CHARACTER
FIELD cIndexInfo AS CHARACTER
INDEX idxId IS PRIMARY UNIQUE iId DESCENDING
.
/* TT for ini-file settings */
DEFINE TEMP-TABLE ttConfig NO-UNDO RCODE-INFORMATION
FIELD cSection AS CHARACTER
FIELD cSetting AS CHARACTER
FIELD cValue AS CHARACTER
FIELD lUser AS LOGICAL
FIELD lDirty AS LOGICAL
INDEX idxPrim IS PRIMARY cSection cSetting
INDEX idxDirty lDirty
INDEX idxUser lUser
.
/* TT for sorting options in user query */
DEFINE TEMP-TABLE ttQuerySort NO-UNDO RCODE-INFORMATION
FIELD iGroup AS INTEGER /* 1:query, 2:browse */
FIELD iSortNr AS INTEGER
FIELD cSortField AS CHARACTER
FIELD lAscending AS LOGICAL
FIELD iExt AS INTEGER
INDEX iPrim IS PRIMARY iGroup iSortNr
.
/* TT for favourite groups */
DEFINE TEMP-TABLE ttFavGroup NO-UNDO RCODE-INFORMATION
FIELD cGroup AS CHARACTER
INDEX iPrim IS PRIMARY cGroup
.
/* _UIB-CODE-BLOCK-END */
&ANALYZE-RESUME
&ANALYZE-SUSPEND _UIB-PREPROCESSOR-BLOCK
/* ******************** Preprocessor Definitions ******************** */
/* _UIB-PREPROCESSOR-BLOCK-END */
&ANALYZE-RESUME
/* *********************** Procedure Settings ************************ */
&ANALYZE-SUSPEND _PROCEDURE-SETTINGS
/* Settings for THIS-PROCEDURE
Type: Include
Allow:
Frames: 0
Add Fields to: Neither
Other Settings: INCLUDE-ONLY
*/
&ANALYZE-RESUME _END-PROCEDURE-SETTINGS
/* ************************* Create Window ************************** */
&ANALYZE-SUSPEND _CREATE-WINDOW
/* DESIGN Window definition (used by the UIB)
CREATE WINDOW Include ASSIGN
HEIGHT = 6
WIDTH = 35.8.
/* END WINDOW DEFINITION */
*/
&ANALYZE-RESUME
&ANALYZE-SUSPEND _UIB-CODE-BLOCK _CUSTOM _MAIN-BLOCK Include
/* *************************** Main Block *************************** */
/* Global-defines for testing purposes */
&if defined(invar) = 0 &then
&if defined(UIB_is_Running) ne 0 &then
&global-define invar variable
&global-define iovar variable
&global-define outvar variable
&else
&global-define invar input parameter
&global-define iovar input-output parameter
&global-define outvar output parameter
&endif
&endif
/* Forward defs */
FUNCTION addConnection RETURNS LOGICAL
( pcDatabase AS CHARACTER
, pcSection AS CHARACTER ) IN SUPER.
FUNCTION formatQueryString RETURNS CHARACTER
( INPUT pcQueryString AS CHARACTER
, INPUT plExpanded AS LOGICAL ) IN SUPER.
FUNCTION getDatabaseList RETURNS CHARACTER IN SUPER.
FUNCTION getEscapedData RETURNS CHARACTER
( INPUT pcTarget AS CHARACTER
, INPUT pcString AS CHARACTER ) IN SUPER.
FUNCTION getColor RETURNS INTEGER
( INPUT pcName AS CHARACTER ) IN SUPER.
FUNCTION getColumnLabel RETURNS CHARACTER
( INPUT phFieldBuffer AS HANDLE ) IN SUPER.
FUNCTION getFont RETURNS INTEGER
( pcFontName AS CHARACTER ) IN SUPER.
FUNCTION getImagePath RETURNS CHARACTER
( pcImage AS CHARACTER ) IN SUPER.
FUNCTION getIndexFields RETURNS CHARACTER
( INPUT pcDatabaseName AS CHARACTER
, INPUT pcTableName AS CHARACTER
, INPUT pcFlags AS CHARACTER
) IN SUPER.
FUNCTION getKeyList RETURNS CHARACTER IN SUPER.
FUNCTION getLinkInfo RETURNS CHARACTER
( INPUT pcFieldName AS CHARACTER
) IN SUPER.
FUNCTION getMaxLength RETURNS INTEGER
( pcSection AS CHARACTER
) IN SUPER.
FUNCTION getOsErrorDesc RETURNS CHARACTER
( INPUT piOsError AS INTEGER
) IN SUPER.
FUNCTION getProgramDir RETURNS CHARACTER IN SUPER.
FUNCTION getQuery RETURNS CHARACTER
( INPUT pcDatabase AS CHARACTER
, INPUT pcTable AS CHARACTER
, INPUT piQuery AS INTEGER
) IN SUPER.
FUNCTION getReadableQuery RETURNS CHARACTER
( INPUT pcQuery AS CHARACTER
) IN SUPER.
FUNCTION getRegistry RETURNS CHARACTER
( pcSection AS CHARACTER
, pcKey AS CHARACTER
) IN SUPER.
FUNCTION getStackSize RETURNS INTEGER
() IN SUPER.
FUNCTION getTableList RETURNS CHARACTER
( INPUT pcDatabaseFilter AS CHARACTER
, INPUT pcTableFilter AS CHARACTER
) IN SUPER.
FUNCTION getUsername RETURNS CHARACTER IN SUPER.
FUNCTION getWidgetUnderMouse RETURNS HANDLE
( INPUT phWidget AS HANDLE ) IN SUPER.
FUNCTION getWorkFolder RETURNS CHARACTER IN SUPER.
FUNCTION isDefaultFontsChanged RETURNS LOGICAL IN SUPER.
FUNCTION isFileLocked RETURNS LOGICAL
( pcFileName AS CHARACTER ) IN SUPER.
FUNCTION isBrowseChanged RETURNS LOGICAL
( INPUT phWidget AS HANDLE ) IN SUPER.
FUNCTION isMouseOver RETURNS LOGICAL
( INPUT phWidget AS HANDLE ) IN SUPER.
FUNCTION isTableFilterUsed RETURNS LOGICAL
( INPUT TABLE ttTableFilter ) IN SUPER.
FUNCTION isWidgetChanged RETURNS LOGICAL
( INPUT phWidget AS HANDLE ) IN SUPER.
FUNCTION readFile RETURNS LONGCHAR
( INPUT pcFilename AS CHARACTER) IN SUPER.
FUNCTION removeConnection RETURNS LOGICAL
( pcDatabase AS CHARACTER ) IN SUPER.
FUNCTION resolveOsVars RETURNS CHARACTER
( pcString AS CHARACTER ) IN SUPER.
FUNCTION setLinkInfo RETURNS LOGICAL
( INPUT pcFieldName AS CHARACTER
, INPUT pcValue AS CHARACTER
) IN SUPER.
FUNCTION setRegistry RETURNS CHARACTER
( pcSection AS CHARACTER
, pcKey AS CHARACTER
, pcValue AS CHARACTER
) IN SUPER.
FUNCTION isValidCodePage RETURNS LOGICAL
(pcCodepage AS CHARACTER) IN SUPER.
/* Initialize */
gcThisProcedure = THIS-PROCEDURE:FILE-NAME.
gcThisProcedure = ENTRY(NUM-ENTRIES(gcThisProcedure,"\"),gcThisProcedure,"\").
gcThisProcedure = ENTRY(1,gcThisProcedure,".").
SUBSCRIBE TO gcThisProcedure ANYWHERE RUN-PROCEDURE "getProcHandle".
/* _UIB-CODE-BLOCK-END */
&ANALYZE-RESUME
/* ********************** Internal Procedures *********************** */
&ANALYZE-SUSPEND _UIB-CODE-BLOCK _PROCEDURE getProcHandle Include
PROCEDURE getProcHandle :
/*
* Name : getProcHandle
* Desc : Return the handle of the procedure this include is in
*/
DEFINE OUTPUT PARAMETER phHandle AS HANDLE NO-UNDO.
phHandle = THIS-PROCEDURE:HANDLE.
END PROCEDURE. /* getProcHandle */
/* _UIB-CODE-BLOCK-END */
&ANALYZE-RESUME