Skip to content
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

Majority of m4a files can't decode: "isomp4: missing moov atom" #289

Open
cybersoulK opened this issue Jun 17, 2024 · 3 comments
Open

Majority of m4a files can't decode: "isomp4: missing moov atom" #289

cybersoulK opened this issue Jun 17, 2024 · 3 comments

Comments

@cybersoulK
Copy link

cybersoulK commented Jun 17, 2024

I made several sounds from audacity and from ffmpeg command line tool.
They play normally on mac and VLC playbacks, but i get this error with Symphonia: Unsupported("isomp4: missing moov atom")

Reading them with a parser reveals that moov is at the end (which is most common in m4a).
I had a couple of files m4a that worked (first file structure)

image

which indicates missing crucial functionality to parse m4a

@cybersoulK cybersoulK changed the title m4a file made by either audacity or by ffmpeg command line tool doesn't work: Unsupported("isomp4: missing moov atom") Majority of m4a files can't decode: "isomp4: missing moov atom" Jun 17, 2024
@cybersoulK
Copy link
Author

cybersoulK commented Jun 17, 2024

running qt-faststart sound.m4a sound2.m4a for all files solved the issue.
I am not sure if this is just a overlooked feature, or a crate choice.

@tGrothmannFluffy
Copy link

Hi there, I am getting the same error message with some m4a files.

@sunaemon
Copy link

sunaemon commented Sep 1, 2024

I've encountered the same "Unsupported("isomp4: missing moov atom")" error, which can be reproduced using the code at https://github.com/sunaemon/missing-moov-atom/blob/main/src/main.rs#L119.

It seems the issue occurs when Symphonia attempts to parse m4a files where the 'moov' atom is placed after the 'mdat' atom in an unseekable MediaSource.

Workarounds:

  1. Save the audio data in a Vec and pass it as Box::new(Cursor::new(data.into_boxed_slice())).
  2. Save the audio data to a file before processing with Symphonia, then pass it as shown in the "Getting Started" example: https://github.com/pdeljanov/Symphonia/blob/master/symphonia/examples/basic-interleaved.rs#L17-L22

It would be helpful if Symphonia could generate a more user-friendly error message in this scenario, perhaps indicating that the file structure is not currently supported for non-seekable sources. This could guide users towards the workarounds more quickly.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants