TDengine/source/dnode/vnode/src/tsdb/dev/tsdbFSet.c

164 lines
3.9 KiB
C
Raw Normal View History

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
}