Expand description

Provides safe trivial transmutes in generic context, emulating specialization on stable Rust. These functions are designed for being optimized out by the compiler, so are probably zero-cost in most cases.

fn specialized_function<T: 'static>(x: T) -> String {
    // We have an efficient algorithm for `i32` and worse algorithm for any other type.
    // With `cismute` we can do:
    match cismute::owned::<T, i32>(x) {
        Ok(x) => format!("got an i32: {x}"),
        Err(x) => format!("got something else"),
    }
}

assert_eq!(specialized_function(42_i32), "got an i32: 42");
assert_eq!(specialized_function(":)"), "got something else");

cismute::owned works only for 'static types. If your type is a reference, you should use cismute::reference or cismute::mutable.

fn specialized_function<T: 'static>(x: &T) -> String {
    // We have an efficient algorithm for `i32` and worse algorithm for any other type.
    // With `cismute` we can do:
    match cismute::reference::<T, i32>(x) {
        Ok(x) => format!("got an i32: {x}"),
        Err(x) => format!("got something else"),
    }
}

assert_eq!(specialized_function(&42_i32), "got an i32: 42");
assert_eq!(specialized_function(&":)"), "got something else");

There’s also a more generic function cismute::value which can do all three. Writing all type arguments can be cumbersome, so you can also pass the type pair as an argument via cismute::value_with:

use cismute::Pair;

fn specialized_function<T: 'static>(x: &T) -> String {
    match cismute::value_with(Pair::<(T, i32)>, x) {
        Ok(x) => format!("got an i32: {x}"),
        Err(x) => format!("got something else"),
    }
}

assert_eq!(specialized_function(&42_i32), "got an i32: 42");
assert_eq!(specialized_function(&":)"), "got something else");

There are also switch!() macro and switch() function to match one value with multiple types.

Macros

Try to match a value with any number of types. This macro does not require the switch feature.

Structs

Pair of two types for passing to cismute::value_with.

Traits

A reference that can be safely transmuted if underlying type is the same.

Functions

Helper function for switch().

Transmutes a mutable reference to type T to &mut U if they are the same type. Returns the passed value back if failed.

Transmutes an owned value of type T to type U if they are the same type. Returns the passed value back if failed.

Transmutes reference to type T to &U if they are the same type. Returns the passed value back if failed.

Try to match T with several (up to 32) other types. This function requires the switch feature, as it increases build time considerably.

Cismutes T or a (possibly mutable) reference to T to U with the same ownership, i.e. owned value is cismuted like with cismute::owned, reference is cismuted to reference and mutable reference is cismuted to mutable reference, if they are the same type. Returns the passed value back if failed.

Cismutes T or a (possibly mutable) reference to T to the type specified by the first argument while preserving ownership, i.e. owned value is cismuted like with cismute::owned, reference is cismuted to reference and mutable reference is cismuted to mutable reference. Returns the passed value back if failed.