TDengine/source/util/src/encode.c

141 lines
3.5 KiB
C
Raw Normal View History

2021-12-31 09:41:04 +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/>.
*/
#include "encode.h"
2022-01-02 09:42:57 +00:00
#if __STDC_VERSION__ >= 201112L
static_assert(sizeof(float) == sizeof(uint32_t), "sizeof(float) must equal to sizeof(uint32_t)");
static_assert(sizeof(double) == sizeof(uint64_t), "sizeof(double) must equal to sizeof(uint64_t)");
#endif
2022-01-02 08:47:28 +00:00
void tCoderInit(SCoder* pCoder, td_endian_t endian, uint8_t* data, int32_t size, td_coder_t type) {
if (type == TD_ENCODER) {
if (data == NULL) size = 0;
} else {
ASSERT(data && size > 0);
}
2021-12-31 09:41:04 +00:00
2022-01-02 08:47:28 +00:00
pCoder->type = type;
2021-12-31 09:41:04 +00:00
pCoder->endian = endian;
pCoder->data = data;
pCoder->size = size;
pCoder->pos = 0;
tFreeListInit(&(pCoder->fl));
TD_SLIST_INIT(&(pCoder->stack));
}
void tCoderClear(SCoder* pCoder) {
tFreeListClear(&(pCoder->fl));
struct SCoderNode* pNode;
for (;;) {
pNode = TD_SLIST_HEAD(&(pCoder->stack));
if (pNode == NULL) break;
TD_SLIST_POP(&(pCoder->stack));
free(pNode);
}
}
int tStartEncode(SCoder* pCoder) {
2022-01-02 06:48:48 +00:00
struct SCoderNode* pNode;
2022-01-03 10:02:21 +00:00
ASSERT(pCoder->type == TD_ENCODER);
2021-12-31 09:41:04 +00:00
if (pCoder->data) {
2022-01-02 06:48:48 +00:00
if (pCoder->size - pCoder->pos < sizeof(int32_t)) return -1;
pNode = malloc(sizeof(*pNode));
2021-12-31 09:41:04 +00:00
if (pNode == NULL) return -1;
pNode->data = pCoder->data;
pNode->pos = pCoder->pos;
pNode->size = pCoder->size;
2022-01-03 08:45:31 +00:00
pCoder->data = pNode->data + pNode->pos + sizeof(int32_t);
2021-12-31 09:41:04 +00:00
pCoder->pos = 0;
pCoder->size = pNode->size - pNode->pos - sizeof(int32_t);
TD_SLIST_PUSH(&(pCoder->stack), pNode);
} else {
pCoder->pos += sizeof(int32_t);
}
return 0;
}
void tEndEncode(SCoder* pCoder) {
struct SCoderNode* pNode;
2022-01-03 08:45:31 +00:00
int32_t len;
2021-12-31 09:41:04 +00:00
2022-01-03 10:02:21 +00:00
ASSERT(pCoder->type == TD_ENCODER);
2021-12-31 09:41:04 +00:00
if (pCoder->data) {
pNode = TD_SLIST_HEAD(&(pCoder->stack));
ASSERT(pNode);
TD_SLIST_POP(&(pCoder->stack));
2022-01-03 08:45:31 +00:00
len = pCoder->pos;
2021-12-31 09:41:04 +00:00
pCoder->data = pNode->data;
pCoder->size = pNode->size;
2022-01-03 08:45:31 +00:00
pCoder->pos = pNode->pos;
2022-01-03 09:34:20 +00:00
if (TD_RT_ENDIAN() == pCoder->endian) {
tPut(int32_t, pCoder->data + pCoder->pos, len);
} else {
tRPut32(pCoder->data + pCoder->pos, len);
}
2022-01-03 08:45:31 +00:00
2022-01-03 10:02:21 +00:00
TD_CODER_MOVE_POS(pCoder, len + sizeof(int32_t));
2021-12-31 09:41:04 +00:00
free(pNode);
}
}
int tStartDecode(SCoder* pCoder) {
2022-01-03 08:45:31 +00:00
int32_t len;
2021-12-31 09:41:04 +00:00
struct SCoderNode* pNode;
2022-01-03 10:02:21 +00:00
ASSERT(pCoder->type == TD_DECODER);
2022-01-03 08:45:31 +00:00
if (tDecodeI32(pCoder, &len) < 0) return -1;
2022-01-02 06:48:48 +00:00
2021-12-31 09:41:04 +00:00
pNode = malloc(sizeof(*pNode));
if (pNode == NULL) return -1;
pNode->data = pCoder->data;
pNode->pos = pCoder->pos;
pNode->size = pCoder->size;
2022-01-03 08:45:31 +00:00
pCoder->data = pNode->data + pNode->pos;
pCoder->size = len;
2021-12-31 09:41:04 +00:00
pCoder->pos = 0;
TD_SLIST_PUSH(&(pCoder->stack), pNode);
return 0;
}
void tEndDecode(SCoder* pCoder) {
struct SCoderNode* pNode;
2022-01-03 10:02:21 +00:00
ASSERT(pCoder->type == TD_DECODER);
2021-12-31 09:41:04 +00:00
pNode = TD_SLIST_HEAD(&(pCoder->stack));
ASSERT(pNode);
TD_SLIST_POP(&(pCoder->stack));
pCoder->data = pNode->data;
2022-01-04 03:46:55 +00:00
pCoder->pos = pCoder->size + pNode->pos;
2021-12-31 09:41:04 +00:00
pCoder->size = pNode->size;
free(pNode);
}