mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer-rs.git
synced 2025-01-10 17:25:33 +00:00
Move futures based BusStream from examples to the bindings
And hide behind the "futures" feature. Fixes https://github.com/sdroege/gstreamer-rs/issues/26
This commit is contained in:
parent
08e2f6d917
commit
165d85646f
6 changed files with 82 additions and 49 deletions
1
Cargo.lock
generated
1
Cargo.lock
generated
|
@ -253,6 +253,7 @@ name = "gstreamer"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bitflags 0.9.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"bitflags 0.9.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"futures 0.1.14 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"glib 0.1.3 (git+https://github.com/gtk-rs/glib)",
|
"glib 0.1.3 (git+https://github.com/gtk-rs/glib)",
|
||||||
"glib-sys 0.3.4 (git+https://github.com/gtk-rs/sys)",
|
"glib-sys 0.3.4 (git+https://github.com/gtk-rs/sys)",
|
||||||
"gobject-sys 0.3.4 (git+https://github.com/gtk-rs/sys)",
|
"gobject-sys 0.3.4 (git+https://github.com/gtk-rs/sys)",
|
||||||
|
|
|
@ -12,13 +12,14 @@ gstreamer-video = { path = "../gstreamer-video" }
|
||||||
gstreamer-player = { path = "../gstreamer-player", optional = true }
|
gstreamer-player = { path = "../gstreamer-player", optional = true }
|
||||||
gtk = { version = "0.1.3", git = "https://github.com/gtk-rs/gtk", features = ["v3_6"] }
|
gtk = { version = "0.1.3", git = "https://github.com/gtk-rs/gtk", features = ["v3_6"] }
|
||||||
gio = { version = "0.1.3", git = "https://github.com/gtk-rs/gio" }
|
gio = { version = "0.1.3", git = "https://github.com/gtk-rs/gio" }
|
||||||
futures = "0.1"
|
futures = { version = "0.1", optional = true }
|
||||||
tokio-core = "0.1"
|
tokio-core = { version = "0.1", optional = true }
|
||||||
send-cell = "0.1"
|
send-cell = "0.1"
|
||||||
byte-slice-cast = "0.1"
|
byte-slice-cast = "0.1"
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
gst-player = ["gstreamer-player"]
|
gst-player = ["gstreamer-player"]
|
||||||
|
tokio = ["gstreamer/futures", "futures", "tokio-core"]
|
||||||
default-features = []
|
default-features = []
|
||||||
|
|
||||||
[badges]
|
[badges]
|
||||||
|
|
|
@ -1,60 +1,20 @@
|
||||||
extern crate gstreamer as gst;
|
extern crate gstreamer as gst;
|
||||||
|
#[cfg(feature = "tokio")]
|
||||||
use gst::*;
|
use gst::*;
|
||||||
|
|
||||||
|
#[cfg(feature = "tokio")]
|
||||||
extern crate futures;
|
extern crate futures;
|
||||||
use futures::{Async, Poll};
|
#[cfg(feature = "tokio")]
|
||||||
use futures::task::Task;
|
|
||||||
use futures::stream::Stream;
|
use futures::stream::Stream;
|
||||||
|
#[cfg(feature = "tokio")]
|
||||||
extern crate tokio_core;
|
extern crate tokio_core;
|
||||||
|
#[cfg(feature = "tokio")]
|
||||||
use tokio_core::reactor::Core;
|
use tokio_core::reactor::Core;
|
||||||
|
|
||||||
|
#[cfg(feature = "tokio")]
|
||||||
use std::env;
|
use std::env;
|
||||||
use std::sync::{Arc, Mutex};
|
|
||||||
|
|
||||||
struct BusStream(Bus, Arc<Mutex<Option<Task>>>);
|
|
||||||
|
|
||||||
impl BusStream {
|
|
||||||
fn new(bus: &Bus) -> Self {
|
|
||||||
let task = Arc::new(Mutex::new(None));
|
|
||||||
let task_clone = task.clone();
|
|
||||||
|
|
||||||
bus.set_sync_handler(move |_, _| {
|
|
||||||
let mut task = task_clone.lock().unwrap();
|
|
||||||
if let Some(task) = task.take() {
|
|
||||||
// FIXME: Force type...
|
|
||||||
let task: Task = task;
|
|
||||||
task.notify();
|
|
||||||
}
|
|
||||||
|
|
||||||
BusSyncReply::Pass
|
|
||||||
});
|
|
||||||
BusStream(bus.clone(), task)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Drop for BusStream {
|
|
||||||
fn drop(&mut self) {
|
|
||||||
self.0.unset_sync_handler();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Stream for BusStream {
|
|
||||||
type Item = Message;
|
|
||||||
type Error = ();
|
|
||||||
|
|
||||||
fn poll(&mut self) -> Poll<Option<Self::Item>, Self::Error> {
|
|
||||||
let mut task = self.1.lock().unwrap();
|
|
||||||
|
|
||||||
let msg = self.0.pop();
|
|
||||||
if let Some(msg) = msg {
|
|
||||||
Ok(Async::Ready(Some(msg)))
|
|
||||||
} else {
|
|
||||||
*task = Some(futures::task::current());
|
|
||||||
Ok(Async::NotReady)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
#[cfg(feature = "tokio")]
|
||||||
fn main() {
|
fn main() {
|
||||||
let pipeline_str = env::args().collect::<Vec<String>>()[1..].join(" ");
|
let pipeline_str = env::args().collect::<Vec<String>>()[1..].join(" ");
|
||||||
|
|
||||||
|
@ -95,3 +55,8 @@ fn main() {
|
||||||
let ret = pipeline.set_state(gst::State::Null);
|
let ret = pipeline.set_state(gst::State::Null);
|
||||||
assert_ne!(ret, gst::StateChangeReturn::Failure);
|
assert_ne!(ret, gst::StateChangeReturn::Failure);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(not(feature = "tokio"))]
|
||||||
|
fn main() {
|
||||||
|
println!("Please compile with --features tokio");
|
||||||
|
}
|
||||||
|
|
|
@ -19,6 +19,7 @@ gstreamer-sys = { version = "0.1.1", git = "https://github.com/sdroege/gstreamer
|
||||||
glib = { version = "0.1.3", git = "https://github.com/gtk-rs/glib" }
|
glib = { version = "0.1.3", git = "https://github.com/gtk-rs/glib" }
|
||||||
num-rational = { version = "0.1.38", default-features = false, features = [] }
|
num-rational = { version = "0.1.38", default-features = false, features = [] }
|
||||||
lazy_static = "0.2"
|
lazy_static = "0.2"
|
||||||
|
futures = { version = "0.1", optional = true }
|
||||||
|
|
||||||
[build-dependencies.rustdoc-stripper]
|
[build-dependencies.rustdoc-stripper]
|
||||||
version = "0.1"
|
version = "0.1"
|
||||||
|
|
|
@ -16,6 +16,17 @@ use glib_ffi;
|
||||||
use glib_ffi::{gboolean, gpointer};
|
use glib_ffi::{gboolean, gpointer};
|
||||||
use std::ptr;
|
use std::ptr;
|
||||||
|
|
||||||
|
#[cfg(feature = "futures")]
|
||||||
|
use std::sync::{Arc, Mutex};
|
||||||
|
#[cfg(feature = "futures")]
|
||||||
|
use futures;
|
||||||
|
#[cfg(feature = "futures")]
|
||||||
|
use futures::{Async, Poll};
|
||||||
|
#[cfg(feature = "futures")]
|
||||||
|
use futures::task::Task;
|
||||||
|
#[cfg(feature = "futures")]
|
||||||
|
use futures::stream::Stream;
|
||||||
|
|
||||||
use Bus;
|
use Bus;
|
||||||
use BusSyncReply;
|
use BusSyncReply;
|
||||||
use Message;
|
use Message;
|
||||||
|
@ -129,3 +140,52 @@ impl Bus {
|
||||||
unsafe { ffi::gst_bus_set_sync_handler(self.to_glib_none().0, None, ptr::null_mut(), None) }
|
unsafe { ffi::gst_bus_set_sync_handler(self.to_glib_none().0, None, ptr::null_mut(), None) }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "futures")]
|
||||||
|
pub struct BusStream(Bus, Arc<Mutex<Option<Task>>>);
|
||||||
|
|
||||||
|
#[cfg(feature = "futures")]
|
||||||
|
impl BusStream {
|
||||||
|
pub fn new(bus: &Bus) -> Self {
|
||||||
|
let task = Arc::new(Mutex::new(None));
|
||||||
|
let task_clone = task.clone();
|
||||||
|
|
||||||
|
bus.set_sync_handler(move |_, _| {
|
||||||
|
let mut task = task_clone.lock().unwrap();
|
||||||
|
if let Some(task) = task.take() {
|
||||||
|
// FIXME: Force type...
|
||||||
|
let task: Task = task;
|
||||||
|
task.notify();
|
||||||
|
}
|
||||||
|
|
||||||
|
BusSyncReply::Pass
|
||||||
|
});
|
||||||
|
|
||||||
|
BusStream(bus.clone(), task)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "futures")]
|
||||||
|
impl Drop for BusStream {
|
||||||
|
fn drop(&mut self) {
|
||||||
|
self.0.unset_sync_handler();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "futures")]
|
||||||
|
impl Stream for BusStream {
|
||||||
|
type Item = Message;
|
||||||
|
type Error = ();
|
||||||
|
|
||||||
|
fn poll(&mut self) -> Poll<Option<Self::Item>, Self::Error> {
|
||||||
|
let mut task = self.1.lock().unwrap();
|
||||||
|
|
||||||
|
let msg = self.0.pop();
|
||||||
|
if let Some(msg) = msg {
|
||||||
|
Ok(Async::Ready(Some(msg)))
|
||||||
|
} else {
|
||||||
|
*task = Some(futures::task::current());
|
||||||
|
Ok(Async::NotReady)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -22,6 +22,9 @@ extern crate glib;
|
||||||
|
|
||||||
extern crate num_rational;
|
extern crate num_rational;
|
||||||
|
|
||||||
|
#[cfg(feature = "futures")]
|
||||||
|
extern crate futures;
|
||||||
|
|
||||||
use glib::translate::{from_glib, from_glib_full};
|
use glib::translate::{from_glib, from_glib_full};
|
||||||
|
|
||||||
macro_rules! callback_guard {
|
macro_rules! callback_guard {
|
||||||
|
@ -102,6 +105,8 @@ pub use child_proxy::ChildProxyExtManual;
|
||||||
pub use tag_setter::TagSetterExtManual;
|
pub use tag_setter::TagSetterExtManual;
|
||||||
pub use self::iterator::Iterator;
|
pub use self::iterator::Iterator;
|
||||||
pub use device_provider::DeviceProviderExtManual;
|
pub use device_provider::DeviceProviderExtManual;
|
||||||
|
#[cfg(feature = "futures")]
|
||||||
|
pub use bus::BusStream;
|
||||||
|
|
||||||
mod value;
|
mod value;
|
||||||
pub use value::*;
|
pub use value::*;
|
||||||
|
|
Loading…
Reference in a new issue