#parser #text-parser #web-vtt #text-format #subrip

subtp

A parser for subtitle files such as the SubRip Subtitle (.srt) and the WebVTT (.vtt)

2 unstable releases

0.2.0 Feb 20, 2024
0.1.0 Feb 17, 2024

#1747 in Parser implementations

Download history 25/week @ 2024-08-29 13/week @ 2024-09-05 39/week @ 2024-09-12 56/week @ 2024-09-19 67/week @ 2024-09-26 45/week @ 2024-10-03 28/week @ 2024-10-10 32/week @ 2024-10-17 32/week @ 2024-10-24 29/week @ 2024-10-31 12/week @ 2024-11-07 21/week @ 2024-11-14 15/week @ 2024-11-21 20/week @ 2024-11-28 37/week @ 2024-12-05 103/week @ 2024-12-12

177 downloads per month
Used in 3 crates

MIT/Apache

155KB
4K SLoC

subtp

A parser in Rust for subtitle text formats such as the SubRip Subtitle (.srt) format and the WebVTT (.vtt) format.

Installation

Run the following Cargo command in your project directory:

cargo add subtp

or add the following line to your Cargo.toml:

[dependencies]
subtp = "0.2.0"

Features

Usage

SubRip Subtitle (.srt)

Parse a SubRip Subtitle (.srt) text into a subtp::srt::SubRip struct.

use subtp::srt::SubRip;

let text = r#"
1
00:00:00,000 --> 00:00:02,000
Hello, world!

2
00:00:02,000 --> 00:00:04,000
This is a subtitle.
"#;

let subrip = SubRip::parse(text)?;

Render a subtp::srt::SubRip struct into a SubRip Subtitle (.srt) text.

subtp::srt::SubRip is constructed with a vector of subtp::srt::SrtSubtitle.

use subtp::srt::{SubRip, SrtSubtitle, SrtTimestamp};

let subrip = SubRip {
    subtitles: vec![
        SrtSubtitle {
            sequence: 1,
            start: SrtTimestamp {
                seconds: 1,
                ..Default::default()
            },
            end: SrtTimestamp {
                seconds: 2,
                ..Default::default()
            },
            text: vec!["This is the first subtitle.".to_string()],
            ..Default::default()
        },
        SrtSubtitle {
            sequence: 2,
            start: SrtTimestamp {
                seconds: 3,
                ..Default::default()
            },
            end: SrtTimestamp {
                seconds: 4,
                ..Default::default()
            },
            text: vec![
                "This is the second subtitle.".to_string(),
                "Subtitle text can span multiple lines.".to_string(),
            ],
            ..Default::default()
        },
    ],
};
 
let text = subrip.render();

WebVTT (.vtt)

Parse a WebVTT (.vtt) text into a subtp::vtt::WebVTT struct.

use subtp::vtt::WebVtt;

let text = r#"WEBVTT

1
00:00:00.000 --> 00:00:02.000
Hello, world!

2
00:00:02.000 --> 00:00:04.000
This is a subtitle.
"#;

let webvtt = WebVtt::parse(text)?;

Render a subtp::vtt::WebVTT struct into a WebVTT (.vtt) text.

subtp::vtt::WebVTT is constructed with a header subtp::vtt::VttHeader and a vector of subtp::vtt::VttBlcok.

subtp::vtt::VttBlcok can be following types:

  • subtp::vtt::VttCue
    • Cue block with an identifier (Optional), timings, settings (Optional) and a subtitle text.
  • subtp::vtt::VttComment
    • Comment block with a noting text.
  • subtp::vtt::VttStyle
    • Style block with a CSS style text.
  • subtp::vtt::VttRegion
    • Region block with a region definition.
use subtp::vtt::{WebVtt, VttBlock, VttCue, VttHeader, VttTimings, VttTimestamp};

let webvtt = WebVtt {
    blocks: vec![
        VttCue {
            identifier: Some("1".to_string()),
            timings: VttTimings {
                start: VttTimestamp {
                    seconds: 0,
                    ..Default::default()
                },
                end: VttTimestamp {
                    seconds: 2,
                    ..Default::default()
                },
            },
            payload: vec!["Hello, world!".to_string()],
            ..Default::default()
        }.into(),
        VttCue {
            identifier: Some("2".to_string()),
            timings: VttTimings {
                start: VttTimestamp {
                    seconds: 2,
                    ..Default::default()
                },
                end: VttTimestamp {
                    seconds: 4,
                    ..Default::default()
                },
            },
            payload: vec!["This is a subtitle.".to_string()],
            ..Default::default()
        }.into(),
    ],
    ..Default::default()
};

let text = webvtt.render();

Other examples

See the ./examples directory.

Changelog

See CHANGELOG.

License

Licensed under either of the Apache License, Version 2.0 or the MIT license at your option.

Dependencies

~270–750KB
~17K SLoC