Provide better feature gates.
- `serialization` becomes `serde`. - `impl-nalgebra` becomes `nalgebra`. - `impl-cgmath` becomes `cgmath`. - `impl-glam` becomes `glam`. Already existing feature gates are kept around so that we don’t introduce a breaking change.
This commit is contained in:
@ -1,7 +1,7 @@
|
||||
//! Available interpolation modes.
|
||||
|
||||
#[cfg(feature = "serialization")]
|
||||
use serde_derive::{Deserialize, Serialize};
|
||||
#[cfg(any(feature = "serialization", feature = "serde"))]
|
||||
use serde::{Deserialize, Serialize};
|
||||
|
||||
/// Available kind of interpolations.
|
||||
///
|
||||
@ -9,7 +9,7 @@ use serde_derive::{Deserialize, Serialize};
|
||||
#[non_exhaustive]
|
||||
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
|
||||
#[cfg_attr(
|
||||
feature = "serialization",
|
||||
any(feature = "serialization", feature = "serde"),
|
||||
derive(Deserialize, Serialize),
|
||||
serde(rename_all = "snake_case")
|
||||
)]
|
||||
|
@ -7,8 +7,8 @@
|
||||
//! interpolation mode on a key-based way, allowing you to implement and encode complex curves.
|
||||
|
||||
use crate::interpolation::Interpolation;
|
||||
#[cfg(feature = "serialization")]
|
||||
use serde_derive::{Deserialize, Serialize};
|
||||
#[cfg(any(feature = "serialization", feature = "serde"))]
|
||||
use serde::{Deserialize, Serialize};
|
||||
|
||||
/// A spline control point.
|
||||
///
|
||||
@ -19,7 +19,7 @@ use serde_derive::{Deserialize, Serialize};
|
||||
/// [`Interpolation`]: crate::interpolation::Interpolation
|
||||
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
|
||||
#[cfg_attr(
|
||||
feature = "serialization",
|
||||
any(feature = "serialization", feature = "serde"),
|
||||
derive(Deserialize, Serialize),
|
||||
serde(rename_all = "snake_case")
|
||||
)]
|
||||
|
16
src/lib.rs
16
src/lib.rs
@ -84,19 +84,19 @@
|
||||
//!
|
||||
//! So here’s a list of currently supported features and how to enable them:
|
||||
//!
|
||||
//! - **Serialization / deserialization.**
|
||||
//! - **Serde.**
|
||||
//! - This feature implements both the `Serialize` and `Deserialize` traits from `serde` for all
|
||||
//! types exported by this crate.
|
||||
//! - Enable with the `"serialization"` feature.
|
||||
//! - Enable with the `"serde"` feature.
|
||||
//! - **[cgmath](https://crates.io/crates/cgmath) implementors.**
|
||||
//! - Adds some useful implementations of `Interpolate` for some cgmath types.
|
||||
//! - Enable with the `"impl-cgmath"` feature.
|
||||
//! - Enable with the `"cgmath"` feature.
|
||||
//! - **[glam](https://crates.io/crates/glam) implementors.**
|
||||
//! - Adds some useful implementations of `Interpolate` for some glam types.
|
||||
//! - Enable with the `"impl-glam"` feature.
|
||||
//! - Enable with the `"glam"` feature.
|
||||
//! - **[nalgebra](https://crates.io/crates/nalgebra) implementors.**
|
||||
//! - Adds some useful implementations of `Interpolate` for some nalgebra types.
|
||||
//! - Enable with the `"impl-nalgebra"` feature.
|
||||
//! - Enable with the `"nalgebra"` feature.
|
||||
//! - **Standard library / no standard library.**
|
||||
//! - It’s possible to compile against the standard library or go on your own without it.
|
||||
//! - Compiling with the standard library is enabled by default.
|
||||
@ -112,15 +112,15 @@
|
||||
#[cfg(not(feature = "std"))]
|
||||
extern crate alloc;
|
||||
|
||||
#[cfg(feature = "impl-cgmath")]
|
||||
#[cfg(any(feature = "impl-cgmath", feature = "cgmath"))]
|
||||
mod cgmath;
|
||||
#[cfg(feature = "impl-glam")]
|
||||
#[cfg(any(feature = "impl-glam", feature = "glam"))]
|
||||
mod glam;
|
||||
pub mod interpolate;
|
||||
pub mod interpolation;
|
||||
pub mod iter;
|
||||
pub mod key;
|
||||
#[cfg(feature = "impl-nalgebra")]
|
||||
#[cfg(any(feature = "impl-nalgebra", feature = "nalgebra"))]
|
||||
mod nalgebra;
|
||||
pub mod spline;
|
||||
|
||||
|
@ -10,8 +10,8 @@ use alloc::vec::Vec;
|
||||
use core::cmp::Ordering;
|
||||
#[cfg(not(feature = "std"))]
|
||||
use core::ops::{Div, Mul};
|
||||
#[cfg(feature = "serialization")]
|
||||
use serde_derive::{Deserialize, Serialize};
|
||||
#[cfg(any(feature = "serialization", feature = "serde"))]
|
||||
use serde::{Deserialize, Serialize};
|
||||
#[cfg(feature = "std")]
|
||||
use std::cmp::Ordering;
|
||||
|
||||
@ -28,7 +28,10 @@ use std::cmp::Ordering;
|
||||
/// - [`Spline::clamped_sample`]: behaves like [`Spline::sample`] but will return either the first
|
||||
/// or last key if out of bound; it will return `None` if not enough key.
|
||||
#[derive(Debug, Clone)]
|
||||
#[cfg_attr(feature = "serialization", derive(Deserialize, Serialize))]
|
||||
#[cfg_attr(
|
||||
any(feature = "serialization", feature = "serde"),
|
||||
derive(Deserialize, Serialize)
|
||||
)]
|
||||
pub struct Spline<T, V>(pub(crate) Vec<Key<T, V>>);
|
||||
|
||||
impl<T, V> Spline<T, V> {
|
||||
|
Reference in New Issue
Block a user