#bit-flags #bitmask

no-std bitflags-serde-legacy

Implement serde traits for bitflags 2.x types compatibly with 1.x

2 releases

0.1.1 May 17, 2023
0.1.0 Feb 8, 2023

#151 in No standard library

Download history 1633/week @ 2025-12-25 1866/week @ 2026-01-01 2947/week @ 2026-01-08 4666/week @ 2026-01-15 5139/week @ 2026-01-22 7444/week @ 2026-01-29 8409/week @ 2026-02-05 4357/week @ 2026-02-12 5247/week @ 2026-02-19 4777/week @ 2026-02-26 5827/week @ 2026-03-05 4979/week @ 2026-03-12 5390/week @ 2026-03-19 4994/week @ 2026-03-26 6360/week @ 2026-04-02 3788/week @ 2026-04-09

21,321 downloads per month
Used in 18 crates (2 directly)

MIT/Apache

10KB
117 lines

bitflags-serde-legacy

The serialization format used by bitflags! has changed between 1.x and 2.x. If you previously #[derive(Serialize, Deserialize], then you can use this library to maintain compatibility while upgrading.

Usage

You can either use this as a regular dependency, or pull the source into a private module in your project.

Add bitflags-serde-legacy to your Cargo.toml:

[dependencies.bitflags_serde_legacy]
version = "0.1.1"

Then, replace an existing #[derive(Serialize, Deserialize)] on your bitflags! generated types with the following manual implementations:

use bitflags::bitflags;

bitflags! {
    // #[derive(Serialize, Deserialize)]
    struct Flags: u32 {
        const A = 0b00000001;
        const B = 0b00000010;
        const C = 0b00000100;
        const ABC = Self::A.bits() | Self::B.bits() | Self::C.bits();
    }
}

impl serde::Serialize for Flags {
    fn serialize<S: serde::Serializer>(&self, serializer: S) -> Result<S::Ok, S::Error> {
        bitflags_serde_legacy::serialize(self, "Flags", serializer)
    }
}

impl<'de> serde::Deserialize<'de> for Flags {
    fn deserialize<D: serde::Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
        bitflags_serde_legacy::deserialize("Flags", deserializer)
    }
}

Dependencies

~175–520KB
~11K SLoC