Oystein Kristoffer Tveit
7eec34ce00
Build and test / build (pull_request) Successful in 1m55s
Details
Build and test / check (pull_request) Successful in 1m52s
Details
Build and test / docs (pull_request) Successful in 2m21s
Details
Build and test / test (pull_request) Successful in 4m9s
Details
Build and test / check (push) Successful in 1m55s
Details
Build and test / build (push) Successful in 1m57s
Details
Build and test / docs (push) Successful in 2m43s
Details
Build and test / test (push) Successful in 5m33s
Details
High-level properties are now optional, considering there are about a thousand of them to parse. The high-level properties are a few chosen ones that I suspect might be useful for most people, with catch-all enum variants for the less common ones. |
||
---|---|---|
.gitea/workflows | ||
examples | ||
scripts | ||
src | ||
tests | ||
.gitignore | ||
COPYING | ||
Cargo.toml | ||
README.md | ||
flake.lock | ||
flake.nix |
README.md
mpvipc
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
mpv
cargo
(makedep)
Install
You can use this package with cargo.
Example
Make sure mpv is started with the following option:
$ 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.
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.
Bugs / Ideas
Check out the Issue Tracker