securityos/node_modules/winamp-eqf/README.md

82 lines
3.5 KiB
Markdown
Raw Normal View History

2024-09-06 15:32:35 +00:00
# Winamp Equalizer Preset Parser
Winamp allows you to save your equalizser settings to `.eqf` file. This package allows you to parse these files.
## Installation
npm install --save winamp-eqf
## Ussage
import {parser, creator} from 'winamp-eqf';
// ... Get your .eqf or .q1 file as an ArrayBuffer
const eqf = parser(eqfArrayBuffer);
const eqfArrayBuffer = creator(eqf);
## API
### `parser(ArrayBuffer)`
#### Return value
```JavaScript
{
"presets": [
{
"name": "Entry1",
"preamp": 33, // 1-64
"hz60": 64, // 1-64
"hz170": 64, // ...
"hz310": 64,
"hz600": 64,
"hz1000": 64,
"hz3000": 64,
"hz6000": 64,
"hz12000": 64,
"hz14000": 64,
"hz16000": 64,
},
// Some files, such as winamp.q1, may contain multiple preset objects.
],
"type": "Winamp EQ library file v1.1",
}
```
### `creator(eqfObject)`
#### Return Value: `ArrayBuffer`
`eqfObject` is an object with the same shape as that returned by `parser()`.
## Source Material
Starting with this spec found here: <http://www.perlmonks.org/bare/?node_id=584875>:
> I've taken a look at some EQF files that I made for the purpose. The format is apparently very simple:
> The file is 299 bytes long.
>
> It starts with a text header, which in my case, is 37 bytes long. It is, in double-quotish notation — note the control-Z character:
>
> Winamp EQ library file v1.1\cZ!--Entry1
>
> Next is a block of null bytes ("\0") up till the next, final part.
> The real data is stored in the last 11 bytes of the file: the last byte is for the general volume, the 10 bytes before that are for each of the 10 EQ controls, in ascending order: the first of these 10 for the deepest bass, the last one (right in front of the volume byte) is for the highest treble.
> The values are 0x20 in neutral position, and are reversed in value: 0x00 is maximum, 0x3F is minimum. So there are 31 positions below, and 31 32 levels above neutral.
Additionally, I got some info from [Darren Owen](https://twitter.com/The_DoctorO) via Twitter:
<https://twitter.com/The_DoctorO/status/856223002530373632>
> Not that i'm aware off as sadly documentation of things was never great. Looking at the link vs files in a hex editor it seems mostly right.
> The current 1.1 format should be fine as I don't believe the format has changed for a very long time :)
And then via direct message:
> Will do it here as I can type a bit more, but the only obvious thing wrong with the link is the signature assumption as it's not guaranteed to be 'entry1' As you can have multiple eq blocks in a file.
> If you've looked at winamp.q1 you should see multiple presets in that file which follow one after each other so the file signature (winamp.q1 or a specific *.eqf file) is "Winamp EQ library file v1.1\x1A!--" (pulled that out from the disassembler) it's then a 257 byte buffer (256 + null character to terminate correctly) then the 10 byte block relating to the eq sliders (need to double-check the range base) followed by the 1 byte for the preamp slider then if there's more presets in the file, they follow on immediately after with the name block looking at the preamp slider, -12dB = 0x3F, 0dB = 0x1F, 12dB = 0 (so a 0-63 range) that seems to be the same for the other sliders (and matches 1:1 with the sdk details) and I think that's it :) in the winamp.q1 file, the 'default' entry is either a flat preset or what's been saved after customisation (in-case you're wanting to mirror the native behaviour via the preset -> save -> default action)