rust-id3

Build Status Crate Documentation

A library for reading and writing ID3 metadata.

Implemented Features

Examples

Reading tag frames

```rust use id3::{Tag, TagLike};

fn main() -> Result<(), Box> { let tag = Tag::readfrompath("testdata/id3v24.id3")?;

// Get a bunch of frames...
if let Some(artist) = tag.artist() {
    println!("artist: {}", artist);
}
if let Some(title) = tag.title() {
    println!("title: {}", title);
}
if let Some(album) = tag.album() {
    println!("album: {}", album);
}

// Get frames before getting their content for more complex tags.
if let Some(artist) = tag.get("TPE1").and_then(|frame| frame.content().text()) {
    println!("artist: {}", artist);
}
Ok(())

} ```

Modifying any existing tag.

```rust use id3::{Error, ErrorKind, Tag, TagLike, Version}; use std::fs::copy;

fn main() -> Result<(), Box> { copy("testdata/quiet.mp3", "/tmp/music.mp3")?;

let mut tag = match Tag::read_from_path("/tmp/music.mp3") {
    Ok(tag) => tag,
    Err(Error{kind: ErrorKind::NoTag, ..}) => Tag::new(),
    Err(err) => return Err(Box::new(err)),
};

tag.set_album("Fancy Album Title");

tag.write_to_path("/tmp/music.mp3", Version::Id3v24)?;
Ok(())

} ```

Creating a new tag, overwriting any old tag.

```rust use id3::{Tag, TagLike, Frame, Version}; use id3::frame::Content; use std::fs::copy;

fn main() -> Result<(), Box> { copy("testdata/quiet.mp3", "/tmp/music.mp3")?;

let mut tag = Tag::new();
tag.set_album("Fancy Album Title");

// Set the album the hard way.
tag.add_frame(Frame::text("TALB", "album"));

tag.write_to_path("/tmp/music.mp3", Version::Id3v24)?;
Ok(())

} ```

Contributing

Do you think you have found a bug? Then please report it via the Github issue tracker. Make sure to attach any problematic files that can be used to reproduce the issue. Such files are also used to create regression tests that ensure that your bug will never return.

When submitting pull requests, please prefix your commit messages with fix: or feat: for bug fixes and new features respectively. This is the Conventional Commits scheme that is used to automate some maintenance chores such as generating the changelog and inferring the next version number.