无法编译调用在Windows上调用vsnprintf的C代码的Rust代码

时间:2017-03-24 01:55:58

标签: windows rust rust-cargo

我试图在调用vsnprintf的Windows上编译Rust代码。我的C代码如下所示:

#include <stdarg.h>
#include <stdio.h>

// A static buffer for storing any formatted messages.
static char buffer[4096];

void rust_logger(const char *fmt, ...) {
    // Reconstruct the variable arguments as a va_list.  This is necessary so we 
    // can chain together a call to vsnprintf.
    va_list varargs;
    va_start(varargs, fmt);

    // Write the formatted string to our target (static) buffer.
    vsnprintf(buffer, sizeof(buffer)-1, fmt, varargs);

    // Call Rust back with final string
    ...

    // Clean up processing of variable arguments
    va_end(varargs);
}

这在macOS上工作正常(我想在Linux下,虽然我没有尝试过)。但在Windows上,我遇到了问题。我得到的错误是:

 "C:\\Program Files (x86)\\Microsoft Visual Studio 14.0\\VC\\bin\\amd64\\link.exe" "/LIBPATH:C:\\Program Files (x86)\\Microsoft Visual Studio 14.0\\VC\\lib\\amd64" "/LIBPATH:C:\\Program Files (x86)\\Windows Kits\\10\\lib\\10.0.10240.0\\ucrt\\x64" "/LIBPATH:C:\\Program Files (x86)\\Windows Kits\\8.1\\lib\\winv6.3\\um\\x64" "/NOLOGO" "/NXCOMPAT" "/LIBPATH:C:\\Users\\mtiller\\.rustup\\toolchains\\stable-x86_64-pc-windows-msvc\\lib\\rustlib\\x86_64-pc-windows-msvc\\lib" "C:\\Users\\mtiller\\Source\\rust-fmu\\target\\debug\\deps\\rust_fmu-dd167e2c1e3583f1.0.o" "/OUT:C:\\Users\\mtiller\\Source\\rust-fmu\\target\\debug\\deps\\rust_fmu-dd167e2c1e3583f1.exe" "/OPT:REF,NOICF" "/DEBUG" "/LIBPATH:C:\\Users\\mtiller\\Source\\rust-fmu\\target\\debug\\deps" "/LIBPATH:C:\\Users\\mtiller\\Source\\rust-fmu\\target\\debug\\build\\rust-fmu-e434516f4288772d\\out" "/LIBPATH:C:\\Users\\mtiller\\.rustup\\toolchains\\stable-x86_64-pc-windows-msvc\\lib\\rustlib\\x86_64-pc-windows-msvc\\lib" "logger.lib" "C:\\Users\\mtiller\\Source\\rust-fmu\\target\\debug\\deps\\liblibloading-c41a2f71457b39f3.rlib" "C:\\Users\\mtiller\\Source\\rust-fmu\\target\\debug\\deps\\liblibc-5dc7b85e748840b4.rlib" "C:\\Users\\mtiller\\Source\\rust-fmu\\target\\debug\\deps\\libkernel32-835ed4d4f4dc2d3e.rlib" "C:\\Users\\mtiller\\Source\\rust-fmu\\target\\debug\\deps\\libwinapi-a5898d7aceb63fac.rlib" "C:\\Users\\mtiller\\.rustup\\toolchains\\stable-x86_64-pc-windows-msvc\\lib\\rustlib\\x86_64-pc-windows-msvc\\lib\\libstd-90fbcc8c07b4a644.rlib" "C:\\Users\\mtiller\\.rustup\\toolchains\\stable-x86_64-pc-windows-msvc\\lib\\rustlib\\x86_64-pc-windows-msvc\\lib\\libpanic_unwind-d2e7baf2c0a36eaf.rlib" "C:\\Users\\mtiller\\.rustup\\toolchains\\stable-x86_64-pc-windows-msvc\\lib\\rustlib\\x86_64-pc-windows-msvc\\lib\\libunwind-112baa0117a60076.rlib" "C:\\Users\\mtiller\\.rustup\\toolchains\\stable-x86_64-pc-windows-msvc\\lib\\rustlib\\x86_64-pc-windows-msvc\\lib\\liblibc-ad15457034b2bf37.rlib" "C:\\Users\\mtiller\\.rustup\\toolchains\\stable-x86_64-pc-windows-msvc\\lib\\rustlib\\x86_64-pc-windows-msvc\\lib\\librand-fa1852079e0fefd1.rlib" "C:\\Users\\mtiller\\.rustup\\toolchains\\stable-x86_64-pc-windows-msvc\\lib\\rustlib\\x86_64-pc-windows-msvc\\lib\\libcollections-27e4c8cc19e6faac.rlib" "C:\\Users\\mtiller\\.rustup\\toolchains\\stable-x86_64-pc-windows-msvc\\lib\\rustlib\\x86_64-pc-windows-msvc\\lib\\liballoc-588bb0bd8c9dd8ca.rlib" "C:\\Users\\mtiller\\.rustup\\toolchains\\stable-x86_64-pc-windows-msvc\\lib\\rustlib\\x86_64-pc-windows-msvc\\lib\\liballoc_system-dbfe715efb71d408.rlib" "C:\\Users\\mtiller\\.rustup\\toolchains\\stable-x86_64-pc-windows-msvc\\lib\\rustlib\\x86_64-pc-windows-msvc\\lib\\libstd_unicode-a2e15800b52a7a60.rlib" "C:\\Users\\mtiller\\.rustup\\toolchains\\stable-x86_64-pc-windows-msvc\\lib\\rustlib\\x86_64-pc-windows-msvc\\lib\\libcore-b2880fdfb9b2b596.rlib" "C:\\Users\\mtiller\\.rustup\\toolchains\\stable-x86_64-pc-windows-msvc\\lib\\rustlib\\x86_64-pc-windows-msvc\\lib\\libcompiler_builtins-9d27746f5ba8488f.rlib" "kernel32.lib" "advapi32.lib" "ws2_32.lib" "userenv.lib" "shell32.lib" "msvcrt.lib"
 note: logger.lib(logger.o) : error LNK2019: unresolved external symbol __ms_vsnprintf referenced in function vsnprintf
          C:\Users\mtiller\Source\rust-fmu\target\debug\deps\rust_fmu-dd167e2c1e3583f1.exe : fatal error LNK1120: 1 unresolved externals

