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 重定向到文件而不是控制台。我不想在控制台中显示很多日志,这对于不关心的用户来说很烦人,也不利于开发者日后查看日志。
提前致谢