Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
慢慢CG
TDengine
提交
aded75a8
T
TDengine
项目概览
慢慢CG
/
TDengine
与 Fork 源项目一致
Fork自
taosdata / TDengine
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
aded75a8
编写于
9月 09, 2019
作者:
H
huili
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[supporting column output per row by row in shell]
上级
1ddd7336
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
242 addition
and
134 deletion
+242
-134
src/kit/shell/inc/shell.h
src/kit/shell/inc/shell.h
+2
-2
src/kit/shell/src/shellEngine.c
src/kit/shell/src/shellEngine.c
+226
-128
src/kit/shell/src/shellLinux.c
src/kit/shell/src/shellLinux.c
+7
-2
src/kit/shell/src/shellWindows.c
src/kit/shell/src/shellWindows.c
+7
-2
未找到文件。
src/kit/shell/inc/shell.h
浏览文件 @
aded75a8
...
...
@@ -76,8 +76,8 @@ void source_file(TAOS* con, char* fptr);
void
get_history_path
(
char
*
history
);
void
cleanup_handler
(
void
*
arg
);
void
exitShell
();
int
shellDumpResult
(
TAOS
*
con
,
char
*
fname
,
int
*
error_no
);
void
shellPrintNChar
(
char
*
str
,
int
width
);
int
shellDumpResult
(
TAOS
*
con
,
char
*
fname
,
int
*
error_no
,
bool
printMode
);
void
shellPrintNChar
(
char
*
str
,
int
width
,
bool
printMode
);
#define max(a, b) ((int)(a) < (int)(b) ? (int)(b) : (int)(a))
/**************** Global variable declarations ****************/
...
...
src/kit/shell/src/shellEngine.c
浏览文件 @
aded75a8
...
...
@@ -128,6 +128,10 @@ void shellReplaceCtrlChar(char *str) {
*
pstr
=
'\t'
;
pstr
++
;
break
;
case
'G'
:
*
pstr
++
=
'\\'
;
*
pstr
++
=
*
str
;
break
;
case
'\\'
:
*
pstr
=
'\\'
;
pstr
++
;
...
...
@@ -208,9 +212,10 @@ void shellRunCommand(TAOS *con, char *command) {
void
shellRunCommandOnServer
(
TAOS
*
con
,
char
command
[])
{
int64_t
st
,
et
;
wordexp_t
full_path
;
char
*
sptr
=
NULL
;
char
*
cptr
=
NULL
;
char
*
fname
=
NULL
;
char
*
sptr
=
NULL
;
char
*
cptr
=
NULL
;
char
*
fname
=
NULL
;
bool
printMode
=
false
;
if
((
sptr
=
strstr
(
command
,
">>"
))
!=
NULL
)
{
cptr
=
strstr
(
command
,
";"
);
...
...
@@ -226,6 +231,16 @@ void shellRunCommandOnServer(TAOS *con, char command[]) {
fname
=
full_path
.
we_wordv
[
0
];
}
if
((
sptr
=
strstr
(
command
,
"
\\
G"
))
!=
NULL
)
{
cptr
=
strstr
(
command
,
";"
);
if
(
cptr
!=
NULL
)
{
*
cptr
=
'\0'
;
}
*
sptr
=
'\0'
;
printMode
=
true
;
// When output to a file, the switch does not work.
}
st
=
taosGetTimestampUs
();
if
(
taos_query
(
con
,
command
))
{
...
...
@@ -242,7 +257,7 @@ void shellRunCommandOnServer(TAOS *con, char command[]) {
int
num_fields
=
taos_field_count
(
con
);
if
(
num_fields
!=
0
)
{
// select and show kinds of commands
int
error_no
=
0
;
int
numOfRows
=
shellDumpResult
(
con
,
fname
,
&
error_no
);
int
numOfRows
=
shellDumpResult
(
con
,
fname
,
&
error_no
,
printMode
);
if
(
numOfRows
<
0
)
return
;
et
=
taosGetTimestampUs
();
...
...
@@ -294,14 +309,14 @@ int regex_match(const char *s, const char *reg, int cflags) {
return
0
;
}
int
shellDumpResult
(
TAOS
*
con
,
char
*
fname
,
int
*
error_no
)
{
int
shellDumpResult
(
TAOS
*
con
,
char
*
fname
,
int
*
error_no
,
bool
printMode
)
{
TAOS_ROW
row
=
NULL
;
int
numOfRows
=
0
;
time_t
tt
;
char
buf
[
25
]
=
"
\0
"
;
struct
tm
*
ptm
;
int
output_bytes
=
0
;
FILE
*
fp
=
NULL
;
FILE
*
fp
=
NULL
;
int
num_fields
=
taos_field_count
(
con
);
wordexp_t
full_path
;
...
...
@@ -334,10 +349,12 @@ int shellDumpResult(TAOS *con, char *fname, int *error_no) {
row
=
taos_fetch_row
(
result
);
char
t_str
[
TSDB_MAX_BYTES_PER_ROW
]
=
"
\0
"
;
int
l
[
TSDB_MAX_COLUMNS
]
=
{
0
};
int
maxLenColumnName
=
0
;
if
(
row
)
{
// Print the header indicator
if
(
fname
==
NULL
)
{
// print to standard output
if
(
!
printMode
)
{
for
(
int
col
=
0
;
col
<
num_fields
;
col
++
)
{
switch
(
fields
[
col
].
type
)
{
case
TSDB_DATA_TYPE_BOOL
:
...
...
@@ -391,9 +408,15 @@ int shellDumpResult(TAOS *con, char *fname, int *error_no) {
printf
(
"
\n
"
);
for
(
int
k
=
0
;
k
<
output_bytes
;
k
++
)
printf
(
"="
);
printf
(
"
\n
"
);
}
else
{
for
(
int
col
=
0
;
col
<
num_fields
;
col
++
)
{
if
(
strlen
(
fields
[
col
].
name
)
>
maxLenColumnName
)
maxLenColumnName
=
strlen
(
fields
[
col
].
name
);
}
}
// print the elements
do
{
if
(
!
printMode
)
{
for
(
int
i
=
0
;
i
<
num_fields
;
i
++
)
{
if
(
row
[
i
]
==
NULL
)
{
printf
(
"%*s|"
,
l
[
i
],
TSDB_DATA_NULL_STR
);
...
...
@@ -433,7 +456,7 @@ int shellDumpResult(TAOS *con, char *fname, int *error_no) {
/* printf("%-*s|",max(fields[i].bytes, strlen(fields[i].name)),
* t_str); */
/* printf("%-*s|", l[i], t_str); */
shellPrintNChar
(
t_str
,
l
[
i
]
);
shellPrintNChar
(
t_str
,
l
[
i
],
printMode
);
break
;
case
TSDB_DATA_TYPE_TIMESTAMP
:
if
(
args
.
is_raw_time
)
{
...
...
@@ -463,8 +486,83 @@ int shellDumpResult(TAOS *con, char *fname, int *error_no) {
break
;
}
}
printf
(
"
\n
"
);
}
else
{
printf
(
"*************************** %d.row ***************************
\n
"
,
numOfRows
+
1
);
for
(
int
i
=
0
;
i
<
num_fields
;
i
++
)
{
// 1. print column name
int
left_space
=
(
int
)(
maxLenColumnName
-
strlen
(
fields
[
i
].
name
));
printf
(
"%*.s%s: "
,
left_space
,
" "
,
fields
[
i
].
name
);
// 2. print column value
if
(
row
[
i
]
==
NULL
)
{
printf
(
"%s
\n
"
,
TSDB_DATA_NULL_STR
);
continue
;
}
switch
(
fields
[
i
].
type
)
{
case
TSDB_DATA_TYPE_BOOL
:
printf
(
"%s
\n
"
,
((((
int
)(
*
((
char
*
)
row
[
i
])))
==
1
)
?
"true"
:
"false"
));
break
;
case
TSDB_DATA_TYPE_TINYINT
:
printf
(
"%d
\n
"
,
(
int
)(
*
((
char
*
)
row
[
i
])));
break
;
case
TSDB_DATA_TYPE_SMALLINT
:
printf
(
"%d
\n
"
,
(
int
)(
*
((
short
*
)
row
[
i
])));
break
;
case
TSDB_DATA_TYPE_INT
:
printf
(
"%d
\n
"
,
*
((
int
*
)
row
[
i
]));
break
;
case
TSDB_DATA_TYPE_BIGINT
:
#ifdef WINDOWS
printf
(
"%lld
\n
"
,
*
((
int64_t
*
)
row
[
i
]));
#else
printf
(
"%ld
\n
"
,
*
((
int64_t
*
)
row
[
i
]));
#endif
break
;
case
TSDB_DATA_TYPE_FLOAT
:
printf
(
"%.5f
\n
"
,
*
((
float
*
)
row
[
i
]));
break
;
case
TSDB_DATA_TYPE_DOUBLE
:
printf
(
"%.9f
\n
"
,
*
((
double
*
)
row
[
i
]));
break
;
case
TSDB_DATA_TYPE_BINARY
:
case
TSDB_DATA_TYPE_NCHAR
:
memset
(
t_str
,
0
,
TSDB_MAX_BYTES_PER_ROW
);
memcpy
(
t_str
,
row
[
i
],
fields
[
i
].
bytes
);
l
[
i
]
=
max
(
fields
[
i
].
bytes
,
strlen
(
fields
[
i
].
name
));
shellPrintNChar
(
t_str
,
l
[
i
],
printMode
);
break
;
case
TSDB_DATA_TYPE_TIMESTAMP
:
if
(
args
.
is_raw_time
)
{
#ifdef WINDOWS
printf
(
"%lld
\n
"
,
*
(
int64_t
*
)
row
[
i
]);
#else
printf
(
"%ld
\n
"
,
*
(
int64_t
*
)
row
[
i
]);
#endif
}
else
{
if
(
taos_result_precision
(
result
)
==
TSDB_TIME_PRECISION_MICRO
)
{
tt
=
*
(
int64_t
*
)
row
[
i
]
/
1000000
;
}
else
{
tt
=
*
(
int64_t
*
)
row
[
i
]
/
1000
;
}
ptm
=
localtime
(
&
tt
);
strftime
(
buf
,
64
,
"%y-%m-%d %H:%M:%S"
,
ptm
);
if
(
taos_result_precision
(
result
)
==
TSDB_TIME_PRECISION_MICRO
)
{
printf
(
"%s.%06d
\n
"
,
buf
,
(
int
)(
*
(
int64_t
*
)
row
[
i
]
%
1000000
));
}
else
{
printf
(
"%s.%03d
\n
"
,
buf
,
(
int
)(
*
(
int64_t
*
)
row
[
i
]
%
1000
));
}
}
break
;
default:
break
;
}
}
}
numOfRows
++
;
}
while
((
row
=
taos_fetch_row
(
result
)));
...
...
@@ -546,7 +644,7 @@ void read_history() {
memset
(
history
.
hist
,
0
,
sizeof
(
char
*
)
*
MAX_HISTORY_SIZE
);
history
.
hstart
=
0
;
history
.
hend
=
0
;
char
*
line
=
NULL
;
char
*
line
=
NULL
;
size_t
line_size
=
0
;
int
read_size
=
0
;
...
...
@@ -615,9 +713,9 @@ static int isCommentLine(char *line) {
void
source_file
(
TAOS
*
con
,
char
*
fptr
)
{
wordexp_t
full_path
;
int
read_len
=
0
;
char
*
cmd
=
malloc
(
MAX_COMMAND_SIZE
);
char
*
cmd
=
malloc
(
MAX_COMMAND_SIZE
);
size_t
cmd_len
=
0
;
char
*
line
=
NULL
;
char
*
line
=
NULL
;
size_t
line_len
=
0
;
if
(
wordexp
(
fptr
,
&
full_path
,
0
)
!=
0
)
{
...
...
src/kit/shell/src/shellLinux.c
浏览文件 @
aded75a8
...
...
@@ -305,7 +305,7 @@ void *shellLoopQuery(void *arg) {
return
NULL
;
}
void
shellPrintNChar
(
char
*
str
,
int
width
)
{
void
shellPrintNChar
(
char
*
str
,
int
width
,
bool
printMode
)
{
int
col_left
=
width
;
wchar_t
wc
;
while
(
col_left
>
0
)
{
...
...
@@ -323,7 +323,12 @@ void shellPrintNChar(char *str, int width) {
printf
(
" "
);
col_left
--
;
}
if
(
!
printMode
)
{
printf
(
"|"
);
}
else
{
printf
(
"
\n
"
);
}
}
int
get_old_terminal_mode
(
struct
termios
*
tio
)
{
...
...
src/kit/shell/src/shellWindows.c
浏览文件 @
aded75a8
...
...
@@ -216,7 +216,7 @@ void *shellLoopQuery(void *arg) {
return
NULL
;
}
void
shellPrintNChar
(
char
*
str
,
int
width
)
{
void
shellPrintNChar
(
char
*
str
,
int
width
,
bool
printMode
)
{
int
col_left
=
width
;
wchar_t
wc
;
while
(
col_left
>
0
)
{
...
...
@@ -234,7 +234,12 @@ void shellPrintNChar(char *str, int width) {
printf
(
" "
);
col_left
--
;
}
if
(
!
printMode
)
{
printf
(
"|"
);
}
else
{
printf
(
"
\n
"
);
}
}
void
get_history_path
(
char
*
history
)
{
sprintf
(
history
,
"%s/%s"
,
"."
,
HISTORY_FILE
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录