根据我的研究,似乎这与MinGW和MinGW64之间的某些不匹配有关,但是当我查看Rust构建的输出时,它似乎使用的是Visual Studio 14.0。

我完全糊涂了。我不太清楚Rust如何确定使用哪个工具链。我使用了rustup-init.exe安装程序,我认为它会“做正确的事情&#34;”,但这里似乎很困惑(或者只是我)。

有关如何使我的工具链对齐的任何建议?另一个限制是我使用libloading包,因为我的程序正在加载DLL。我希望那部分也可以工作,但由于构建问题,我们还没有在Windows下测试它。

P.S。 - 我需要v版本vsnprintf,因为我已经通过了varargs,我需要一种方法来实际处理它们。

1 个答案:

答案 0 :(得分:0)

我的机器上安装了MSVC,MinGW64和MinGW。鉴于错误消息,我陷入了陷阱,认为它与rustc调用错误的编译器/链接器有关,因为我的路径中存在问题或者我自己对机器上工具的假设。

事实证明我正在使用的构建脚本是直接调用gccar,它调用了MinGW命令。我认为Rust拥有这些命令的“包装器”,因此它们在所有平台上都表现相同(因此我对这些没有关注)。

当我更仔细地阅读documentation on build scripts时,我发现他们重复相同(非可移植)的方法,但后来谈到缺乏对该方法的跨平台支持,然后显示更简单的方法更便携的方式来做到这一点。

底线,使用:

[build-dependencies]
gcc = "0.3"

...并仔细阅读构建脚本文档。现在一切都在macOS和Windows上都很好。