-
Notifications
You must be signed in to change notification settings - Fork 81
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow Hdlr to be not the first in the Meta box #95
Conversation
571d2db
to
3a900c6
Compare
I'm not sure how you're interpreting the spec in that way? According to the syntax description in ISO 14496-12-2012 section 8.11.1.2, the |
Oh, I've actually look at the verbal description instead of the syntactic one. The verbal one said "The 'meta' box is required to contain a ‘hdlr’ box indicating the structure or format of the ‘meta’ box contents.", so I figured "contain" is "contains anywhere" The syntactic one does give an explicit order though... So... Apparently this is not according to standard, but I do have a file, which seems to be produced by I think it's still a good idea to support it, as the spec still guarantees that the contents of the |
Oh yikes, so I see we're out of spec territory then. Since you do have a sample from a real encoder with this behavior, I do agree with "being liberal with what you accept" here. To actually answer your original question, yes, all the data should at least be Boxes, so your PR seems like an improvement in that respect. |
3a900c6
to
20db61e
Compare
- enum-map to a newer version of the GAT PR (KamilaBorowska/enum-map#35) - mp4 to the rebased Hdlr PR (alfg/mp4-rust#95)
20db61e
to
75d5e02
Compare
While the spec says that the hdlr box should be the first one, not all implementations follow that. Actually look over all boxes in Meta to find Hdlr. Also add a test for such weirdly-formatted box Change the way unknown MetaBox is stored: store a list of boxes instead of raw bytes
75d5e02
to
d735464
Compare
Rebased and squashed, CI fails again due to an unrelated lint =( |
While the spec says that the hdlr box should be the first one, not all implementations follow that. Actually look over all boxes in Meta to find Hdlr. Also add a test for such weirdly-formatted box Change the way unknown MetaBox is stored: store a list of boxes instead of raw bytes Co-authored-by: Alfred Gutierrez <alfg@users.noreply.github.com>
While the spec says that the hdlr box should be the first one, not all implementations follow that. Actually look over all boxes in Meta to find Hdlr. Also add a test for such weirdly-formatted box Change the way unknown MetaBox is stored: store a list of boxes instead of raw bytes Co-authored-by: Alfred Gutierrez <alfg@users.noreply.github.com>
* Add support for multiple trex boxes. While it's common to construct a fMP4 file for a single track, it's totally valid to have multiple tracks. This means you also need multiple to support multiple trex boxes. Untested. * cargo fmt * Add a missing write_box call for mvex. * Ran clippy * Fix more errors when serializing a mvex box. udta is also broken but that can be fixed in another PR. * Derive Default trait for DataType (alfg#100) * fix clippy (rustc 1.71.0) (alfg#115) * Allow Hdlr to be not the first in the Meta box (alfg#95) While the spec says that the hdlr box should be the first one, not all implementations follow that. Actually look over all boxes in Meta to find Hdlr. Also add a test for such weirdly-formatted box Change the way unknown MetaBox is stored: store a list of boxes instead of raw bytes Co-authored-by: Alfred Gutierrez <alfg@users.noreply.github.com> * Try to skip extended header in MetaBox. (alfg#111) Fixes alfg#102 Co-authored-by: Alfred Gutierrez <alfg@users.noreply.github.com> * Release 0.14.0 (alfg#117) * Update Cargo.toml * Update README.md * Fix getting samples from movie fragments (alfg#106) * Fix getting samples from movie fragments * Add a function to the reader to read in fragments from a different reader --------- Co-authored-by: Alfred Gutierrez <alfg@users.noreply.github.com> * Export all boxes to allow more flexible use for writing (alfg#108) Co-authored-by: Alfred Gutierrez <alfg@users.noreply.github.com> * Fix some minor issues writing traf box (alfg#109) Co-authored-by: Alfred Gutierrez <alfg@users.noreply.github.com> * Fix writing SLConfigDescriptor (alfg#107) Co-authored-by: Alfred Gutierrez <alfg@users.noreply.github.com> * Extract esds box from wave box (alfg#96) * Extract esds from wave box * Allow empty, multi-byte, and arbitrary NUL terminated strings * Skip unsupported avc1 sub-boxes * Fixed non-integer framerates * Fixed bitrate calculation * Fixed format issue * Public read sample offset * Fix lint warning. --------- Co-authored-by: Alfred Gutierrez <alfg@users.noreply.github.com> * hev1 box parser (alfg#101) Co-authored-by: Alfred Gutierrez <alfg@users.noreply.github.com> --------- Co-authored-by: Luke Curley <kixelated@gmail.com> Co-authored-by: Linus Unnebäck <linus@folkdatorn.se> Co-authored-by: rolleifx <110799844+rolleifx@users.noreply.github.com> Co-authored-by: ⭐️NINIKA⭐️ <DCNick3@users.noreply.github.com> Co-authored-by: Alfred Gutierrez <alfg@users.noreply.github.com> Co-authored-by: w-flo <w-flo@users.noreply.github.com> Co-authored-by: jensenn <neil.jensen@pluto.tv> Co-authored-by: emkman99 <emkman99@users.noreply.github.com> Co-authored-by: Andrey Tkachenko <andrey@aidev.ru>
While the spec says that the hdlr box should be the first one, not all implementations follow that. Actually look over all boxes in Meta to find Hdlr. Also add a test for such weirdly-formatted box Change the way unknown MetaBox is stored: store a list of boxes instead of raw bytes Co-authored-by: Alfred Gutierrez <alfg@users.noreply.github.com>
The spec seems to allow the hdlr box to be located at any place in the meta box. This commit addresses that.