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

Refactor of JASC-PAL #620

Open
wants to merge 5 commits into
base: master
Choose a base branch
from

Conversation

waterwheels
Copy link
Contributor

Simplified the line-reading function to use fgets() which handles windows/unix line endings internally. Simplified the main palette-reading function, and consolidated all the error checking logic in it.

I added checks for as many errors I could think of, but happy to add more checks if anyone has suggestions.

Thanks to my friend Lito, who knows C much better than me, and workshopped the bones of this refactor with me.

Simplified the line-reading function to use `fgets()` which handles windows/unix line endings internally. Simplified the main palette-reading function, and consolidated all the error checking logic in it.

I added checks for as many errors I could think of, but happy to add more checks if anyone has suggestions.

Thanks to my friend Lito, who knows C much better than me, and workshopped the bones of this refactor with me.
tools/gbagfx/jasc_pal.c Outdated Show resolved Hide resolved
tools/gbagfx/jasc_pal.c Outdated Show resolved Hide resolved
tools/gbagfx/jasc_pal.c Show resolved Hide resolved
Colour number parsing reverted to use `ParseNumber()` to handle long to int conversion and malformed line errors
Colour number error message reverted to specify minimum value (1)
Colour channels checked for being in-bounds before assignment
@GriffinRichards
Copy link
Member

Sorry for the delay. After more testing I'm still seeing some error messages worse than before.
Example: if I have a palette with the invalid color entry 74 65 90 255 123, the error I got before would be

The line "74 65 90 25" is too long.

and the error I get now is

Invalid color format in color ""

@waterwheels
Copy link
Contributor Author

waterwheels commented May 21, 2023

No rush, I really appreciate you looking over this. I tried to replicate the issue, but adding your example line to a new test set palette didn't produce the same results. Could you share the palette you were testing with? Here's the full set of test palettes I've been using to check the changes I've made, now including 'five colours.pal'. I run them all with find . -type f -iname "*.pal" -exec echo "Encoding "{} \; -execdir "$gbafx" {} out.gbapal \; and they should each work or produce the specified error. (There's one more test palette called 'permission denied' but it seems pointless to share it since I need to allow access to zip it).

tools/gbagfx/jasc_pal.c Outdated Show resolved Hide resolved
tools/gbagfx/jasc_pal.c Outdated Show resolved Hide resolved
Fixed range on number of colours error message to [1, 256]
Added newlines to colour component out-of-range errors

Co-Authored-By: Sophia <73026338+sophxm@users.noreply.github.com>
@waterwheels
Copy link
Contributor Author

New test set with a palette with an out-of-range colour component

@GriffinRichards
Copy link
Member

I tried to replicate the issue, but adding your example line to a new test set palette didn't produce the same results.

I changed this color
https://github.com/pret/pokefirered/blob/master/graphics/battle_interface/healthbar.pal#L9
to 74 65 90 255 123
and then allowed gbagfx to run automatically as part of the build process (i.e. tools/gbagfx/gbagfx graphics/battle_interface/healthbar.pal graphics/battle_interface/healthbar.gbapal). That gives me the error Invalid color format in color ""

@sophxm
Copy link
Contributor

sophxm commented May 22, 2023

I tried to replicate the issue, but adding your example line to a new test set palette didn't produce the same results.

I changed this color https://github.com/pret/pokefirered/blob/master/graphics/battle_interface/healthbar.pal#L9 to 74 65 90 255 123 and then allowed gbagfx to run automatically as part of the build process (i.e. tools/gbagfx/gbagfx graphics/battle_interface/healthbar.pal graphics/battle_interface/healthbar.gbapal). That gives me the error Invalid color format in color ""

@waterwheels This is because fgets stops reading after MAX_LINE_LENGTH, in this case making the line endings the next piece of input. Your five colours.pal test file uses unix line endings and 74 65 90 255 123\n fits in the buffer exactly, but 74 65 90 255 123\r\n does not (try changing 74 to 174 to recreate the bug with unix line endings, or just insert a blank line anyway).

It's probably better to avoid trying to sscanf it all at once and just parse it in steps, trying to create a format string that exclusively matches this ends up borderline-incomprehensible.

@waterwheels
Copy link
Contributor Author

Thank you, that confirms my current line of testing. Increasing the max line length arbitrarily large 'solves' this issue, but that's not really a solution, so I'm working on having ReadJascPaletteLine() detect when it's filled up the line buffer without finding a newline and throw a more verbose error

tools/gbagfx/jasc_pal.c Outdated Show resolved Hide resolved
@sophxm
Copy link
Contributor

sophxm commented May 22, 2023

Thank you, that confirms my current line of testing. Increasing the max line length arbitrarily large 'solves' this issue, but that's not really a solution, so I'm working on having ReadJascPaletteLine() detect when it's filled up the line buffer without finding a newline and throw a more verbose error

Unfortunately sscanf will still happily accept bad input like 123 123 123a (which currently is just silently ignored), or 0 0 0, it's not really designed to ensure an exact match, which is what you generally want for parsing a format.

waterwheels and others added 2 commits May 22, 2023 12:02
Fixed error where `\r` in a windows line-ending palette could fit in line buffer but the following `\n` would exceed it and cause the next line read to be empty. Func now checks what index the first newline char is found at, and if it's greater than the max length - 3 (to account for `\r\n\0`) throws a line too long error.
Added checks to successful line reading of JASC-PAL, version code, and num colours lines. Additionally added a check that the number of colours line is max 3 chars long (excluding `\0`) to make sure we're not just parsing the first colour channel

Co-Authored-By: Sophia <73026338+sophxm@users.noreply.github.com>
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

Successfully merging this pull request may close these issues.

3 participants