diff options
author | sanine <sanine.not@pm.me> | 2022-09-05 19:56:04 -0500 |
---|---|---|
committer | sanine <sanine.not@pm.me> | 2022-09-05 19:56:04 -0500 |
commit | be94297366c4a016a23f428613f65da0957df1b4 (patch) | |
tree | c74851241297b7dcc1057d49574ca151c9422371 | |
parent | 1ac240ed77536f259c04edb26953ef445dd4ee37 (diff) |
add mossrose_channel_stop
-rw-r--r-- | src/channel.c | 6 | ||||
-rw-r--r-- | src/channel.h | 1 | ||||
-rw-r--r-- | src/mossrose.c | 6 |
3 files changed, 13 insertions, 0 deletions
diff --git a/src/channel.c b/src/channel.c index a7a3643..23c3565 100644 --- a/src/channel.c +++ b/src/channel.c @@ -56,6 +56,12 @@ void channel_resume(struct channel_t *chan) } +void channel_stop(struct channel_t *chan) +{ + p_atomic_int_set(&(chan->shared.active), false); +} + + void channel_set_volume(struct channel_t *chan, float volume) { if (volume > 1.0f) volume = 1.0f; diff --git a/src/channel.h b/src/channel.h index 61a1c7d..b0c83a2 100644 --- a/src/channel.h +++ b/src/channel.h @@ -39,6 +39,7 @@ struct channel_t { void channel_init(struct channel_t *chan); void channel_reset(struct channel_t *chan); void channel_pause(struct channel_t *chan); +void channel_stop(struct channel_t *chan); void channel_resume(struct channel_t *chan); void channel_set_volume(struct channel_t *chan, float volume); void channel_set_pan(struct channel_t *chan, float pan_left, float pan_right); diff --git a/src/mossrose.c b/src/mossrose.c index 2e27c45..8a99770 100644 --- a/src/mossrose.c +++ b/src/mossrose.c @@ -132,6 +132,12 @@ void mossrose_channel_resume(int channel) { } +void mossrose_channel_stop(int channel) { + struct channel_t *chan = mossrose_global.channels + channel; + channel_stop(chan); +} + + void mossrose_channel_set_callback(int channel, channel_callback_t callback, void *userdata) { struct channel_t *chan = mossrose_global.channels + channel; |