From 6ad5d7c0fbe4f0cc84f06adf7dbe0aaf116261f4 Mon Sep 17 00:00:00 2001 From: wangmm0220 Date: Tue, 27 Sep 2022 19:28:31 +0800 Subject: [PATCH] fix:add new interface for schemaless to support '\0' in line value --- src/client/src/tscParseLineProtocol.c | 14 +++++++++++--- src/client/src/tscParseOpenTSDB.c | 10 ++++++++-- 2 files changed, 19 insertions(+), 5 deletions(-) diff --git a/src/client/src/tscParseLineProtocol.c b/src/client/src/tscParseLineProtocol.c index f6a5112426..3abf56502f 100644 --- a/src/client/src/tscParseLineProtocol.c +++ b/src/client/src/tscParseLineProtocol.c @@ -577,7 +577,9 @@ static int32_t getSuperTableMetaFromLocalCache(TAOS* taos, char* tableName, STab // Check if the table name available or not if (tscValidateName(&tableToken, true, &dbIncluded) != TSDB_CODE_SUCCESS) { code = TSDB_CODE_TSC_INVALID_TABLE_ID_LENGTH; - sprintf(pSql->cmd.payload, "table name is invalid"); + if(pSql->cmd.payload){ + sprintf(pSql->cmd.payload, "table name is invalid"); + } taosReleaseRef(tscObjRef, pSql->self); return code; } @@ -2674,7 +2676,10 @@ int32_t tscParseLines(char* data, int32_t len, char* lines[], int numLines, SArr char* tmp = data; int32_t lenTmp = 0; for(int i = 0; i < len; i++){ - if(data[i] == '\n'){ + if(data[i] == '\n' || i == len - 1){ + if(data[i] != '\n' || i == len - 1){ + lenTmp ++; + } if(lenTmp > 0) { code = tscParseLinesInner(tmp, lenTmp, points, info); if(code != TSDB_CODE_SUCCESS){ @@ -2705,6 +2710,9 @@ int taos_insert_lines(TAOS* taos, char* data, int len, char* lines[], int numLin if (data){ numLines = 0; for(int i = 0; i < len; i++){ + if(data[i] == '\0'){ + data[i] = '0'; + } if(data[i] == '\n' || i == len - 1){ numLines++; } @@ -2736,7 +2744,7 @@ int taos_insert_lines(TAOS* taos, char* data, int len, char* lines[], int numLin return TSDB_CODE_TSC_OUT_OF_MEMORY; } - tscDebug("SML:0x%"PRIx64" taos_insert_lines begin inserting %d lines, first line: %s", info->id, numLines, lines[0]); + tscDebug("SML:0x%"PRIx64" taos_insert_lines begin inserting %d lines", info->id, numLines); code = tscParseLines(data, len, lines, numLines, lpPoints, NULL, info); size_t numPoints = taosArrayGetSize(lpPoints); diff --git a/src/client/src/tscParseOpenTSDB.c b/src/client/src/tscParseOpenTSDB.c index 51ce5ae809..a1c011db2a 100644 --- a/src/client/src/tscParseOpenTSDB.c +++ b/src/client/src/tscParseOpenTSDB.c @@ -231,7 +231,7 @@ static int32_t parseTelnetTagKey(TAOS_SML_KV *pKV, const char **idx, int32_t sql cur++; len++; } - if (len == 0 || cur - *idx < sqlLen) { + if (len == 0 || cur - *idx == sqlLen) { return TSDB_CODE_TSC_LINE_SYNTAX_ERROR; } key[len] = '\0'; @@ -427,7 +427,10 @@ static int32_t tscParseTelnetLines(char* data, int32_t len, char* lines[], int n char* tmp = data; int32_t lenTmp = 0; for(int i = 0; i < len; i++){ - if(data[i] == '\n'){ + if(data[i] == '\n' || i == len - 1){ + if(data[i] != '\n' || i == len - 1){ + lenTmp++; + } if(lenTmp > 0) { code = tscParseTelnetLinesInner(tmp, lenTmp, points, info); if(code != TSDB_CODE_SUCCESS){ @@ -458,6 +461,9 @@ int taos_insert_telnet_lines(TAOS* taos, char* data, int32_t len, char* lines[], if (data && !lines){ numLines = 0; for(int i = 0; i < len; i++){ + if(data[i] == '\0'){ + data[i] = '0'; + } if(data[i] == '\n' || i == len - 1){ numLines++; } -- GitLab