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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
pub const BUFFER_SIZE: u32 = 128;
pub const MAX_CHANNELS: usize = 32;
pub mod alloc;
pub mod buffer;
pub mod context;
pub mod control;
pub mod media;
pub mod node;
pub mod param;
pub mod process;
pub mod spatial;
#[cfg(test)]
mod snapshot;
#[cfg(not(test))]
mod io;
mod analysis;
mod graph;
mod message;
#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord)]
pub struct SampleRate(pub u32);
#[derive(Debug, Clone, Copy)]
pub struct IndexSizeError {}
use std::fmt;
use std::sync::atomic::{AtomicU64, Ordering};
impl fmt::Display for IndexSizeError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{:?}", self)
}
}
impl std::error::Error for IndexSizeError {}
#[derive(Debug, Clone, Copy)]
pub struct BufferDepletedError {}
impl fmt::Display for BufferDepletedError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{:?}", self)
}
}
impl std::error::Error for BufferDepletedError {}
#[derive(Debug)]
pub(crate) struct AtomicF64 {
inner: AtomicU64,
}
impl AtomicF64 {
pub fn new(v: f64) -> Self {
Self {
inner: AtomicU64::new(u64::from_ne_bytes(v.to_ne_bytes())),
}
}
pub fn load(&self) -> f64 {
f64::from_ne_bytes(self.inner.load(Ordering::SeqCst).to_ne_bytes())
}
pub fn store(&self, v: f64) {
self.inner
.store(u64::from_ne_bytes(v.to_ne_bytes()), Ordering::SeqCst)
}
pub fn swap(&self, v: f64) -> f64 {
let prev = self
.inner
.swap(u64::from_ne_bytes(v.to_ne_bytes()), Ordering::SeqCst);
f64::from_ne_bytes(prev.to_ne_bytes())
}
}
#[cfg(test)]
mod tests {
use float_eq::assert_float_eq;
use super::*;
#[test]
fn test_atomic_f64() {
let f = AtomicF64::new(2.0);
assert_float_eq!(f.load(), 2.0, ulps <= 0);
f.store(3.0);
assert_float_eq!(f.load(), 3.0, ulps <= 0);
let prev = f.swap(4.0);
assert_float_eq!(prev, 3.0, ulps <= 0);
assert_float_eq!(f.load(), 4.0, ulps <= 0);
}
}