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

Metatags #60

Open
MrSVCD opened this issue Nov 8, 2024 · 3 comments
Open

Metatags #60

MrSVCD opened this issue Nov 8, 2024 · 3 comments

Comments

@MrSVCD
Copy link

MrSVCD commented Nov 8, 2024

Hi,
Is there a official/endorsed metataging format for QOA?
With metatag I mean artist and title information etc.
While there is a handful of formats out there (I have been looking at ape-tag) it feels like QO* would make its own QOT format.

@phoboslab
Copy link
Owner

I don't really see the use case for metatags in QOA. It's not like you have your music library in this format or exchange QOA files on Napster. So, no plan to add this.

If I were to create a tagging format, it would be a simple key-value structure. Pretty much something like APE, actually :)

As far as I know, APE tags can be just appended to the end of a file, so that would work for QOA, too.

@MrSVCD
Copy link
Author

MrSVCD commented Nov 12, 2024

I am mostly asking because I have a dream of making a RaspberryPi Pico based iPod clone, and I want to use QOA as the main format for it (because I can).
One of the requirements I think is some sort of tag format for the audio files.
The parts needed I think would be a Pico, a small OLED, a SD card slot, some sort of battery and a PCB with touch sensor to mount it all to.
I also realize that I will never make it because of who I am and that retroPod exists for Android.

@terinjokes
Copy link

APE certainly works, and I've written support for it with QOA files in my player. Thanks for the suggestions. However, in places it does feel a bit at odds with QOA.

For example, while the footer can be nicely read with a series of 64-bit reads, like QOA, the key-values can't. The header of each tag includes the length of the value, but to find the length of the key you need to scan to find the \0 sentinel. In comparison, the equivalent structure in Vorbis (aka Xiph) comments the length field is over both the key and value, simplifying a read to a buffer.

Certainly not insurmountable, but something to noodle on, should there ever be "Quite OK Metadata".

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