#bindings #driver #ffi #windivert

sys windivert-sys

Raw FFI bindings for WinDivert user mode library

10 releases (6 breaking)

0.11.0-beta.0 Dec 8, 2024
0.10.0 May 26, 2023
0.9.3 Apr 3, 2023
0.9.2 Mar 23, 2023
0.5.2 Feb 7, 2021

#240 in #driver

Download history 36/week @ 2024-09-18 87/week @ 2024-09-25 34/week @ 2024-10-02 36/week @ 2024-10-09 76/week @ 2024-10-16 87/week @ 2024-10-23 60/week @ 2024-10-30 25/week @ 2024-11-06 9/week @ 2024-11-13 32/week @ 2024-11-20 86/week @ 2024-11-27 147/week @ 2024-12-04 115/week @ 2024-12-11 89/week @ 2024-12-18 70/week @ 2024-12-25 141/week @ 2025-01-01

431 downloads per month
Used in 2 crates

LGPL-3.0-or-later

800KB
18K SLoC

C 16K SLoC // 0.1% comments Rust 1.5K SLoC // 0.1% comments Visual Studio Project 449 SLoC // 0.5% comments Shell 216 SLoC // 0.3% comments Batch 99 SLoC // 0.4% comments Monkey C 22 SLoC // 0.6% comments Bitbake 9 SLoC

WinDivert 2 Rust Wrapper

GitHub

Note: This is a work in process, so the crates won't follow semantic versioning until 1.0.0 release, so any version change below 1.0.0 might introduce breaking changes in the API or the crate usage in general.

This projects allows you to use WinDivert from rust. It consists of two crates:

  • windivert-sys crates.io docs dependency status: Crate providing raw bindings to the WinDivert user mode library.
  • windivert crates.io docs dependency status: (WIP) Built on top of windivert-sys and providing a friendlier Rust API and some abstractions.

Build

To be able to build windivert-sys you require WinDivert library files:

  • It's recommended to specify the path of the folder containing downloaded dll, lib & sys files using the WINDIVERT_PATH environment variable.
  • As a fallback windivert dll & lib files can be compiled from source if the vendored feature is enabled. To avoid multiple compilations set WINDIVERT_DLL_OUTPUT environment variable to save the generated build.
  • It's possible to compile for statically linking to the windivert library by enabling the static feature. Static linking can also be enabled if the WINDIVERT_STATIC is set and it takes priority over the crate features.
  • Any vendoring method will only compile the library. Sys files must always be provided.

Usage

  • windivert-sys shares the same API the native library uses. Read official documentation for more details.
  • windivert WIP

Note: WinDivert dll expects the corresponding driver sys file to be located on the same folder. Since the dll lib & sys files come in the same folder when downloading from official web windivert-sys will search for it on the path provided with WINDIVERT_PATH.

Dependencies

~0.3–1MB
~24K SLoC