Skip to content

Commit

Permalink
style/color: derive serialize & deserialize
Browse files Browse the repository at this point in the history
Using serde is useful in production, not just during development,
so move it to optional dependencies instead of dev-dependencies.

This allows to derive serialize/deserialize for the color structs
which are very simple using the default implementation, allowing
to pass colors along via serialization channels and formats.
  • Loading branch information
10ne1 committed Dec 4, 2024
1 parent 48ed63f commit 5eb2238
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 1 deletion.
3 changes: 2 additions & 1 deletion plotters/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ deprecated = { level = "allow" }
[dependencies]
num-traits = "0.2.14"
chrono = { version = "0.4.32", optional = true }
serde = { version = "1.0.139", optional = true }

[dependencies.plotters-backend]
version = "0.3.6"
Expand Down Expand Up @@ -113,6 +114,7 @@ ab_glyph = ["dep:ab_glyph", "once_cell"]

# Misc
datetime = ["chrono"]
serialization = ["serde"]
evcxr = ["svg_backend"]
evcxr_bitmap = ["evcxr", "bitmap_backend", "plotters-svg/bitmap_encoder"]
deprecated_items = [] # Keep some of the deprecated items for backward compatibility
Expand All @@ -122,7 +124,6 @@ itertools = "0.10.0"
criterion = "0.5.1"
rayon = "1.5.1"
serde_json = "1.0.82"
serde = "1.0.139"
serde_derive = "1.0.140"

[target.'cfg(not(target_arch = "wasm32"))'.dev-dependencies]
Expand Down
7 changes: 7 additions & 0 deletions plotters/src/style/color.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,9 @@ use super::ShapeStyle;

use plotters_backend::{BackendColor, BackendStyle};

#[cfg(feature = "serialization")]
use serde::{Deserialize, Serialize};

use std::marker::PhantomData;

/// Any color representation
Expand Down Expand Up @@ -64,6 +67,7 @@ impl<T: Color> Color for &'_ T {
///
/// If you want to directly create a RGB color with transparency use [RGBColor::mix]
#[derive(Copy, Clone, PartialEq, Debug, Default)]
#[cfg_attr(feature = "serialization", derive(Serialize, Deserialize))]
pub struct RGBAColor(pub u8, pub u8, pub u8, pub f64);

impl Color for RGBAColor {
Expand All @@ -84,6 +88,7 @@ impl From<RGBColor> for RGBAColor {

/// A color in the given palette
#[derive(Copy, Clone, Eq, PartialEq, Hash, Debug, Default)]
#[cfg_attr(feature = "serialization", derive(Serialize, Deserialize))]
pub struct PaletteColor<P: Palette>(usize, PhantomData<P>);

impl<P: Palette> PaletteColor<P> {
Expand All @@ -105,6 +110,7 @@ impl<P: Palette> Color for PaletteColor<P> {

/// The color described by its RGB value
#[derive(Copy, Clone, Eq, PartialEq, Hash, Debug, Default)]
#[cfg_attr(feature = "serialization", derive(Serialize, Deserialize))]
pub struct RGBColor(pub u8, pub u8, pub u8);

impl BackendStyle for RGBAColor {
Expand All @@ -130,6 +136,7 @@ impl BackendStyle for RGBColor {

/// The color described by HSL color space
#[derive(Copy, Clone, PartialEq, Debug, Default)]
#[cfg_attr(feature = "serialization", derive(Serialize, Deserialize))]
pub struct HSLColor(pub f64, pub f64, pub f64);

impl Color for HSLColor {
Expand Down

0 comments on commit 5eb2238

Please sign in to comment.