mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-01-24 10:12:25 -05:00
2dfd236dcd
Matroska::Reader functions now return DecoderErrorOr instead of values being declared Optional. Useful errors can be handled by the users of the parser, similarly to the VP9 decoder. A lot of the error checking in the reader is a lot cleaner thanks to this change, since all reads can be range checked in Streamer::read_octet() now. Most functions for the Streamer class are now also out-of-line in Reader.cpp now instead of residing in the header.
59 lines
2.9 KiB
C++
59 lines
2.9 KiB
C++
/*
|
|
* Copyright (c) 2021, Hunter Salyer <thefalsehonesty@gmail.com>
|
|
* Copyright (c) 2022, Gregory Bertilson <zaggy1024@gmail.com>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <LibMain/Main.h>
|
|
#include <LibVideo/Containers/Matroska/Reader.h>
|
|
|
|
ErrorOr<int> serenity_main(Main::Arguments)
|
|
{
|
|
auto document_result = Video::Matroska::Reader::parse_matroska_from_file("/home/anon/Videos/test-webm.webm"sv);
|
|
if (document_result.is_error()) {
|
|
outln("Encountered an error during parsing: {}", document_result.release_error().string_literal());
|
|
return Error::from_string_literal("Failed to parse :(");
|
|
}
|
|
auto document = document_result.release_value();
|
|
|
|
outln("DocType is {}", document->header().doc_type.characters());
|
|
outln("DocTypeVersion is {}", document->header().doc_type_version);
|
|
auto segment_information = document->segment_information();
|
|
if (segment_information.has_value()) {
|
|
outln("Timestamp scale is {}", segment_information.value().timestamp_scale());
|
|
outln("Muxing app is \"{}\"", segment_information.value().muxing_app().as_string().to_string().characters());
|
|
outln("Writing app is \"{}\"", segment_information.value().writing_app().as_string().to_string().characters());
|
|
}
|
|
outln("Document has {} tracks", document->tracks().size());
|
|
for (auto const& track_entry : document->tracks()) {
|
|
auto const& track = *track_entry.value;
|
|
outln("\tTrack #{} with TrackID {}", track.track_number(), track.track_uid());
|
|
outln("\tTrack has TrackType {}", static_cast<u8>(track.track_type()));
|
|
outln("\tTrack has Language \"{}\"", track.language().characters());
|
|
outln("\tTrack has CodecID \"{}\"", track.codec_id().characters());
|
|
|
|
if (track.track_type() == Video::Matroska::TrackEntry::TrackType::Video) {
|
|
auto const video_track = track.video_track().value();
|
|
outln("\t\tVideo is {} pixels wide by {} pixels tall", video_track.pixel_width, video_track.pixel_height);
|
|
} else if (track.track_type() == Video::Matroska::TrackEntry::TrackType::Audio) {
|
|
auto const audio_track = track.audio_track().value();
|
|
outln("\t\tAudio has {} channels with a bit depth of {}", audio_track.channels, audio_track.bit_depth);
|
|
}
|
|
}
|
|
|
|
outln("Document has {} clusters", document->clusters().size());
|
|
for (auto const& cluster : document->clusters()) {
|
|
outln("\tCluster timestamp is {}", cluster.timestamp());
|
|
|
|
outln("\tCluster has {} blocks", cluster.blocks().size());
|
|
for (auto const& block : cluster.blocks()) {
|
|
(void)block;
|
|
outln("\t\tBlock for track #{} has {} frames", block.track_number(), block.frame_count());
|
|
outln("\t\tBlock's timestamp is {}", block.timestamp());
|
|
outln("\t\tBlock has lacing {}", static_cast<u8>(block.lacing()));
|
|
}
|
|
}
|
|
|
|
return 0;
|
|
}
|