gpt4 book ai didi

c++ - 将 clangd stderr 重定向到文件而不是控制台

转载 作者:行者123 更新时间:2023-12-01 14:53:48 24 4
gpt4 key购买 nike

clangd 将日志消息写入标准错误。在 Linux 中,我需要它将 stderr 重定向到日志文件以备将来使用,而不是控制台

我使用的命令是:

clangd --clang-tidy -compile-commands-dir=$SOME_PATH --log=error > $SOME_PATH/clangd.log 2>&1

它可以启动并重定向到文件,但几秒钟后,clangd 停止并在 clangd.log 文件中出现此错误

I[18:10:31.484] clangd version 9.0.0 (https://github.com/llvm-mirror/llvm c62b24f070c9a4bb1a76409e623042a740cac4cd)
I[18:10:31.484] Working directory: ......
I[18:10:31.484] argv[0]: clangd
I[18:10:31.484] argv[1]: --clang-tidy
I[18:10:31.484] argv[2]: -compile-commands-dir=......
I[18:10:31.484] argv[3]: --log=error
I[18:10:31.484] Starting LSP over stdin/stdout
......

I[18:10:31.706] <-- initialize("1")
I[18:10:31.707] --> reply:initialize("1") 0 ms
Content-Length: 1038
......


V[18:10:41.710] <<< {"id":"2","jsonrpc":"2.0","method":"shutdown","params":null}

I[18:10:41.711] <-- shutdown("2")
I[18:10:41.711] --> reply:shutdown("2") 0 ms
Content-Length: 40

{"id":"2","jsonrpc":"2.0","result":null}V[18:10:41.711] >>> {"id":"2","jsonrpc":"2.0","result":null}

E[18:10:46.711] Transport error: Input/output error

我错过了什么?为什么传输错误?对于 clangd 进程,stderr 是控制台还是文件应该不是问题?

我只想将 stderr 重定向到一个文件而不是控制台。我不想在控制台显示很多日志,这对不关心的用户来说很烦人,也不利于开发人员以后查看日志。

提前致谢

最佳答案

我犯了一个愚蠢而常见的错误,“总是将 stdout 与 stderr 一起重定向”

像这样

> $SOME_PATH/clangd.log 2>&1

我通过仅将 stderr 重定向到一个文件来解决它,而单独保留 stdout。

工作脚本是

clangd --clang-tidy -compile-commands-dir=$SOME_PATH --log=error 2> $SOME_PATH/clangd.log

关于c++ - 将 clangd stderr 重定向到文件而不是控制台,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59681022/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com