-
Notifications
You must be signed in to change notification settings - Fork 13
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
decode_effect.py fails to parse CRN_CHO.ZD2 (MS-70CDR+ effect file) due to non-ascii character in TXE1 chunk #76
Comments
Seeing the same issue with MS-60B+ effects
|
MS-60B+ where group name issue, not quiet the same. Fixed that though.... Not 100% sure how to screen for a 0x81 byte. You can perhaps use an 'Adapter' where you define how to encode/decode. I used these in another project to handle the fact that values in midi are 7-bit
|
It could also be a possibility that the file is 'just corrupt', I've known the weirdest things happen.... |
I stumbled on 'FixedSized' and it gives me None when parsing fails, can you do something like??
|
When I run
python3 ./decode_effect.py --dump CRN_CHO.ZD2
, the command fails with the following error:Here's the corresponding hex values for the TXE1 chunk in the CRN_CHO.ZD2 file:
There is a 0x81 byte in the chunk, which trips up the Construct library decoding, as this is not a valid ascii character (as required in zoomzt2.py):
I have tried specifying other encodings, as described in the Construct library docs (https://construct.readthedocs.io/en/latest/api/strings.html#construct.core.possiblestringencodings), but none of them work.
I have googled extended ascii tables and other encoding standards to see if I could find one where 0x81 is an apostrophe, without success.
Also, the next character "f" (0x66) is also a bit of a mystery. Is it just a typo, or is the 2-byte encoding 0x81 0x66 supposed to represent an apostrophe?
I haven't come up with a good solution for this. One could perhaps read the TXE1 chunk as an array of bytes (like what is done for the TXJ1 chunk), then replace 0x81 0x66 with an apostrophe, and then convert the data to a string, but that seems like quite a hack, and I don't know how to make the Construct library to that for us, so it would probably result in some slightly ugly code.
The text was updated successfully, but these errors were encountered: