2023-03-27 08:30:22 +00:00
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
|
|
|
|
|
*
|
|
|
|
|
* This program is free software: you can use, redistribute, and/or modify
|
|
|
|
|
* it under the terms of the GNU Affero General Public License, version 3
|
|
|
|
|
* or later ("AGPL"), as published by the Free Software Foundation.
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
*/
|
|
|
|
|
|
2023-05-08 02:27:55 +00:00
|
|
|
#include "inc/tsdbFSet.h"
|
2023-04-10 09:52:51 +00:00
|
|
|
|
2023-05-08 08:16:45 +00:00
|
|
|
static int32_t stt_lvl_to_json(const SSttLvl *lvl, cJSON *json) {
|
|
|
|
|
if (cJSON_AddNumberToObject(json, "lvl", lvl->lvl) == NULL) {
|
|
|
|
|
return TSDB_CODE_OUT_OF_MEMORY;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
cJSON *arr = cJSON_AddArrayToObject(json, "stt");
|
|
|
|
|
if (arr == NULL) return TSDB_CODE_OUT_OF_MEMORY;
|
|
|
|
|
|
|
|
|
|
// TODO: .stt files
|
|
|
|
|
// STFile *f;
|
|
|
|
|
// LISTD_FOREACH(&lvl->fstt, f, listNode) {
|
|
|
|
|
// cJSON *item = cJSON_CreateObject();
|
|
|
|
|
// if (item == NULL) return TSDB_CODE_OUT_OF_MEMORY;
|
|
|
|
|
|
|
|
|
|
// int32_t code = tsdbTFileToJson(f, item);
|
|
|
|
|
// if (code) return code;
|
|
|
|
|
|
|
|
|
|
// cJSON_AddItemToArray(arr, item);
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-08 10:15:31 +00:00
|
|
|
static int32_t stt_lvl_from_json(const cJSON *json, SSttLvl *lvl) {
|
|
|
|
|
// TODO
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-08 08:16:45 +00:00
|
|
|
int32_t tsdbFileSetToJson(const STFileSet *fset, cJSON *json) {
|
2023-04-10 09:52:51 +00:00
|
|
|
int32_t code = 0;
|
|
|
|
|
|
2023-05-08 08:16:45 +00:00
|
|
|
// fid
|
|
|
|
|
if (cJSON_AddNumberToObject(json, "fid", fset->fid) == NULL) {
|
|
|
|
|
return TSDB_CODE_OUT_OF_MEMORY;
|
|
|
|
|
}
|
2023-04-10 09:52:51 +00:00
|
|
|
|
2023-05-08 08:16:45 +00:00
|
|
|
for (int32_t ftype = TSDB_FTYPE_MIN; ftype < TSDB_FTYPE_MAX; ++ftype) {
|
|
|
|
|
if (fset->farr[ftype] == NULL) {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
code = tsdbTFileToJson(fset->farr[ftype], json);
|
|
|
|
|
if (code) return code;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// each level
|
|
|
|
|
cJSON *ajson = cJSON_AddArrayToObject(json, "stt");
|
|
|
|
|
if (ajson == NULL) return TSDB_CODE_OUT_OF_MEMORY;
|
|
|
|
|
|
|
|
|
|
SSttLvl *sttLvl;
|
|
|
|
|
LISTD_FOREACH(&fset->lvl0, sttLvl, listNode) {
|
|
|
|
|
cJSON *ljson = cJSON_CreateObject();
|
|
|
|
|
if (ljson == NULL) return TSDB_CODE_OUT_OF_MEMORY;
|
|
|
|
|
|
|
|
|
|
code = stt_lvl_to_json(sttLvl, ljson);
|
|
|
|
|
if (code) return code;
|
|
|
|
|
|
|
|
|
|
cJSON_AddItemToArray(ajson, ljson);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return 0;
|
2023-04-11 09:04:52 +00:00
|
|
|
}
|
|
|
|
|
|
2023-05-08 10:15:31 +00:00
|
|
|
int32_t tsdbFileSetFromJson(const cJSON *json, STFileSet *fset) {
|
|
|
|
|
const cJSON *item;
|
|
|
|
|
|
|
|
|
|
/* fid */
|
|
|
|
|
item = cJSON_GetObjectItem(json, "fid");
|
|
|
|
|
if (cJSON_IsNumber(item)) {
|
|
|
|
|
fset->fid = item->valueint;
|
|
|
|
|
} else {
|
|
|
|
|
return TSDB_CODE_FILE_CORRUPTED;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (int32_t ftype = TSDB_FTYPE_MIN; ftype < TSDB_FTYPE_MAX; ++ftype) {
|
|
|
|
|
int32_t code = tsdbTFileFromJson(json, ftype, &fset->farr[ftype]);
|
|
|
|
|
if (code) return code;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// each level
|
|
|
|
|
item = cJSON_GetObjectItem(json, "stt");
|
|
|
|
|
if (cJSON_IsArray(item)) {
|
|
|
|
|
// TODO
|
|
|
|
|
} else {
|
|
|
|
|
return TSDB_CODE_FILE_CORRUPTED;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-11 10:16:55 +00:00
|
|
|
int32_t tsdbFSetCmprFn(const STFileSet *pSet1, const STFileSet *pSet2) {
|
|
|
|
|
if (pSet1->fid < pSet2->fid) return -1;
|
|
|
|
|
if (pSet1->fid > pSet2->fid) return 1;
|
|
|
|
|
return 0;
|
2023-05-12 01:07:50 +00:00
|
|
|
}
|
|
|
|
|
|
2023-05-12 08:23:07 +00:00
|
|
|
int32_t tsdbFSetEdit(STFileSet *fset, const STFileOp *op) {
|
|
|
|
|
ASSERT(fset->fid == op->fid);
|
|
|
|
|
|
|
|
|
|
if (op->oState.size == 0) {
|
|
|
|
|
// create
|
|
|
|
|
STFile *f = taosMemoryMalloc(sizeof(STFile));
|
|
|
|
|
if (f == NULL) return TSDB_CODE_OUT_OF_MEMORY;
|
|
|
|
|
|
|
|
|
|
f[0] = op->nState;
|
|
|
|
|
|
|
|
|
|
if (f[0].type == TSDB_FTYPE_STT) {
|
|
|
|
|
SSttLvl *lvl;
|
|
|
|
|
LISTD_FOREACH(&fset->lvl0, lvl, listNode) {
|
|
|
|
|
if (lvl->lvl == f[0].stt.lvl) {
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (lvl == NULL) {
|
|
|
|
|
// TODO: create the level
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// TODO: add the stt file to the level
|
|
|
|
|
} else {
|
|
|
|
|
fset->farr[f[0].type] = f;
|
|
|
|
|
}
|
|
|
|
|
} else if (op->nState.size == 0) {
|
|
|
|
|
// delete
|
|
|
|
|
} else {
|
|
|
|
|
// modify
|
|
|
|
|
}
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int32_t tsdbFileSetInit(STFileSet *pSet) {
|
|
|
|
|
for (tsdb_ftype_t ftype = TSDB_FTYPE_MIN; ftype < TSDB_FTYPE_MAX; ftype++) {
|
|
|
|
|
pSet->farr[ftype] = NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
LISTD_INIT(&pSet->lvl0, listNode);
|
|
|
|
|
pSet->lvl0.lvl = 0;
|
|
|
|
|
pSet->lvl0.nstt = 0;
|
|
|
|
|
pSet->lvl0.fstt = NULL;
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int32_t tsdbFileSetClear(STFileSet *pSet) {
|
2023-05-12 01:07:50 +00:00
|
|
|
// TODO
|
|
|
|
|
return 0;
|
2023-05-12 08:23:07 +00:00
|
|
|
}
|