Misc changes (see commit log) #3

Merged
oysteikt merged 9 commits from rework-error-messages into master 2024-05-04 00:50:33 +02:00
4 changed files with 68 additions and 82 deletions
Showing only changes of commit 2ed8025046 - Show all commits

View File

@ -1,12 +1,15 @@
[package] [package]
name = "mpvipc" name = "mpvipc"
version = "1.3.0" version = "1.3.0"
authors = ["Jonas Frei <freijon@pm.me>"] authors = [
"Jonas Frei <freijon@pm.me>",
"h7x4 <h7x4@nani.wtf>"
]
description = "A small library which provides bindings to control existing mpv instances through sockets." description = "A small library which provides bindings to control existing mpv instances through sockets."
license = "GPL-3.0" license = "GPL-3.0"
homepage = "https://gitlab.com/mpv-ipc/mpvipc" homepage = "https://git.pvv.ntnu.no/oysteikt/mpvipc"
repository = "https://gitlab.com/mpv-ipc/mpvipc" repository = "https://git.pvv.ntnu.no/oysteikt/mpvipc"
documentation = "https://docs.rs/mpvipc/" documentation = "https://pvv.ntnu.no/~oysteikt/gitea/mpvipc/master/docs/mpvipc/"
edition = "2021" edition = "2021"
rust-version = "1.75" rust-version = "1.75"

View File

