3 releases

Uses old Rust 2015

0.1.2 Nov 30, 2022
0.1.1 Feb 15, 2022
0.1.0 Jan 16, 2019

#2004 in Development tools

Download history 33825/week @ 2024-08-28 36852/week @ 2024-09-04 32834/week @ 2024-09-11 28804/week @ 2024-09-18 34161/week @ 2024-09-25 40841/week @ 2024-10-02 39029/week @ 2024-10-09 44124/week @ 2024-10-16 41377/week @ 2024-10-23 42521/week @ 2024-10-30 44379/week @ 2024-11-06 47340/week @ 2024-11-13 46628/week @ 2024-11-20 48578/week @ 2024-11-27 45925/week @ 2024-12-04 39318/week @ 2024-12-11

188,738 downloads per month
Used in 230 crates (via vswhom)

MIT license

28KB
326 lines

vswhom-sys.rs TravisCI Build Status AppVeyorCI Build Status Licence

Pure FFI to Jon Blow's VS discovery script.

Please note that the native code was discovered to cause memory corruption in some cases.

Documentation

Special thanks

To all who support further development on Patreon, in particular:

  • ThePhD
  • Embark Studios
  • Jasper Bekkers

lib.rs:

Pure FFI to Jon Blow's VS discovery script.

The rest of this crate's documentation is copied borderline verbatim from the original C++ source code.

HOW TO USE THIS CODE

The purpose of this file is to find the folders that contain libraries you may need to link against, on Windows, if you are linking with any compiled C or C++ code. This will be necessary for many non-C++ programming language environments that want to provide compatibility.

We find the place where the Visual Studio libraries live (for example, libvcruntime.lib), where the linker and compiler executables live (for example, link.exe), and where the Windows SDK libraries reside (kernel32.lib, libucrt.lib).

We all wish you didn't have to worry about so many weird dependencies, but we don't really have a choice about this, sadly.

I don't claim that this is the absolute best way to solve this problem, and so far we punt on things (if you have multiple versions of Visual Studio installed, we return the first one, rather than the newest). But it will solve the basic problem for you as simply as I know how to do it, and because there isn't too much code here, it's easy to modify and expand.

Here is the API you need to know about:

Call vswhom_find_visual_studio_and_windows_sdk(), look at the resulting paths, then call vswhom_free_resources() on the result.

This file was about 400 lines before we started adding these comments. You might think that's way too much code to do something as simple as finding a few library and executable paths. I agree. However, Microsoft's own solution to this problem, called "vswhere", is a mere EIGHT THOUSAND LINE PROGRAM, spread across 70 files, that they posted to github unironically.

I am not making this up: https://github.com/Microsoft/vswhere

Several people have therefore found the need to solve this problem themselves. We referred to some of these other solutions when figuring out what to do, most prominently ziglang's version, by Ryan Saunderson.

I hate this kind of code. The fact that we have to do this at all is stupid, and the actual maneuvers we need to go through are just painful. If programming were like this all the time, I would quit.

One other shortcut I took is that this is hardcoded to return the folders for x64 libraries. If you want x86 or arm, you can make slight edits to the code below, or, if enough people want this, I can work it in here.

Dependencies

~51KB