Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Mange/mpris-rs
Idiomatic MPRIS D-Bus interface library for Rust
https://github.com/Mange/mpris-rs
d-bus dbus mpris mpris-ctl rust-library
Last synced: about 1 month ago
JSON representation
Idiomatic MPRIS D-Bus interface library for Rust
- Host: GitHub
- URL: https://github.com/Mange/mpris-rs
- Owner: Mange
- License: apache-2.0
- Created: 2017-11-02T00:26:53.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2024-06-15T10:49:13.000Z (7 months ago)
- Last Synced: 2024-07-18T09:59:10.898Z (6 months ago)
- Topics: d-bus, dbus, mpris, mpris-ctl, rust-library
- Language: Rust
- Size: 430 KB
- Stars: 68
- Watchers: 5
- Forks: 17
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# mpris
> A Rust library for dealing with [MPRIS2][mpris2]-compatible players over
> D-Bus.[![Crates.io][crate-badge]][crate] [![Documentation][docs-badge]][docs] [![Build Status][ci-badge]][ci] ![Actively developed][maintenance-badge]
## What is MPRIS2?
> The Media Player Remote Interfacing Specification is a standard D-Bus
> interface which aims to provide a common programmatic API for controlling
> media players.
>
> It provides a mechanism for discovery, querying and basic playback control of
> compliant media players, as well as a tracklist interface which is used to
> add context to the active media item.From [*About*, in the MPRIS2 specification][mpris-about].
Basically, you can use it to control media players on your computer. This is
most commonly used to build media player applets, UIs or to pause other players
before your own software performs some action.You can also use it in order to query metadata about what is currently playing,
or *if* something is playing.## How to use
```rust
use mpris::PlayerFinder;// Pauses currently playing media and prints metadata information about that
// media.
// If no player is running, exits with an error.
fn main() {
let player = PlayerFinder::new()
.expect("Could not connect to D-Bus")
.find_active()
.expect("Could not find any player");player.pause().expect("Could not pause");
let metadata = player.get_metadata().expect("Could not get metadata for player");
println!("{:#?}", metadata);
}
```See the `examples` directory for more examples.
## License
Copyright 2017-2022 Magnus Bergmark
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License athttp://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.[mpris2]: https://specifications.freedesktop.org/mpris-spec/latest/
[mpris-about]: https://specifications.freedesktop.org/mpris-spec/latest/#About
[docs]: https://docs.rs/mpris/
[docs-badge]: https://docs.rs/mpris/badge.svg
[crate]: https://crates.io/crates/mpris
[crate-badge]: https://img.shields.io/crates/v/mpris.svg
[maintenance-badge]: https://img.shields.io/badge/maintenance-actively--developed-brightgreen.svg
[ci-badge]: https://travis-ci.org/Mange/mpris-rs.svg?branch=master
[ci]: https://travis-ci.org/Mange/mpris-rs