@ -5,46 +5,30 @@
A small library which provides bindings to control existing mpv instances through sockets. A small library which provides bindings to control existing mpv instances through sockets.
To make use of this library, please make sure mpv is started with the following option:
`
$ mpv --input-ipc-server=/tmp/mpv.sock --idle ...
`
## Dependencies ## Dependencies
- `mpv` - `mpv`
- `cargo` (makedep) - `cargo` (make dependency)
- `cargo-nextest` (test depencency)
## Install - `grcov` (test depencency)
- [Cargo](https://crates.io/crates/mpvipc)
You can use this package with cargo.
## Example ## Example
Make sure mpv is started with the following option: Make sure mpv is started with the following option:
`
```bash
$ mpv --input-ipc-server=/tmp/mpv.sock --idle $ mpv --input-ipc-server=/tmp/mpv.sock --idle
`
Here is a small code example which connects to the socket /tmp/mpv.sock and toggles playback.
```rust
extern crate mpvipc;
use mpvipc::*;
use std::sync::mpsc::channel;
fn main() {
let mpv = Mpv::connect("/tmp/mpv.sock").unwrap();
let paused: bool = mpv.get_property("pause").unwrap();
mpv.set_property("pause", !paused).expect("Error pausing");
}
``` ```
For a more extensive example and proof of concept, see project [mpvc](https://gitlab.com/mpv-ipc/mpvc). Here is a small code example which connects to the socket `/tmp/mpv.sock` and toggles playback.
## Bugs / Ideas ```rust
use mpvipc::*;
Check out the [Issue Tracker](https://gitlab.com/mpv-ipc/mpvipc/issues) #[tokio::main]
async fn main() -> Result<(), MpvError> {
let mpv = Mpv::connect("/tmp/mpv.sock").await?;
let paused: bool = mpv.get_property("pause").await?;
mpv.set_property("pause", !paused).expect("Error pausing");
}
```

View File

@ -1,15 +1,19 @@
use mpvipc::{MpvError, Mpv, MpvExt}; use mpvipc::{Mpv, MpvError, MpvExt};
#[tokio::main] #[tokio::main]
async fn main() -> Result<(), MpvError> { async fn main() -> Result<(), MpvError> {
env_logger::init(); env_logger::init();
let mpv = Mpv::connect("/tmp/mpv.sock").await?; let mpv = Mpv::connect("/tmp/mpv.sock").await?;
let meta = mpv.get_metadata().await?; let meta = mpv.get_metadata().await?;
println!("metadata: {:?}", meta); println!("metadata: {:?}", meta);
let playlist = mpv.get_playlist().await?; let playlist = mpv.get_playlist().await?;
println!("playlist: {:?}", playlist); println!("playlist: {:?}", playlist);
let playback_time: f64 = mpv.get_property("playback-time").await?; let playback_time: f64 = mpv.get_property("playback-time").await?;
println!("playback-time: {}", playback_time); println!("playback-time: {}", playback_time);
Ok(()) Ok(())
} }

View File

@ -1,4 +1,5 @@
use mpvipc::{MpvError, Mpv, MpvExt}; use futures::StreamExt;
use mpvipc::{parse_event_property, Event, Mpv, MpvDataType, MpvError, MpvExt, Property};
fn seconds_to_hms(total: f64) -> String { fn seconds_to_hms(total: f64) -> String {
let total = total as u64; let total = total as u64;
@ -14,55 +15,49 @@ async fn main() -> Result<(), MpvError> {
env_logger::init(); env_logger::init();
let mpv = Mpv::connect("/tmp/mpv.sock").await?; let mpv = Mpv::connect("/tmp/mpv.sock").await?;
let pause = false;
let playback_time = std::f64::NAN;
let duration = std::f64::NAN;
mpv.observe_property(1, "path").await?; mpv.observe_property(1, "path").await?;
mpv.observe_property(2, "pause").await?; mpv.observe_property(2, "pause").await?;
mpv.observe_property(3, "playback-time").await?; mpv.observe_property(3, "playback-time").await?;
mpv.observe_property(4, "duration").await?; mpv.observe_property(4, "duration").await?;
mpv.observe_property(5, "metadata").await?; mpv.observe_property(5, "metadata").await?;
loop {
// TODO: let mut events = mpv.get_event_stream().await;
// let event = mpv.event_listen()?; while let Some(Ok(event)) = events.next().await {
// match event { match event {
// Event::PropertyChange { id: _, property } => match property { mpvipc::Event::PropertyChange { .. } => match parse_event_property(event)? {
// Property::Path(Some(value)) => println!("\nPlaying: {}", value), (1, Property::Path(Some(value))) => println!("\nPlaying: {}", value),
// Property::Path(None) => (), (2, Property::Pause(value)) => {
// Property::Pause(value) => pause = value, println!("Pause: {}", value);
// Property::PlaybackTime(Some(value)) => playback_time = value, }
// Property::PlaybackTime(None) => playback_time = std::f64::NAN, (3, Property::PlaybackTime(Some(value))) => {
// Property::Duration(Some(value)) => duration = value, println!("Playback time: {}", seconds_to_hms(value));
// Property::Duration(None) => duration = std::f64::NAN, }
// Property::Metadata(Some(value)) => { (4, Property::Duration(Some(value))) => {
// println!("File tags:"); println!("Duration: {}", seconds_to_hms(value));
// if let Some(MpvDataType::String(value)) = value.get("ARTIST") { }
// println!(" Artist: {}", value); (5, Property::Metadata(Some(value))) => {
// } println!("File tags:");
// if let Some(MpvDataType::String(value)) = value.get("ALBUM") { if let Some(MpvDataType::String(value)) = value.get("ARTIST") {
// println!(" Album: {}", value); println!(" Artist: {}", value);
// } }
// if let Some(MpvDataType::String(value)) = value.get("TITLE") { if let Some(MpvDataType::String(value)) = value.get("ALBUM") {
// println!(" Title: {}", value); println!(" Album: {}", value);
// } }
// if let Some(MpvDataType::String(value)) = value.get("TRACK") { if let Some(MpvDataType::String(value)) = value.get("TITLE") {
// println!(" Track: {}", value); println!(" Title: {}", value);
// } }
// } if let Some(MpvDataType::String(value)) = value.get("TRACK") {
// Property::Metadata(None) => (), println!(" Track: {}", value);
// Property::Unknown { name: _, data: _ } => (), }
// }, }
// Event::Shutdown => return Ok(()), _ => (),
// Event::Unimplemented => panic!("Unimplemented event"), },
// _ => (), Event::Shutdown => return Ok(()),
// } Event::Unimplemented(_) => panic!("Unimplemented event"),
// print!( _ => (),
// "{}{} / {} ({:.0}%)\r", }
// if pause { "(Paused) " } else { "" },
// seconds_to_hms(playback_time),
// seconds_to_hms(duration),
// 100. * playback_time / duration
// );
// io::stdout().flush().unwrap();
} }
Ok(())
} }