Changeset 11679 for trunk/ippdb/src/ippdb.c
- Timestamp:
- Feb 6, 2007, 3:46:45 PM (19 years ago)
- File:
-
- 1 edited
-
trunk/ippdb/src/ippdb.c (modified) (185 diffs)
Legend:
- Unmodified
- Added
- Removed
-
trunk/ippdb/src/ippdb.c
r11635 r11679 20 20 /* 21 21 * 22 * This file was generated by glueforge 1.0022 * This file was generated by glueforge 0.36 23 23 * 24 24 * Do NOT directly edit this file. … … 62 62 #define DETRESIDEXP_TABLE_NAME "detResidExp" 63 63 #define DETRUNSUMMARY_TABLE_NAME "detRunSummary" 64 #define P4RUN_TABLE_NAME "p4Run" 65 #define P4INPUTIMFILE_TABLE_NAME "p4InputImfile" 66 #define P4WARPEDIMFILE_TABLE_NAME "p4WarpedImfile" 67 #define P4STACKEDIMFILE_TABLE_NAME "p4StackedImfile" 68 #define P4DIFFIMFILE_TABLE_NAME "p4DiffImfile" 64 #define P4ARUN_TABLE_NAME "p4aRun" 65 #define P4AINPUTEXP_TABLE_NAME "p4aInputExp" 66 #define P4ASCFILE_TABLE_NAME "p4aScfile" 67 #define P4BRUN_TABLE_NAME "p4bRun" 68 #define P4BINPUTSCFILE_TABLE_NAME "p4bInputScfile" 69 #define P4BDIFFSCFILE_TABLE_NAME "p4bDiffScfile" 70 #define P4CRUN_TABLE_NAME "p4cRun" 71 #define P4CINPUTEXP_TABLE_NAME "p4cInputExp" 69 72 #define P4MAGICMASKIMFILE_TABLE_NAME "p4MagicMaskImfile" 73 #define SKYCELL_TABLE_NAME "skyCell" 74 #define SKYCELLMAP_TABLE_NAME "skyCellMap" 70 75 #define MAX_STRING_LENGTH 1024 71 76 … … 438 443 psMetadata *where = expTagCounterMetadataFromObject(object); 439 444 long long count = psDBDeleteRows(dbh, EXPTAGCOUNTER_TABLE_NAME, where, 0); 440 psFree(where) 445 psFree(where); 441 446 if (count < 0) { 442 447 psError(PS_ERR_UNKNOWN, true, "failed to delete row from expTagCounter"); … … 460 465 psMetadata *where = expTagCounterMetadataFromObject(object); 461 466 long long count = psDBDeleteRows(dbh, EXPTAGCOUNTER_TABLE_NAME, where, limit); 462 psFree(where) 467 psFree(where); 463 468 if (count < 0) { 464 469 psError(PS_ERR_UNKNOWN, true, "failed to delete row from expTagCounter"); … … 843 848 psMetadata *where = summitExpMetadataFromObject(object); 844 849 long long count = psDBDeleteRows(dbh, SUMMITEXP_TABLE_NAME, where, 0); 845 psFree(where) 850 psFree(where); 846 851 if (count < 0) { 847 852 psError(PS_ERR_UNKNOWN, true, "failed to delete row from summitExp"); … … 865 870 psMetadata *where = summitExpMetadataFromObject(object); 866 871 long long count = psDBDeleteRows(dbh, SUMMITEXP_TABLE_NAME, where, limit); 867 psFree(where) 872 psFree(where); 868 873 if (count < 0) { 869 874 psError(PS_ERR_UNKNOWN, true, "failed to delete row from summitExp"); … … 1292 1297 psMetadata *where = summitImfileMetadataFromObject(object); 1293 1298 long long count = psDBDeleteRows(dbh, SUMMITIMFILE_TABLE_NAME, where, 0); 1294 psFree(where) 1299 psFree(where); 1295 1300 if (count < 0) { 1296 1301 psError(PS_ERR_UNKNOWN, true, "failed to delete row from summitImfile"); … … 1314 1319 psMetadata *where = summitImfileMetadataFromObject(object); 1315 1320 long long count = psDBDeleteRows(dbh, SUMMITIMFILE_TABLE_NAME, where, limit); 1316 psFree(where) 1321 psFree(where); 1317 1322 if (count < 0) { 1318 1323 psError(PS_ERR_UNKNOWN, true, "failed to delete row from summitImfile"); … … 1610 1615 psMetadata *where = pzPendingExpMetadataFromObject(object); 1611 1616 long long count = psDBDeleteRows(dbh, PZPENDINGEXP_TABLE_NAME, where, 0); 1612 psFree(where) 1617 psFree(where); 1613 1618 if (count < 0) { 1614 1619 psError(PS_ERR_UNKNOWN, true, "failed to delete row from pzPendingExp"); … … 1632 1637 psMetadata *where = pzPendingExpMetadataFromObject(object); 1633 1638 long long count = psDBDeleteRows(dbh, PZPENDINGEXP_TABLE_NAME, where, limit); 1634 psFree(where) 1639 psFree(where); 1635 1640 if (count < 0) { 1636 1641 psError(PS_ERR_UNKNOWN, true, "failed to delete row from pzPendingExp"); … … 1994 1999 psMetadata *where = pzPendingImfileMetadataFromObject(object); 1995 2000 long long count = psDBDeleteRows(dbh, PZPENDINGIMFILE_TABLE_NAME, where, 0); 1996 psFree(where) 2001 psFree(where); 1997 2002 if (count < 0) { 1998 2003 psError(PS_ERR_UNKNOWN, true, "failed to delete row from pzPendingImfile"); … … 2016 2021 psMetadata *where = pzPendingImfileMetadataFromObject(object); 2017 2022 long long count = psDBDeleteRows(dbh, PZPENDINGIMFILE_TABLE_NAME, where, limit); 2018 psFree(where) 2023 psFree(where); 2019 2024 if (count < 0) { 2020 2025 psError(PS_ERR_UNKNOWN, true, "failed to delete row from pzPendingImfile"); … … 2312 2317 psMetadata *where = pzDoneExpMetadataFromObject(object); 2313 2318 long long count = psDBDeleteRows(dbh, PZDONEEXP_TABLE_NAME, where, 0); 2314 psFree(where) 2319 psFree(where); 2315 2320 if (count < 0) { 2316 2321 psError(PS_ERR_UNKNOWN, true, "failed to delete row from pzDoneExp"); … … 2334 2339 psMetadata *where = pzDoneExpMetadataFromObject(object); 2335 2340 long long count = psDBDeleteRows(dbh, PZDONEEXP_TABLE_NAME, where, limit); 2336 psFree(where) 2341 psFree(where); 2337 2342 if (count < 0) { 2338 2343 psError(PS_ERR_UNKNOWN, true, "failed to delete row from pzDoneExp"); … … 2718 2723 psMetadata *where = pzDoneImfileMetadataFromObject(object); 2719 2724 long long count = psDBDeleteRows(dbh, PZDONEIMFILE_TABLE_NAME, where, 0); 2720 psFree(where) 2725 psFree(where); 2721 2726 if (count < 0) { 2722 2727 psError(PS_ERR_UNKNOWN, true, "failed to delete row from pzDoneImfile"); … … 2740 2745 psMetadata *where = pzDoneImfileMetadataFromObject(object); 2741 2746 long long count = psDBDeleteRows(dbh, PZDONEIMFILE_TABLE_NAME, where, limit); 2742 psFree(where) 2747 psFree(where); 2743 2748 if (count < 0) { 2744 2749 psError(PS_ERR_UNKNOWN, true, "failed to delete row from pzDoneImfile"); … … 3101 3106 psMetadata *where = newExpMetadataFromObject(object); 3102 3107 long long count = psDBDeleteRows(dbh, NEWEXP_TABLE_NAME, where, 0); 3103 psFree(where) 3108 psFree(where); 3104 3109 if (count < 0) { 3105 3110 psError(PS_ERR_UNKNOWN, true, "failed to delete row from newExp"); … … 3123 3128 psMetadata *where = newExpMetadataFromObject(object); 3124 3129 long long count = psDBDeleteRows(dbh, NEWEXP_TABLE_NAME, where, limit); 3125 psFree(where) 3130 psFree(where); 3126 3131 if (count < 0) { 3127 3132 psError(PS_ERR_UNKNOWN, true, "failed to delete row from newExp"); … … 3441 3446 psMetadata *where = newImfileMetadataFromObject(object); 3442 3447 long long count = psDBDeleteRows(dbh, NEWIMFILE_TABLE_NAME, where, 0); 3443 psFree(where) 3448 psFree(where); 3444 3449 if (count < 0) { 3445 3450 psError(PS_ERR_UNKNOWN, true, "failed to delete row from newImfile"); … … 3463 3468 psMetadata *where = newImfileMetadataFromObject(object); 3464 3469 long long count = psDBDeleteRows(dbh, NEWIMFILE_TABLE_NAME, where, limit); 3465 psFree(where) 3470 psFree(where); 3466 3471 if (count < 0) { 3467 3472 psError(PS_ERR_UNKNOWN, true, "failed to delete row from newImfile"); … … 4164 4169 psMetadata *where = rawExpMetadataFromObject(object); 4165 4170 long long count = psDBDeleteRows(dbh, RAWEXP_TABLE_NAME, where, 0); 4166 psFree(where) 4171 psFree(where); 4167 4172 if (count < 0) { 4168 4173 psError(PS_ERR_UNKNOWN, true, "failed to delete row from rawExp"); … … 4186 4191 psMetadata *where = rawExpMetadataFromObject(object); 4187 4192 long long count = psDBDeleteRows(dbh, RAWEXP_TABLE_NAME, where, limit); 4188 psFree(where) 4193 psFree(where); 4189 4194 if (count < 0) { 4190 4195 psError(PS_ERR_UNKNOWN, true, "failed to delete row from rawExp"); … … 4844 4849 psMetadata *where = rawImfileMetadataFromObject(object); 4845 4850 long long count = psDBDeleteRows(dbh, RAWIMFILE_TABLE_NAME, where, 0); 4846 psFree(where) 4851 psFree(where); 4847 4852 if (count < 0) { 4848 4853 psError(PS_ERR_UNKNOWN, true, "failed to delete row from rawImfile"); … … 4866 4871 psMetadata *where = rawImfileMetadataFromObject(object); 4867 4872 long long count = psDBDeleteRows(dbh, RAWIMFILE_TABLE_NAME, where, limit); 4868 psFree(where) 4873 psFree(where); 4869 4874 if (count < 0) { 4870 4875 psError(PS_ERR_UNKNOWN, true, "failed to delete row from rawImfile"); … … 5161 5166 psMetadata *where = p1PendingExpMetadataFromObject(object); 5162 5167 long long count = psDBDeleteRows(dbh, P1PENDINGEXP_TABLE_NAME, where, 0); 5163 psFree(where) 5168 psFree(where); 5164 5169 if (count < 0) { 5165 5170 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p1PendingExp"); … … 5183 5188 psMetadata *where = p1PendingExpMetadataFromObject(object); 5184 5189 long long count = psDBDeleteRows(dbh, P1PENDINGEXP_TABLE_NAME, where, limit); 5185 psFree(where) 5190 psFree(where); 5186 5191 if (count < 0) { 5187 5192 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p1PendingExp"); … … 5521 5526 psMetadata *where = p2PendingExpMetadataFromObject(object); 5522 5527 long long count = psDBDeleteRows(dbh, P2PENDINGEXP_TABLE_NAME, where, 0); 5523 psFree(where) 5528 psFree(where); 5524 5529 if (count < 0) { 5525 5530 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p2PendingExp"); … … 5543 5548 psMetadata *where = p2PendingExpMetadataFromObject(object); 5544 5549 long long count = psDBDeleteRows(dbh, P2PENDINGEXP_TABLE_NAME, where, limit); 5545 psFree(where) 5550 psFree(where); 5546 5551 if (count < 0) { 5547 5552 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p2PendingExp"); … … 5903 5908 psMetadata *where = p2PendingImfileMetadataFromObject(object); 5904 5909 long long count = psDBDeleteRows(dbh, P2PENDINGIMFILE_TABLE_NAME, where, 0); 5905 psFree(where) 5910 psFree(where); 5906 5911 if (count < 0) { 5907 5912 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p2PendingImfile"); … … 5925 5930 psMetadata *where = p2PendingImfileMetadataFromObject(object); 5926 5931 long long count = psDBDeleteRows(dbh, P2PENDINGIMFILE_TABLE_NAME, where, limit); 5927 psFree(where) 5932 psFree(where); 5928 5933 if (count < 0) { 5929 5934 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p2PendingImfile"); … … 6241 6246 psMetadata *where = p2ProcessedExpMetadataFromObject(object); 6242 6247 long long count = psDBDeleteRows(dbh, P2PROCESSEDEXP_TABLE_NAME, where, 0); 6243 psFree(where) 6248 psFree(where); 6244 6249 if (count < 0) { 6245 6250 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p2ProcessedExp"); … … 6263 6268 psMetadata *where = p2ProcessedExpMetadataFromObject(object); 6264 6269 long long count = psDBDeleteRows(dbh, P2PROCESSEDEXP_TABLE_NAME, where, limit); 6265 psFree(where) 6270 psFree(where); 6266 6271 if (count < 0) { 6267 6272 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p2ProcessedExp"); … … 6515 6520 psMetadata *where = p2MaskMetadataFromObject(object); 6516 6521 long long count = psDBDeleteRows(dbh, P2MASK_TABLE_NAME, where, 0); 6517 psFree(where) 6522 psFree(where); 6518 6523 if (count < 0) { 6519 6524 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p2Mask"); … … 6537 6542 psMetadata *where = p2MaskMetadataFromObject(object); 6538 6543 long long count = psDBDeleteRows(dbh, P2MASK_TABLE_NAME, where, limit); 6539 psFree(where) 6544 psFree(where); 6540 6545 if (count < 0) { 6541 6546 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p2Mask"); … … 7025 7030 psMetadata *where = p2ProcessedImfileMetadataFromObject(object); 7026 7031 long long count = psDBDeleteRows(dbh, P2PROCESSEDIMFILE_TABLE_NAME, where, 0); 7027 psFree(where) 7032 psFree(where); 7028 7033 if (count < 0) { 7029 7034 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p2ProcessedImfile"); … … 7047 7052 psMetadata *where = p2ProcessedImfileMetadataFromObject(object); 7048 7053 long long count = psDBDeleteRows(dbh, P2PROCESSEDIMFILE_TABLE_NAME, where, limit); 7049 psFree(where) 7054 psFree(where); 7050 7055 if (count < 0) { 7051 7056 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p2ProcessedImfile"); … … 7363 7368 psMetadata *where = p3PendingExpMetadataFromObject(object); 7364 7369 long long count = psDBDeleteRows(dbh, P3PENDINGEXP_TABLE_NAME, where, 0); 7365 psFree(where) 7370 psFree(where); 7366 7371 if (count < 0) { 7367 7372 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p3PendingExp"); … … 7385 7390 psMetadata *where = p3PendingExpMetadataFromObject(object); 7386 7391 long long count = psDBDeleteRows(dbh, P3PENDINGEXP_TABLE_NAME, where, limit); 7387 psFree(where) 7392 psFree(where); 7388 7393 if (count < 0) { 7389 7394 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p3PendingExp"); … … 7978 7983 psMetadata *where = p3ProcessedExpMetadataFromObject(object); 7979 7984 long long count = psDBDeleteRows(dbh, P3PROCESSEDEXP_TABLE_NAME, where, 0); 7980 psFree(where) 7985 psFree(where); 7981 7986 if (count < 0) { 7982 7987 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p3ProcessedExp"); … … 8000 8005 psMetadata *where = p3ProcessedExpMetadataFromObject(object); 8001 8006 long long count = psDBDeleteRows(dbh, P3PROCESSEDEXP_TABLE_NAME, where, limit); 8002 psFree(where) 8007 psFree(where); 8003 8008 if (count < 0) { 8004 8009 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p3ProcessedExp"); … … 8252 8257 psMetadata *where = p3MaskMetadataFromObject(object); 8253 8258 long long count = psDBDeleteRows(dbh, P3MASK_TABLE_NAME, where, 0); 8254 psFree(where) 8259 psFree(where); 8255 8260 if (count < 0) { 8256 8261 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p3Mask"); … … 8274 8279 psMetadata *where = p3MaskMetadataFromObject(object); 8275 8280 long long count = psDBDeleteRows(dbh, P3MASK_TABLE_NAME, where, limit); 8276 psFree(where) 8281 psFree(where); 8277 8282 if (count < 0) { 8278 8283 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p3Mask"); … … 9000 9005 psMetadata *where = detRunMetadataFromObject(object); 9001 9006 long long count = psDBDeleteRows(dbh, DETRUN_TABLE_NAME, where, 0); 9002 psFree(where) 9007 psFree(where); 9003 9008 if (count < 0) { 9004 9009 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detRun"); … … 9022 9027 psMetadata *where = detRunMetadataFromObject(object); 9023 9028 long long count = psDBDeleteRows(dbh, DETRUN_TABLE_NAME, where, limit); 9024 psFree(where) 9029 psFree(where); 9025 9030 if (count < 0) { 9026 9031 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detRun"); … … 9337 9342 psMetadata *where = detInputExpMetadataFromObject(object); 9338 9343 long long count = psDBDeleteRows(dbh, DETINPUTEXP_TABLE_NAME, where, 0); 9339 psFree(where) 9344 psFree(where); 9340 9345 if (count < 0) { 9341 9346 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detInputExp"); … … 9359 9364 psMetadata *where = detInputExpMetadataFromObject(object); 9360 9365 long long count = psDBDeleteRows(dbh, DETINPUTEXP_TABLE_NAME, where, limit); 9361 psFree(where) 9366 psFree(where); 9362 9367 if (count < 0) { 9363 9368 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detInputExp"); … … 9826 9831 psMetadata *where = detProcessedImfileMetadataFromObject(object); 9827 9832 long long count = psDBDeleteRows(dbh, DETPROCESSEDIMFILE_TABLE_NAME, where, 0); 9828 psFree(where) 9833 psFree(where); 9829 9834 if (count < 0) { 9830 9835 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detProcessedImfile"); … … 9848 9853 psMetadata *where = detProcessedImfileMetadataFromObject(object); 9849 9854 long long count = psDBDeleteRows(dbh, DETPROCESSEDIMFILE_TABLE_NAME, where, limit); 9850 psFree(where) 9855 psFree(where); 9851 9856 if (count < 0) { 9852 9857 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detProcessedImfile"); … … 10271 10276 psMetadata *where = detProcessedExpMetadataFromObject(object); 10272 10277 long long count = psDBDeleteRows(dbh, DETPROCESSEDEXP_TABLE_NAME, where, 0); 10273 psFree(where) 10278 psFree(where); 10274 10279 if (count < 0) { 10275 10280 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detProcessedExp"); … … 10293 10298 psMetadata *where = detProcessedExpMetadataFromObject(object); 10294 10299 long long count = psDBDeleteRows(dbh, DETPROCESSEDEXP_TABLE_NAME, where, limit); 10295 psFree(where) 10300 psFree(where); 10296 10301 if (count < 0) { 10297 10302 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detProcessedExp"); … … 10715 10720 psMetadata *where = detStackedImfileMetadataFromObject(object); 10716 10721 long long count = psDBDeleteRows(dbh, DETSTACKEDIMFILE_TABLE_NAME, where, 0); 10717 psFree(where) 10722 psFree(where); 10718 10723 if (count < 0) { 10719 10724 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detStackedImfile"); … … 10737 10742 psMetadata *where = detStackedImfileMetadataFromObject(object); 10738 10743 long long count = psDBDeleteRows(dbh, DETSTACKEDIMFILE_TABLE_NAME, where, limit); 10739 psFree(where) 10744 psFree(where); 10740 10745 if (count < 0) { 10741 10746 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detStackedImfile"); … … 11073 11078 psMetadata *where = detNormalizedStatImfileMetadataFromObject(object); 11074 11079 long long count = psDBDeleteRows(dbh, DETNORMALIZEDSTATIMFILE_TABLE_NAME, where, 0); 11075 psFree(where) 11080 psFree(where); 11076 11081 if (count < 0) { 11077 11082 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detNormalizedStatImfile"); … … 11095 11100 psMetadata *where = detNormalizedStatImfileMetadataFromObject(object); 11096 11101 long long count = psDBDeleteRows(dbh, DETNORMALIZEDSTATIMFILE_TABLE_NAME, where, limit); 11097 psFree(where) 11102 psFree(where); 11098 11103 if (count < 0) { 11099 11104 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detNormalizedStatImfile"); … … 11539 11544 psMetadata *where = detNormalizedImfileMetadataFromObject(object); 11540 11545 long long count = psDBDeleteRows(dbh, DETNORMALIZEDIMFILE_TABLE_NAME, where, 0); 11541 psFree(where) 11546 psFree(where); 11542 11547 if (count < 0) { 11543 11548 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detNormalizedImfile"); … … 11561 11566 psMetadata *where = detNormalizedImfileMetadataFromObject(object); 11562 11567 long long count = psDBDeleteRows(dbh, DETNORMALIZEDIMFILE_TABLE_NAME, where, limit); 11563 psFree(where) 11568 psFree(where); 11564 11569 if (count < 0) { 11565 11570 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detNormalizedImfile"); … … 11983 11988 psMetadata *where = detNormalizedExpMetadataFromObject(object); 11984 11989 long long count = psDBDeleteRows(dbh, DETNORMALIZEDEXP_TABLE_NAME, where, 0); 11985 psFree(where) 11990 psFree(where); 11986 11991 if (count < 0) { 11987 11992 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detNormalizedExp"); … … 12005 12010 psMetadata *where = detNormalizedExpMetadataFromObject(object); 12006 12011 long long count = psDBDeleteRows(dbh, DETNORMALIZEDEXP_TABLE_NAME, where, limit); 12007 psFree(where) 12012 psFree(where); 12008 12013 if (count < 0) { 12009 12014 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detNormalizedExp"); … … 12493 12498 psMetadata *where = detResidImfileMetadataFromObject(object); 12494 12499 long long count = psDBDeleteRows(dbh, DETRESIDIMFILE_TABLE_NAME, where, 0); 12495 psFree(where) 12500 psFree(where); 12496 12501 if (count < 0) { 12497 12502 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detResidImfile"); … … 12515 12520 psMetadata *where = detResidImfileMetadataFromObject(object); 12516 12521 long long count = psDBDeleteRows(dbh, DETRESIDIMFILE_TABLE_NAME, where, limit); 12517 psFree(where) 12522 psFree(where); 12518 12523 if (count < 0) { 12519 12524 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detResidImfile"); … … 12980 12985 psMetadata *where = detResidExpMetadataFromObject(object); 12981 12986 long long count = psDBDeleteRows(dbh, DETRESIDEXP_TABLE_NAME, where, 0); 12982 psFree(where) 12987 psFree(where); 12983 12988 if (count < 0) { 12984 12989 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detResidExp"); … … 13002 13007 psMetadata *where = detResidExpMetadataFromObject(object); 13003 13008 long long count = psDBDeleteRows(dbh, DETRESIDEXP_TABLE_NAME, where, limit); 13004 psFree(where) 13009 psFree(where); 13005 13010 if (count < 0) { 13006 13011 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detResidExp"); … … 13379 13384 psMetadata *where = detRunSummaryMetadataFromObject(object); 13380 13385 long long count = psDBDeleteRows(dbh, DETRUNSUMMARY_TABLE_NAME, where, 0); 13381 psFree(where) 13386 psFree(where); 13382 13387 if (count < 0) { 13383 13388 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detRunSummary"); … … 13401 13406 psMetadata *where = detRunSummaryMetadataFromObject(object); 13402 13407 long long count = psDBDeleteRows(dbh, DETRUNSUMMARY_TABLE_NAME, where, limit); 13403 psFree(where) 13408 psFree(where); 13404 13409 if (count < 0) { 13405 13410 psError(PS_ERR_UNKNOWN, true, "failed to delete row from detRunSummary"); … … 13458 13463 return true; 13459 13464 } 13460 static void p4RunRowFree(p4RunRow *object); 13461 13462 p4RunRow *p4RunRowAlloc(psS32 p4_id, const char *survey_mode, const char *state, const char *workdir, const char *filter, const char *skycell_id, const char *tess_id, psF64 ra, psF64 decl, const char *input_ss, const char *output_ss) 13463 { 13464 p4RunRow *_object; 13465 13466 _object = psAlloc(sizeof(p4RunRow)); 13467 psMemSetDeallocator(_object, (psFreeFunc)p4RunRowFree); 13468 13469 _object->p4_id = p4_id; 13470 _object->survey_mode = psStringCopy(survey_mode); 13465 static void p4aRunRowFree(p4aRunRow *object); 13466 13467 p4aRunRow *p4aRunRowAlloc(psS32 p4a_id, const char *state, const char *workdir, bool magic) 13468 { 13469 p4aRunRow *_object; 13470 13471 _object = psAlloc(sizeof(p4aRunRow)); 13472 psMemSetDeallocator(_object, (psFreeFunc)p4aRunRowFree); 13473 13474 _object->p4a_id = p4a_id; 13471 13475 _object->state = psStringCopy(state); 13472 13476 _object->workdir = psStringCopy(workdir); 13473 _object->filter = psStringCopy(filter); 13474 _object->skycell_id = psStringCopy(skycell_id); 13475 _object->tess_id = psStringCopy(tess_id); 13476 _object->ra = ra; 13477 _object->decl = decl; 13478 _object->input_ss = psStringCopy(input_ss); 13479 _object->output_ss = psStringCopy(output_ss); 13477 _object->magic = magic; 13480 13478 13481 13479 return _object; 13482 13480 } 13483 13481 13484 static void p4RunRowFree(p4RunRow *object) 13485 { 13486 psFree(object->survey_mode); 13482 static void p4aRunRowFree(p4aRunRow *object) 13483 { 13487 13484 psFree(object->state); 13488 13485 psFree(object->workdir); 13489 psFree(object->filter); 13490 psFree(object->skycell_id); 13491 psFree(object->tess_id); 13492 psFree(object->input_ss); 13493 psFree(object->output_ss); 13494 } 13495 13496 bool p4RunCreateTable(psDB *dbh) 13486 } 13487 13488 bool p4aRunCreateTable(psDB *dbh) 13497 13489 { 13498 13490 psMetadata *md = psMetadataAlloc(); 13499 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4_id", PS_DATA_S32, "Primary Key AUTO_INCREMENT", 0)) { 13500 psError(PS_ERR_UNKNOWN, false, "failed to add item p4_id"); 13501 psFree(md); 13502 return false; 13503 } 13504 if (!psMetadataAdd(md, PS_LIST_TAIL, "survey_mode", PS_DATA_STRING, "Key", "64")) { 13505 psError(PS_ERR_UNKNOWN, false, "failed to add item survey_mode"); 13491 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4a_id", PS_DATA_S32, "Primary Key AUTO_INCREMENT", 0)) { 13492 psError(PS_ERR_UNKNOWN, false, "failed to add item p4a_id"); 13506 13493 psFree(md); 13507 13494 return false; … … 13517 13504 return false; 13518 13505 } 13519 if (!psMetadataAdd(md, PS_LIST_TAIL, "filter", PS_DATA_STRING, NULL, "64")) { 13520 psError(PS_ERR_UNKNOWN, false, "failed to add item filter"); 13521 psFree(md); 13522 return false; 13523 } 13524 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, NULL, "64")) { 13525 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 13526 psFree(md); 13527 return false; 13528 } 13529 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, NULL, "64")) { 13530 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 13531 psFree(md); 13532 return false; 13533 } 13534 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra", PS_DATA_F64, NULL, 0.0)) { 13535 psError(PS_ERR_UNKNOWN, false, "failed to add item ra"); 13536 psFree(md); 13537 return false; 13538 } 13539 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl", PS_DATA_F64, NULL, 0.0)) { 13540 psError(PS_ERR_UNKNOWN, false, "failed to add item decl"); 13541 psFree(md); 13542 return false; 13543 } 13544 if (!psMetadataAdd(md, PS_LIST_TAIL, "input_ss", PS_DATA_STRING, NULL, "64")) { 13545 psError(PS_ERR_UNKNOWN, false, "failed to add item input_ss"); 13546 psFree(md); 13547 return false; 13548 } 13549 if (!psMetadataAdd(md, PS_LIST_TAIL, "output_ss", PS_DATA_STRING, NULL, "64")) { 13550 psError(PS_ERR_UNKNOWN, false, "failed to add item output_ss"); 13551 psFree(md); 13552 return false; 13553 } 13554 13555 bool status = psDBCreateTable(dbh, P4RUN_TABLE_NAME, md); 13506 if (!psMetadataAdd(md, PS_LIST_TAIL, "magic", PS_DATA_BOOL, "Primary Key", 0)) { 13507 psError(PS_ERR_UNKNOWN, false, "failed to add item magic"); 13508 psFree(md); 13509 return false; 13510 } 13511 13512 bool status = psDBCreateTable(dbh, P4ARUN_TABLE_NAME, md); 13556 13513 13557 13514 psFree(md); … … 13560 13517 } 13561 13518 13562 bool p4 RunDropTable(psDB *dbh)13563 { 13564 return psDBDropTable(dbh, P4 RUN_TABLE_NAME);13565 } 13566 13567 bool p4 RunInsert(psDB * dbh, psS32 p4_id, const char *survey_mode, const char *state, const char *workdir, const char *filter, const char *skycell_id, const char *tess_id, psF64 ra, psF64 decl, const char *input_ss, const char *output_ss)13519 bool p4aRunDropTable(psDB *dbh) 13520 { 13521 return psDBDropTable(dbh, P4ARUN_TABLE_NAME); 13522 } 13523 13524 bool p4aRunInsert(psDB * dbh, psS32 p4a_id, const char *state, const char *workdir, bool magic) 13568 13525 { 13569 13526 psMetadata *md = psMetadataAlloc(); 13570 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4_id", PS_DATA_S32, NULL, p4_id)) { 13571 psError(PS_ERR_UNKNOWN, false, "failed to add item p4_id"); 13572 psFree(md); 13573 return false; 13574 } 13575 if (!psMetadataAdd(md, PS_LIST_TAIL, "survey_mode", PS_DATA_STRING, NULL, survey_mode)) { 13576 psError(PS_ERR_UNKNOWN, false, "failed to add item survey_mode"); 13527 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4a_id", PS_DATA_S32, NULL, p4a_id)) { 13528 psError(PS_ERR_UNKNOWN, false, "failed to add item p4a_id"); 13577 13529 psFree(md); 13578 13530 return false; … … 13588 13540 return false; 13589 13541 } 13590 if (!psMetadataAdd(md, PS_LIST_TAIL, "filter", PS_DATA_STRING, NULL, filter)) { 13591 psError(PS_ERR_UNKNOWN, false, "failed to add item filter"); 13592 psFree(md); 13593 return false; 13594 } 13595 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, NULL, skycell_id)) { 13596 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 13597 psFree(md); 13598 return false; 13599 } 13600 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, NULL, tess_id)) { 13601 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 13602 psFree(md); 13603 return false; 13604 } 13605 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra", PS_DATA_F64, NULL, ra)) { 13606 psError(PS_ERR_UNKNOWN, false, "failed to add item ra"); 13607 psFree(md); 13608 return false; 13609 } 13610 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl", PS_DATA_F64, NULL, decl)) { 13611 psError(PS_ERR_UNKNOWN, false, "failed to add item decl"); 13612 psFree(md); 13613 return false; 13614 } 13615 if (!psMetadataAdd(md, PS_LIST_TAIL, "input_ss", PS_DATA_STRING, NULL, input_ss)) { 13616 psError(PS_ERR_UNKNOWN, false, "failed to add item input_ss"); 13617 psFree(md); 13618 return false; 13619 } 13620 if (!psMetadataAdd(md, PS_LIST_TAIL, "output_ss", PS_DATA_STRING, NULL, output_ss)) { 13621 psError(PS_ERR_UNKNOWN, false, "failed to add item output_ss"); 13622 psFree(md); 13623 return false; 13624 } 13625 13626 bool status = psDBInsertOneRow(dbh, P4RUN_TABLE_NAME, md); 13542 if (!psMetadataAdd(md, PS_LIST_TAIL, "magic", PS_DATA_BOOL, NULL, magic)) { 13543 psError(PS_ERR_UNKNOWN, false, "failed to add item magic"); 13544 psFree(md); 13545 return false; 13546 } 13547 13548 bool status = psDBInsertOneRow(dbh, P4ARUN_TABLE_NAME, md); 13627 13549 psFree(md); 13628 13550 … … 13630 13552 } 13631 13553 13632 long long p4 RunDelete(psDB *dbh, const psMetadata *where, unsigned long long limit)13554 long long p4aRunDelete(psDB *dbh, const psMetadata *where, unsigned long long limit) 13633 13555 { 13634 13556 long long deleted = 0; 13635 13557 13636 long long count = psDBDeleteRows(dbh, P4 RUN_TABLE_NAME, where, limit);13558 long long count = psDBDeleteRows(dbh, P4ARUN_TABLE_NAME, where, limit); 13637 13559 if (count < 0) { 13638 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 Run");13560 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4aRun"); 13639 13561 return count; 13640 13562 … … 13644 13566 return deleted; 13645 13567 } 13646 bool p4 RunInsertObject(psDB *dbh, p4RunRow *object)13647 { 13648 return p4 RunInsert(dbh, object->p4_id, object->survey_mode, object->state, object->workdir, object->filter, object->skycell_id, object->tess_id, object->ra, object->decl, object->input_ss, object->output_ss);13649 } 13650 13651 bool p4 RunInsertObjects(psDB *dbh, psArray *objects)13568 bool p4aRunInsertObject(psDB *dbh, p4aRunRow *object) 13569 { 13570 return p4aRunInsert(dbh, object->p4a_id, object->state, object->workdir, object->magic); 13571 } 13572 13573 bool p4aRunInsertObjects(psDB *dbh, psArray *objects) 13652 13574 { 13653 13575 for (long i = 0; i < psArrayLength(objects); i++) { 13654 if (!p4 RunInsertObject(dbh, objects->data[i])) {13576 if (!p4aRunInsertObject(dbh, objects->data[i])) { 13655 13577 return false; 13656 13578 } … … 13660 13582 } 13661 13583 13662 bool p4 RunInsertFits(psDB *dbh, const psFits *fits)13584 bool p4aRunInsertFits(psDB *dbh, const psFits *fits) 13663 13585 { 13664 13586 psArray *rowSet; 13665 13587 13666 // move to (the first?) extension named P4 RUN_TABLE_NAME13667 if (!psFitsMoveExtName(fits, P4 RUN_TABLE_NAME)) {13668 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4 RUN_TABLE_NAME);13588 // move to (the first?) extension named P4ARUN_TABLE_NAME 13589 if (!psFitsMoveExtName(fits, P4ARUN_TABLE_NAME)) { 13590 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4ARUN_TABLE_NAME); 13669 13591 return false; 13670 13592 } … … 13684 13606 } 13685 13607 13686 if (!psDBInsertRows(dbh, P4 RUN_TABLE_NAME, rowSet)) {13608 if (!psDBInsertRows(dbh, P4ARUN_TABLE_NAME, rowSet)) { 13687 13609 psError(PS_ERR_UNKNOWN, false, "databse insert failed"); 13688 13610 psFree(rowSet); … … 13695 13617 } 13696 13618 13697 bool p4 RunSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit)13619 bool p4aRunSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit) 13698 13620 { 13699 13621 psArray *rowSet; 13700 13622 13701 rowSet = psDBSelectRows(dbh, P4 RUN_TABLE_NAME, where, limit);13623 rowSet = psDBSelectRows(dbh, P4ARUN_TABLE_NAME, where, limit); 13702 13624 if (!rowSet) { 13703 13625 return false; … … 13705 13627 13706 13628 // output to fits 13707 if (!psFitsWriteTable(fits, NULL, rowSet, P4 RUN_TABLE_NAME)) {13629 if (!psFitsWriteTable(fits, NULL, rowSet, P4ARUN_TABLE_NAME)) { 13708 13630 psError(PS_ERR_UNKNOWN, false, "FITS table write failed"); 13709 13631 psFree(rowSet); … … 13716 13638 } 13717 13639 13718 psMetadata *p4 RunMetadataFromObject(const p4RunRow *object)13640 psMetadata *p4aRunMetadataFromObject(const p4aRunRow *object) 13719 13641 { 13720 13642 psMetadata *md = psMetadataAlloc(); 13721 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4_id", PS_DATA_S32, NULL, object->p4_id)) { 13722 psError(PS_ERR_UNKNOWN, false, "failed to add item p4_id"); 13723 psFree(md); 13724 return false; 13725 } 13726 if (!psMetadataAdd(md, PS_LIST_TAIL, "survey_mode", PS_DATA_STRING, NULL, object->survey_mode)) { 13727 psError(PS_ERR_UNKNOWN, false, "failed to add item survey_mode"); 13643 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4a_id", PS_DATA_S32, NULL, object->p4a_id)) { 13644 psError(PS_ERR_UNKNOWN, false, "failed to add item p4a_id"); 13728 13645 psFree(md); 13729 13646 return false; … … 13739 13656 return false; 13740 13657 } 13741 if (!psMetadataAdd(md, PS_LIST_TAIL, "filter", PS_DATA_STRING, NULL, object->filter)) { 13742 psError(PS_ERR_UNKNOWN, false, "failed to add item filter"); 13743 psFree(md); 13744 return false; 13745 } 13746 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, NULL, object->skycell_id)) { 13747 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 13748 psFree(md); 13749 return false; 13750 } 13751 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, NULL, object->tess_id)) { 13752 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 13753 psFree(md); 13754 return false; 13755 } 13756 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra", PS_DATA_F64, NULL, object->ra)) { 13757 psError(PS_ERR_UNKNOWN, false, "failed to add item ra"); 13758 psFree(md); 13759 return false; 13760 } 13761 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl", PS_DATA_F64, NULL, object->decl)) { 13762 psError(PS_ERR_UNKNOWN, false, "failed to add item decl"); 13763 psFree(md); 13764 return false; 13765 } 13766 if (!psMetadataAdd(md, PS_LIST_TAIL, "input_ss", PS_DATA_STRING, NULL, object->input_ss)) { 13767 psError(PS_ERR_UNKNOWN, false, "failed to add item input_ss"); 13768 psFree(md); 13769 return false; 13770 } 13771 if (!psMetadataAdd(md, PS_LIST_TAIL, "output_ss", PS_DATA_STRING, NULL, object->output_ss)) { 13772 psError(PS_ERR_UNKNOWN, false, "failed to add item output_ss"); 13658 if (!psMetadataAdd(md, PS_LIST_TAIL, "magic", PS_DATA_BOOL, NULL, object->magic)) { 13659 psError(PS_ERR_UNKNOWN, false, "failed to add item magic"); 13773 13660 psFree(md); 13774 13661 return false; … … 13779 13666 } 13780 13667 13781 p4 RunRow *p4RunObjectFromMetadata(psMetadata *md)13668 p4aRunRow *p4aRunObjectFromMetadata(psMetadata *md) 13782 13669 { 13783 13670 13784 13671 bool status = false; 13785 psS32 p4_id = psMetadataLookupS32(&status, md, "p4_id"); 13786 if (!status) { 13787 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4_id"); 13788 return false; 13789 } 13790 char* survey_mode = psMetadataLookupPtr(&status, md, "survey_mode"); 13791 if (!status) { 13792 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item survey_mode"); 13672 psS32 p4a_id = psMetadataLookupS32(&status, md, "p4a_id"); 13673 if (!status) { 13674 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4a_id"); 13793 13675 return false; 13794 13676 } … … 13803 13685 return false; 13804 13686 } 13805 char* filter = psMetadataLookupPtr(&status, md, "filter"); 13806 if (!status) { 13807 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item filter"); 13808 return false; 13809 } 13810 char* skycell_id = psMetadataLookupPtr(&status, md, "skycell_id"); 13811 if (!status) { 13812 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item skycell_id"); 13813 return false; 13814 } 13815 char* tess_id = psMetadataLookupPtr(&status, md, "tess_id"); 13816 if (!status) { 13817 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item tess_id"); 13818 return false; 13819 } 13820 psF64 ra = psMetadataLookupF64(&status, md, "ra"); 13821 if (!status) { 13822 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item ra"); 13823 return false; 13824 } 13825 psF64 decl = psMetadataLookupF64(&status, md, "decl"); 13826 if (!status) { 13827 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item decl"); 13828 return false; 13829 } 13830 char* input_ss = psMetadataLookupPtr(&status, md, "input_ss"); 13831 if (!status) { 13832 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item input_ss"); 13833 return false; 13834 } 13835 char* output_ss = psMetadataLookupPtr(&status, md, "output_ss"); 13836 if (!status) { 13837 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item output_ss"); 13838 return false; 13839 } 13840 13841 return p4RunRowAlloc(p4_id, survey_mode, state, workdir, filter, skycell_id, tess_id, ra, decl, input_ss, output_ss); 13842 } 13843 psArray *p4RunSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) 13687 bool magic = psMetadataLookupBool(&status, md, "magic"); 13688 if (!status) { 13689 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item magic"); 13690 return false; 13691 } 13692 13693 return p4aRunRowAlloc(p4a_id, state, workdir, magic); 13694 } 13695 psArray *p4aRunSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) 13844 13696 { 13845 13697 psArray *rowSet; … … 13847 13699 psU64 i; 13848 13700 13849 rowSet = psDBSelectRows(dbh, P4 RUN_TABLE_NAME, where, limit);13701 rowSet = psDBSelectRows(dbh, P4ARUN_TABLE_NAME, where, limit); 13850 13702 if (!rowSet) { 13851 13703 return NULL; … … 13857 13709 13858 13710 for (i = 0; i < rowSet->n; i++) { 13859 p4 RunRow *object = p4RunObjectFromMetadata(rowSet->data[i]);13711 p4aRunRow *object = p4aRunObjectFromMetadata(rowSet->data[i]); 13860 13712 psArrayAdd(returnSet, 0, object); 13861 13713 psFree(object); … … 13866 13718 return returnSet; 13867 13719 } 13868 bool p4 RunDeleteObject(psDB *dbh, const p4RunRow *object)13869 { 13870 psMetadata *where = p4 RunMetadataFromObject(object);13871 long long count = psDBDeleteRows(dbh, P4 RUN_TABLE_NAME, where, 0);13872 psFree(where) 13720 bool p4aRunDeleteObject(psDB *dbh, const p4aRunRow *object) 13721 { 13722 psMetadata *where = p4aRunMetadataFromObject(object); 13723 long long count = psDBDeleteRows(dbh, P4ARUN_TABLE_NAME, where, 0); 13724 psFree(where); 13873 13725 if (count < 0) { 13874 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 Run");13726 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4aRun"); 13875 13727 return false; 13876 13728 } … … 13878 13730 // XXX should this be a psAbort() instead? It is possible that 13879 13731 // having an object match multiple rows was by design. 13880 psError(PS_ERR_UNKNOWN, true, "p4 RunRow object matched more then one row. Check your database schema");13881 return false; 13882 } 13883 13884 return true; 13885 } 13886 long long p4 RunDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit)13732 psError(PS_ERR_UNKNOWN, true, "p4aRunRow object matched more then one row. Check your database schema"); 13733 return false; 13734 } 13735 13736 return true; 13737 } 13738 long long p4aRunDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit) 13887 13739 { 13888 13740 long long deleted = 0; 13889 13741 13890 13742 for (long long i = 0; i < objects->n; i++) { 13891 p4 RunRow *object = objects->data[i];13892 psMetadata *where = p4 RunMetadataFromObject(object);13893 long long count = psDBDeleteRows(dbh, P4 RUN_TABLE_NAME, where, limit);13894 psFree(where) 13743 p4aRunRow *object = objects->data[i]; 13744 psMetadata *where = p4aRunMetadataFromObject(object); 13745 long long count = psDBDeleteRows(dbh, P4ARUN_TABLE_NAME, where, limit); 13746 psFree(where); 13895 13747 if (count < 0) { 13896 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 Run");13748 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4aRun"); 13897 13749 return count; 13898 13750 } … … 13903 13755 return deleted; 13904 13756 } 13905 bool p4 RunPrintObjects(FILE *stream, psArray *objects, bool mdcf)13757 bool p4aRunPrintObjects(FILE *stream, psArray *objects, bool mdcf) 13906 13758 { 13907 13759 PS_ASSERT_PTR_NON_NULL(objects, false); … … 13909 13761 psMetadata *output = psMetadataAlloc(); 13910 13762 for (long i = 0; i < psArrayLength(objects); i++) { 13911 psMetadata *md = p4 RunMetadataFromObject(objects->data[i]);13763 psMetadata *md = p4aRunMetadataFromObject(objects->data[i]); 13912 13764 if (!psMetadataAddMetadata( 13913 13765 output, 13914 13766 PS_LIST_TAIL, 13915 P4 RUN_TABLE_NAME,13767 P4ARUN_TABLE_NAME, 13916 13768 PS_META_DUPLICATE_OK, 13917 13769 NULL, … … 13934 13786 return true; 13935 13787 } 13936 bool p4 RunPrintObject(FILE *stream, p4RunRow *object, bool mdcf)13788 bool p4aRunPrintObject(FILE *stream, p4aRunRow *object, bool mdcf) 13937 13789 { 13938 13790 PS_ASSERT_PTR_NON_NULL(object, false); 13939 13791 13940 psMetadata *md = p4 RunMetadataFromObject(object);13792 psMetadata *md = p4aRunMetadataFromObject(object); 13941 13793 13942 13794 if (!ippdbPrintMetadataRaw(stream, md, mdcf)) { … … 13949 13801 return true; 13950 13802 } 13951 static void p4 InputImfileRowFree(p4InputImfileRow *object);13952 13953 p4 InputImfileRow *p4InputImfileRowAlloc(psS32 p4_id, const char *exp_tag, psS32 p3_version, const char *class_id)13954 { 13955 p4 InputImfileRow*_object;13956 13957 _object = psAlloc(sizeof(p4 InputImfileRow));13958 psMemSetDeallocator(_object, (psFreeFunc)p4 InputImfileRowFree);13959 13960 _object->p4 _id = p4_id;13803 static void p4aInputExpRowFree(p4aInputExpRow *object); 13804 13805 p4aInputExpRow *p4aInputExpRowAlloc(psS32 p4a_id, const char *exp_tag, psS32 p3_version) 13806 { 13807 p4aInputExpRow *_object; 13808 13809 _object = psAlloc(sizeof(p4aInputExpRow)); 13810 psMemSetDeallocator(_object, (psFreeFunc)p4aInputExpRowFree); 13811 13812 _object->p4a_id = p4a_id; 13961 13813 _object->exp_tag = psStringCopy(exp_tag); 13962 13814 _object->p3_version = p3_version; 13963 _object->class_id = psStringCopy(class_id);13964 13815 13965 13816 return _object; 13966 13817 } 13967 13818 13968 static void p4 InputImfileRowFree(p4InputImfileRow *object)13819 static void p4aInputExpRowFree(p4aInputExpRow *object) 13969 13820 { 13970 13821 psFree(object->exp_tag); 13971 psFree(object->class_id); 13972 } 13973 13974 bool p4InputImfileCreateTable(psDB *dbh) 13822 } 13823 13824 bool p4aInputExpCreateTable(psDB *dbh) 13975 13825 { 13976 13826 psMetadata *md = psMetadataAlloc(); 13977 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4 _id", PS_DATA_S32, "Primary Key", 0)) {13978 psError(PS_ERR_UNKNOWN, false, "failed to add item p4 _id");13827 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4a_id", PS_DATA_S32, "Primary Key", 0)) { 13828 psError(PS_ERR_UNKNOWN, false, "failed to add item p4a_id"); 13979 13829 psFree(md); 13980 13830 return false; … … 13990 13840 return false; 13991 13841 } 13992 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, "Primary Key", "64")) { 13993 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id"); 13994 psFree(md); 13995 return false; 13996 } 13997 13998 bool status = psDBCreateTable(dbh, P4INPUTIMFILE_TABLE_NAME, md); 13842 13843 bool status = psDBCreateTable(dbh, P4AINPUTEXP_TABLE_NAME, md); 13999 13844 14000 13845 psFree(md); … … 14003 13848 } 14004 13849 14005 bool p4 InputImfileDropTable(psDB *dbh)14006 { 14007 return psDBDropTable(dbh, P4 INPUTIMFILE_TABLE_NAME);14008 } 14009 14010 bool p4 InputImfileInsert(psDB * dbh, psS32 p4_id, const char *exp_tag, psS32 p3_version, const char *class_id)13850 bool p4aInputExpDropTable(psDB *dbh) 13851 { 13852 return psDBDropTable(dbh, P4AINPUTEXP_TABLE_NAME); 13853 } 13854 13855 bool p4aInputExpInsert(psDB * dbh, psS32 p4a_id, const char *exp_tag, psS32 p3_version) 14011 13856 { 14012 13857 psMetadata *md = psMetadataAlloc(); 14013 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4 _id", PS_DATA_S32, NULL, p4_id)) {14014 psError(PS_ERR_UNKNOWN, false, "failed to add item p4 _id");13858 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4a_id", PS_DATA_S32, NULL, p4a_id)) { 13859 psError(PS_ERR_UNKNOWN, false, "failed to add item p4a_id"); 14015 13860 psFree(md); 14016 13861 return false; … … 14026 13871 return false; 14027 13872 } 14028 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, NULL, class_id)) { 14029 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id"); 14030 psFree(md); 14031 return false; 14032 } 14033 14034 bool status = psDBInsertOneRow(dbh, P4INPUTIMFILE_TABLE_NAME, md); 13873 13874 bool status = psDBInsertOneRow(dbh, P4AINPUTEXP_TABLE_NAME, md); 14035 13875 psFree(md); 14036 13876 … … 14038 13878 } 14039 13879 14040 long long p4 InputImfileDelete(psDB *dbh, const psMetadata *where, unsigned long long limit)13880 long long p4aInputExpDelete(psDB *dbh, const psMetadata *where, unsigned long long limit) 14041 13881 { 14042 13882 long long deleted = 0; 14043 13883 14044 long long count = psDBDeleteRows(dbh, P4 INPUTIMFILE_TABLE_NAME, where, limit);13884 long long count = psDBDeleteRows(dbh, P4AINPUTEXP_TABLE_NAME, where, limit); 14045 13885 if (count < 0) { 14046 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 InputImfile");13886 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4aInputExp"); 14047 13887 return count; 14048 13888 … … 14052 13892 return deleted; 14053 13893 } 14054 bool p4 InputImfileInsertObject(psDB *dbh, p4InputImfileRow *object)14055 { 14056 return p4 InputImfileInsert(dbh, object->p4_id, object->exp_tag, object->p3_version, object->class_id);14057 } 14058 14059 bool p4 InputImfileInsertObjects(psDB *dbh, psArray *objects)13894 bool p4aInputExpInsertObject(psDB *dbh, p4aInputExpRow *object) 13895 { 13896 return p4aInputExpInsert(dbh, object->p4a_id, object->exp_tag, object->p3_version); 13897 } 13898 13899 bool p4aInputExpInsertObjects(psDB *dbh, psArray *objects) 14060 13900 { 14061 13901 for (long i = 0; i < psArrayLength(objects); i++) { 14062 if (!p4 InputImfileInsertObject(dbh, objects->data[i])) {13902 if (!p4aInputExpInsertObject(dbh, objects->data[i])) { 14063 13903 return false; 14064 13904 } … … 14068 13908 } 14069 13909 14070 bool p4 InputImfileInsertFits(psDB *dbh, const psFits *fits)13910 bool p4aInputExpInsertFits(psDB *dbh, const psFits *fits) 14071 13911 { 14072 13912 psArray *rowSet; 14073 13913 14074 // move to (the first?) extension named P4 INPUTIMFILE_TABLE_NAME14075 if (!psFitsMoveExtName(fits, P4 INPUTIMFILE_TABLE_NAME)) {14076 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4 INPUTIMFILE_TABLE_NAME);13914 // move to (the first?) extension named P4AINPUTEXP_TABLE_NAME 13915 if (!psFitsMoveExtName(fits, P4AINPUTEXP_TABLE_NAME)) { 13916 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4AINPUTEXP_TABLE_NAME); 14077 13917 return false; 14078 13918 } … … 14092 13932 } 14093 13933 14094 if (!psDBInsertRows(dbh, P4 INPUTIMFILE_TABLE_NAME, rowSet)) {13934 if (!psDBInsertRows(dbh, P4AINPUTEXP_TABLE_NAME, rowSet)) { 14095 13935 psError(PS_ERR_UNKNOWN, false, "databse insert failed"); 14096 13936 psFree(rowSet); … … 14103 13943 } 14104 13944 14105 bool p4 InputImfileSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit)13945 bool p4aInputExpSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit) 14106 13946 { 14107 13947 psArray *rowSet; 14108 13948 14109 rowSet = psDBSelectRows(dbh, P4 INPUTIMFILE_TABLE_NAME, where, limit);13949 rowSet = psDBSelectRows(dbh, P4AINPUTEXP_TABLE_NAME, where, limit); 14110 13950 if (!rowSet) { 14111 13951 return false; … … 14113 13953 14114 13954 // output to fits 14115 if (!psFitsWriteTable(fits, NULL, rowSet, P4 INPUTIMFILE_TABLE_NAME)) {13955 if (!psFitsWriteTable(fits, NULL, rowSet, P4AINPUTEXP_TABLE_NAME)) { 14116 13956 psError(PS_ERR_UNKNOWN, false, "FITS table write failed"); 14117 13957 psFree(rowSet); … … 14124 13964 } 14125 13965 14126 psMetadata *p4 InputImfileMetadataFromObject(const p4InputImfileRow *object)13966 psMetadata *p4aInputExpMetadataFromObject(const p4aInputExpRow *object) 14127 13967 { 14128 13968 psMetadata *md = psMetadataAlloc(); 14129 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4 _id", PS_DATA_S32, NULL, object->p4_id)) {14130 psError(PS_ERR_UNKNOWN, false, "failed to add item p4 _id");13969 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4a_id", PS_DATA_S32, NULL, object->p4a_id)) { 13970 psError(PS_ERR_UNKNOWN, false, "failed to add item p4a_id"); 14131 13971 psFree(md); 14132 13972 return false; … … 14142 13982 return false; 14143 13983 } 14144 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, NULL, object->class_id)) {14145 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id");14146 psFree(md);14147 return false;14148 }14149 13984 14150 13985 … … 14152 13987 } 14153 13988 14154 p4 InputImfileRow *p4InputImfileObjectFromMetadata(psMetadata *md)13989 p4aInputExpRow *p4aInputExpObjectFromMetadata(psMetadata *md) 14155 13990 { 14156 13991 14157 13992 bool status = false; 14158 psS32 p4 _id = psMetadataLookupS32(&status, md, "p4_id");14159 if (!status) { 14160 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4 _id");13993 psS32 p4a_id = psMetadataLookupS32(&status, md, "p4a_id"); 13994 if (!status) { 13995 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4a_id"); 14161 13996 return false; 14162 13997 } … … 14171 14006 return false; 14172 14007 } 14173 char* class_id = psMetadataLookupPtr(&status, md, "class_id"); 14174 if (!status) { 14175 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item class_id"); 14176 return false; 14177 } 14178 14179 return p4InputImfileRowAlloc(p4_id, exp_tag, p3_version, class_id); 14180 } 14181 psArray *p4InputImfileSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) 14008 14009 return p4aInputExpRowAlloc(p4a_id, exp_tag, p3_version); 14010 } 14011 psArray *p4aInputExpSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) 14182 14012 { 14183 14013 psArray *rowSet; … … 14185 14015 psU64 i; 14186 14016 14187 rowSet = psDBSelectRows(dbh, P4 INPUTIMFILE_TABLE_NAME, where, limit);14017 rowSet = psDBSelectRows(dbh, P4AINPUTEXP_TABLE_NAME, where, limit); 14188 14018 if (!rowSet) { 14189 14019 return NULL; … … 14195 14025 14196 14026 for (i = 0; i < rowSet->n; i++) { 14197 p4 InputImfileRow *object = p4InputImfileObjectFromMetadata(rowSet->data[i]);14027 p4aInputExpRow *object = p4aInputExpObjectFromMetadata(rowSet->data[i]); 14198 14028 psArrayAdd(returnSet, 0, object); 14199 14029 psFree(object); … … 14204 14034 return returnSet; 14205 14035 } 14206 bool p4 InputImfileDeleteObject(psDB *dbh, const p4InputImfileRow *object)14207 { 14208 psMetadata *where = p4 InputImfileMetadataFromObject(object);14209 long long count = psDBDeleteRows(dbh, P4 INPUTIMFILE_TABLE_NAME, where, 0);14210 psFree(where) 14036 bool p4aInputExpDeleteObject(psDB *dbh, const p4aInputExpRow *object) 14037 { 14038 psMetadata *where = p4aInputExpMetadataFromObject(object); 14039 long long count = psDBDeleteRows(dbh, P4AINPUTEXP_TABLE_NAME, where, 0); 14040 psFree(where); 14211 14041 if (count < 0) { 14212 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 InputImfile");14042 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4aInputExp"); 14213 14043 return false; 14214 14044 } … … 14216 14046 // XXX should this be a psAbort() instead? It is possible that 14217 14047 // having an object match multiple rows was by design. 14218 psError(PS_ERR_UNKNOWN, true, "p4 InputImfileRow object matched more then one row. Check your database schema");14219 return false; 14220 } 14221 14222 return true; 14223 } 14224 long long p4 InputImfileDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit)14048 psError(PS_ERR_UNKNOWN, true, "p4aInputExpRow object matched more then one row. Check your database schema"); 14049 return false; 14050 } 14051 14052 return true; 14053 } 14054 long long p4aInputExpDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit) 14225 14055 { 14226 14056 long long deleted = 0; 14227 14057 14228 14058 for (long long i = 0; i < objects->n; i++) { 14229 p4 InputImfileRow *object = objects->data[i];14230 psMetadata *where = p4 InputImfileMetadataFromObject(object);14231 long long count = psDBDeleteRows(dbh, P4 INPUTIMFILE_TABLE_NAME, where, limit);14232 psFree(where) 14059 p4aInputExpRow *object = objects->data[i]; 14060 psMetadata *where = p4aInputExpMetadataFromObject(object); 14061 long long count = psDBDeleteRows(dbh, P4AINPUTEXP_TABLE_NAME, where, limit); 14062 psFree(where); 14233 14063 if (count < 0) { 14234 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 InputImfile");14064 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4aInputExp"); 14235 14065 return count; 14236 14066 } … … 14241 14071 return deleted; 14242 14072 } 14243 bool p4 InputImfilePrintObjects(FILE *stream, psArray *objects, bool mdcf)14073 bool p4aInputExpPrintObjects(FILE *stream, psArray *objects, bool mdcf) 14244 14074 { 14245 14075 PS_ASSERT_PTR_NON_NULL(objects, false); … … 14247 14077 psMetadata *output = psMetadataAlloc(); 14248 14078 for (long i = 0; i < psArrayLength(objects); i++) { 14249 psMetadata *md = p4 InputImfileMetadataFromObject(objects->data[i]);14079 psMetadata *md = p4aInputExpMetadataFromObject(objects->data[i]); 14250 14080 if (!psMetadataAddMetadata( 14251 14081 output, 14252 14082 PS_LIST_TAIL, 14253 P4 INPUTIMFILE_TABLE_NAME,14083 P4AINPUTEXP_TABLE_NAME, 14254 14084 PS_META_DUPLICATE_OK, 14255 14085 NULL, … … 14272 14102 return true; 14273 14103 } 14274 bool p4 InputImfilePrintObject(FILE *stream, p4InputImfileRow *object, bool mdcf)14104 bool p4aInputExpPrintObject(FILE *stream, p4aInputExpRow *object, bool mdcf) 14275 14105 { 14276 14106 PS_ASSERT_PTR_NON_NULL(object, false); 14277 14107 14278 psMetadata *md = p4 InputImfileMetadataFromObject(object);14108 psMetadata *md = p4aInputExpMetadataFromObject(object); 14279 14109 14280 14110 if (!ippdbPrintMetadataRaw(stream, md, mdcf)) { … … 14287 14117 return true; 14288 14118 } 14289 static void p4WarpedImfileRowFree(p4WarpedImfileRow *object); 14290 14291 p4WarpedImfileRow *p4WarpedImfileRowAlloc(psS32 p4_id, const char *exp_tag, psS32 p3_version, const char *class_id, const char *uri, const char *b1_uri, const char *b2_uri) 14292 { 14293 p4WarpedImfileRow *_object; 14294 14295 _object = psAlloc(sizeof(p4WarpedImfileRow)); 14296 psMemSetDeallocator(_object, (psFreeFunc)p4WarpedImfileRowFree); 14297 14298 _object->p4_id = p4_id; 14119 static void p4aScfileRowFree(p4aScfileRow *object); 14120 14121 p4aScfileRow *p4aScfileRowAlloc(psS32 p4a_id, const char *skycell_id, const char *tess_id, const char *exp_tag, psS32 p3_version, const char *uri, psF64 bg, psF64 bg_mean_stdev) 14122 { 14123 p4aScfileRow *_object; 14124 14125 _object = psAlloc(sizeof(p4aScfileRow)); 14126 psMemSetDeallocator(_object, (psFreeFunc)p4aScfileRowFree); 14127 14128 _object->p4a_id = p4a_id; 14129 _object->skycell_id = psStringCopy(skycell_id); 14130 _object->tess_id = psStringCopy(tess_id); 14299 14131 _object->exp_tag = psStringCopy(exp_tag); 14300 14132 _object->p3_version = p3_version; 14301 _object->class_id = psStringCopy(class_id);14302 14133 _object->uri = psStringCopy(uri); 14303 _object->b 1_uri = psStringCopy(b1_uri);14304 _object->b 2_uri = psStringCopy(b2_uri);14134 _object->bg = bg; 14135 _object->bg_mean_stdev = bg_mean_stdev; 14305 14136 14306 14137 return _object; 14307 14138 } 14308 14139 14309 static void p4WarpedImfileRowFree(p4WarpedImfileRow *object) 14310 { 14140 static void p4aScfileRowFree(p4aScfileRow *object) 14141 { 14142 psFree(object->skycell_id); 14143 psFree(object->tess_id); 14311 14144 psFree(object->exp_tag); 14312 psFree(object->class_id);14313 14145 psFree(object->uri); 14314 psFree(object->b1_uri); 14315 psFree(object->b2_uri); 14316 } 14317 14318 bool p4WarpedImfileCreateTable(psDB *dbh) 14146 } 14147 14148 bool p4aScfileCreateTable(psDB *dbh) 14319 14149 { 14320 14150 psMetadata *md = psMetadataAlloc(); 14321 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4_id", PS_DATA_S32, "Primary Key", 0)) { 14322 psError(PS_ERR_UNKNOWN, false, "failed to add item p4_id"); 14151 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4a_id", PS_DATA_S32, "Primary Key", 0)) { 14152 psError(PS_ERR_UNKNOWN, false, "failed to add item p4a_id"); 14153 psFree(md); 14154 return false; 14155 } 14156 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, "Primary Key", "64")) { 14157 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 14158 psFree(md); 14159 return false; 14160 } 14161 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, "Primary Key", "64")) { 14162 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 14323 14163 psFree(md); 14324 14164 return false; … … 14334 14174 return false; 14335 14175 } 14336 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, "Primary Key", "64")) {14337 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id");14338 psFree(md);14339 return false;14340 }14341 14176 if (!psMetadataAdd(md, PS_LIST_TAIL, "uri", PS_DATA_STRING, NULL, "255")) { 14342 14177 psError(PS_ERR_UNKNOWN, false, "failed to add item uri"); … … 14344 14179 return false; 14345 14180 } 14346 if (!psMetadataAdd(md, PS_LIST_TAIL, "b 1_uri", PS_DATA_STRING, NULL, "255")) {14347 psError(PS_ERR_UNKNOWN, false, "failed to add item b 1_uri");14348 psFree(md); 14349 return false; 14350 } 14351 if (!psMetadataAdd(md, PS_LIST_TAIL, "b 2_uri", PS_DATA_STRING, NULL, "255")) {14352 psError(PS_ERR_UNKNOWN, false, "failed to add item b 2_uri");14353 psFree(md); 14354 return false; 14355 } 14356 14357 bool status = psDBCreateTable(dbh, P4 WARPEDIMFILE_TABLE_NAME, md);14181 if (!psMetadataAdd(md, PS_LIST_TAIL, "bg", PS_DATA_F64, NULL, 0.0)) { 14182 psError(PS_ERR_UNKNOWN, false, "failed to add item bg"); 14183 psFree(md); 14184 return false; 14185 } 14186 if (!psMetadataAdd(md, PS_LIST_TAIL, "bg_mean_stdev", PS_DATA_F64, NULL, 0.0)) { 14187 psError(PS_ERR_UNKNOWN, false, "failed to add item bg_mean_stdev"); 14188 psFree(md); 14189 return false; 14190 } 14191 14192 bool status = psDBCreateTable(dbh, P4ASCFILE_TABLE_NAME, md); 14358 14193 14359 14194 psFree(md); … … 14362 14197 } 14363 14198 14364 bool p4 WarpedImfileDropTable(psDB *dbh)14365 { 14366 return psDBDropTable(dbh, P4 WARPEDIMFILE_TABLE_NAME);14367 } 14368 14369 bool p4 WarpedImfileInsert(psDB * dbh, psS32 p4_id, const char *exp_tag, psS32 p3_version, const char *class_id, const char *uri, const char *b1_uri, const char *b2_uri)14199 bool p4aScfileDropTable(psDB *dbh) 14200 { 14201 return psDBDropTable(dbh, P4ASCFILE_TABLE_NAME); 14202 } 14203 14204 bool p4aScfileInsert(psDB * dbh, psS32 p4a_id, const char *skycell_id, const char *tess_id, const char *exp_tag, psS32 p3_version, const char *uri, psF64 bg, psF64 bg_mean_stdev) 14370 14205 { 14371 14206 psMetadata *md = psMetadataAlloc(); 14372 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4_id", PS_DATA_S32, NULL, p4_id)) { 14373 psError(PS_ERR_UNKNOWN, false, "failed to add item p4_id"); 14207 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4a_id", PS_DATA_S32, NULL, p4a_id)) { 14208 psError(PS_ERR_UNKNOWN, false, "failed to add item p4a_id"); 14209 psFree(md); 14210 return false; 14211 } 14212 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, NULL, skycell_id)) { 14213 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 14214 psFree(md); 14215 return false; 14216 } 14217 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, NULL, tess_id)) { 14218 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 14374 14219 psFree(md); 14375 14220 return false; … … 14385 14230 return false; 14386 14231 } 14387 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, NULL, class_id)) {14388 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id");14389 psFree(md);14390 return false;14391 }14392 14232 if (!psMetadataAdd(md, PS_LIST_TAIL, "uri", PS_DATA_STRING, NULL, uri)) { 14393 14233 psError(PS_ERR_UNKNOWN, false, "failed to add item uri"); … … 14395 14235 return false; 14396 14236 } 14397 if (!psMetadataAdd(md, PS_LIST_TAIL, "b 1_uri", PS_DATA_STRING, NULL, b1_uri)) {14398 psError(PS_ERR_UNKNOWN, false, "failed to add item b 1_uri");14399 psFree(md); 14400 return false; 14401 } 14402 if (!psMetadataAdd(md, PS_LIST_TAIL, "b 2_uri", PS_DATA_STRING, NULL, b2_uri)) {14403 psError(PS_ERR_UNKNOWN, false, "failed to add item b 2_uri");14404 psFree(md); 14405 return false; 14406 } 14407 14408 bool status = psDBInsertOneRow(dbh, P4 WARPEDIMFILE_TABLE_NAME, md);14237 if (!psMetadataAdd(md, PS_LIST_TAIL, "bg", PS_DATA_F64, NULL, bg)) { 14238 psError(PS_ERR_UNKNOWN, false, "failed to add item bg"); 14239 psFree(md); 14240 return false; 14241 } 14242 if (!psMetadataAdd(md, PS_LIST_TAIL, "bg_mean_stdev", PS_DATA_F64, NULL, bg_mean_stdev)) { 14243 psError(PS_ERR_UNKNOWN, false, "failed to add item bg_mean_stdev"); 14244 psFree(md); 14245 return false; 14246 } 14247 14248 bool status = psDBInsertOneRow(dbh, P4ASCFILE_TABLE_NAME, md); 14409 14249 psFree(md); 14410 14250 … … 14412 14252 } 14413 14253 14414 long long p4 WarpedImfileDelete(psDB *dbh, const psMetadata *where, unsigned long long limit)14254 long long p4aScfileDelete(psDB *dbh, const psMetadata *where, unsigned long long limit) 14415 14255 { 14416 14256 long long deleted = 0; 14417 14257 14418 long long count = psDBDeleteRows(dbh, P4 WARPEDIMFILE_TABLE_NAME, where, limit);14258 long long count = psDBDeleteRows(dbh, P4ASCFILE_TABLE_NAME, where, limit); 14419 14259 if (count < 0) { 14420 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 WarpedImfile");14260 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4aScfile"); 14421 14261 return count; 14422 14262 … … 14426 14266 return deleted; 14427 14267 } 14428 bool p4 WarpedImfileInsertObject(psDB *dbh, p4WarpedImfileRow *object)14429 { 14430 return p4 WarpedImfileInsert(dbh, object->p4_id, object->exp_tag, object->p3_version, object->class_id, object->uri, object->b1_uri, object->b2_uri);14431 } 14432 14433 bool p4 WarpedImfileInsertObjects(psDB *dbh, psArray *objects)14268 bool p4aScfileInsertObject(psDB *dbh, p4aScfileRow *object) 14269 { 14270 return p4aScfileInsert(dbh, object->p4a_id, object->skycell_id, object->tess_id, object->exp_tag, object->p3_version, object->uri, object->bg, object->bg_mean_stdev); 14271 } 14272 14273 bool p4aScfileInsertObjects(psDB *dbh, psArray *objects) 14434 14274 { 14435 14275 for (long i = 0; i < psArrayLength(objects); i++) { 14436 if (!p4 WarpedImfileInsertObject(dbh, objects->data[i])) {14276 if (!p4aScfileInsertObject(dbh, objects->data[i])) { 14437 14277 return false; 14438 14278 } … … 14442 14282 } 14443 14283 14444 bool p4 WarpedImfileInsertFits(psDB *dbh, const psFits *fits)14284 bool p4aScfileInsertFits(psDB *dbh, const psFits *fits) 14445 14285 { 14446 14286 psArray *rowSet; 14447 14287 14448 // move to (the first?) extension named P4 WARPEDIMFILE_TABLE_NAME14449 if (!psFitsMoveExtName(fits, P4 WARPEDIMFILE_TABLE_NAME)) {14450 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4 WARPEDIMFILE_TABLE_NAME);14288 // move to (the first?) extension named P4ASCFILE_TABLE_NAME 14289 if (!psFitsMoveExtName(fits, P4ASCFILE_TABLE_NAME)) { 14290 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4ASCFILE_TABLE_NAME); 14451 14291 return false; 14452 14292 } … … 14466 14306 } 14467 14307 14468 if (!psDBInsertRows(dbh, P4 WARPEDIMFILE_TABLE_NAME, rowSet)) {14308 if (!psDBInsertRows(dbh, P4ASCFILE_TABLE_NAME, rowSet)) { 14469 14309 psError(PS_ERR_UNKNOWN, false, "databse insert failed"); 14470 14310 psFree(rowSet); … … 14477 14317 } 14478 14318 14479 bool p4 WarpedImfileSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit)14319 bool p4aScfileSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit) 14480 14320 { 14481 14321 psArray *rowSet; 14482 14322 14483 rowSet = psDBSelectRows(dbh, P4 WARPEDIMFILE_TABLE_NAME, where, limit);14323 rowSet = psDBSelectRows(dbh, P4ASCFILE_TABLE_NAME, where, limit); 14484 14324 if (!rowSet) { 14485 14325 return false; … … 14487 14327 14488 14328 // output to fits 14489 if (!psFitsWriteTable(fits, NULL, rowSet, P4 WARPEDIMFILE_TABLE_NAME)) {14329 if (!psFitsWriteTable(fits, NULL, rowSet, P4ASCFILE_TABLE_NAME)) { 14490 14330 psError(PS_ERR_UNKNOWN, false, "FITS table write failed"); 14491 14331 psFree(rowSet); … … 14498 14338 } 14499 14339 14500 psMetadata *p4 WarpedImfileMetadataFromObject(const p4WarpedImfileRow *object)14340 psMetadata *p4aScfileMetadataFromObject(const p4aScfileRow *object) 14501 14341 { 14502 14342 psMetadata *md = psMetadataAlloc(); 14503 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4_id", PS_DATA_S32, NULL, object->p4_id)) { 14504 psError(PS_ERR_UNKNOWN, false, "failed to add item p4_id"); 14343 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4a_id", PS_DATA_S32, NULL, object->p4a_id)) { 14344 psError(PS_ERR_UNKNOWN, false, "failed to add item p4a_id"); 14345 psFree(md); 14346 return false; 14347 } 14348 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, NULL, object->skycell_id)) { 14349 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 14350 psFree(md); 14351 return false; 14352 } 14353 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, NULL, object->tess_id)) { 14354 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 14505 14355 psFree(md); 14506 14356 return false; … … 14516 14366 return false; 14517 14367 } 14518 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, NULL, object->class_id)) {14519 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id");14520 psFree(md);14521 return false;14522 }14523 14368 if (!psMetadataAdd(md, PS_LIST_TAIL, "uri", PS_DATA_STRING, NULL, object->uri)) { 14524 14369 psError(PS_ERR_UNKNOWN, false, "failed to add item uri"); … … 14526 14371 return false; 14527 14372 } 14528 if (!psMetadataAdd(md, PS_LIST_TAIL, "b 1_uri", PS_DATA_STRING, NULL, object->b1_uri)) {14529 psError(PS_ERR_UNKNOWN, false, "failed to add item b 1_uri");14530 psFree(md); 14531 return false; 14532 } 14533 if (!psMetadataAdd(md, PS_LIST_TAIL, "b 2_uri", PS_DATA_STRING, NULL, object->b2_uri)) {14534 psError(PS_ERR_UNKNOWN, false, "failed to add item b 2_uri");14373 if (!psMetadataAdd(md, PS_LIST_TAIL, "bg", PS_DATA_F64, NULL, object->bg)) { 14374 psError(PS_ERR_UNKNOWN, false, "failed to add item bg"); 14375 psFree(md); 14376 return false; 14377 } 14378 if (!psMetadataAdd(md, PS_LIST_TAIL, "bg_mean_stdev", PS_DATA_F64, NULL, object->bg_mean_stdev)) { 14379 psError(PS_ERR_UNKNOWN, false, "failed to add item bg_mean_stdev"); 14535 14380 psFree(md); 14536 14381 return false; … … 14541 14386 } 14542 14387 14543 p4 WarpedImfileRow *p4WarpedImfileObjectFromMetadata(psMetadata *md)14388 p4aScfileRow *p4aScfileObjectFromMetadata(psMetadata *md) 14544 14389 { 14545 14390 14546 14391 bool status = false; 14547 psS32 p4_id = psMetadataLookupS32(&status, md, "p4_id"); 14548 if (!status) { 14549 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4_id"); 14392 psS32 p4a_id = psMetadataLookupS32(&status, md, "p4a_id"); 14393 if (!status) { 14394 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4a_id"); 14395 return false; 14396 } 14397 char* skycell_id = psMetadataLookupPtr(&status, md, "skycell_id"); 14398 if (!status) { 14399 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item skycell_id"); 14400 return false; 14401 } 14402 char* tess_id = psMetadataLookupPtr(&status, md, "tess_id"); 14403 if (!status) { 14404 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item tess_id"); 14550 14405 return false; 14551 14406 } … … 14560 14415 return false; 14561 14416 } 14562 char* class_id = psMetadataLookupPtr(&status, md, "class_id");14563 if (!status) {14564 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item class_id");14565 return false;14566 }14567 14417 char* uri = psMetadataLookupPtr(&status, md, "uri"); 14568 14418 if (!status) { … … 14570 14420 return false; 14571 14421 } 14572 char* b1_uri = psMetadataLookupPtr(&status, md, "b1_uri");14573 if (!status) { 14574 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item b 1_uri");14575 return false; 14576 } 14577 char* b2_uri = psMetadataLookupPtr(&status, md, "b2_uri");14578 if (!status) { 14579 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item b 2_uri");14580 return false; 14581 } 14582 14583 return p4 WarpedImfileRowAlloc(p4_id, exp_tag, p3_version, class_id, uri, b1_uri, b2_uri);14584 } 14585 psArray *p4 WarpedImfileSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit)14422 psF64 bg = psMetadataLookupF64(&status, md, "bg"); 14423 if (!status) { 14424 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item bg"); 14425 return false; 14426 } 14427 psF64 bg_mean_stdev = psMetadataLookupF64(&status, md, "bg_mean_stdev"); 14428 if (!status) { 14429 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item bg_mean_stdev"); 14430 return false; 14431 } 14432 14433 return p4aScfileRowAlloc(p4a_id, skycell_id, tess_id, exp_tag, p3_version, uri, bg, bg_mean_stdev); 14434 } 14435 psArray *p4aScfileSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) 14586 14436 { 14587 14437 psArray *rowSet; … … 14589 14439 psU64 i; 14590 14440 14591 rowSet = psDBSelectRows(dbh, P4 WARPEDIMFILE_TABLE_NAME, where, limit);14441 rowSet = psDBSelectRows(dbh, P4ASCFILE_TABLE_NAME, where, limit); 14592 14442 if (!rowSet) { 14593 14443 return NULL; … … 14599 14449 14600 14450 for (i = 0; i < rowSet->n; i++) { 14601 p4 WarpedImfileRow *object = p4WarpedImfileObjectFromMetadata(rowSet->data[i]);14451 p4aScfileRow *object = p4aScfileObjectFromMetadata(rowSet->data[i]); 14602 14452 psArrayAdd(returnSet, 0, object); 14603 14453 psFree(object); … … 14608 14458 return returnSet; 14609 14459 } 14610 bool p4 WarpedImfileDeleteObject(psDB *dbh, const p4WarpedImfileRow *object)14611 { 14612 psMetadata *where = p4 WarpedImfileMetadataFromObject(object);14613 long long count = psDBDeleteRows(dbh, P4 WARPEDIMFILE_TABLE_NAME, where, 0);14614 psFree(where) 14460 bool p4aScfileDeleteObject(psDB *dbh, const p4aScfileRow *object) 14461 { 14462 psMetadata *where = p4aScfileMetadataFromObject(object); 14463 long long count = psDBDeleteRows(dbh, P4ASCFILE_TABLE_NAME, where, 0); 14464 psFree(where); 14615 14465 if (count < 0) { 14616 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 WarpedImfile");14466 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4aScfile"); 14617 14467 return false; 14618 14468 } … … 14620 14470 // XXX should this be a psAbort() instead? It is possible that 14621 14471 // having an object match multiple rows was by design. 14622 psError(PS_ERR_UNKNOWN, true, "p4 WarpedImfileRow object matched more then one row. Check your database schema");14623 return false; 14624 } 14625 14626 return true; 14627 } 14628 long long p4 WarpedImfileDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit)14472 psError(PS_ERR_UNKNOWN, true, "p4aScfileRow object matched more then one row. Check your database schema"); 14473 return false; 14474 } 14475 14476 return true; 14477 } 14478 long long p4aScfileDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit) 14629 14479 { 14630 14480 long long deleted = 0; 14631 14481 14632 14482 for (long long i = 0; i < objects->n; i++) { 14633 p4 WarpedImfileRow *object = objects->data[i];14634 psMetadata *where = p4 WarpedImfileMetadataFromObject(object);14635 long long count = psDBDeleteRows(dbh, P4 WARPEDIMFILE_TABLE_NAME, where, limit);14636 psFree(where) 14483 p4aScfileRow *object = objects->data[i]; 14484 psMetadata *where = p4aScfileMetadataFromObject(object); 14485 long long count = psDBDeleteRows(dbh, P4ASCFILE_TABLE_NAME, where, limit); 14486 psFree(where); 14637 14487 if (count < 0) { 14638 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 WarpedImfile");14488 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4aScfile"); 14639 14489 return count; 14640 14490 } … … 14645 14495 return deleted; 14646 14496 } 14647 bool p4 WarpedImfilePrintObjects(FILE *stream, psArray *objects, bool mdcf)14497 bool p4aScfilePrintObjects(FILE *stream, psArray *objects, bool mdcf) 14648 14498 { 14649 14499 PS_ASSERT_PTR_NON_NULL(objects, false); … … 14651 14501 psMetadata *output = psMetadataAlloc(); 14652 14502 for (long i = 0; i < psArrayLength(objects); i++) { 14653 psMetadata *md = p4 WarpedImfileMetadataFromObject(objects->data[i]);14503 psMetadata *md = p4aScfileMetadataFromObject(objects->data[i]); 14654 14504 if (!psMetadataAddMetadata( 14655 14505 output, 14656 14506 PS_LIST_TAIL, 14657 P4 WARPEDIMFILE_TABLE_NAME,14507 P4ASCFILE_TABLE_NAME, 14658 14508 PS_META_DUPLICATE_OK, 14659 14509 NULL, … … 14676 14526 return true; 14677 14527 } 14678 bool p4 WarpedImfilePrintObject(FILE *stream, p4WarpedImfileRow *object, bool mdcf)14528 bool p4aScfilePrintObject(FILE *stream, p4aScfileRow *object, bool mdcf) 14679 14529 { 14680 14530 PS_ASSERT_PTR_NON_NULL(object, false); 14681 14531 14682 psMetadata *md = p4 WarpedImfileMetadataFromObject(object);14532 psMetadata *md = p4aScfileMetadataFromObject(object); 14683 14533 14684 14534 if (!ippdbPrintMetadataRaw(stream, md, mdcf)) { … … 14691 14541 return true; 14692 14542 } 14693 static void p4StackedImfileRowFree(p4StackedImfileRow *object); 14694 14695 p4StackedImfileRow *p4StackedImfileRowAlloc(psS32 p4_id, const char *class_id, const char *uri, const char *b1_uri, const char *b2_uri) 14696 { 14697 p4StackedImfileRow *_object; 14698 14699 _object = psAlloc(sizeof(p4StackedImfileRow)); 14700 psMemSetDeallocator(_object, (psFreeFunc)p4StackedImfileRowFree); 14701 14702 _object->p4_id = p4_id; 14703 _object->class_id = psStringCopy(class_id); 14704 _object->uri = psStringCopy(uri); 14705 _object->b1_uri = psStringCopy(b1_uri); 14706 _object->b2_uri = psStringCopy(b2_uri); 14543 static void p4bRunRowFree(p4bRunRow *object); 14544 14545 p4bRunRow *p4bRunRowAlloc(psS32 p4b_id, const char *state, const char *workdir, bool magic) 14546 { 14547 p4bRunRow *_object; 14548 14549 _object = psAlloc(sizeof(p4bRunRow)); 14550 psMemSetDeallocator(_object, (psFreeFunc)p4bRunRowFree); 14551 14552 _object->p4b_id = p4b_id; 14553 _object->state = psStringCopy(state); 14554 _object->workdir = psStringCopy(workdir); 14555 _object->magic = magic; 14707 14556 14708 14557 return _object; 14709 14558 } 14710 14559 14711 static void p4StackedImfileRowFree(p4StackedImfileRow *object) 14712 { 14713 psFree(object->class_id); 14714 psFree(object->uri); 14715 psFree(object->b1_uri); 14716 psFree(object->b2_uri); 14717 } 14718 14719 bool p4StackedImfileCreateTable(psDB *dbh) 14560 static void p4bRunRowFree(p4bRunRow *object) 14561 { 14562 psFree(object->state); 14563 psFree(object->workdir); 14564 } 14565 14566 bool p4bRunCreateTable(psDB *dbh) 14720 14567 { 14721 14568 psMetadata *md = psMetadataAlloc(); 14722 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4_id", PS_DATA_S32, "Primary Key", 0)) { 14723 psError(PS_ERR_UNKNOWN, false, "failed to add item p4_id"); 14724 psFree(md); 14725 return false; 14726 } 14727 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, "Primary Key", "64")) { 14728 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id"); 14729 psFree(md); 14730 return false; 14731 } 14732 if (!psMetadataAdd(md, PS_LIST_TAIL, "uri", PS_DATA_STRING, NULL, "255")) { 14733 psError(PS_ERR_UNKNOWN, false, "failed to add item uri"); 14734 psFree(md); 14735 return false; 14736 } 14737 if (!psMetadataAdd(md, PS_LIST_TAIL, "b1_uri", PS_DATA_STRING, NULL, "255")) { 14738 psError(PS_ERR_UNKNOWN, false, "failed to add item b1_uri"); 14739 psFree(md); 14740 return false; 14741 } 14742 if (!psMetadataAdd(md, PS_LIST_TAIL, "b2_uri", PS_DATA_STRING, NULL, "255")) { 14743 psError(PS_ERR_UNKNOWN, false, "failed to add item b2_uri"); 14744 psFree(md); 14745 return false; 14746 } 14747 14748 bool status = psDBCreateTable(dbh, P4STACKEDIMFILE_TABLE_NAME, md); 14569 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4b_id", PS_DATA_S32, "Primary Key AUTO_INCREMENT", 0)) { 14570 psError(PS_ERR_UNKNOWN, false, "failed to add item p4b_id"); 14571 psFree(md); 14572 return false; 14573 } 14574 if (!psMetadataAdd(md, PS_LIST_TAIL, "state", PS_DATA_STRING, "Key", "64")) { 14575 psError(PS_ERR_UNKNOWN, false, "failed to add item state"); 14576 psFree(md); 14577 return false; 14578 } 14579 if (!psMetadataAdd(md, PS_LIST_TAIL, "workdir", PS_DATA_STRING, NULL, "255")) { 14580 psError(PS_ERR_UNKNOWN, false, "failed to add item workdir"); 14581 psFree(md); 14582 return false; 14583 } 14584 if (!psMetadataAdd(md, PS_LIST_TAIL, "magic", PS_DATA_BOOL, "Primary Key", 0)) { 14585 psError(PS_ERR_UNKNOWN, false, "failed to add item magic"); 14586 psFree(md); 14587 return false; 14588 } 14589 14590 bool status = psDBCreateTable(dbh, P4BRUN_TABLE_NAME, md); 14749 14591 14750 14592 psFree(md); … … 14753 14595 } 14754 14596 14755 bool p4 StackedImfileDropTable(psDB *dbh)14756 { 14757 return psDBDropTable(dbh, P4 STACKEDIMFILE_TABLE_NAME);14758 } 14759 14760 bool p4 StackedImfileInsert(psDB * dbh, psS32 p4_id, const char *class_id, const char *uri, const char *b1_uri, const char *b2_uri)14597 bool p4bRunDropTable(psDB *dbh) 14598 { 14599 return psDBDropTable(dbh, P4BRUN_TABLE_NAME); 14600 } 14601 14602 bool p4bRunInsert(psDB * dbh, psS32 p4b_id, const char *state, const char *workdir, bool magic) 14761 14603 { 14762 14604 psMetadata *md = psMetadataAlloc(); 14763 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4_id", PS_DATA_S32, NULL, p4_id)) { 14764 psError(PS_ERR_UNKNOWN, false, "failed to add item p4_id"); 14765 psFree(md); 14766 return false; 14767 } 14768 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, NULL, class_id)) { 14769 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id"); 14770 psFree(md); 14771 return false; 14772 } 14773 if (!psMetadataAdd(md, PS_LIST_TAIL, "uri", PS_DATA_STRING, NULL, uri)) { 14774 psError(PS_ERR_UNKNOWN, false, "failed to add item uri"); 14775 psFree(md); 14776 return false; 14777 } 14778 if (!psMetadataAdd(md, PS_LIST_TAIL, "b1_uri", PS_DATA_STRING, NULL, b1_uri)) { 14779 psError(PS_ERR_UNKNOWN, false, "failed to add item b1_uri"); 14780 psFree(md); 14781 return false; 14782 } 14783 if (!psMetadataAdd(md, PS_LIST_TAIL, "b2_uri", PS_DATA_STRING, NULL, b2_uri)) { 14784 psError(PS_ERR_UNKNOWN, false, "failed to add item b2_uri"); 14785 psFree(md); 14786 return false; 14787 } 14788 14789 bool status = psDBInsertOneRow(dbh, P4STACKEDIMFILE_TABLE_NAME, md); 14605 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4b_id", PS_DATA_S32, NULL, p4b_id)) { 14606 psError(PS_ERR_UNKNOWN, false, "failed to add item p4b_id"); 14607 psFree(md); 14608 return false; 14609 } 14610 if (!psMetadataAdd(md, PS_LIST_TAIL, "state", PS_DATA_STRING, NULL, state)) { 14611 psError(PS_ERR_UNKNOWN, false, "failed to add item state"); 14612 psFree(md); 14613 return false; 14614 } 14615 if (!psMetadataAdd(md, PS_LIST_TAIL, "workdir", PS_DATA_STRING, NULL, workdir)) { 14616 psError(PS_ERR_UNKNOWN, false, "failed to add item workdir"); 14617 psFree(md); 14618 return false; 14619 } 14620 if (!psMetadataAdd(md, PS_LIST_TAIL, "magic", PS_DATA_BOOL, NULL, magic)) { 14621 psError(PS_ERR_UNKNOWN, false, "failed to add item magic"); 14622 psFree(md); 14623 return false; 14624 } 14625 14626 bool status = psDBInsertOneRow(dbh, P4BRUN_TABLE_NAME, md); 14790 14627 psFree(md); 14791 14628 … … 14793 14630 } 14794 14631 14795 long long p4 StackedImfileDelete(psDB *dbh, const psMetadata *where, unsigned long long limit)14632 long long p4bRunDelete(psDB *dbh, const psMetadata *where, unsigned long long limit) 14796 14633 { 14797 14634 long long deleted = 0; 14798 14635 14799 long long count = psDBDeleteRows(dbh, P4 STACKEDIMFILE_TABLE_NAME, where, limit);14636 long long count = psDBDeleteRows(dbh, P4BRUN_TABLE_NAME, where, limit); 14800 14637 if (count < 0) { 14801 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 StackedImfile");14638 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4bRun"); 14802 14639 return count; 14803 14640 … … 14807 14644 return deleted; 14808 14645 } 14809 bool p4 StackedImfileInsertObject(psDB *dbh, p4StackedImfileRow *object)14810 { 14811 return p4 StackedImfileInsert(dbh, object->p4_id, object->class_id, object->uri, object->b1_uri, object->b2_uri);14812 } 14813 14814 bool p4 StackedImfileInsertObjects(psDB *dbh, psArray *objects)14646 bool p4bRunInsertObject(psDB *dbh, p4bRunRow *object) 14647 { 14648 return p4bRunInsert(dbh, object->p4b_id, object->state, object->workdir, object->magic); 14649 } 14650 14651 bool p4bRunInsertObjects(psDB *dbh, psArray *objects) 14815 14652 { 14816 14653 for (long i = 0; i < psArrayLength(objects); i++) { 14817 if (!p4 StackedImfileInsertObject(dbh, objects->data[i])) {14654 if (!p4bRunInsertObject(dbh, objects->data[i])) { 14818 14655 return false; 14819 14656 } … … 14823 14660 } 14824 14661 14825 bool p4 StackedImfileInsertFits(psDB *dbh, const psFits *fits)14662 bool p4bRunInsertFits(psDB *dbh, const psFits *fits) 14826 14663 { 14827 14664 psArray *rowSet; 14828 14665 14829 // move to (the first?) extension named P4 STACKEDIMFILE_TABLE_NAME14830 if (!psFitsMoveExtName(fits, P4 STACKEDIMFILE_TABLE_NAME)) {14831 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4 STACKEDIMFILE_TABLE_NAME);14666 // move to (the first?) extension named P4BRUN_TABLE_NAME 14667 if (!psFitsMoveExtName(fits, P4BRUN_TABLE_NAME)) { 14668 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4BRUN_TABLE_NAME); 14832 14669 return false; 14833 14670 } … … 14847 14684 } 14848 14685 14849 if (!psDBInsertRows(dbh, P4 STACKEDIMFILE_TABLE_NAME, rowSet)) {14686 if (!psDBInsertRows(dbh, P4BRUN_TABLE_NAME, rowSet)) { 14850 14687 psError(PS_ERR_UNKNOWN, false, "databse insert failed"); 14851 14688 psFree(rowSet); … … 14858 14695 } 14859 14696 14860 bool p4 StackedImfileSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit)14697 bool p4bRunSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit) 14861 14698 { 14862 14699 psArray *rowSet; 14863 14700 14864 rowSet = psDBSelectRows(dbh, P4 STACKEDIMFILE_TABLE_NAME, where, limit);14701 rowSet = psDBSelectRows(dbh, P4BRUN_TABLE_NAME, where, limit); 14865 14702 if (!rowSet) { 14866 14703 return false; … … 14868 14705 14869 14706 // output to fits 14870 if (!psFitsWriteTable(fits, NULL, rowSet, P4 STACKEDIMFILE_TABLE_NAME)) {14707 if (!psFitsWriteTable(fits, NULL, rowSet, P4BRUN_TABLE_NAME)) { 14871 14708 psError(PS_ERR_UNKNOWN, false, "FITS table write failed"); 14872 14709 psFree(rowSet); … … 14879 14716 } 14880 14717 14881 psMetadata *p4 StackedImfileMetadataFromObject(const p4StackedImfileRow *object)14718 psMetadata *p4bRunMetadataFromObject(const p4bRunRow *object) 14882 14719 { 14883 14720 psMetadata *md = psMetadataAlloc(); 14884 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4_id", PS_DATA_S32, NULL, object->p4_id)) { 14885 psError(PS_ERR_UNKNOWN, false, "failed to add item p4_id"); 14886 psFree(md); 14887 return false; 14888 } 14889 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, NULL, object->class_id)) { 14890 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id"); 14891 psFree(md); 14892 return false; 14893 } 14894 if (!psMetadataAdd(md, PS_LIST_TAIL, "uri", PS_DATA_STRING, NULL, object->uri)) { 14895 psError(PS_ERR_UNKNOWN, false, "failed to add item uri"); 14896 psFree(md); 14897 return false; 14898 } 14899 if (!psMetadataAdd(md, PS_LIST_TAIL, "b1_uri", PS_DATA_STRING, NULL, object->b1_uri)) { 14900 psError(PS_ERR_UNKNOWN, false, "failed to add item b1_uri"); 14901 psFree(md); 14902 return false; 14903 } 14904 if (!psMetadataAdd(md, PS_LIST_TAIL, "b2_uri", PS_DATA_STRING, NULL, object->b2_uri)) { 14905 psError(PS_ERR_UNKNOWN, false, "failed to add item b2_uri"); 14721 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4b_id", PS_DATA_S32, NULL, object->p4b_id)) { 14722 psError(PS_ERR_UNKNOWN, false, "failed to add item p4b_id"); 14723 psFree(md); 14724 return false; 14725 } 14726 if (!psMetadataAdd(md, PS_LIST_TAIL, "state", PS_DATA_STRING, NULL, object->state)) { 14727 psError(PS_ERR_UNKNOWN, false, "failed to add item state"); 14728 psFree(md); 14729 return false; 14730 } 14731 if (!psMetadataAdd(md, PS_LIST_TAIL, "workdir", PS_DATA_STRING, NULL, object->workdir)) { 14732 psError(PS_ERR_UNKNOWN, false, "failed to add item workdir"); 14733 psFree(md); 14734 return false; 14735 } 14736 if (!psMetadataAdd(md, PS_LIST_TAIL, "magic", PS_DATA_BOOL, NULL, object->magic)) { 14737 psError(PS_ERR_UNKNOWN, false, "failed to add item magic"); 14906 14738 psFree(md); 14907 14739 return false; … … 14912 14744 } 14913 14745 14914 p4 StackedImfileRow *p4StackedImfileObjectFromMetadata(psMetadata *md)14746 p4bRunRow *p4bRunObjectFromMetadata(psMetadata *md) 14915 14747 { 14916 14748 14917 14749 bool status = false; 14918 psS32 p4_id = psMetadataLookupS32(&status, md, "p4_id"); 14919 if (!status) { 14920 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4_id"); 14921 return false; 14922 } 14923 char* class_id = psMetadataLookupPtr(&status, md, "class_id"); 14924 if (!status) { 14925 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item class_id"); 14926 return false; 14927 } 14928 char* uri = psMetadataLookupPtr(&status, md, "uri"); 14929 if (!status) { 14930 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item uri"); 14931 return false; 14932 } 14933 char* b1_uri = psMetadataLookupPtr(&status, md, "b1_uri"); 14934 if (!status) { 14935 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item b1_uri"); 14936 return false; 14937 } 14938 char* b2_uri = psMetadataLookupPtr(&status, md, "b2_uri"); 14939 if (!status) { 14940 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item b2_uri"); 14941 return false; 14942 } 14943 14944 return p4StackedImfileRowAlloc(p4_id, class_id, uri, b1_uri, b2_uri); 14945 } 14946 psArray *p4StackedImfileSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) 14750 psS32 p4b_id = psMetadataLookupS32(&status, md, "p4b_id"); 14751 if (!status) { 14752 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4b_id"); 14753 return false; 14754 } 14755 char* state = psMetadataLookupPtr(&status, md, "state"); 14756 if (!status) { 14757 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item state"); 14758 return false; 14759 } 14760 char* workdir = psMetadataLookupPtr(&status, md, "workdir"); 14761 if (!status) { 14762 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item workdir"); 14763 return false; 14764 } 14765 bool magic = psMetadataLookupBool(&status, md, "magic"); 14766 if (!status) { 14767 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item magic"); 14768 return false; 14769 } 14770 14771 return p4bRunRowAlloc(p4b_id, state, workdir, magic); 14772 } 14773 psArray *p4bRunSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) 14947 14774 { 14948 14775 psArray *rowSet; … … 14950 14777 psU64 i; 14951 14778 14952 rowSet = psDBSelectRows(dbh, P4 STACKEDIMFILE_TABLE_NAME, where, limit);14779 rowSet = psDBSelectRows(dbh, P4BRUN_TABLE_NAME, where, limit); 14953 14780 if (!rowSet) { 14954 14781 return NULL; … … 14960 14787 14961 14788 for (i = 0; i < rowSet->n; i++) { 14962 p4 StackedImfileRow *object = p4StackedImfileObjectFromMetadata(rowSet->data[i]);14789 p4bRunRow *object = p4bRunObjectFromMetadata(rowSet->data[i]); 14963 14790 psArrayAdd(returnSet, 0, object); 14964 14791 psFree(object); … … 14969 14796 return returnSet; 14970 14797 } 14971 bool p4 StackedImfileDeleteObject(psDB *dbh, const p4StackedImfileRow *object)14972 { 14973 psMetadata *where = p4 StackedImfileMetadataFromObject(object);14974 long long count = psDBDeleteRows(dbh, P4 STACKEDIMFILE_TABLE_NAME, where, 0);14975 psFree(where) 14798 bool p4bRunDeleteObject(psDB *dbh, const p4bRunRow *object) 14799 { 14800 psMetadata *where = p4bRunMetadataFromObject(object); 14801 long long count = psDBDeleteRows(dbh, P4BRUN_TABLE_NAME, where, 0); 14802 psFree(where); 14976 14803 if (count < 0) { 14977 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 StackedImfile");14804 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4bRun"); 14978 14805 return false; 14979 14806 } … … 14981 14808 // XXX should this be a psAbort() instead? It is possible that 14982 14809 // having an object match multiple rows was by design. 14983 psError(PS_ERR_UNKNOWN, true, "p4 StackedImfileRow object matched more then one row. Check your database schema");14984 return false; 14985 } 14986 14987 return true; 14988 } 14989 long long p4 StackedImfileDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit)14810 psError(PS_ERR_UNKNOWN, true, "p4bRunRow object matched more then one row. Check your database schema"); 14811 return false; 14812 } 14813 14814 return true; 14815 } 14816 long long p4bRunDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit) 14990 14817 { 14991 14818 long long deleted = 0; 14992 14819 14993 14820 for (long long i = 0; i < objects->n; i++) { 14994 p4 StackedImfileRow *object = objects->data[i];14995 psMetadata *where = p4 StackedImfileMetadataFromObject(object);14996 long long count = psDBDeleteRows(dbh, P4 STACKEDIMFILE_TABLE_NAME, where, limit);14997 psFree(where) 14821 p4bRunRow *object = objects->data[i]; 14822 psMetadata *where = p4bRunMetadataFromObject(object); 14823 long long count = psDBDeleteRows(dbh, P4BRUN_TABLE_NAME, where, limit); 14824 psFree(where); 14998 14825 if (count < 0) { 14999 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 StackedImfile");14826 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4bRun"); 15000 14827 return count; 15001 14828 } … … 15006 14833 return deleted; 15007 14834 } 15008 bool p4 StackedImfilePrintObjects(FILE *stream, psArray *objects, bool mdcf)14835 bool p4bRunPrintObjects(FILE *stream, psArray *objects, bool mdcf) 15009 14836 { 15010 14837 PS_ASSERT_PTR_NON_NULL(objects, false); … … 15012 14839 psMetadata *output = psMetadataAlloc(); 15013 14840 for (long i = 0; i < psArrayLength(objects); i++) { 15014 psMetadata *md = p4 StackedImfileMetadataFromObject(objects->data[i]);14841 psMetadata *md = p4bRunMetadataFromObject(objects->data[i]); 15015 14842 if (!psMetadataAddMetadata( 15016 14843 output, 15017 14844 PS_LIST_TAIL, 15018 P4 STACKEDIMFILE_TABLE_NAME,14845 P4BRUN_TABLE_NAME, 15019 14846 PS_META_DUPLICATE_OK, 15020 14847 NULL, … … 15037 14864 return true; 15038 14865 } 15039 bool p4 StackedImfilePrintObject(FILE *stream, p4StackedImfileRow *object, bool mdcf)14866 bool p4bRunPrintObject(FILE *stream, p4bRunRow *object, bool mdcf) 15040 14867 { 15041 14868 PS_ASSERT_PTR_NON_NULL(object, false); 15042 14869 15043 psMetadata *md = p4 StackedImfileMetadataFromObject(object);14870 psMetadata *md = p4bRunMetadataFromObject(object); 15044 14871 15045 14872 if (!ippdbPrintMetadataRaw(stream, md, mdcf)) { … … 15052 14879 return true; 15053 14880 } 15054 static void p4DiffImfileRowFree(p4DiffImfileRow *object); 15055 15056 p4DiffImfileRow *p4DiffImfileRowAlloc(psS32 p4_id, const char *exp_tag, psS32 p3_version, const char *class_id, const char *uri, const char *b1_uri, const char *b2_uri) 15057 { 15058 p4DiffImfileRow *_object; 15059 15060 _object = psAlloc(sizeof(p4DiffImfileRow)); 15061 psMemSetDeallocator(_object, (psFreeFunc)p4DiffImfileRowFree); 15062 15063 _object->p4_id = p4_id; 14881 static void p4bInputScfileRowFree(p4bInputScfileRow *object); 14882 14883 p4bInputScfileRow *p4bInputScfileRowAlloc(psS32 p4b_id, const char *skycell_id, const char *tess_id, const char *exp_tag, psS32 p3_version, const char *kind) 14884 { 14885 p4bInputScfileRow *_object; 14886 14887 _object = psAlloc(sizeof(p4bInputScfileRow)); 14888 psMemSetDeallocator(_object, (psFreeFunc)p4bInputScfileRowFree); 14889 14890 _object->p4b_id = p4b_id; 14891 _object->skycell_id = psStringCopy(skycell_id); 14892 _object->tess_id = psStringCopy(tess_id); 15064 14893 _object->exp_tag = psStringCopy(exp_tag); 15065 14894 _object->p3_version = p3_version; 15066 _object->class_id = psStringCopy(class_id); 15067 _object->uri = psStringCopy(uri); 15068 _object->b1_uri = psStringCopy(b1_uri); 15069 _object->b2_uri = psStringCopy(b2_uri); 14895 _object->kind = psStringCopy(kind); 15070 14896 15071 14897 return _object; 15072 14898 } 15073 14899 15074 static void p4DiffImfileRowFree(p4DiffImfileRow *object) 15075 { 14900 static void p4bInputScfileRowFree(p4bInputScfileRow *object) 14901 { 14902 psFree(object->skycell_id); 14903 psFree(object->tess_id); 15076 14904 psFree(object->exp_tag); 15077 psFree(object->class_id); 15078 psFree(object->uri); 15079 psFree(object->b1_uri); 15080 psFree(object->b2_uri); 15081 } 15082 15083 bool p4DiffImfileCreateTable(psDB *dbh) 14905 psFree(object->kind); 14906 } 14907 14908 bool p4bInputScfileCreateTable(psDB *dbh) 15084 14909 { 15085 14910 psMetadata *md = psMetadataAlloc(); 15086 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4_id", PS_DATA_S32, "Primary Key", 0)) { 15087 psError(PS_ERR_UNKNOWN, false, "failed to add item p4_id"); 14911 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4b_id", PS_DATA_S32, "Primary Key", 0)) { 14912 psError(PS_ERR_UNKNOWN, false, "failed to add item p4b_id"); 14913 psFree(md); 14914 return false; 14915 } 14916 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, "Primary Key", "64")) { 14917 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 14918 psFree(md); 14919 return false; 14920 } 14921 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, "Primary Key", "64")) { 14922 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 15088 14923 psFree(md); 15089 14924 return false; … … 15099 14934 return false; 15100 14935 } 15101 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, "Primary Key", "64")) { 15102 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id"); 15103 psFree(md); 15104 return false; 15105 } 15106 if (!psMetadataAdd(md, PS_LIST_TAIL, "uri", PS_DATA_STRING, NULL, "255")) { 15107 psError(PS_ERR_UNKNOWN, false, "failed to add item uri"); 15108 psFree(md); 15109 return false; 15110 } 15111 if (!psMetadataAdd(md, PS_LIST_TAIL, "b1_uri", PS_DATA_STRING, NULL, "255")) { 15112 psError(PS_ERR_UNKNOWN, false, "failed to add item b1_uri"); 15113 psFree(md); 15114 return false; 15115 } 15116 if (!psMetadataAdd(md, PS_LIST_TAIL, "b2_uri", PS_DATA_STRING, NULL, "255")) { 15117 psError(PS_ERR_UNKNOWN, false, "failed to add item b2_uri"); 15118 psFree(md); 15119 return false; 15120 } 15121 15122 bool status = psDBCreateTable(dbh, P4DIFFIMFILE_TABLE_NAME, md); 14936 if (!psMetadataAdd(md, PS_LIST_TAIL, "kind", PS_DATA_STRING, "Key", "64")) { 14937 psError(PS_ERR_UNKNOWN, false, "failed to add item kind"); 14938 psFree(md); 14939 return false; 14940 } 14941 14942 bool status = psDBCreateTable(dbh, P4BINPUTSCFILE_TABLE_NAME, md); 15123 14943 15124 14944 psFree(md); … … 15127 14947 } 15128 14948 15129 bool p4 DiffImfileDropTable(psDB *dbh)15130 { 15131 return psDBDropTable(dbh, P4 DIFFIMFILE_TABLE_NAME);15132 } 15133 15134 bool p4 DiffImfileInsert(psDB * dbh, psS32 p4_id, const char *exp_tag, psS32 p3_version, const char *class_id, const char *uri, const char *b1_uri, const char *b2_uri)14949 bool p4bInputScfileDropTable(psDB *dbh) 14950 { 14951 return psDBDropTable(dbh, P4BINPUTSCFILE_TABLE_NAME); 14952 } 14953 14954 bool p4bInputScfileInsert(psDB * dbh, psS32 p4b_id, const char *skycell_id, const char *tess_id, const char *exp_tag, psS32 p3_version, const char *kind) 15135 14955 { 15136 14956 psMetadata *md = psMetadataAlloc(); 15137 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4_id", PS_DATA_S32, NULL, p4_id)) { 15138 psError(PS_ERR_UNKNOWN, false, "failed to add item p4_id"); 14957 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4b_id", PS_DATA_S32, NULL, p4b_id)) { 14958 psError(PS_ERR_UNKNOWN, false, "failed to add item p4b_id"); 14959 psFree(md); 14960 return false; 14961 } 14962 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, NULL, skycell_id)) { 14963 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 14964 psFree(md); 14965 return false; 14966 } 14967 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, NULL, tess_id)) { 14968 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 15139 14969 psFree(md); 15140 14970 return false; … … 15150 14980 return false; 15151 14981 } 15152 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, NULL, class_id)) { 15153 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id"); 15154 psFree(md); 15155 return false; 15156 } 15157 if (!psMetadataAdd(md, PS_LIST_TAIL, "uri", PS_DATA_STRING, NULL, uri)) { 15158 psError(PS_ERR_UNKNOWN, false, "failed to add item uri"); 15159 psFree(md); 15160 return false; 15161 } 15162 if (!psMetadataAdd(md, PS_LIST_TAIL, "b1_uri", PS_DATA_STRING, NULL, b1_uri)) { 15163 psError(PS_ERR_UNKNOWN, false, "failed to add item b1_uri"); 15164 psFree(md); 15165 return false; 15166 } 15167 if (!psMetadataAdd(md, PS_LIST_TAIL, "b2_uri", PS_DATA_STRING, NULL, b2_uri)) { 15168 psError(PS_ERR_UNKNOWN, false, "failed to add item b2_uri"); 15169 psFree(md); 15170 return false; 15171 } 15172 15173 bool status = psDBInsertOneRow(dbh, P4DIFFIMFILE_TABLE_NAME, md); 14982 if (!psMetadataAdd(md, PS_LIST_TAIL, "kind", PS_DATA_STRING, NULL, kind)) { 14983 psError(PS_ERR_UNKNOWN, false, "failed to add item kind"); 14984 psFree(md); 14985 return false; 14986 } 14987 14988 bool status = psDBInsertOneRow(dbh, P4BINPUTSCFILE_TABLE_NAME, md); 15174 14989 psFree(md); 15175 14990 … … 15177 14992 } 15178 14993 15179 long long p4 DiffImfileDelete(psDB *dbh, const psMetadata *where, unsigned long long limit)14994 long long p4bInputScfileDelete(psDB *dbh, const psMetadata *where, unsigned long long limit) 15180 14995 { 15181 14996 long long deleted = 0; 15182 14997 15183 long long count = psDBDeleteRows(dbh, P4 DIFFIMFILE_TABLE_NAME, where, limit);14998 long long count = psDBDeleteRows(dbh, P4BINPUTSCFILE_TABLE_NAME, where, limit); 15184 14999 if (count < 0) { 15185 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 DiffImfile");15000 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4bInputScfile"); 15186 15001 return count; 15187 15002 … … 15191 15006 return deleted; 15192 15007 } 15193 bool p4 DiffImfileInsertObject(psDB *dbh, p4DiffImfileRow *object)15194 { 15195 return p4 DiffImfileInsert(dbh, object->p4_id, object->exp_tag, object->p3_version, object->class_id, object->uri, object->b1_uri, object->b2_uri);15196 } 15197 15198 bool p4 DiffImfileInsertObjects(psDB *dbh, psArray *objects)15008 bool p4bInputScfileInsertObject(psDB *dbh, p4bInputScfileRow *object) 15009 { 15010 return p4bInputScfileInsert(dbh, object->p4b_id, object->skycell_id, object->tess_id, object->exp_tag, object->p3_version, object->kind); 15011 } 15012 15013 bool p4bInputScfileInsertObjects(psDB *dbh, psArray *objects) 15199 15014 { 15200 15015 for (long i = 0; i < psArrayLength(objects); i++) { 15201 if (!p4 DiffImfileInsertObject(dbh, objects->data[i])) {15016 if (!p4bInputScfileInsertObject(dbh, objects->data[i])) { 15202 15017 return false; 15203 15018 } … … 15207 15022 } 15208 15023 15209 bool p4 DiffImfileInsertFits(psDB *dbh, const psFits *fits)15024 bool p4bInputScfileInsertFits(psDB *dbh, const psFits *fits) 15210 15025 { 15211 15026 psArray *rowSet; 15212 15027 15213 // move to (the first?) extension named P4 DIFFIMFILE_TABLE_NAME15214 if (!psFitsMoveExtName(fits, P4 DIFFIMFILE_TABLE_NAME)) {15215 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4 DIFFIMFILE_TABLE_NAME);15028 // move to (the first?) extension named P4BINPUTSCFILE_TABLE_NAME 15029 if (!psFitsMoveExtName(fits, P4BINPUTSCFILE_TABLE_NAME)) { 15030 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4BINPUTSCFILE_TABLE_NAME); 15216 15031 return false; 15217 15032 } … … 15231 15046 } 15232 15047 15233 if (!psDBInsertRows(dbh, P4 DIFFIMFILE_TABLE_NAME, rowSet)) {15048 if (!psDBInsertRows(dbh, P4BINPUTSCFILE_TABLE_NAME, rowSet)) { 15234 15049 psError(PS_ERR_UNKNOWN, false, "databse insert failed"); 15235 15050 psFree(rowSet); … … 15242 15057 } 15243 15058 15244 bool p4 DiffImfileSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit)15059 bool p4bInputScfileSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit) 15245 15060 { 15246 15061 psArray *rowSet; 15247 15062 15248 rowSet = psDBSelectRows(dbh, P4 DIFFIMFILE_TABLE_NAME, where, limit);15063 rowSet = psDBSelectRows(dbh, P4BINPUTSCFILE_TABLE_NAME, where, limit); 15249 15064 if (!rowSet) { 15250 15065 return false; … … 15252 15067 15253 15068 // output to fits 15254 if (!psFitsWriteTable(fits, NULL, rowSet, P4 DIFFIMFILE_TABLE_NAME)) {15069 if (!psFitsWriteTable(fits, NULL, rowSet, P4BINPUTSCFILE_TABLE_NAME)) { 15255 15070 psError(PS_ERR_UNKNOWN, false, "FITS table write failed"); 15256 15071 psFree(rowSet); … … 15263 15078 } 15264 15079 15265 psMetadata *p4 DiffImfileMetadataFromObject(const p4DiffImfileRow *object)15080 psMetadata *p4bInputScfileMetadataFromObject(const p4bInputScfileRow *object) 15266 15081 { 15267 15082 psMetadata *md = psMetadataAlloc(); 15268 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4_id", PS_DATA_S32, NULL, object->p4_id)) { 15269 psError(PS_ERR_UNKNOWN, false, "failed to add item p4_id"); 15083 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4b_id", PS_DATA_S32, NULL, object->p4b_id)) { 15084 psError(PS_ERR_UNKNOWN, false, "failed to add item p4b_id"); 15085 psFree(md); 15086 return false; 15087 } 15088 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, NULL, object->skycell_id)) { 15089 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 15090 psFree(md); 15091 return false; 15092 } 15093 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, NULL, object->tess_id)) { 15094 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 15270 15095 psFree(md); 15271 15096 return false; … … 15281 15106 return false; 15282 15107 } 15283 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, NULL, object->class_id)) { 15284 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id"); 15285 psFree(md); 15286 return false; 15287 } 15288 if (!psMetadataAdd(md, PS_LIST_TAIL, "uri", PS_DATA_STRING, NULL, object->uri)) { 15289 psError(PS_ERR_UNKNOWN, false, "failed to add item uri"); 15290 psFree(md); 15291 return false; 15292 } 15293 if (!psMetadataAdd(md, PS_LIST_TAIL, "b1_uri", PS_DATA_STRING, NULL, object->b1_uri)) { 15294 psError(PS_ERR_UNKNOWN, false, "failed to add item b1_uri"); 15295 psFree(md); 15296 return false; 15297 } 15298 if (!psMetadataAdd(md, PS_LIST_TAIL, "b2_uri", PS_DATA_STRING, NULL, object->b2_uri)) { 15299 psError(PS_ERR_UNKNOWN, false, "failed to add item b2_uri"); 15108 if (!psMetadataAdd(md, PS_LIST_TAIL, "kind", PS_DATA_STRING, NULL, object->kind)) { 15109 psError(PS_ERR_UNKNOWN, false, "failed to add item kind"); 15300 15110 psFree(md); 15301 15111 return false; … … 15306 15116 } 15307 15117 15308 p4 DiffImfileRow *p4DiffImfileObjectFromMetadata(psMetadata *md)15118 p4bInputScfileRow *p4bInputScfileObjectFromMetadata(psMetadata *md) 15309 15119 { 15310 15120 15311 15121 bool status = false; 15312 psS32 p4_id = psMetadataLookupS32(&status, md, "p4_id"); 15313 if (!status) { 15314 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4_id"); 15122 psS32 p4b_id = psMetadataLookupS32(&status, md, "p4b_id"); 15123 if (!status) { 15124 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4b_id"); 15125 return false; 15126 } 15127 char* skycell_id = psMetadataLookupPtr(&status, md, "skycell_id"); 15128 if (!status) { 15129 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item skycell_id"); 15130 return false; 15131 } 15132 char* tess_id = psMetadataLookupPtr(&status, md, "tess_id"); 15133 if (!status) { 15134 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item tess_id"); 15315 15135 return false; 15316 15136 } … … 15325 15145 return false; 15326 15146 } 15327 char* class_id = psMetadataLookupPtr(&status, md, "class_id"); 15328 if (!status) { 15329 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item class_id"); 15330 return false; 15331 } 15332 char* uri = psMetadataLookupPtr(&status, md, "uri"); 15333 if (!status) { 15334 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item uri"); 15335 return false; 15336 } 15337 char* b1_uri = psMetadataLookupPtr(&status, md, "b1_uri"); 15338 if (!status) { 15339 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item b1_uri"); 15340 return false; 15341 } 15342 char* b2_uri = psMetadataLookupPtr(&status, md, "b2_uri"); 15343 if (!status) { 15344 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item b2_uri"); 15345 return false; 15346 } 15347 15348 return p4DiffImfileRowAlloc(p4_id, exp_tag, p3_version, class_id, uri, b1_uri, b2_uri); 15349 } 15350 psArray *p4DiffImfileSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) 15147 char* kind = psMetadataLookupPtr(&status, md, "kind"); 15148 if (!status) { 15149 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item kind"); 15150 return false; 15151 } 15152 15153 return p4bInputScfileRowAlloc(p4b_id, skycell_id, tess_id, exp_tag, p3_version, kind); 15154 } 15155 psArray *p4bInputScfileSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) 15351 15156 { 15352 15157 psArray *rowSet; … … 15354 15159 psU64 i; 15355 15160 15356 rowSet = psDBSelectRows(dbh, P4 DIFFIMFILE_TABLE_NAME, where, limit);15161 rowSet = psDBSelectRows(dbh, P4BINPUTSCFILE_TABLE_NAME, where, limit); 15357 15162 if (!rowSet) { 15358 15163 return NULL; … … 15364 15169 15365 15170 for (i = 0; i < rowSet->n; i++) { 15366 p4 DiffImfileRow *object = p4DiffImfileObjectFromMetadata(rowSet->data[i]);15171 p4bInputScfileRow *object = p4bInputScfileObjectFromMetadata(rowSet->data[i]); 15367 15172 psArrayAdd(returnSet, 0, object); 15368 15173 psFree(object); … … 15373 15178 return returnSet; 15374 15179 } 15375 bool p4 DiffImfileDeleteObject(psDB *dbh, const p4DiffImfileRow *object)15376 { 15377 psMetadata *where = p4 DiffImfileMetadataFromObject(object);15378 long long count = psDBDeleteRows(dbh, P4 DIFFIMFILE_TABLE_NAME, where, 0);15379 psFree(where) 15180 bool p4bInputScfileDeleteObject(psDB *dbh, const p4bInputScfileRow *object) 15181 { 15182 psMetadata *where = p4bInputScfileMetadataFromObject(object); 15183 long long count = psDBDeleteRows(dbh, P4BINPUTSCFILE_TABLE_NAME, where, 0); 15184 psFree(where); 15380 15185 if (count < 0) { 15381 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 DiffImfile");15186 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4bInputScfile"); 15382 15187 return false; 15383 15188 } … … 15385 15190 // XXX should this be a psAbort() instead? It is possible that 15386 15191 // having an object match multiple rows was by design. 15387 psError(PS_ERR_UNKNOWN, true, "p4 DiffImfileRow object matched more then one row. Check your database schema");15388 return false; 15389 } 15390 15391 return true; 15392 } 15393 long long p4 DiffImfileDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit)15192 psError(PS_ERR_UNKNOWN, true, "p4bInputScfileRow object matched more then one row. Check your database schema"); 15193 return false; 15194 } 15195 15196 return true; 15197 } 15198 long long p4bInputScfileDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit) 15394 15199 { 15395 15200 long long deleted = 0; 15396 15201 15397 15202 for (long long i = 0; i < objects->n; i++) { 15398 p4 DiffImfileRow *object = objects->data[i];15399 psMetadata *where = p4 DiffImfileMetadataFromObject(object);15400 long long count = psDBDeleteRows(dbh, P4 DIFFIMFILE_TABLE_NAME, where, limit);15401 psFree(where) 15203 p4bInputScfileRow *object = objects->data[i]; 15204 psMetadata *where = p4bInputScfileMetadataFromObject(object); 15205 long long count = psDBDeleteRows(dbh, P4BINPUTSCFILE_TABLE_NAME, where, limit); 15206 psFree(where); 15402 15207 if (count < 0) { 15403 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 DiffImfile");15208 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4bInputScfile"); 15404 15209 return count; 15405 15210 } … … 15410 15215 return deleted; 15411 15216 } 15412 bool p4 DiffImfilePrintObjects(FILE *stream, psArray *objects, bool mdcf)15217 bool p4bInputScfilePrintObjects(FILE *stream, psArray *objects, bool mdcf) 15413 15218 { 15414 15219 PS_ASSERT_PTR_NON_NULL(objects, false); … … 15416 15221 psMetadata *output = psMetadataAlloc(); 15417 15222 for (long i = 0; i < psArrayLength(objects); i++) { 15418 psMetadata *md = p4 DiffImfileMetadataFromObject(objects->data[i]);15223 psMetadata *md = p4bInputScfileMetadataFromObject(objects->data[i]); 15419 15224 if (!psMetadataAddMetadata( 15420 15225 output, 15421 15226 PS_LIST_TAIL, 15422 P4 DIFFIMFILE_TABLE_NAME,15227 P4BINPUTSCFILE_TABLE_NAME, 15423 15228 PS_META_DUPLICATE_OK, 15424 15229 NULL, … … 15441 15246 return true; 15442 15247 } 15443 bool p4 DiffImfilePrintObject(FILE *stream, p4DiffImfileRow *object, bool mdcf)15248 bool p4bInputScfilePrintObject(FILE *stream, p4bInputScfileRow *object, bool mdcf) 15444 15249 { 15445 15250 PS_ASSERT_PTR_NON_NULL(object, false); 15446 15251 15447 psMetadata *md = p4 DiffImfileMetadataFromObject(object);15252 psMetadata *md = p4bInputScfileMetadataFromObject(object); 15448 15253 15449 15254 if (!ippdbPrintMetadataRaw(stream, md, mdcf)) { … … 15456 15261 return true; 15457 15262 } 15458 static void p4MagicMaskImfileRowFree(p4MagicMaskImfileRow *object); 15459 15460 p4MagicMaskImfileRow *p4MagicMaskImfileRowAlloc(psS32 p4_id, const char *exp_tag, psS32 p3_version, const char *class_id, const char *uri) 15461 { 15462 p4MagicMaskImfileRow *_object; 15463 15464 _object = psAlloc(sizeof(p4MagicMaskImfileRow)); 15465 psMemSetDeallocator(_object, (psFreeFunc)p4MagicMaskImfileRowFree); 15466 15467 _object->p4_id = p4_id; 15263 static void p4bDiffScfileRowFree(p4bDiffScfileRow *object); 15264 15265 p4bDiffScfileRow *p4bDiffScfileRowAlloc(psS32 p4b_id, const char *skycell_id, const char *tess_id, const char *exp_tag, psS32 p3_version, const char *uri, psF64 bg, psF64 bg_mean_stdev) 15266 { 15267 p4bDiffScfileRow *_object; 15268 15269 _object = psAlloc(sizeof(p4bDiffScfileRow)); 15270 psMemSetDeallocator(_object, (psFreeFunc)p4bDiffScfileRowFree); 15271 15272 _object->p4b_id = p4b_id; 15273 _object->skycell_id = psStringCopy(skycell_id); 15274 _object->tess_id = psStringCopy(tess_id); 15468 15275 _object->exp_tag = psStringCopy(exp_tag); 15469 15276 _object->p3_version = p3_version; 15470 _object->class_id = psStringCopy(class_id);15471 15277 _object->uri = psStringCopy(uri); 15278 _object->bg = bg; 15279 _object->bg_mean_stdev = bg_mean_stdev; 15472 15280 15473 15281 return _object; 15474 15282 } 15475 15283 15476 static void p4MagicMaskImfileRowFree(p4MagicMaskImfileRow *object) 15477 { 15284 static void p4bDiffScfileRowFree(p4bDiffScfileRow *object) 15285 { 15286 psFree(object->skycell_id); 15287 psFree(object->tess_id); 15478 15288 psFree(object->exp_tag); 15479 psFree(object->class_id);15480 15289 psFree(object->uri); 15481 15290 } 15482 15291 15483 bool p4 MagicMaskImfileCreateTable(psDB *dbh)15292 bool p4bDiffScfileCreateTable(psDB *dbh) 15484 15293 { 15485 15294 psMetadata *md = psMetadataAlloc(); 15486 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4_id", PS_DATA_S32, "Primary Key", 0)) { 15487 psError(PS_ERR_UNKNOWN, false, "failed to add item p4_id"); 15295 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4b_id", PS_DATA_S32, "Primary Key", 0)) { 15296 psError(PS_ERR_UNKNOWN, false, "failed to add item p4b_id"); 15297 psFree(md); 15298 return false; 15299 } 15300 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, "Primary Key", "64")) { 15301 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 15302 psFree(md); 15303 return false; 15304 } 15305 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, "Primary Key", "64")) { 15306 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 15488 15307 psFree(md); 15489 15308 return false; … … 15499 15318 return false; 15500 15319 } 15501 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, "Primary Key", "64")) {15502 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id");15503 psFree(md);15504 return false;15505 }15506 15320 if (!psMetadataAdd(md, PS_LIST_TAIL, "uri", PS_DATA_STRING, NULL, "255")) { 15507 15321 psError(PS_ERR_UNKNOWN, false, "failed to add item uri"); … … 15509 15323 return false; 15510 15324 } 15511 15512 bool status = psDBCreateTable(dbh, P4MAGICMASKIMFILE_TABLE_NAME, md); 15325 if (!psMetadataAdd(md, PS_LIST_TAIL, "bg", PS_DATA_F64, NULL, 0.0)) { 15326 psError(PS_ERR_UNKNOWN, false, "failed to add item bg"); 15327 psFree(md); 15328 return false; 15329 } 15330 if (!psMetadataAdd(md, PS_LIST_TAIL, "bg_mean_stdev", PS_DATA_F64, NULL, 0.0)) { 15331 psError(PS_ERR_UNKNOWN, false, "failed to add item bg_mean_stdev"); 15332 psFree(md); 15333 return false; 15334 } 15335 15336 bool status = psDBCreateTable(dbh, P4BDIFFSCFILE_TABLE_NAME, md); 15513 15337 15514 15338 psFree(md); … … 15517 15341 } 15518 15342 15519 bool p4 MagicMaskImfileDropTable(psDB *dbh)15520 { 15521 return psDBDropTable(dbh, P4 MAGICMASKIMFILE_TABLE_NAME);15522 } 15523 15524 bool p4 MagicMaskImfileInsert(psDB * dbh, psS32 p4_id, const char *exp_tag, psS32 p3_version, const char *class_id, const char *uri)15343 bool p4bDiffScfileDropTable(psDB *dbh) 15344 { 15345 return psDBDropTable(dbh, P4BDIFFSCFILE_TABLE_NAME); 15346 } 15347 15348 bool p4bDiffScfileInsert(psDB * dbh, psS32 p4b_id, const char *skycell_id, const char *tess_id, const char *exp_tag, psS32 p3_version, const char *uri, psF64 bg, psF64 bg_mean_stdev) 15525 15349 { 15526 15350 psMetadata *md = psMetadataAlloc(); 15527 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4_id", PS_DATA_S32, NULL, p4_id)) { 15528 psError(PS_ERR_UNKNOWN, false, "failed to add item p4_id"); 15351 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4b_id", PS_DATA_S32, NULL, p4b_id)) { 15352 psError(PS_ERR_UNKNOWN, false, "failed to add item p4b_id"); 15353 psFree(md); 15354 return false; 15355 } 15356 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, NULL, skycell_id)) { 15357 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 15358 psFree(md); 15359 return false; 15360 } 15361 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, NULL, tess_id)) { 15362 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 15529 15363 psFree(md); 15530 15364 return false; … … 15540 15374 return false; 15541 15375 } 15542 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, NULL, class_id)) {15543 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id");15544 psFree(md);15545 return false;15546 }15547 15376 if (!psMetadataAdd(md, PS_LIST_TAIL, "uri", PS_DATA_STRING, NULL, uri)) { 15548 15377 psError(PS_ERR_UNKNOWN, false, "failed to add item uri"); … … 15550 15379 return false; 15551 15380 } 15552 15553 bool status = psDBInsertOneRow(dbh, P4MAGICMASKIMFILE_TABLE_NAME, md); 15381 if (!psMetadataAdd(md, PS_LIST_TAIL, "bg", PS_DATA_F64, NULL, bg)) { 15382 psError(PS_ERR_UNKNOWN, false, "failed to add item bg"); 15383 psFree(md); 15384 return false; 15385 } 15386 if (!psMetadataAdd(md, PS_LIST_TAIL, "bg_mean_stdev", PS_DATA_F64, NULL, bg_mean_stdev)) { 15387 psError(PS_ERR_UNKNOWN, false, "failed to add item bg_mean_stdev"); 15388 psFree(md); 15389 return false; 15390 } 15391 15392 bool status = psDBInsertOneRow(dbh, P4BDIFFSCFILE_TABLE_NAME, md); 15554 15393 psFree(md); 15555 15394 … … 15557 15396 } 15558 15397 15559 long long p4 MagicMaskImfileDelete(psDB *dbh, const psMetadata *where, unsigned long long limit)15398 long long p4bDiffScfileDelete(psDB *dbh, const psMetadata *where, unsigned long long limit) 15560 15399 { 15561 15400 long long deleted = 0; 15562 15401 15563 long long count = psDBDeleteRows(dbh, P4 MAGICMASKIMFILE_TABLE_NAME, where, limit);15402 long long count = psDBDeleteRows(dbh, P4BDIFFSCFILE_TABLE_NAME, where, limit); 15564 15403 if (count < 0) { 15565 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4 MagicMaskImfile");15404 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4bDiffScfile"); 15566 15405 return count; 15567 15406 … … 15571 15410 return deleted; 15572 15411 } 15573 bool p4 MagicMaskImfileInsertObject(psDB *dbh, p4MagicMaskImfileRow *object)15574 { 15575 return p4 MagicMaskImfileInsert(dbh, object->p4_id, object->exp_tag, object->p3_version, object->class_id, object->uri);15576 } 15577 15578 bool p4 MagicMaskImfileInsertObjects(psDB *dbh, psArray *objects)15412 bool p4bDiffScfileInsertObject(psDB *dbh, p4bDiffScfileRow *object) 15413 { 15414 return p4bDiffScfileInsert(dbh, object->p4b_id, object->skycell_id, object->tess_id, object->exp_tag, object->p3_version, object->uri, object->bg, object->bg_mean_stdev); 15415 } 15416 15417 bool p4bDiffScfileInsertObjects(psDB *dbh, psArray *objects) 15579 15418 { 15580 15419 for (long i = 0; i < psArrayLength(objects); i++) { 15581 if (!p4 MagicMaskImfileInsertObject(dbh, objects->data[i])) {15420 if (!p4bDiffScfileInsertObject(dbh, objects->data[i])) { 15582 15421 return false; 15583 15422 } … … 15587 15426 } 15588 15427 15589 bool p4 MagicMaskImfileInsertFits(psDB *dbh, const psFits *fits)15428 bool p4bDiffScfileInsertFits(psDB *dbh, const psFits *fits) 15590 15429 { 15591 15430 psArray *rowSet; 15592 15431 15593 // move to (the first?) extension named P4 MAGICMASKIMFILE_TABLE_NAME15594 if (!psFitsMoveExtName(fits, P4 MAGICMASKIMFILE_TABLE_NAME)) {15595 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4 MAGICMASKIMFILE_TABLE_NAME);15432 // move to (the first?) extension named P4BDIFFSCFILE_TABLE_NAME 15433 if (!psFitsMoveExtName(fits, P4BDIFFSCFILE_TABLE_NAME)) { 15434 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4BDIFFSCFILE_TABLE_NAME); 15596 15435 return false; 15597 15436 } … … 15611 15450 } 15612 15451 15452 if (!psDBInsertRows(dbh, P4BDIFFSCFILE_TABLE_NAME, rowSet)) { 15453 psError(PS_ERR_UNKNOWN, false, "databse insert failed"); 15454 psFree(rowSet); 15455 return false; 15456 } 15457 15458 psFree(rowSet); 15459 15460 return true; 15461 } 15462 15463 bool p4bDiffScfileSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit) 15464 { 15465 psArray *rowSet; 15466 15467 rowSet = psDBSelectRows(dbh, P4BDIFFSCFILE_TABLE_NAME, where, limit); 15468 if (!rowSet) { 15469 return false; 15470 } 15471 15472 // output to fits 15473 if (!psFitsWriteTable(fits, NULL, rowSet, P4BDIFFSCFILE_TABLE_NAME)) { 15474 psError(PS_ERR_UNKNOWN, false, "FITS table write failed"); 15475 psFree(rowSet); 15476 return false; 15477 } 15478 15479 psFree(rowSet); 15480 15481 return true; 15482 } 15483 15484 psMetadata *p4bDiffScfileMetadataFromObject(const p4bDiffScfileRow *object) 15485 { 15486 psMetadata *md = psMetadataAlloc(); 15487 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4b_id", PS_DATA_S32, NULL, object->p4b_id)) { 15488 psError(PS_ERR_UNKNOWN, false, "failed to add item p4b_id"); 15489 psFree(md); 15490 return false; 15491 } 15492 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, NULL, object->skycell_id)) { 15493 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 15494 psFree(md); 15495 return false; 15496 } 15497 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, NULL, object->tess_id)) { 15498 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 15499 psFree(md); 15500 return false; 15501 } 15502 if (!psMetadataAdd(md, PS_LIST_TAIL, "exp_tag", PS_DATA_STRING, NULL, object->exp_tag)) { 15503 psError(PS_ERR_UNKNOWN, false, "failed to add item exp_tag"); 15504 psFree(md); 15505 return false; 15506 } 15507 if (!psMetadataAdd(md, PS_LIST_TAIL, "p3_version", PS_DATA_S32, NULL, object->p3_version)) { 15508 psError(PS_ERR_UNKNOWN, false, "failed to add item p3_version"); 15509 psFree(md); 15510 return false; 15511 } 15512 if (!psMetadataAdd(md, PS_LIST_TAIL, "uri", PS_DATA_STRING, NULL, object->uri)) { 15513 psError(PS_ERR_UNKNOWN, false, "failed to add item uri"); 15514 psFree(md); 15515 return false; 15516 } 15517 if (!psMetadataAdd(md, PS_LIST_TAIL, "bg", PS_DATA_F64, NULL, object->bg)) { 15518 psError(PS_ERR_UNKNOWN, false, "failed to add item bg"); 15519 psFree(md); 15520 return false; 15521 } 15522 if (!psMetadataAdd(md, PS_LIST_TAIL, "bg_mean_stdev", PS_DATA_F64, NULL, object->bg_mean_stdev)) { 15523 psError(PS_ERR_UNKNOWN, false, "failed to add item bg_mean_stdev"); 15524 psFree(md); 15525 return false; 15526 } 15527 15528 15529 return md; 15530 } 15531 15532 p4bDiffScfileRow *p4bDiffScfileObjectFromMetadata(psMetadata *md) 15533 { 15534 15535 bool status = false; 15536 psS32 p4b_id = psMetadataLookupS32(&status, md, "p4b_id"); 15537 if (!status) { 15538 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4b_id"); 15539 return false; 15540 } 15541 char* skycell_id = psMetadataLookupPtr(&status, md, "skycell_id"); 15542 if (!status) { 15543 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item skycell_id"); 15544 return false; 15545 } 15546 char* tess_id = psMetadataLookupPtr(&status, md, "tess_id"); 15547 if (!status) { 15548 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item tess_id"); 15549 return false; 15550 } 15551 char* exp_tag = psMetadataLookupPtr(&status, md, "exp_tag"); 15552 if (!status) { 15553 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item exp_tag"); 15554 return false; 15555 } 15556 psS32 p3_version = psMetadataLookupS32(&status, md, "p3_version"); 15557 if (!status) { 15558 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p3_version"); 15559 return false; 15560 } 15561 char* uri = psMetadataLookupPtr(&status, md, "uri"); 15562 if (!status) { 15563 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item uri"); 15564 return false; 15565 } 15566 psF64 bg = psMetadataLookupF64(&status, md, "bg"); 15567 if (!status) { 15568 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item bg"); 15569 return false; 15570 } 15571 psF64 bg_mean_stdev = psMetadataLookupF64(&status, md, "bg_mean_stdev"); 15572 if (!status) { 15573 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item bg_mean_stdev"); 15574 return false; 15575 } 15576 15577 return p4bDiffScfileRowAlloc(p4b_id, skycell_id, tess_id, exp_tag, p3_version, uri, bg, bg_mean_stdev); 15578 } 15579 psArray *p4bDiffScfileSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) 15580 { 15581 psArray *rowSet; 15582 psArray *returnSet; 15583 psU64 i; 15584 15585 rowSet = psDBSelectRows(dbh, P4BDIFFSCFILE_TABLE_NAME, where, limit); 15586 if (!rowSet) { 15587 return NULL; 15588 } 15589 15590 // convert psMetadata rows to row objects 15591 15592 returnSet = psArrayAllocEmpty(rowSet->n); 15593 15594 for (i = 0; i < rowSet->n; i++) { 15595 p4bDiffScfileRow *object = p4bDiffScfileObjectFromMetadata(rowSet->data[i]); 15596 psArrayAdd(returnSet, 0, object); 15597 psFree(object); 15598 } 15599 15600 psFree(rowSet); 15601 15602 return returnSet; 15603 } 15604 bool p4bDiffScfileDeleteObject(psDB *dbh, const p4bDiffScfileRow *object) 15605 { 15606 psMetadata *where = p4bDiffScfileMetadataFromObject(object); 15607 long long count = psDBDeleteRows(dbh, P4BDIFFSCFILE_TABLE_NAME, where, 0); 15608 psFree(where); 15609 if (count < 0) { 15610 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4bDiffScfile"); 15611 return false; 15612 } 15613 if (count > 1) { 15614 // XXX should this be a psAbort() instead? It is possible that 15615 // having an object match multiple rows was by design. 15616 psError(PS_ERR_UNKNOWN, true, "p4bDiffScfileRow object matched more then one row. Check your database schema"); 15617 return false; 15618 } 15619 15620 return true; 15621 } 15622 long long p4bDiffScfileDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit) 15623 { 15624 long long deleted = 0; 15625 15626 for (long long i = 0; i < objects->n; i++) { 15627 p4bDiffScfileRow *object = objects->data[i]; 15628 psMetadata *where = p4bDiffScfileMetadataFromObject(object); 15629 long long count = psDBDeleteRows(dbh, P4BDIFFSCFILE_TABLE_NAME, where, limit); 15630 psFree(where); 15631 if (count < 0) { 15632 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4bDiffScfile"); 15633 return count; 15634 } 15635 15636 deleted += count; 15637 } 15638 15639 return deleted; 15640 } 15641 bool p4bDiffScfilePrintObjects(FILE *stream, psArray *objects, bool mdcf) 15642 { 15643 PS_ASSERT_PTR_NON_NULL(objects, false); 15644 15645 psMetadata *output = psMetadataAlloc(); 15646 for (long i = 0; i < psArrayLength(objects); i++) { 15647 psMetadata *md = p4bDiffScfileMetadataFromObject(objects->data[i]); 15648 if (!psMetadataAddMetadata( 15649 output, 15650 PS_LIST_TAIL, 15651 P4BDIFFSCFILE_TABLE_NAME, 15652 PS_META_DUPLICATE_OK, 15653 NULL, 15654 md 15655 )) { 15656 psError(PS_ERR_UNKNOWN, false, "failed to add metadata"); 15657 psFree(md); 15658 psFree(output); 15659 return false; 15660 } 15661 psFree(md); 15662 } 15663 15664 if (!ippdbPrintMetadataRaw(stream, output, mdcf)) { 15665 psError(PS_ERR_UNKNOWN, false, "failed to print metadata"); 15666 psFree(output); 15667 } 15668 psFree(output); 15669 15670 return true; 15671 } 15672 bool p4bDiffScfilePrintObject(FILE *stream, p4bDiffScfileRow *object, bool mdcf) 15673 { 15674 PS_ASSERT_PTR_NON_NULL(object, false); 15675 15676 psMetadata *md = p4bDiffScfileMetadataFromObject(object); 15677 15678 if (!ippdbPrintMetadataRaw(stream, md, mdcf)) { 15679 psError(PS_ERR_UNKNOWN, false, "failed to print metadata"); 15680 psFree(md); 15681 } 15682 15683 psFree(md); 15684 15685 return true; 15686 } 15687 static void p4cRunRowFree(p4cRunRow *object); 15688 15689 p4cRunRow *p4cRunRowAlloc(psS32 p4c_id, const char *state, const char *workdir, bool magic) 15690 { 15691 p4cRunRow *_object; 15692 15693 _object = psAlloc(sizeof(p4cRunRow)); 15694 psMemSetDeallocator(_object, (psFreeFunc)p4cRunRowFree); 15695 15696 _object->p4c_id = p4c_id; 15697 _object->state = psStringCopy(state); 15698 _object->workdir = psStringCopy(workdir); 15699 _object->magic = magic; 15700 15701 return _object; 15702 } 15703 15704 static void p4cRunRowFree(p4cRunRow *object) 15705 { 15706 psFree(object->state); 15707 psFree(object->workdir); 15708 } 15709 15710 bool p4cRunCreateTable(psDB *dbh) 15711 { 15712 psMetadata *md = psMetadataAlloc(); 15713 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4c_id", PS_DATA_S32, "Primary Key AUTO_INCREMENT", 0)) { 15714 psError(PS_ERR_UNKNOWN, false, "failed to add item p4c_id"); 15715 psFree(md); 15716 return false; 15717 } 15718 if (!psMetadataAdd(md, PS_LIST_TAIL, "state", PS_DATA_STRING, "Key", "64")) { 15719 psError(PS_ERR_UNKNOWN, false, "failed to add item state"); 15720 psFree(md); 15721 return false; 15722 } 15723 if (!psMetadataAdd(md, PS_LIST_TAIL, "workdir", PS_DATA_STRING, NULL, "255")) { 15724 psError(PS_ERR_UNKNOWN, false, "failed to add item workdir"); 15725 psFree(md); 15726 return false; 15727 } 15728 if (!psMetadataAdd(md, PS_LIST_TAIL, "magic", PS_DATA_BOOL, "Primary Key", 0)) { 15729 psError(PS_ERR_UNKNOWN, false, "failed to add item magic"); 15730 psFree(md); 15731 return false; 15732 } 15733 15734 bool status = psDBCreateTable(dbh, P4CRUN_TABLE_NAME, md); 15735 15736 psFree(md); 15737 15738 return status; 15739 } 15740 15741 bool p4cRunDropTable(psDB *dbh) 15742 { 15743 return psDBDropTable(dbh, P4CRUN_TABLE_NAME); 15744 } 15745 15746 bool p4cRunInsert(psDB * dbh, psS32 p4c_id, const char *state, const char *workdir, bool magic) 15747 { 15748 psMetadata *md = psMetadataAlloc(); 15749 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4c_id", PS_DATA_S32, NULL, p4c_id)) { 15750 psError(PS_ERR_UNKNOWN, false, "failed to add item p4c_id"); 15751 psFree(md); 15752 return false; 15753 } 15754 if (!psMetadataAdd(md, PS_LIST_TAIL, "state", PS_DATA_STRING, NULL, state)) { 15755 psError(PS_ERR_UNKNOWN, false, "failed to add item state"); 15756 psFree(md); 15757 return false; 15758 } 15759 if (!psMetadataAdd(md, PS_LIST_TAIL, "workdir", PS_DATA_STRING, NULL, workdir)) { 15760 psError(PS_ERR_UNKNOWN, false, "failed to add item workdir"); 15761 psFree(md); 15762 return false; 15763 } 15764 if (!psMetadataAdd(md, PS_LIST_TAIL, "magic", PS_DATA_BOOL, NULL, magic)) { 15765 psError(PS_ERR_UNKNOWN, false, "failed to add item magic"); 15766 psFree(md); 15767 return false; 15768 } 15769 15770 bool status = psDBInsertOneRow(dbh, P4CRUN_TABLE_NAME, md); 15771 psFree(md); 15772 15773 return status; 15774 } 15775 15776 long long p4cRunDelete(psDB *dbh, const psMetadata *where, unsigned long long limit) 15777 { 15778 long long deleted = 0; 15779 15780 long long count = psDBDeleteRows(dbh, P4CRUN_TABLE_NAME, where, limit); 15781 if (count < 0) { 15782 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4cRun"); 15783 return count; 15784 15785 deleted += count; 15786 } 15787 15788 return deleted; 15789 } 15790 bool p4cRunInsertObject(psDB *dbh, p4cRunRow *object) 15791 { 15792 return p4cRunInsert(dbh, object->p4c_id, object->state, object->workdir, object->magic); 15793 } 15794 15795 bool p4cRunInsertObjects(psDB *dbh, psArray *objects) 15796 { 15797 for (long i = 0; i < psArrayLength(objects); i++) { 15798 if (!p4cRunInsertObject(dbh, objects->data[i])) { 15799 return false; 15800 } 15801 } 15802 15803 return true; 15804 } 15805 15806 bool p4cRunInsertFits(psDB *dbh, const psFits *fits) 15807 { 15808 psArray *rowSet; 15809 15810 // move to (the first?) extension named P4CRUN_TABLE_NAME 15811 if (!psFitsMoveExtName(fits, P4CRUN_TABLE_NAME)) { 15812 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4CRUN_TABLE_NAME); 15813 return false; 15814 } 15815 15816 // check HDU type 15817 if (psFitsGetExtType(fits) != PS_FITS_TYPE_BINARY_TABLE) { 15818 psError(PS_ERR_UNKNOWN, true, "FITS HDU type is not PS_FITS_TYPE_BINARY_TABLE"); 15819 return false; 15820 } 15821 15822 // read fits table 15823 rowSet = psFitsReadTable(fits); 15824 if (!rowSet) { 15825 psError(PS_ERR_UNKNOWN, true, "FITS read error or FITS table is empty"); 15826 psFree(rowSet); 15827 return false; 15828 } 15829 15830 if (!psDBInsertRows(dbh, P4CRUN_TABLE_NAME, rowSet)) { 15831 psError(PS_ERR_UNKNOWN, false, "databse insert failed"); 15832 psFree(rowSet); 15833 return false; 15834 } 15835 15836 psFree(rowSet); 15837 15838 return true; 15839 } 15840 15841 bool p4cRunSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit) 15842 { 15843 psArray *rowSet; 15844 15845 rowSet = psDBSelectRows(dbh, P4CRUN_TABLE_NAME, where, limit); 15846 if (!rowSet) { 15847 return false; 15848 } 15849 15850 // output to fits 15851 if (!psFitsWriteTable(fits, NULL, rowSet, P4CRUN_TABLE_NAME)) { 15852 psError(PS_ERR_UNKNOWN, false, "FITS table write failed"); 15853 psFree(rowSet); 15854 return false; 15855 } 15856 15857 psFree(rowSet); 15858 15859 return true; 15860 } 15861 15862 psMetadata *p4cRunMetadataFromObject(const p4cRunRow *object) 15863 { 15864 psMetadata *md = psMetadataAlloc(); 15865 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4c_id", PS_DATA_S32, NULL, object->p4c_id)) { 15866 psError(PS_ERR_UNKNOWN, false, "failed to add item p4c_id"); 15867 psFree(md); 15868 return false; 15869 } 15870 if (!psMetadataAdd(md, PS_LIST_TAIL, "state", PS_DATA_STRING, NULL, object->state)) { 15871 psError(PS_ERR_UNKNOWN, false, "failed to add item state"); 15872 psFree(md); 15873 return false; 15874 } 15875 if (!psMetadataAdd(md, PS_LIST_TAIL, "workdir", PS_DATA_STRING, NULL, object->workdir)) { 15876 psError(PS_ERR_UNKNOWN, false, "failed to add item workdir"); 15877 psFree(md); 15878 return false; 15879 } 15880 if (!psMetadataAdd(md, PS_LIST_TAIL, "magic", PS_DATA_BOOL, NULL, object->magic)) { 15881 psError(PS_ERR_UNKNOWN, false, "failed to add item magic"); 15882 psFree(md); 15883 return false; 15884 } 15885 15886 15887 return md; 15888 } 15889 15890 p4cRunRow *p4cRunObjectFromMetadata(psMetadata *md) 15891 { 15892 15893 bool status = false; 15894 psS32 p4c_id = psMetadataLookupS32(&status, md, "p4c_id"); 15895 if (!status) { 15896 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4c_id"); 15897 return false; 15898 } 15899 char* state = psMetadataLookupPtr(&status, md, "state"); 15900 if (!status) { 15901 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item state"); 15902 return false; 15903 } 15904 char* workdir = psMetadataLookupPtr(&status, md, "workdir"); 15905 if (!status) { 15906 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item workdir"); 15907 return false; 15908 } 15909 bool magic = psMetadataLookupBool(&status, md, "magic"); 15910 if (!status) { 15911 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item magic"); 15912 return false; 15913 } 15914 15915 return p4cRunRowAlloc(p4c_id, state, workdir, magic); 15916 } 15917 psArray *p4cRunSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) 15918 { 15919 psArray *rowSet; 15920 psArray *returnSet; 15921 psU64 i; 15922 15923 rowSet = psDBSelectRows(dbh, P4CRUN_TABLE_NAME, where, limit); 15924 if (!rowSet) { 15925 return NULL; 15926 } 15927 15928 // convert psMetadata rows to row objects 15929 15930 returnSet = psArrayAllocEmpty(rowSet->n); 15931 15932 for (i = 0; i < rowSet->n; i++) { 15933 p4cRunRow *object = p4cRunObjectFromMetadata(rowSet->data[i]); 15934 psArrayAdd(returnSet, 0, object); 15935 psFree(object); 15936 } 15937 15938 psFree(rowSet); 15939 15940 return returnSet; 15941 } 15942 bool p4cRunDeleteObject(psDB *dbh, const p4cRunRow *object) 15943 { 15944 psMetadata *where = p4cRunMetadataFromObject(object); 15945 long long count = psDBDeleteRows(dbh, P4CRUN_TABLE_NAME, where, 0); 15946 psFree(where); 15947 if (count < 0) { 15948 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4cRun"); 15949 return false; 15950 } 15951 if (count > 1) { 15952 // XXX should this be a psAbort() instead? It is possible that 15953 // having an object match multiple rows was by design. 15954 psError(PS_ERR_UNKNOWN, true, "p4cRunRow object matched more then one row. Check your database schema"); 15955 return false; 15956 } 15957 15958 return true; 15959 } 15960 long long p4cRunDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit) 15961 { 15962 long long deleted = 0; 15963 15964 for (long long i = 0; i < objects->n; i++) { 15965 p4cRunRow *object = objects->data[i]; 15966 psMetadata *where = p4cRunMetadataFromObject(object); 15967 long long count = psDBDeleteRows(dbh, P4CRUN_TABLE_NAME, where, limit); 15968 psFree(where); 15969 if (count < 0) { 15970 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4cRun"); 15971 return count; 15972 } 15973 15974 deleted += count; 15975 } 15976 15977 return deleted; 15978 } 15979 bool p4cRunPrintObjects(FILE *stream, psArray *objects, bool mdcf) 15980 { 15981 PS_ASSERT_PTR_NON_NULL(objects, false); 15982 15983 psMetadata *output = psMetadataAlloc(); 15984 for (long i = 0; i < psArrayLength(objects); i++) { 15985 psMetadata *md = p4cRunMetadataFromObject(objects->data[i]); 15986 if (!psMetadataAddMetadata( 15987 output, 15988 PS_LIST_TAIL, 15989 P4CRUN_TABLE_NAME, 15990 PS_META_DUPLICATE_OK, 15991 NULL, 15992 md 15993 )) { 15994 psError(PS_ERR_UNKNOWN, false, "failed to add metadata"); 15995 psFree(md); 15996 psFree(output); 15997 return false; 15998 } 15999 psFree(md); 16000 } 16001 16002 if (!ippdbPrintMetadataRaw(stream, output, mdcf)) { 16003 psError(PS_ERR_UNKNOWN, false, "failed to print metadata"); 16004 psFree(output); 16005 } 16006 psFree(output); 16007 16008 return true; 16009 } 16010 bool p4cRunPrintObject(FILE *stream, p4cRunRow *object, bool mdcf) 16011 { 16012 PS_ASSERT_PTR_NON_NULL(object, false); 16013 16014 psMetadata *md = p4cRunMetadataFromObject(object); 16015 16016 if (!ippdbPrintMetadataRaw(stream, md, mdcf)) { 16017 psError(PS_ERR_UNKNOWN, false, "failed to print metadata"); 16018 psFree(md); 16019 } 16020 16021 psFree(md); 16022 16023 return true; 16024 } 16025 static void p4cInputExpRowFree(p4cInputExpRow *object); 16026 16027 p4cInputExpRow *p4cInputExpRowAlloc(psS32 p4c_id, const char *exp_tag, psS32 p3_version) 16028 { 16029 p4cInputExpRow *_object; 16030 16031 _object = psAlloc(sizeof(p4cInputExpRow)); 16032 psMemSetDeallocator(_object, (psFreeFunc)p4cInputExpRowFree); 16033 16034 _object->p4c_id = p4c_id; 16035 _object->exp_tag = psStringCopy(exp_tag); 16036 _object->p3_version = p3_version; 16037 16038 return _object; 16039 } 16040 16041 static void p4cInputExpRowFree(p4cInputExpRow *object) 16042 { 16043 psFree(object->exp_tag); 16044 } 16045 16046 bool p4cInputExpCreateTable(psDB *dbh) 16047 { 16048 psMetadata *md = psMetadataAlloc(); 16049 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4c_id", PS_DATA_S32, "Primary Key", 0)) { 16050 psError(PS_ERR_UNKNOWN, false, "failed to add item p4c_id"); 16051 psFree(md); 16052 return false; 16053 } 16054 if (!psMetadataAdd(md, PS_LIST_TAIL, "exp_tag", PS_DATA_STRING, "Primary Key", "64")) { 16055 psError(PS_ERR_UNKNOWN, false, "failed to add item exp_tag"); 16056 psFree(md); 16057 return false; 16058 } 16059 if (!psMetadataAdd(md, PS_LIST_TAIL, "p3_version", PS_DATA_S32, "Primary Key", 0)) { 16060 psError(PS_ERR_UNKNOWN, false, "failed to add item p3_version"); 16061 psFree(md); 16062 return false; 16063 } 16064 16065 bool status = psDBCreateTable(dbh, P4CINPUTEXP_TABLE_NAME, md); 16066 16067 psFree(md); 16068 16069 return status; 16070 } 16071 16072 bool p4cInputExpDropTable(psDB *dbh) 16073 { 16074 return psDBDropTable(dbh, P4CINPUTEXP_TABLE_NAME); 16075 } 16076 16077 bool p4cInputExpInsert(psDB * dbh, psS32 p4c_id, const char *exp_tag, psS32 p3_version) 16078 { 16079 psMetadata *md = psMetadataAlloc(); 16080 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4c_id", PS_DATA_S32, NULL, p4c_id)) { 16081 psError(PS_ERR_UNKNOWN, false, "failed to add item p4c_id"); 16082 psFree(md); 16083 return false; 16084 } 16085 if (!psMetadataAdd(md, PS_LIST_TAIL, "exp_tag", PS_DATA_STRING, NULL, exp_tag)) { 16086 psError(PS_ERR_UNKNOWN, false, "failed to add item exp_tag"); 16087 psFree(md); 16088 return false; 16089 } 16090 if (!psMetadataAdd(md, PS_LIST_TAIL, "p3_version", PS_DATA_S32, NULL, p3_version)) { 16091 psError(PS_ERR_UNKNOWN, false, "failed to add item p3_version"); 16092 psFree(md); 16093 return false; 16094 } 16095 16096 bool status = psDBInsertOneRow(dbh, P4CINPUTEXP_TABLE_NAME, md); 16097 psFree(md); 16098 16099 return status; 16100 } 16101 16102 long long p4cInputExpDelete(psDB *dbh, const psMetadata *where, unsigned long long limit) 16103 { 16104 long long deleted = 0; 16105 16106 long long count = psDBDeleteRows(dbh, P4CINPUTEXP_TABLE_NAME, where, limit); 16107 if (count < 0) { 16108 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4cInputExp"); 16109 return count; 16110 16111 deleted += count; 16112 } 16113 16114 return deleted; 16115 } 16116 bool p4cInputExpInsertObject(psDB *dbh, p4cInputExpRow *object) 16117 { 16118 return p4cInputExpInsert(dbh, object->p4c_id, object->exp_tag, object->p3_version); 16119 } 16120 16121 bool p4cInputExpInsertObjects(psDB *dbh, psArray *objects) 16122 { 16123 for (long i = 0; i < psArrayLength(objects); i++) { 16124 if (!p4cInputExpInsertObject(dbh, objects->data[i])) { 16125 return false; 16126 } 16127 } 16128 16129 return true; 16130 } 16131 16132 bool p4cInputExpInsertFits(psDB *dbh, const psFits *fits) 16133 { 16134 psArray *rowSet; 16135 16136 // move to (the first?) extension named P4CINPUTEXP_TABLE_NAME 16137 if (!psFitsMoveExtName(fits, P4CINPUTEXP_TABLE_NAME)) { 16138 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4CINPUTEXP_TABLE_NAME); 16139 return false; 16140 } 16141 16142 // check HDU type 16143 if (psFitsGetExtType(fits) != PS_FITS_TYPE_BINARY_TABLE) { 16144 psError(PS_ERR_UNKNOWN, true, "FITS HDU type is not PS_FITS_TYPE_BINARY_TABLE"); 16145 return false; 16146 } 16147 16148 // read fits table 16149 rowSet = psFitsReadTable(fits); 16150 if (!rowSet) { 16151 psError(PS_ERR_UNKNOWN, true, "FITS read error or FITS table is empty"); 16152 psFree(rowSet); 16153 return false; 16154 } 16155 16156 if (!psDBInsertRows(dbh, P4CINPUTEXP_TABLE_NAME, rowSet)) { 16157 psError(PS_ERR_UNKNOWN, false, "databse insert failed"); 16158 psFree(rowSet); 16159 return false; 16160 } 16161 16162 psFree(rowSet); 16163 16164 return true; 16165 } 16166 16167 bool p4cInputExpSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit) 16168 { 16169 psArray *rowSet; 16170 16171 rowSet = psDBSelectRows(dbh, P4CINPUTEXP_TABLE_NAME, where, limit); 16172 if (!rowSet) { 16173 return false; 16174 } 16175 16176 // output to fits 16177 if (!psFitsWriteTable(fits, NULL, rowSet, P4CINPUTEXP_TABLE_NAME)) { 16178 psError(PS_ERR_UNKNOWN, false, "FITS table write failed"); 16179 psFree(rowSet); 16180 return false; 16181 } 16182 16183 psFree(rowSet); 16184 16185 return true; 16186 } 16187 16188 psMetadata *p4cInputExpMetadataFromObject(const p4cInputExpRow *object) 16189 { 16190 psMetadata *md = psMetadataAlloc(); 16191 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4c_id", PS_DATA_S32, NULL, object->p4c_id)) { 16192 psError(PS_ERR_UNKNOWN, false, "failed to add item p4c_id"); 16193 psFree(md); 16194 return false; 16195 } 16196 if (!psMetadataAdd(md, PS_LIST_TAIL, "exp_tag", PS_DATA_STRING, NULL, object->exp_tag)) { 16197 psError(PS_ERR_UNKNOWN, false, "failed to add item exp_tag"); 16198 psFree(md); 16199 return false; 16200 } 16201 if (!psMetadataAdd(md, PS_LIST_TAIL, "p3_version", PS_DATA_S32, NULL, object->p3_version)) { 16202 psError(PS_ERR_UNKNOWN, false, "failed to add item p3_version"); 16203 psFree(md); 16204 return false; 16205 } 16206 16207 16208 return md; 16209 } 16210 16211 p4cInputExpRow *p4cInputExpObjectFromMetadata(psMetadata *md) 16212 { 16213 16214 bool status = false; 16215 psS32 p4c_id = psMetadataLookupS32(&status, md, "p4c_id"); 16216 if (!status) { 16217 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4c_id"); 16218 return false; 16219 } 16220 char* exp_tag = psMetadataLookupPtr(&status, md, "exp_tag"); 16221 if (!status) { 16222 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item exp_tag"); 16223 return false; 16224 } 16225 psS32 p3_version = psMetadataLookupS32(&status, md, "p3_version"); 16226 if (!status) { 16227 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p3_version"); 16228 return false; 16229 } 16230 16231 return p4cInputExpRowAlloc(p4c_id, exp_tag, p3_version); 16232 } 16233 psArray *p4cInputExpSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) 16234 { 16235 psArray *rowSet; 16236 psArray *returnSet; 16237 psU64 i; 16238 16239 rowSet = psDBSelectRows(dbh, P4CINPUTEXP_TABLE_NAME, where, limit); 16240 if (!rowSet) { 16241 return NULL; 16242 } 16243 16244 // convert psMetadata rows to row objects 16245 16246 returnSet = psArrayAllocEmpty(rowSet->n); 16247 16248 for (i = 0; i < rowSet->n; i++) { 16249 p4cInputExpRow *object = p4cInputExpObjectFromMetadata(rowSet->data[i]); 16250 psArrayAdd(returnSet, 0, object); 16251 psFree(object); 16252 } 16253 16254 psFree(rowSet); 16255 16256 return returnSet; 16257 } 16258 bool p4cInputExpDeleteObject(psDB *dbh, const p4cInputExpRow *object) 16259 { 16260 psMetadata *where = p4cInputExpMetadataFromObject(object); 16261 long long count = psDBDeleteRows(dbh, P4CINPUTEXP_TABLE_NAME, where, 0); 16262 psFree(where); 16263 if (count < 0) { 16264 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4cInputExp"); 16265 return false; 16266 } 16267 if (count > 1) { 16268 // XXX should this be a psAbort() instead? It is possible that 16269 // having an object match multiple rows was by design. 16270 psError(PS_ERR_UNKNOWN, true, "p4cInputExpRow object matched more then one row. Check your database schema"); 16271 return false; 16272 } 16273 16274 return true; 16275 } 16276 long long p4cInputExpDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit) 16277 { 16278 long long deleted = 0; 16279 16280 for (long long i = 0; i < objects->n; i++) { 16281 p4cInputExpRow *object = objects->data[i]; 16282 psMetadata *where = p4cInputExpMetadataFromObject(object); 16283 long long count = psDBDeleteRows(dbh, P4CINPUTEXP_TABLE_NAME, where, limit); 16284 psFree(where); 16285 if (count < 0) { 16286 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4cInputExp"); 16287 return count; 16288 } 16289 16290 deleted += count; 16291 } 16292 16293 return deleted; 16294 } 16295 bool p4cInputExpPrintObjects(FILE *stream, psArray *objects, bool mdcf) 16296 { 16297 PS_ASSERT_PTR_NON_NULL(objects, false); 16298 16299 psMetadata *output = psMetadataAlloc(); 16300 for (long i = 0; i < psArrayLength(objects); i++) { 16301 psMetadata *md = p4cInputExpMetadataFromObject(objects->data[i]); 16302 if (!psMetadataAddMetadata( 16303 output, 16304 PS_LIST_TAIL, 16305 P4CINPUTEXP_TABLE_NAME, 16306 PS_META_DUPLICATE_OK, 16307 NULL, 16308 md 16309 )) { 16310 psError(PS_ERR_UNKNOWN, false, "failed to add metadata"); 16311 psFree(md); 16312 psFree(output); 16313 return false; 16314 } 16315 psFree(md); 16316 } 16317 16318 if (!ippdbPrintMetadataRaw(stream, output, mdcf)) { 16319 psError(PS_ERR_UNKNOWN, false, "failed to print metadata"); 16320 psFree(output); 16321 } 16322 psFree(output); 16323 16324 return true; 16325 } 16326 bool p4cInputExpPrintObject(FILE *stream, p4cInputExpRow *object, bool mdcf) 16327 { 16328 PS_ASSERT_PTR_NON_NULL(object, false); 16329 16330 psMetadata *md = p4cInputExpMetadataFromObject(object); 16331 16332 if (!ippdbPrintMetadataRaw(stream, md, mdcf)) { 16333 psError(PS_ERR_UNKNOWN, false, "failed to print metadata"); 16334 psFree(md); 16335 } 16336 16337 psFree(md); 16338 16339 return true; 16340 } 16341 static void p4MagicMaskImfileRowFree(p4MagicMaskImfileRow *object); 16342 16343 p4MagicMaskImfileRow *p4MagicMaskImfileRowAlloc(psS32 p4c_id, const char *exp_tag, psS32 p3_version, const char *class_id, const char *uri) 16344 { 16345 p4MagicMaskImfileRow *_object; 16346 16347 _object = psAlloc(sizeof(p4MagicMaskImfileRow)); 16348 psMemSetDeallocator(_object, (psFreeFunc)p4MagicMaskImfileRowFree); 16349 16350 _object->p4c_id = p4c_id; 16351 _object->exp_tag = psStringCopy(exp_tag); 16352 _object->p3_version = p3_version; 16353 _object->class_id = psStringCopy(class_id); 16354 _object->uri = psStringCopy(uri); 16355 16356 return _object; 16357 } 16358 16359 static void p4MagicMaskImfileRowFree(p4MagicMaskImfileRow *object) 16360 { 16361 psFree(object->exp_tag); 16362 psFree(object->class_id); 16363 psFree(object->uri); 16364 } 16365 16366 bool p4MagicMaskImfileCreateTable(psDB *dbh) 16367 { 16368 psMetadata *md = psMetadataAlloc(); 16369 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4c_id", PS_DATA_S32, "Primary Key", 0)) { 16370 psError(PS_ERR_UNKNOWN, false, "failed to add item p4c_id"); 16371 psFree(md); 16372 return false; 16373 } 16374 if (!psMetadataAdd(md, PS_LIST_TAIL, "exp_tag", PS_DATA_STRING, "Primary Key", "64")) { 16375 psError(PS_ERR_UNKNOWN, false, "failed to add item exp_tag"); 16376 psFree(md); 16377 return false; 16378 } 16379 if (!psMetadataAdd(md, PS_LIST_TAIL, "p3_version", PS_DATA_S32, "Primary Key", 0)) { 16380 psError(PS_ERR_UNKNOWN, false, "failed to add item p3_version"); 16381 psFree(md); 16382 return false; 16383 } 16384 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, "Primary Key", "64")) { 16385 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id"); 16386 psFree(md); 16387 return false; 16388 } 16389 if (!psMetadataAdd(md, PS_LIST_TAIL, "uri", PS_DATA_STRING, NULL, "255")) { 16390 psError(PS_ERR_UNKNOWN, false, "failed to add item uri"); 16391 psFree(md); 16392 return false; 16393 } 16394 16395 bool status = psDBCreateTable(dbh, P4MAGICMASKIMFILE_TABLE_NAME, md); 16396 16397 psFree(md); 16398 16399 return status; 16400 } 16401 16402 bool p4MagicMaskImfileDropTable(psDB *dbh) 16403 { 16404 return psDBDropTable(dbh, P4MAGICMASKIMFILE_TABLE_NAME); 16405 } 16406 16407 bool p4MagicMaskImfileInsert(psDB * dbh, psS32 p4c_id, const char *exp_tag, psS32 p3_version, const char *class_id, const char *uri) 16408 { 16409 psMetadata *md = psMetadataAlloc(); 16410 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4c_id", PS_DATA_S32, NULL, p4c_id)) { 16411 psError(PS_ERR_UNKNOWN, false, "failed to add item p4c_id"); 16412 psFree(md); 16413 return false; 16414 } 16415 if (!psMetadataAdd(md, PS_LIST_TAIL, "exp_tag", PS_DATA_STRING, NULL, exp_tag)) { 16416 psError(PS_ERR_UNKNOWN, false, "failed to add item exp_tag"); 16417 psFree(md); 16418 return false; 16419 } 16420 if (!psMetadataAdd(md, PS_LIST_TAIL, "p3_version", PS_DATA_S32, NULL, p3_version)) { 16421 psError(PS_ERR_UNKNOWN, false, "failed to add item p3_version"); 16422 psFree(md); 16423 return false; 16424 } 16425 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, NULL, class_id)) { 16426 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id"); 16427 psFree(md); 16428 return false; 16429 } 16430 if (!psMetadataAdd(md, PS_LIST_TAIL, "uri", PS_DATA_STRING, NULL, uri)) { 16431 psError(PS_ERR_UNKNOWN, false, "failed to add item uri"); 16432 psFree(md); 16433 return false; 16434 } 16435 16436 bool status = psDBInsertOneRow(dbh, P4MAGICMASKIMFILE_TABLE_NAME, md); 16437 psFree(md); 16438 16439 return status; 16440 } 16441 16442 long long p4MagicMaskImfileDelete(psDB *dbh, const psMetadata *where, unsigned long long limit) 16443 { 16444 long long deleted = 0; 16445 16446 long long count = psDBDeleteRows(dbh, P4MAGICMASKIMFILE_TABLE_NAME, where, limit); 16447 if (count < 0) { 16448 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4MagicMaskImfile"); 16449 return count; 16450 16451 deleted += count; 16452 } 16453 16454 return deleted; 16455 } 16456 bool p4MagicMaskImfileInsertObject(psDB *dbh, p4MagicMaskImfileRow *object) 16457 { 16458 return p4MagicMaskImfileInsert(dbh, object->p4c_id, object->exp_tag, object->p3_version, object->class_id, object->uri); 16459 } 16460 16461 bool p4MagicMaskImfileInsertObjects(psDB *dbh, psArray *objects) 16462 { 16463 for (long i = 0; i < psArrayLength(objects); i++) { 16464 if (!p4MagicMaskImfileInsertObject(dbh, objects->data[i])) { 16465 return false; 16466 } 16467 } 16468 16469 return true; 16470 } 16471 16472 bool p4MagicMaskImfileInsertFits(psDB *dbh, const psFits *fits) 16473 { 16474 psArray *rowSet; 16475 16476 // move to (the first?) extension named P4MAGICMASKIMFILE_TABLE_NAME 16477 if (!psFitsMoveExtName(fits, P4MAGICMASKIMFILE_TABLE_NAME)) { 16478 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", P4MAGICMASKIMFILE_TABLE_NAME); 16479 return false; 16480 } 16481 16482 // check HDU type 16483 if (psFitsGetExtType(fits) != PS_FITS_TYPE_BINARY_TABLE) { 16484 psError(PS_ERR_UNKNOWN, true, "FITS HDU type is not PS_FITS_TYPE_BINARY_TABLE"); 16485 return false; 16486 } 16487 16488 // read fits table 16489 rowSet = psFitsReadTable(fits); 16490 if (!rowSet) { 16491 psError(PS_ERR_UNKNOWN, true, "FITS read error or FITS table is empty"); 16492 psFree(rowSet); 16493 return false; 16494 } 16495 15613 16496 if (!psDBInsertRows(dbh, P4MAGICMASKIMFILE_TABLE_NAME, rowSet)) { 15614 16497 psError(PS_ERR_UNKNOWN, false, "databse insert failed"); … … 15646 16529 { 15647 16530 psMetadata *md = psMetadataAlloc(); 15648 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4 _id", PS_DATA_S32, NULL, object->p4_id)) {15649 psError(PS_ERR_UNKNOWN, false, "failed to add item p4 _id");16531 if (!psMetadataAdd(md, PS_LIST_TAIL, "p4c_id", PS_DATA_S32, NULL, object->p4c_id)) { 16532 psError(PS_ERR_UNKNOWN, false, "failed to add item p4c_id"); 15650 16533 psFree(md); 15651 16534 return false; … … 15680 16563 15681 16564 bool status = false; 15682 psS32 p4 _id = psMetadataLookupS32(&status, md, "p4_id");15683 if (!status) { 15684 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4 _id");16565 psS32 p4c_id = psMetadataLookupS32(&status, md, "p4c_id"); 16566 if (!status) { 16567 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item p4c_id"); 15685 16568 return false; 15686 16569 } … … 15706 16589 } 15707 16590 15708 return p4MagicMaskImfileRowAlloc(p4 _id, exp_tag, p3_version, class_id, uri);16591 return p4MagicMaskImfileRowAlloc(p4c_id, exp_tag, p3_version, class_id, uri); 15709 16592 } 15710 16593 psArray *p4MagicMaskImfileSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) … … 15737 16620 psMetadata *where = p4MagicMaskImfileMetadataFromObject(object); 15738 16621 long long count = psDBDeleteRows(dbh, P4MAGICMASKIMFILE_TABLE_NAME, where, 0); 15739 psFree(where) 16622 psFree(where); 15740 16623 if (count < 0) { 15741 16624 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4MagicMaskImfile"); … … 15759 16642 psMetadata *where = p4MagicMaskImfileMetadataFromObject(object); 15760 16643 long long count = psDBDeleteRows(dbh, P4MAGICMASKIMFILE_TABLE_NAME, where, limit); 15761 psFree(where) 16644 psFree(where); 15762 16645 if (count < 0) { 15763 16646 psError(PS_ERR_UNKNOWN, true, "failed to delete row from p4MagicMaskImfile"); … … 15816 16699 return true; 15817 16700 } 16701 static void skyCellRowFree(skyCellRow *object); 16702 16703 skyCellRow *skyCellRowAlloc(const char *skycell_id, const char *tess_id, psF64 ra1, psF64 decl1, psF64 ra2, psF64 decl2, psF64 ra3, psF64 decl3, psF64 ra4, psF64 decl4) 16704 { 16705 skyCellRow *_object; 16706 16707 _object = psAlloc(sizeof(skyCellRow)); 16708 psMemSetDeallocator(_object, (psFreeFunc)skyCellRowFree); 16709 16710 _object->skycell_id = psStringCopy(skycell_id); 16711 _object->tess_id = psStringCopy(tess_id); 16712 _object->ra1 = ra1; 16713 _object->decl1 = decl1; 16714 _object->ra2 = ra2; 16715 _object->decl2 = decl2; 16716 _object->ra3 = ra3; 16717 _object->decl3 = decl3; 16718 _object->ra4 = ra4; 16719 _object->decl4 = decl4; 16720 16721 return _object; 16722 } 16723 16724 static void skyCellRowFree(skyCellRow *object) 16725 { 16726 psFree(object->skycell_id); 16727 psFree(object->tess_id); 16728 } 16729 16730 bool skyCellCreateTable(psDB *dbh) 16731 { 16732 psMetadata *md = psMetadataAlloc(); 16733 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, "Primary Key", "64")) { 16734 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 16735 psFree(md); 16736 return false; 16737 } 16738 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, "Primary Key", "64")) { 16739 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 16740 psFree(md); 16741 return false; 16742 } 16743 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra1", PS_DATA_F64, NULL, 0.0)) { 16744 psError(PS_ERR_UNKNOWN, false, "failed to add item ra1"); 16745 psFree(md); 16746 return false; 16747 } 16748 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl1", PS_DATA_F64, NULL, 0.0)) { 16749 psError(PS_ERR_UNKNOWN, false, "failed to add item decl1"); 16750 psFree(md); 16751 return false; 16752 } 16753 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra2", PS_DATA_F64, NULL, 0.0)) { 16754 psError(PS_ERR_UNKNOWN, false, "failed to add item ra2"); 16755 psFree(md); 16756 return false; 16757 } 16758 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl2", PS_DATA_F64, NULL, 0.0)) { 16759 psError(PS_ERR_UNKNOWN, false, "failed to add item decl2"); 16760 psFree(md); 16761 return false; 16762 } 16763 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra3", PS_DATA_F64, NULL, 0.0)) { 16764 psError(PS_ERR_UNKNOWN, false, "failed to add item ra3"); 16765 psFree(md); 16766 return false; 16767 } 16768 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl3", PS_DATA_F64, NULL, 0.0)) { 16769 psError(PS_ERR_UNKNOWN, false, "failed to add item decl3"); 16770 psFree(md); 16771 return false; 16772 } 16773 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra4", PS_DATA_F64, NULL, 0.0)) { 16774 psError(PS_ERR_UNKNOWN, false, "failed to add item ra4"); 16775 psFree(md); 16776 return false; 16777 } 16778 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl4", PS_DATA_F64, NULL, 0.0)) { 16779 psError(PS_ERR_UNKNOWN, false, "failed to add item decl4"); 16780 psFree(md); 16781 return false; 16782 } 16783 16784 bool status = psDBCreateTable(dbh, SKYCELL_TABLE_NAME, md); 16785 16786 psFree(md); 16787 16788 return status; 16789 } 16790 16791 bool skyCellDropTable(psDB *dbh) 16792 { 16793 return psDBDropTable(dbh, SKYCELL_TABLE_NAME); 16794 } 16795 16796 bool skyCellInsert(psDB * dbh, const char *skycell_id, const char *tess_id, psF64 ra1, psF64 decl1, psF64 ra2, psF64 decl2, psF64 ra3, psF64 decl3, psF64 ra4, psF64 decl4) 16797 { 16798 psMetadata *md = psMetadataAlloc(); 16799 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, NULL, skycell_id)) { 16800 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 16801 psFree(md); 16802 return false; 16803 } 16804 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, NULL, tess_id)) { 16805 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 16806 psFree(md); 16807 return false; 16808 } 16809 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra1", PS_DATA_F64, NULL, ra1)) { 16810 psError(PS_ERR_UNKNOWN, false, "failed to add item ra1"); 16811 psFree(md); 16812 return false; 16813 } 16814 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl1", PS_DATA_F64, NULL, decl1)) { 16815 psError(PS_ERR_UNKNOWN, false, "failed to add item decl1"); 16816 psFree(md); 16817 return false; 16818 } 16819 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra2", PS_DATA_F64, NULL, ra2)) { 16820 psError(PS_ERR_UNKNOWN, false, "failed to add item ra2"); 16821 psFree(md); 16822 return false; 16823 } 16824 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl2", PS_DATA_F64, NULL, decl2)) { 16825 psError(PS_ERR_UNKNOWN, false, "failed to add item decl2"); 16826 psFree(md); 16827 return false; 16828 } 16829 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra3", PS_DATA_F64, NULL, ra3)) { 16830 psError(PS_ERR_UNKNOWN, false, "failed to add item ra3"); 16831 psFree(md); 16832 return false; 16833 } 16834 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl3", PS_DATA_F64, NULL, decl3)) { 16835 psError(PS_ERR_UNKNOWN, false, "failed to add item decl3"); 16836 psFree(md); 16837 return false; 16838 } 16839 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra4", PS_DATA_F64, NULL, ra4)) { 16840 psError(PS_ERR_UNKNOWN, false, "failed to add item ra4"); 16841 psFree(md); 16842 return false; 16843 } 16844 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl4", PS_DATA_F64, NULL, decl4)) { 16845 psError(PS_ERR_UNKNOWN, false, "failed to add item decl4"); 16846 psFree(md); 16847 return false; 16848 } 16849 16850 bool status = psDBInsertOneRow(dbh, SKYCELL_TABLE_NAME, md); 16851 psFree(md); 16852 16853 return status; 16854 } 16855 16856 long long skyCellDelete(psDB *dbh, const psMetadata *where, unsigned long long limit) 16857 { 16858 long long deleted = 0; 16859 16860 long long count = psDBDeleteRows(dbh, SKYCELL_TABLE_NAME, where, limit); 16861 if (count < 0) { 16862 psError(PS_ERR_UNKNOWN, true, "failed to delete row from skyCell"); 16863 return count; 16864 16865 deleted += count; 16866 } 16867 16868 return deleted; 16869 } 16870 bool skyCellInsertObject(psDB *dbh, skyCellRow *object) 16871 { 16872 return skyCellInsert(dbh, object->skycell_id, object->tess_id, object->ra1, object->decl1, object->ra2, object->decl2, object->ra3, object->decl3, object->ra4, object->decl4); 16873 } 16874 16875 bool skyCellInsertObjects(psDB *dbh, psArray *objects) 16876 { 16877 for (long i = 0; i < psArrayLength(objects); i++) { 16878 if (!skyCellInsertObject(dbh, objects->data[i])) { 16879 return false; 16880 } 16881 } 16882 16883 return true; 16884 } 16885 16886 bool skyCellInsertFits(psDB *dbh, const psFits *fits) 16887 { 16888 psArray *rowSet; 16889 16890 // move to (the first?) extension named SKYCELL_TABLE_NAME 16891 if (!psFitsMoveExtName(fits, SKYCELL_TABLE_NAME)) { 16892 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", SKYCELL_TABLE_NAME); 16893 return false; 16894 } 16895 16896 // check HDU type 16897 if (psFitsGetExtType(fits) != PS_FITS_TYPE_BINARY_TABLE) { 16898 psError(PS_ERR_UNKNOWN, true, "FITS HDU type is not PS_FITS_TYPE_BINARY_TABLE"); 16899 return false; 16900 } 16901 16902 // read fits table 16903 rowSet = psFitsReadTable(fits); 16904 if (!rowSet) { 16905 psError(PS_ERR_UNKNOWN, true, "FITS read error or FITS table is empty"); 16906 psFree(rowSet); 16907 return false; 16908 } 16909 16910 if (!psDBInsertRows(dbh, SKYCELL_TABLE_NAME, rowSet)) { 16911 psError(PS_ERR_UNKNOWN, false, "databse insert failed"); 16912 psFree(rowSet); 16913 return false; 16914 } 16915 16916 psFree(rowSet); 16917 16918 return true; 16919 } 16920 16921 bool skyCellSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit) 16922 { 16923 psArray *rowSet; 16924 16925 rowSet = psDBSelectRows(dbh, SKYCELL_TABLE_NAME, where, limit); 16926 if (!rowSet) { 16927 return false; 16928 } 16929 16930 // output to fits 16931 if (!psFitsWriteTable(fits, NULL, rowSet, SKYCELL_TABLE_NAME)) { 16932 psError(PS_ERR_UNKNOWN, false, "FITS table write failed"); 16933 psFree(rowSet); 16934 return false; 16935 } 16936 16937 psFree(rowSet); 16938 16939 return true; 16940 } 16941 16942 psMetadata *skyCellMetadataFromObject(const skyCellRow *object) 16943 { 16944 psMetadata *md = psMetadataAlloc(); 16945 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, NULL, object->skycell_id)) { 16946 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 16947 psFree(md); 16948 return false; 16949 } 16950 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, NULL, object->tess_id)) { 16951 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 16952 psFree(md); 16953 return false; 16954 } 16955 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra1", PS_DATA_F64, NULL, object->ra1)) { 16956 psError(PS_ERR_UNKNOWN, false, "failed to add item ra1"); 16957 psFree(md); 16958 return false; 16959 } 16960 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl1", PS_DATA_F64, NULL, object->decl1)) { 16961 psError(PS_ERR_UNKNOWN, false, "failed to add item decl1"); 16962 psFree(md); 16963 return false; 16964 } 16965 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra2", PS_DATA_F64, NULL, object->ra2)) { 16966 psError(PS_ERR_UNKNOWN, false, "failed to add item ra2"); 16967 psFree(md); 16968 return false; 16969 } 16970 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl2", PS_DATA_F64, NULL, object->decl2)) { 16971 psError(PS_ERR_UNKNOWN, false, "failed to add item decl2"); 16972 psFree(md); 16973 return false; 16974 } 16975 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra3", PS_DATA_F64, NULL, object->ra3)) { 16976 psError(PS_ERR_UNKNOWN, false, "failed to add item ra3"); 16977 psFree(md); 16978 return false; 16979 } 16980 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl3", PS_DATA_F64, NULL, object->decl3)) { 16981 psError(PS_ERR_UNKNOWN, false, "failed to add item decl3"); 16982 psFree(md); 16983 return false; 16984 } 16985 if (!psMetadataAdd(md, PS_LIST_TAIL, "ra4", PS_DATA_F64, NULL, object->ra4)) { 16986 psError(PS_ERR_UNKNOWN, false, "failed to add item ra4"); 16987 psFree(md); 16988 return false; 16989 } 16990 if (!psMetadataAdd(md, PS_LIST_TAIL, "decl4", PS_DATA_F64, NULL, object->decl4)) { 16991 psError(PS_ERR_UNKNOWN, false, "failed to add item decl4"); 16992 psFree(md); 16993 return false; 16994 } 16995 16996 16997 return md; 16998 } 16999 17000 skyCellRow *skyCellObjectFromMetadata(psMetadata *md) 17001 { 17002 17003 bool status = false; 17004 char* skycell_id = psMetadataLookupPtr(&status, md, "skycell_id"); 17005 if (!status) { 17006 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item skycell_id"); 17007 return false; 17008 } 17009 char* tess_id = psMetadataLookupPtr(&status, md, "tess_id"); 17010 if (!status) { 17011 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item tess_id"); 17012 return false; 17013 } 17014 psF64 ra1 = psMetadataLookupF64(&status, md, "ra1"); 17015 if (!status) { 17016 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item ra1"); 17017 return false; 17018 } 17019 psF64 decl1 = psMetadataLookupF64(&status, md, "decl1"); 17020 if (!status) { 17021 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item decl1"); 17022 return false; 17023 } 17024 psF64 ra2 = psMetadataLookupF64(&status, md, "ra2"); 17025 if (!status) { 17026 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item ra2"); 17027 return false; 17028 } 17029 psF64 decl2 = psMetadataLookupF64(&status, md, "decl2"); 17030 if (!status) { 17031 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item decl2"); 17032 return false; 17033 } 17034 psF64 ra3 = psMetadataLookupF64(&status, md, "ra3"); 17035 if (!status) { 17036 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item ra3"); 17037 return false; 17038 } 17039 psF64 decl3 = psMetadataLookupF64(&status, md, "decl3"); 17040 if (!status) { 17041 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item decl3"); 17042 return false; 17043 } 17044 psF64 ra4 = psMetadataLookupF64(&status, md, "ra4"); 17045 if (!status) { 17046 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item ra4"); 17047 return false; 17048 } 17049 psF64 decl4 = psMetadataLookupF64(&status, md, "decl4"); 17050 if (!status) { 17051 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item decl4"); 17052 return false; 17053 } 17054 17055 return skyCellRowAlloc(skycell_id, tess_id, ra1, decl1, ra2, decl2, ra3, decl3, ra4, decl4); 17056 } 17057 psArray *skyCellSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) 17058 { 17059 psArray *rowSet; 17060 psArray *returnSet; 17061 psU64 i; 17062 17063 rowSet = psDBSelectRows(dbh, SKYCELL_TABLE_NAME, where, limit); 17064 if (!rowSet) { 17065 return NULL; 17066 } 17067 17068 // convert psMetadata rows to row objects 17069 17070 returnSet = psArrayAllocEmpty(rowSet->n); 17071 17072 for (i = 0; i < rowSet->n; i++) { 17073 skyCellRow *object = skyCellObjectFromMetadata(rowSet->data[i]); 17074 psArrayAdd(returnSet, 0, object); 17075 psFree(object); 17076 } 17077 17078 psFree(rowSet); 17079 17080 return returnSet; 17081 } 17082 bool skyCellDeleteObject(psDB *dbh, const skyCellRow *object) 17083 { 17084 psMetadata *where = skyCellMetadataFromObject(object); 17085 long long count = psDBDeleteRows(dbh, SKYCELL_TABLE_NAME, where, 0); 17086 psFree(where); 17087 if (count < 0) { 17088 psError(PS_ERR_UNKNOWN, true, "failed to delete row from skyCell"); 17089 return false; 17090 } 17091 if (count > 1) { 17092 // XXX should this be a psAbort() instead? It is possible that 17093 // having an object match multiple rows was by design. 17094 psError(PS_ERR_UNKNOWN, true, "skyCellRow object matched more then one row. Check your database schema"); 17095 return false; 17096 } 17097 17098 return true; 17099 } 17100 long long skyCellDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit) 17101 { 17102 long long deleted = 0; 17103 17104 for (long long i = 0; i < objects->n; i++) { 17105 skyCellRow *object = objects->data[i]; 17106 psMetadata *where = skyCellMetadataFromObject(object); 17107 long long count = psDBDeleteRows(dbh, SKYCELL_TABLE_NAME, where, limit); 17108 psFree(where); 17109 if (count < 0) { 17110 psError(PS_ERR_UNKNOWN, true, "failed to delete row from skyCell"); 17111 return count; 17112 } 17113 17114 deleted += count; 17115 } 17116 17117 return deleted; 17118 } 17119 bool skyCellPrintObjects(FILE *stream, psArray *objects, bool mdcf) 17120 { 17121 PS_ASSERT_PTR_NON_NULL(objects, false); 17122 17123 psMetadata *output = psMetadataAlloc(); 17124 for (long i = 0; i < psArrayLength(objects); i++) { 17125 psMetadata *md = skyCellMetadataFromObject(objects->data[i]); 17126 if (!psMetadataAddMetadata( 17127 output, 17128 PS_LIST_TAIL, 17129 SKYCELL_TABLE_NAME, 17130 PS_META_DUPLICATE_OK, 17131 NULL, 17132 md 17133 )) { 17134 psError(PS_ERR_UNKNOWN, false, "failed to add metadata"); 17135 psFree(md); 17136 psFree(output); 17137 return false; 17138 } 17139 psFree(md); 17140 } 17141 17142 if (!ippdbPrintMetadataRaw(stream, output, mdcf)) { 17143 psError(PS_ERR_UNKNOWN, false, "failed to print metadata"); 17144 psFree(output); 17145 } 17146 psFree(output); 17147 17148 return true; 17149 } 17150 bool skyCellPrintObject(FILE *stream, skyCellRow *object, bool mdcf) 17151 { 17152 PS_ASSERT_PTR_NON_NULL(object, false); 17153 17154 psMetadata *md = skyCellMetadataFromObject(object); 17155 17156 if (!ippdbPrintMetadataRaw(stream, md, mdcf)) { 17157 psError(PS_ERR_UNKNOWN, false, "failed to print metadata"); 17158 psFree(md); 17159 } 17160 17161 psFree(md); 17162 17163 return true; 17164 } 17165 static void skyCellMapRowFree(skyCellMapRow *object); 17166 17167 skyCellMapRow *skyCellMapRowAlloc(const char *skycell_id, const char *tess_id, const char *exp_tag, const char *class_id) 17168 { 17169 skyCellMapRow *_object; 17170 17171 _object = psAlloc(sizeof(skyCellMapRow)); 17172 psMemSetDeallocator(_object, (psFreeFunc)skyCellMapRowFree); 17173 17174 _object->skycell_id = psStringCopy(skycell_id); 17175 _object->tess_id = psStringCopy(tess_id); 17176 _object->exp_tag = psStringCopy(exp_tag); 17177 _object->class_id = psStringCopy(class_id); 17178 17179 return _object; 17180 } 17181 17182 static void skyCellMapRowFree(skyCellMapRow *object) 17183 { 17184 psFree(object->skycell_id); 17185 psFree(object->tess_id); 17186 psFree(object->exp_tag); 17187 psFree(object->class_id); 17188 } 17189 17190 bool skyCellMapCreateTable(psDB *dbh) 17191 { 17192 psMetadata *md = psMetadataAlloc(); 17193 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, "Primary Key", "64")) { 17194 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 17195 psFree(md); 17196 return false; 17197 } 17198 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, "Primary Key", "64")) { 17199 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 17200 psFree(md); 17201 return false; 17202 } 17203 if (!psMetadataAdd(md, PS_LIST_TAIL, "exp_tag", PS_DATA_STRING, "Primary Key", "64")) { 17204 psError(PS_ERR_UNKNOWN, false, "failed to add item exp_tag"); 17205 psFree(md); 17206 return false; 17207 } 17208 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, "Primary Key", "64")) { 17209 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id"); 17210 psFree(md); 17211 return false; 17212 } 17213 17214 bool status = psDBCreateTable(dbh, SKYCELLMAP_TABLE_NAME, md); 17215 17216 psFree(md); 17217 17218 return status; 17219 } 17220 17221 bool skyCellMapDropTable(psDB *dbh) 17222 { 17223 return psDBDropTable(dbh, SKYCELLMAP_TABLE_NAME); 17224 } 17225 17226 bool skyCellMapInsert(psDB * dbh, const char *skycell_id, const char *tess_id, const char *exp_tag, const char *class_id) 17227 { 17228 psMetadata *md = psMetadataAlloc(); 17229 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, NULL, skycell_id)) { 17230 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 17231 psFree(md); 17232 return false; 17233 } 17234 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, NULL, tess_id)) { 17235 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 17236 psFree(md); 17237 return false; 17238 } 17239 if (!psMetadataAdd(md, PS_LIST_TAIL, "exp_tag", PS_DATA_STRING, NULL, exp_tag)) { 17240 psError(PS_ERR_UNKNOWN, false, "failed to add item exp_tag"); 17241 psFree(md); 17242 return false; 17243 } 17244 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, NULL, class_id)) { 17245 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id"); 17246 psFree(md); 17247 return false; 17248 } 17249 17250 bool status = psDBInsertOneRow(dbh, SKYCELLMAP_TABLE_NAME, md); 17251 psFree(md); 17252 17253 return status; 17254 } 17255 17256 long long skyCellMapDelete(psDB *dbh, const psMetadata *where, unsigned long long limit) 17257 { 17258 long long deleted = 0; 17259 17260 long long count = psDBDeleteRows(dbh, SKYCELLMAP_TABLE_NAME, where, limit); 17261 if (count < 0) { 17262 psError(PS_ERR_UNKNOWN, true, "failed to delete row from skyCellMap"); 17263 return count; 17264 17265 deleted += count; 17266 } 17267 17268 return deleted; 17269 } 17270 bool skyCellMapInsertObject(psDB *dbh, skyCellMapRow *object) 17271 { 17272 return skyCellMapInsert(dbh, object->skycell_id, object->tess_id, object->exp_tag, object->class_id); 17273 } 17274 17275 bool skyCellMapInsertObjects(psDB *dbh, psArray *objects) 17276 { 17277 for (long i = 0; i < psArrayLength(objects); i++) { 17278 if (!skyCellMapInsertObject(dbh, objects->data[i])) { 17279 return false; 17280 } 17281 } 17282 17283 return true; 17284 } 17285 17286 bool skyCellMapInsertFits(psDB *dbh, const psFits *fits) 17287 { 17288 psArray *rowSet; 17289 17290 // move to (the first?) extension named SKYCELLMAP_TABLE_NAME 17291 if (!psFitsMoveExtName(fits, SKYCELLMAP_TABLE_NAME)) { 17292 psError(PS_ERR_UNKNOWN, true, "failed to find FITS extension %s", SKYCELLMAP_TABLE_NAME); 17293 return false; 17294 } 17295 17296 // check HDU type 17297 if (psFitsGetExtType(fits) != PS_FITS_TYPE_BINARY_TABLE) { 17298 psError(PS_ERR_UNKNOWN, true, "FITS HDU type is not PS_FITS_TYPE_BINARY_TABLE"); 17299 return false; 17300 } 17301 17302 // read fits table 17303 rowSet = psFitsReadTable(fits); 17304 if (!rowSet) { 17305 psError(PS_ERR_UNKNOWN, true, "FITS read error or FITS table is empty"); 17306 psFree(rowSet); 17307 return false; 17308 } 17309 17310 if (!psDBInsertRows(dbh, SKYCELLMAP_TABLE_NAME, rowSet)) { 17311 psError(PS_ERR_UNKNOWN, false, "databse insert failed"); 17312 psFree(rowSet); 17313 return false; 17314 } 17315 17316 psFree(rowSet); 17317 17318 return true; 17319 } 17320 17321 bool skyCellMapSelectRowsFits(psDB *dbh, psFits *fits, const psMetadata *where, unsigned long long limit) 17322 { 17323 psArray *rowSet; 17324 17325 rowSet = psDBSelectRows(dbh, SKYCELLMAP_TABLE_NAME, where, limit); 17326 if (!rowSet) { 17327 return false; 17328 } 17329 17330 // output to fits 17331 if (!psFitsWriteTable(fits, NULL, rowSet, SKYCELLMAP_TABLE_NAME)) { 17332 psError(PS_ERR_UNKNOWN, false, "FITS table write failed"); 17333 psFree(rowSet); 17334 return false; 17335 } 17336 17337 psFree(rowSet); 17338 17339 return true; 17340 } 17341 17342 psMetadata *skyCellMapMetadataFromObject(const skyCellMapRow *object) 17343 { 17344 psMetadata *md = psMetadataAlloc(); 17345 if (!psMetadataAdd(md, PS_LIST_TAIL, "skycell_id", PS_DATA_STRING, NULL, object->skycell_id)) { 17346 psError(PS_ERR_UNKNOWN, false, "failed to add item skycell_id"); 17347 psFree(md); 17348 return false; 17349 } 17350 if (!psMetadataAdd(md, PS_LIST_TAIL, "tess_id", PS_DATA_STRING, NULL, object->tess_id)) { 17351 psError(PS_ERR_UNKNOWN, false, "failed to add item tess_id"); 17352 psFree(md); 17353 return false; 17354 } 17355 if (!psMetadataAdd(md, PS_LIST_TAIL, "exp_tag", PS_DATA_STRING, NULL, object->exp_tag)) { 17356 psError(PS_ERR_UNKNOWN, false, "failed to add item exp_tag"); 17357 psFree(md); 17358 return false; 17359 } 17360 if (!psMetadataAdd(md, PS_LIST_TAIL, "class_id", PS_DATA_STRING, NULL, object->class_id)) { 17361 psError(PS_ERR_UNKNOWN, false, "failed to add item class_id"); 17362 psFree(md); 17363 return false; 17364 } 17365 17366 17367 return md; 17368 } 17369 17370 skyCellMapRow *skyCellMapObjectFromMetadata(psMetadata *md) 17371 { 17372 17373 bool status = false; 17374 char* skycell_id = psMetadataLookupPtr(&status, md, "skycell_id"); 17375 if (!status) { 17376 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item skycell_id"); 17377 return false; 17378 } 17379 char* tess_id = psMetadataLookupPtr(&status, md, "tess_id"); 17380 if (!status) { 17381 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item tess_id"); 17382 return false; 17383 } 17384 char* exp_tag = psMetadataLookupPtr(&status, md, "exp_tag"); 17385 if (!status) { 17386 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item exp_tag"); 17387 return false; 17388 } 17389 char* class_id = psMetadataLookupPtr(&status, md, "class_id"); 17390 if (!status) { 17391 psError(PS_ERR_UNKNOWN, true, "failed to lookup value for item class_id"); 17392 return false; 17393 } 17394 17395 return skyCellMapRowAlloc(skycell_id, tess_id, exp_tag, class_id); 17396 } 17397 psArray *skyCellMapSelectRowObjects(psDB *dbh, const psMetadata *where, unsigned long long limit) 17398 { 17399 psArray *rowSet; 17400 psArray *returnSet; 17401 psU64 i; 17402 17403 rowSet = psDBSelectRows(dbh, SKYCELLMAP_TABLE_NAME, where, limit); 17404 if (!rowSet) { 17405 return NULL; 17406 } 17407 17408 // convert psMetadata rows to row objects 17409 17410 returnSet = psArrayAllocEmpty(rowSet->n); 17411 17412 for (i = 0; i < rowSet->n; i++) { 17413 skyCellMapRow *object = skyCellMapObjectFromMetadata(rowSet->data[i]); 17414 psArrayAdd(returnSet, 0, object); 17415 psFree(object); 17416 } 17417 17418 psFree(rowSet); 17419 17420 return returnSet; 17421 } 17422 bool skyCellMapDeleteObject(psDB *dbh, const skyCellMapRow *object) 17423 { 17424 psMetadata *where = skyCellMapMetadataFromObject(object); 17425 long long count = psDBDeleteRows(dbh, SKYCELLMAP_TABLE_NAME, where, 0); 17426 psFree(where); 17427 if (count < 0) { 17428 psError(PS_ERR_UNKNOWN, true, "failed to delete row from skyCellMap"); 17429 return false; 17430 } 17431 if (count > 1) { 17432 // XXX should this be a psAbort() instead? It is possible that 17433 // having an object match multiple rows was by design. 17434 psError(PS_ERR_UNKNOWN, true, "skyCellMapRow object matched more then one row. Check your database schema"); 17435 return false; 17436 } 17437 17438 return true; 17439 } 17440 long long skyCellMapDeleteRowObjects(psDB *dbh, const psArray *objects, unsigned long long limit) 17441 { 17442 long long deleted = 0; 17443 17444 for (long long i = 0; i < objects->n; i++) { 17445 skyCellMapRow *object = objects->data[i]; 17446 psMetadata *where = skyCellMapMetadataFromObject(object); 17447 long long count = psDBDeleteRows(dbh, SKYCELLMAP_TABLE_NAME, where, limit); 17448 psFree(where); 17449 if (count < 0) { 17450 psError(PS_ERR_UNKNOWN, true, "failed to delete row from skyCellMap"); 17451 return count; 17452 } 17453 17454 deleted += count; 17455 } 17456 17457 return deleted; 17458 } 17459 bool skyCellMapPrintObjects(FILE *stream, psArray *objects, bool mdcf) 17460 { 17461 PS_ASSERT_PTR_NON_NULL(objects, false); 17462 17463 psMetadata *output = psMetadataAlloc(); 17464 for (long i = 0; i < psArrayLength(objects); i++) { 17465 psMetadata *md = skyCellMapMetadataFromObject(objects->data[i]); 17466 if (!psMetadataAddMetadata( 17467 output, 17468 PS_LIST_TAIL, 17469 SKYCELLMAP_TABLE_NAME, 17470 PS_META_DUPLICATE_OK, 17471 NULL, 17472 md 17473 )) { 17474 psError(PS_ERR_UNKNOWN, false, "failed to add metadata"); 17475 psFree(md); 17476 psFree(output); 17477 return false; 17478 } 17479 psFree(md); 17480 } 17481 17482 if (!ippdbPrintMetadataRaw(stream, output, mdcf)) { 17483 psError(PS_ERR_UNKNOWN, false, "failed to print metadata"); 17484 psFree(output); 17485 } 17486 psFree(output); 17487 17488 return true; 17489 } 17490 bool skyCellMapPrintObject(FILE *stream, skyCellMapRow *object, bool mdcf) 17491 { 17492 PS_ASSERT_PTR_NON_NULL(object, false); 17493 17494 psMetadata *md = skyCellMapMetadataFromObject(object); 17495 17496 if (!ippdbPrintMetadataRaw(stream, md, mdcf)) { 17497 psError(PS_ERR_UNKNOWN, false, "failed to print metadata"); 17498 psFree(md); 17499 } 17500 17501 psFree(md); 17502 17503 return true; 17504 }
Note:
See TracChangeset
for help on using the changeset viewer.
