#const #closures #const-fn #nightly

yanked const_closure

Helpers for creating const callable closures

8 releases

0.3.1 Dec 12, 2024
0.3.0 Nov 28, 2022
0.2.3 Nov 10, 2022
0.2.2 Sep 25, 2022
0.1.1 Sep 13, 2022

#31 in #const-fn

Download history 1/week @ 2024-09-22 3/week @ 2024-10-13 4/week @ 2024-11-03 138/week @ 2024-12-08 24/week @ 2024-12-15

162 downloads per month

MIT/Apache

15KB
252 lines

Const Closure

docs.rs crates.io rustc

THIS CRATE IS BROKEN - Archive Note

The last tested working rust version is 1.71.0-nightly (nightly-2023-04-18). Most const traits have been removed from the standard library. Once they are back this crate might make a return if it is still needed.

Description

This crate allows you to create types which represent closures in const contexts.

To do this simply create an instance of the provided closure helper: ConstClosure with the associated new function.

A closure helper instance gets the data to capture as a tuple of same ownership (Owned, Mut or ref) and the implementation function to execute.

The implementation function must be a const fn that gets the captured state (a tuple of: owned values for FnOnce, &mut for FnMut and & for Fn) and a tuple representing the arguments of the closure.

A closure helper instance returns the return value of the closure function on call.

Example

#![feature(const_trait_impl)]
#![feature(const_mut_refs)] // Only required for the FnMut example

use const_closure::ConstClosure;

// FnOnce:
const _: () = {
  const fn imp((state,): (i32,), (arg,): (i32,)) -> i32 {
    state + arg
  }
  let cl = ConstClosure::new((5,), imp);
  assert!(7 == cl(2));
};

// FnMut:
const _: () = {
  const fn imp((state,): (&mut i32,), (arg,): (i32,)) -> i32 {
    *state += arg;
    *state
  }
  let mut i = 5;
  let mut cl = ConstClosure::new((&mut i,), imp);

  assert!(7 == cl(2));
  assert!(8 == cl(1));
};

// Fn:
const _: () = {
  const fn imp((state,): (&i32,), (arg,): (i32,)) -> i32 {
    *state + arg
  }
  let i = 5;
  let mut cl = ConstClosure::new((&i,), imp);
  assert!(7 == cl(2));
  assert!(8 == cl(3));
  assert!(6 == cl(1));
};

Note: The const_closure macro has been removed in favour of the new generic based approach.

Authors

raldone01 and onestacked are the primary authors and maintainers of this library.

License

This project is released under either:

at your choosing.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

No runtime deps