#windows #ffi #com #mscorlib

sys mscorlib-sys

Raw FFI bindings for mscorlib

12 releases

0.1.11 Feb 24, 2019
0.1.10 Aug 17, 2018
0.1.8 Jul 31, 2018

#38 in Windows APIs

Download history 39/week @ 2020-06-19 1/week @ 2020-06-26 25/week @ 2020-07-03 24/week @ 2020-07-10 2/week @ 2020-07-17 12/week @ 2020-07-24 26/week @ 2020-08-07 16/week @ 2020-08-14 18/week @ 2020-08-21 17/week @ 2020-08-28 53/week @ 2020-09-04 5/week @ 2020-09-11 4/week @ 2020-09-18 4/week @ 2020-09-25 16/week @ 2020-10-02

67 downloads per month
Used in 2 crates

MIT license

1MB
10K SLoC

mscorlib-sys

Rust bindings to mscorlib

Provides raw FFI-compatible bindings to interfaces, structs, and enums defined in mscorlib, for use with stuff like COM and other aspects of Windows.

Makes extensive use of winapi macros and defines.

Getting Started

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes. See deployment for notes on how to deploy the project on a live system.

Prerequisites

What things you need to install the software and how to install them

Windows 10
Visual Studio Community 2017
.Net >= 4.6.1
Rust >= 1.28

Unfortunately the library relies on building a C dll wrapper around mscorlib.dll in order to make the symbols accessible to the rust linker. Upcoming work will be to make this less onerous and available on more platforms. (IE, downloading a pre-built DLL?)

Installing

Clone the repository

git clone https://github.com/ZerothLaw/mscorlib-rs-sys.git

Move into the directory

cd mscorlib-rs-sys/

Build the library

cargo build

See examples\array_list.rs for an example how to work the bindings.

Or add this line to your .toml file:

[dependencies]
mscorlib-sys = "0.1.10"
```

## Running the tests

```
cargo test
```

## Deployment

This is intended to be compiled into a final executable, not deployed on its own. 

## Built With

* [Rust](https://www.rust-lang.org/) - the language, compiler, and package management
* [winapi-rs](https://github.com/retep998/winapi-rs) - invaluable model for the bindings, as well as original developer of many of the macros used.

## Contributing

Please read [CONTRIBUTING.md]() for details on our code of conduct, and the process for submitting pull requests to us.

## Versioning

We use [SemVer](http://semver.org/) for versioning. For the versions available, see the [tags on this repository](https://github.com/ZerothLaw/mscorlib-rs-sys/tags). 

## Authors

* **Tyler Laing** - *Initial work* - [ZerothLaw](https://github.com/ZerothLaw)

## License

This project is licensed under the MIT License - see the [LICENSE.md](LICENSE.md) file for details

## Acknowledgments

* Rust developers and designers for an excellent language and environment
* retep998 for winapi

Dependencies