#parser #escaping #python #version #origin #msd #parse-msd

msdparser

Rust version of the MSD parser by Garcia (https://github.com/garcia/msdparser/)

1 unstable release

0.1.0 Jun 21, 2024

#2634 in Parser implementations

MIT license

42KB
650 lines

Rust MSDParser

This is a port of the MSD Parser library by Garcia to Rust. This library exposes APIs similar to its Python origin, namely the parse_msd function.

fn parse_msd<R: Read>(input: R, escapes: bool, ignore_stray_text: bool) -> MSDParser<R>;

The returned struct is an iterator that yields Result<MSDParameter, MSDParserError>, where MSDParameter is a key-value pair. The keys and values can be accessed by using .key() and .value() respectively.

See example below to get an idea of how it works.

Usage

use msdparser::{MSDParameter, parse_msd};
use std::error::Error;
use std::vec::Vec;

let example_input = b"\
#VERSION:0.83;
#TITLE:Springtime;
#SUBTITLE:;
#ARTIST:Kommisar;";
let mut result: Vec<MSDParameter> = Vec::new();

// here we set `escapes` to true and `ignore_stray_text` to false
// which is the default value in the original python library
for parameter in parse_msd(example_input.as_ref(), true, false) {
    match parameter {
       Ok(parameter) => result.push(parameter),
       Err(e) => panic!("{}", e), // = MSDParserError
    }   
}

assert_eq!(result.len(), 4);
assert_eq!(result[0].key().unwrap(), "VERSION".to_string());
assert_eq!(result[1].value().unwrap(), "Springtime".to_string());
assert_eq!(result[2].value().unwrap(), "".to_string());
assert_eq!(result[3].key().unwrap(), "ARTIST".to_string());

Installation

  1. Add the following to your Cargo.toml:
[dependencies]
msdparser = { version = "0.1.0", git = "https://github.com/smdbs01/rust_msdparser.git" }

Or

  1. Use Cargo add msdparser.

Contribute

This is my first project using Rust, so it is very likely that the codebase is not "rusty" enough. So, if you find any bugs or suggestions, please feel free to open an issue or PR.

Dependencies

~2.2–3MB
~55K SLoC