Merge branch 'develop' into feature/query
This commit is contained in:
commit
656128d9cf
|
@ -1888,11 +1888,14 @@ static void transferNcharData(SSqlObj *pSql, int32_t columnIndex, TAOS_FIELD *pF
|
||||||
/* string terminated char for binary data*/
|
/* string terminated char for binary data*/
|
||||||
memset(pRes->buffer[columnIndex], 0, pField->bytes + TSDB_NCHAR_SIZE);
|
memset(pRes->buffer[columnIndex], 0, pField->bytes + TSDB_NCHAR_SIZE);
|
||||||
|
|
||||||
if (taosUcs4ToMbs(pRes->tsrow[columnIndex], pField->bytes - VARSTR_HEADER_SIZE, pRes->buffer[columnIndex])) {
|
int32_t length = taosUcs4ToMbs(pRes->tsrow[columnIndex], pRes->length[columnIndex], pRes->buffer[columnIndex]);
|
||||||
|
if ( length >= 0 ) {
|
||||||
pRes->tsrow[columnIndex] = pRes->buffer[columnIndex];
|
pRes->tsrow[columnIndex] = pRes->buffer[columnIndex];
|
||||||
|
pRes->length[columnIndex] = length;
|
||||||
} else {
|
} else {
|
||||||
tscError("%p charset:%s to %s. val:%ls convert failed.", pSql, DEFAULT_UNICODE_ENCODEC, tsCharset, pRes->tsrow[columnIndex]);
|
tscError("%p charset:%s to %s. val:%ls convert failed.", pSql, DEFAULT_UNICODE_ENCODEC, tsCharset, pRes->tsrow[columnIndex]);
|
||||||
pRes->tsrow[columnIndex] = NULL;
|
pRes->tsrow[columnIndex] = NULL;
|
||||||
|
pRes->length[columnIndex] = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -68,7 +68,6 @@ void get_history_path(char* history);
|
||||||
void cleanup_handler(void* arg);
|
void cleanup_handler(void* arg);
|
||||||
void exitShell();
|
void exitShell();
|
||||||
int shellDumpResult(TAOS* con, char* fname, int* error_no, bool printMode);
|
int shellDumpResult(TAOS* con, char* fname, int* error_no, bool printMode);
|
||||||
void shellPrintNChar(const char* str, int length, int width);
|
|
||||||
void shellGetGrantInfo(void *con);
|
void shellGetGrantInfo(void *con);
|
||||||
int isCommentLine(char *line);
|
int isCommentLine(char *line);
|
||||||
|
|
||||||
|
|
|
@ -349,31 +349,6 @@ void *shellLoopQuery(void *arg) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void shellPrintNChar(const char *str, int length, int width) {
|
|
||||||
int pos = 0, cols = 0;
|
|
||||||
while (pos < length) {
|
|
||||||
wchar_t wc;
|
|
||||||
pos += mbtowc(&wc, str + pos, MB_CUR_MAX);
|
|
||||||
if (pos > length) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
int w = wcwidth(wc);
|
|
||||||
if (w > 0) {
|
|
||||||
if (width > 0 && cols + w > width) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
printf("%lc", wc);
|
|
||||||
cols += w;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (; cols < width; cols++) {
|
|
||||||
putchar(' ');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int get_old_terminal_mode(struct termios *tio) {
|
int get_old_terminal_mode(struct termios *tio) {
|
||||||
/* Make sure stdin is a terminal. */
|
/* Make sure stdin is a terminal. */
|
||||||
if (!isatty(STDIN_FILENO)) {
|
if (!isatty(STDIN_FILENO)) {
|
||||||
|
|
|
@ -435,7 +435,6 @@ static int dumpResultToFile(const char* fname, TAOS_RES* result) {
|
||||||
|
|
||||||
int num_fields = taos_num_fields(result);
|
int num_fields = taos_num_fields(result);
|
||||||
TAOS_FIELD *fields = taos_fetch_fields(result);
|
TAOS_FIELD *fields = taos_fetch_fields(result);
|
||||||
int32_t* length = taos_fetch_lengths(result);
|
|
||||||
int precision = taos_result_precision(result);
|
int precision = taos_result_precision(result);
|
||||||
|
|
||||||
for (int col = 0; col < num_fields; col++) {
|
for (int col = 0; col < num_fields; col++) {
|
||||||
|
@ -448,6 +447,7 @@ static int dumpResultToFile(const char* fname, TAOS_RES* result) {
|
||||||
|
|
||||||
int numOfRows = 0;
|
int numOfRows = 0;
|
||||||
do {
|
do {
|
||||||
|
int32_t* length = taos_fetch_lengths(result);
|
||||||
for (int i = 0; i < num_fields; i++) {
|
for (int i = 0; i < num_fields; i++) {
|
||||||
if (i > 0) {
|
if (i > 0) {
|
||||||
fputc(',', fp);
|
fputc(',', fp);
|
||||||
|
@ -465,6 +465,39 @@ static int dumpResultToFile(const char* fname, TAOS_RES* result) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void shellPrintNChar(const char *str, int length, int width) {
|
||||||
|
int pos = 0, cols = 0;
|
||||||
|
while (pos < length) {
|
||||||
|
wchar_t wc;
|
||||||
|
int bytes = mbtowc(&wc, str + pos, MB_CUR_MAX);
|
||||||
|
if (bytes == 0) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
pos += bytes;
|
||||||
|
if (pos > length) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef WINDOWS
|
||||||
|
int w = bytes;
|
||||||
|
#else
|
||||||
|
int w = wcwidth(wc);
|
||||||
|
#endif
|
||||||
|
if (w > 0) {
|
||||||
|
if (width > 0 && cols + w > width) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
printf("%lc", wc);
|
||||||
|
cols += w;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (; cols < width; cols++) {
|
||||||
|
putchar(' ');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void printField(const char* val, TAOS_FIELD* field, int width, int32_t length, int precision) {
|
static void printField(const char* val, TAOS_FIELD* field, int width, int32_t length, int precision) {
|
||||||
if (val == NULL) {
|
if (val == NULL) {
|
||||||
int w = width;
|
int w = width;
|
||||||
|
@ -523,7 +556,6 @@ static int verticalPrintResult(TAOS_RES* result) {
|
||||||
|
|
||||||
int num_fields = taos_num_fields(result);
|
int num_fields = taos_num_fields(result);
|
||||||
TAOS_FIELD *fields = taos_fetch_fields(result);
|
TAOS_FIELD *fields = taos_fetch_fields(result);
|
||||||
int32_t* length = taos_fetch_lengths(result);
|
|
||||||
int precision = taos_result_precision(result);
|
int precision = taos_result_precision(result);
|
||||||
|
|
||||||
int maxColNameLen = 0;
|
int maxColNameLen = 0;
|
||||||
|
@ -537,6 +569,7 @@ static int verticalPrintResult(TAOS_RES* result) {
|
||||||
int numOfRows = 0;
|
int numOfRows = 0;
|
||||||
do {
|
do {
|
||||||
printf("*************************** %d.row ***************************\n", numOfRows + 1);
|
printf("*************************** %d.row ***************************\n", numOfRows + 1);
|
||||||
|
int32_t* length = taos_fetch_lengths(result);
|
||||||
for (int i = 0; i < num_fields; i++) {
|
for (int i = 0; i < num_fields; i++) {
|
||||||
TAOS_FIELD* field = fields + i;
|
TAOS_FIELD* field = fields + i;
|
||||||
|
|
||||||
|
@ -631,7 +664,6 @@ static int horizontalPrintResult(TAOS_RES* result) {
|
||||||
|
|
||||||
int num_fields = taos_num_fields(result);
|
int num_fields = taos_num_fields(result);
|
||||||
TAOS_FIELD *fields = taos_fetch_fields(result);
|
TAOS_FIELD *fields = taos_fetch_fields(result);
|
||||||
int32_t* length = taos_fetch_lengths(result);
|
|
||||||
int precision = taos_result_precision(result);
|
int precision = taos_result_precision(result);
|
||||||
|
|
||||||
int width[TSDB_MAX_COLUMNS];
|
int width[TSDB_MAX_COLUMNS];
|
||||||
|
@ -643,6 +675,7 @@ static int horizontalPrintResult(TAOS_RES* result) {
|
||||||
|
|
||||||
int numOfRows = 0;
|
int numOfRows = 0;
|
||||||
do {
|
do {
|
||||||
|
int32_t* length = taos_fetch_lengths(result);
|
||||||
for (int i = 0; i < num_fields; i++) {
|
for (int i = 0; i < num_fields; i++) {
|
||||||
putchar(' ');
|
putchar(' ');
|
||||||
printField(row[i], fields + i, width[i], length[i], precision);
|
printField(row[i], fields + i, width[i], length[i], precision);
|
||||||
|
|
|
@ -323,30 +323,6 @@ void *shellLoopQuery(void *arg) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void shellPrintNChar(const char *str, int length, int width) {
|
|
||||||
int pos = 0, cols = 0;
|
|
||||||
while (pos < length) {
|
|
||||||
wchar_t wc;
|
|
||||||
pos += mbtowc(&wc, str + pos, MB_CUR_MAX);
|
|
||||||
if (pos > length) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
int w = wcwidth(wc);
|
|
||||||
if (w > 0) {
|
|
||||||
if (width > 0 && cols + w > width) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
printf("%lc", wc);
|
|
||||||
cols += w;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (; cols < width; cols++) {
|
|
||||||
putchar(' ');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int get_old_terminal_mode(struct termios *tio) {
|
int get_old_terminal_mode(struct termios *tio) {
|
||||||
/* Make sure stdin is a terminal. */
|
/* Make sure stdin is a terminal. */
|
||||||
if (!isatty(STDIN_FILENO)) {
|
if (!isatty(STDIN_FILENO)) {
|
||||||
|
|
|
@ -214,32 +214,6 @@ void *shellLoopQuery(void *arg) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void shellPrintNChar(const char *str, int length, int width) {
|
|
||||||
int pos = 0, cols = 0;
|
|
||||||
while (pos < length) {
|
|
||||||
wchar_t wc;
|
|
||||||
int bytes = mbtowc(&wc, str + pos, MB_CUR_MAX);
|
|
||||||
pos += bytes;
|
|
||||||
if (pos > length) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
int w = bytes;
|
|
||||||
if (w > 0) {
|
|
||||||
if (width > 0 && cols + w > width) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
printf("%lc", wc);
|
|
||||||
cols += w;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (; cols < width; cols++) {
|
|
||||||
putchar(' ');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void get_history_path(char *history) { sprintf(history, "%s/%s", ".", HISTORY_FILE); }
|
void get_history_path(char *history) { sprintf(history, "%s/%s", ".", HISTORY_FILE); }
|
||||||
|
|
||||||
void exitShell() { exit(EXIT_SUCCESS); }
|
void exitShell() { exit(EXIT_SUCCESS); }
|
||||||
|
|
|
@ -145,7 +145,7 @@ bool taosMbsToUcs4(char *mbs, size_t mbs_len, char *ucs4, int32_t ucs4_max_len,
|
||||||
|
|
||||||
int tasoUcs4Compare(void* f1_ucs4, void *f2_ucs4, int bytes);
|
int tasoUcs4Compare(void* f1_ucs4, void *f2_ucs4, int bytes);
|
||||||
|
|
||||||
bool taosUcs4ToMbs(void *ucs4, int32_t ucs4_max_len, char *mbs);
|
int32_t taosUcs4ToMbs(void *ucs4, int32_t ucs4_max_len, char *mbs);
|
||||||
|
|
||||||
bool taosValidateEncodec(const char *encodec);
|
bool taosValidateEncodec(const char *encodec);
|
||||||
|
|
||||||
|
|
|
@ -447,10 +447,10 @@ int tasoUcs4Compare(void* f1_ucs4, void *f2_ucs4, int bytes) {
|
||||||
int32_t ucs4_max_len = bytes + 4;
|
int32_t ucs4_max_len = bytes + 4;
|
||||||
char *f1_mbs = calloc(bytes, 1);
|
char *f1_mbs = calloc(bytes, 1);
|
||||||
char *f2_mbs = calloc(bytes, 1);
|
char *f2_mbs = calloc(bytes, 1);
|
||||||
if (!taosUcs4ToMbs(f1_ucs4, ucs4_max_len, f1_mbs)) {
|
if (taosUcs4ToMbs(f1_ucs4, ucs4_max_len, f1_mbs) < 0) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if (!taosUcs4ToMbs(f2_ucs4, ucs4_max_len, f2_mbs)) {
|
if (taosUcs4ToMbs(f2_ucs4, ucs4_max_len, f2_mbs) < 0) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
int32_t ret = strcmp(f1_mbs, f2_mbs);
|
int32_t ret = strcmp(f1_mbs, f2_mbs);
|
||||||
|
@ -464,29 +464,29 @@ int tasoUcs4Compare(void* f1_ucs4, void *f2_ucs4, int bytes) {
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
bool taosUcs4ToMbs(void *ucs4, int32_t ucs4_max_len, char *mbs) {
|
int32_t taosUcs4ToMbs(void *ucs4, int32_t ucs4_max_len, char *mbs) {
|
||||||
#ifdef USE_LIBICONV
|
#ifdef USE_LIBICONV
|
||||||
iconv_t cd = iconv_open(tsCharset, DEFAULT_UNICODE_ENCODEC);
|
iconv_t cd = iconv_open(tsCharset, DEFAULT_UNICODE_ENCODEC);
|
||||||
size_t ucs4_input_len = ucs4_max_len;
|
size_t ucs4_input_len = ucs4_max_len;
|
||||||
size_t outLen = ucs4_max_len;
|
size_t outLen = ucs4_max_len;
|
||||||
if (iconv(cd, (char **)&ucs4, &ucs4_input_len, &mbs, &outLen) == -1) {
|
if (iconv(cd, (char **)&ucs4, &ucs4_input_len, &mbs, &outLen) == -1) {
|
||||||
iconv_close(cd);
|
iconv_close(cd);
|
||||||
return false;
|
return -1;
|
||||||
}
|
}
|
||||||
iconv_close(cd);
|
iconv_close(cd);
|
||||||
return true;
|
return (int32_t)(ucs4_max_len - outLen);
|
||||||
#else
|
#else
|
||||||
mbstate_t state = {0};
|
mbstate_t state = {0};
|
||||||
int32_t len = (int32_t) wcsnrtombs(NULL, (const wchar_t **) &ucs4, ucs4_max_len / 4, 0, &state);
|
int32_t len = (int32_t) wcsnrtombs(NULL, (const wchar_t **) &ucs4, ucs4_max_len / 4, 0, &state);
|
||||||
if (len < 0) {
|
if (len < 0) {
|
||||||
return false;
|
return -1;
|
||||||
}
|
}
|
||||||
memset(&state, 0, sizeof(state));
|
memset(&state, 0, sizeof(state));
|
||||||
len = wcsnrtombs(mbs, (const wchar_t **) &ucs4, ucs4_max_len / 4, (size_t) len, &state);
|
len = wcsnrtombs(mbs, (const wchar_t **) &ucs4, ucs4_max_len / 4, (size_t) len, &state);
|
||||||
if (len < 0) {
|
if (len < 0) {
|
||||||
return false;
|
return -1;
|
||||||
}
|
}
|
||||||
return true;
|
return len;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue