Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
9c07d24a
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
9c07d24a
编写于
10月 28, 2021
作者:
S
Shengliang Guan
提交者:
GitHub
10月 28, 2021
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #8452 from taosdata/fix/TS-441
[TS-441]<fix>: add windows unicode support
上级
74abaf2e
4dfd2bd7
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
17 addition
and
5 deletion
+17
-5
src/kit/shell/CMakeLists.txt
src/kit/shell/CMakeLists.txt
+2
-0
src/kit/shell/src/shellMain.c
src/kit/shell/src/shellMain.c
+3
-0
src/kit/shell/src/shellWindows.c
src/kit/shell/src/shellWindows.c
+12
-5
未找到文件。
src/kit/shell/CMakeLists.txt
浏览文件 @
9c07d24a
...
...
@@ -26,6 +26,8 @@ ENDIF ()
SET_TARGET_PROPERTIES
(
shell PROPERTIES OUTPUT_NAME taos
)
ELSEIF
(
TD_WINDOWS
)
ADD_DEFINITIONS
(
-DUNICODE
)
ADD_DEFINITIONS
(
-D_UNICODE
)
LIST
(
APPEND SRC ./src/shellEngine.c
)
LIST
(
APPEND SRC ./src/shellMain.c
)
LIST
(
APPEND SRC ./src/shellWindows.c
)
...
...
src/kit/shell/src/shellMain.c
浏览文件 @
9c07d24a
...
...
@@ -89,6 +89,9 @@ SShellArguments args = {
*/
int
main
(
int
argc
,
char
*
argv
[])
{
/*setlocale(LC_ALL, "en_US.UTF-8"); */
#ifdef WINDOWS
SetConsoleOutputCP
(
CP_UTF8
);
#endif
if
(
!
checkVersion
())
{
exit
(
EXIT_FAILURE
);
...
...
src/kit/shell/src/shellWindows.c
浏览文件 @
9c07d24a
...
...
@@ -232,13 +232,16 @@ int32_t shellReadCommand(TAOS *con, char command[]) {
cmd
.
command
=
(
char
*
)
calloc
(
1
,
MAX_COMMAND_SIZE
);
// Read input.
char
c
;
void
*
console
=
GetStdHandle
(
STD_INPUT_HANDLE
);
unsigned
long
read
;
wchar_t
c
;
char
mbStr
[
16
];
while
(
1
)
{
c
=
getchar
();
int
ret
=
ReadConsole
(
console
,
&
c
,
1
,
&
read
,
NULL
);
int
size
=
WideCharToMultiByte
(
CP_UTF8
,
0
,
&
c
,
read
,
mbStr
,
sizeof
(
mbStr
),
NULL
,
NULL
);
mbStr
[
size
]
=
0
;
switch
(
c
)
{
case
'\n'
:
case
'\r'
:
if
(
isReadyGo
(
&
cmd
))
{
sprintf
(
command
,
"%s%s"
,
cmd
.
buffer
,
cmd
.
command
);
free
(
cmd
.
buffer
);
...
...
@@ -251,8 +254,12 @@ int32_t shellReadCommand(TAOS *con, char command[]) {
updateBuffer
(
&
cmd
);
}
break
;
case
'\r'
:
break
;
default:
insertChar
(
&
cmd
,
c
);
for
(
int
i
=
0
;
i
<
size
;
++
i
)
{
insertChar
(
&
cmd
,
mbStr
[
i
]);
}
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录