blob: 475b0dcebcb791ace0056ea9abd5c962ec47d1d2 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
# Version 4.5.0
- Add a `portable-atomic` feature that enables the usage of fallback primitives for CPUs without atomics. (#58)
# Version 4.4.1
- Clarify safety documentation for `spawn_unchecked`. (#49)
# Version 4.4.0
- Ensure that the allocation doesn't exceed `isize::MAX` (#32)
- Add `FallibleTask::is_finished()` (#34)
- Add a metadata generic parameter to tasks (#33)
- Add panic propagation to tasks (#37)
- Add a way to tell if the task was woken while running from the schedule function (#42)
# Version 4.3.0
- Bump MSRV to Rust 1.47. (#30)
- Evaluate the layouts for the tasks at compile time. (#30)
- Add layout_info field to TaskVTable so that debuggers can decode raw tasks. (#29)
# Version 4.2.0
- Add `Task::is_finished`. (#19)
# Version 4.1.0
- Add `FallibleTask`. (#21)
# Version 4.0.3
- Document the return value of `Runnable::run()` better.
# Version 4.0.2
- Nits in the docs.
# Version 4.0.1
- Nits in the docs.
# Version 4.0.0
- Rename `Task` to `Runnable`.
- Rename `JoinHandle` to `Task`.
- Cancel `Task` on drop.
- Add `Task::detach()` and `Task::cancel()`.
- Add `spawn_unchecked()`.
# Version 3.0.0
- Use `ThreadId` in `spawn_local` because OS-provided IDs can get recycled.
- Add `std` feature to `Cargo.toml`.
# Version 2.1.1
- Allocate large futures on the heap.
# Version 2.1.0
- `JoinHandle` now only evaluates after the task's future has been dropped.
# Version 2.0.0
- Return `true` in `Task::run()`.
# Version 1.3.1
- Make `spawn_local` available only on unix and windows.
# Version 1.3.0
- Add `waker_fn`.
# Version 1.2.1
- Add the `no-std` category to the package.
# Version 1.2.0
- The crate is now marked with `#![no_std]`.
- Add `Task::waker` and `JoinHandle::waker`.
- Add `Task::into_raw` and `Task::from_raw`.
# Version 1.1.1
- Fix a use-after-free bug where the schedule function is dropped while running.
# Version 1.1.0
- If a task is dropped or canceled outside the `run` method, it gets re-scheduled.
- Add `spawn_local` constructor.
# Version 1.0.0
- Initial release
|