-
Notifications
You must be signed in to change notification settings - Fork 161
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
Losslessly optimize out images and documents to save 53MB in the repository #471
base: master
Are you sure you want to change the base?
Conversation
I am not sure how I can review these changes. |
I am a bit nervous merging a PR that affects most of the files on the repository and could have a domino effect on the rest of the project. That said, I can also see the appeal of reducing the repository by 53MB, especially for devices with limited space. I presume there is a way to rollback the Pull Release if we were to merge it and find that people were having issues with the new smaller files. @fpscan or @RobLoach if you could confirm that rollback is a possibility, that would be great. If rollback is not an option, I would propose that this PR be closed and request that @C0rn3j consider submitting a new PR that limits the scope of the next PR to a single theme. For example, if the optimization was limited to If things go well with the single theme, @C0rn3j could submit a larger PR that contained all the themes except Monochrome and see how it goes. That way, the default files for XMB and Ozone would not be touched, leaving most end users with a functioning system. If that went well, a third and final PR with Monochrome could be submitted. Long-term, I'd really like to figure out a way that, as new files or themes are added, that optimization was a part of the process. For years, I have been optimizing my PNGs with ImageOptim, but had never thought about optimizing the SVGs. |
A few things...
|
Thanks @RobLoach for your perspective. The long-term goal is to eliminate PNGs from the repository and require all themes to have 100% SVG source. The PNGs would be created and optimized via script, and that would dramatically reduce the file size of the repository, while also giving priority and flexibility in the build process. For example, a Vita build may only need 64² pixel icons or an 8K output of Lakka could need a 512² or 1024² set. They'd only have to build what they need, instead of getting everything and the kitchen sink as they do in the current paradigm. For more info, please check out #341. @C0rn3j Hopefully these perspectives will help you decide what to do next. We really appreciate you going to the effort to make this PR and would appreciate your help with the repository. |
I have pushed a much smaller PR which runs jpegoptim against the logo file, pdftk decompress/compress on two PDFs and svgo for the handful of the worst SVG files - #472 Repacking TTFs with fontools additionally gets some nice 300KB savings there - #473
I have checked the mentioned xmb-convert.sh and found ANOTHER convert_xmb_assets.sh file which already runs optipng! And so do some other scripts! optipng is practically superseded by oxipng however, so it should be swapped out. I have NOT used --zopfli with oxipng for this PR, which gains considerable further savings at the cost of exponentially increased runtime - for this reason it might be a good idea to keep the exported PNGs in the repository as is the state right now. I will do a --zopfli run for the final PNG changes - it takes a REALLY long time, unfortunately. I have switched all shell scripts to oxipng, added the missing optimization step to xmb-convert.sh and also added --zopfli, which may be a bit controversial, but the space savings are worth it in my opinion. #474 I am not against splitting the work up further if necessary. |
Exact optimization parameters used can be seen here: https://rys.rs/optimization
The worrying changes are in SVGs, which, if other software relies on random metadata within them, need to be checked.
This PR attempts to losslessly optimize over 10K+ files, achieving massive file size savings at hopefully no cost to any compatibility.
All EXIF data in JPEGs/PNGs was retained.
Winner of this optimization PR is a GameCube SVG that went from 9MB to 7KB: