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

Gui Overlays not saved in UTF-8 #38

Open
rafajafar opened this issue Oct 31, 2024 · 1 comment
Open

Gui Overlays not saved in UTF-8 #38

rafajafar opened this issue Oct 31, 2024 · 1 comment

Comments

@rafajafar
Copy link

Describe the bug
I just spent an absurd amount of time debugging this. For some reason, when I made a custom CSS for the overlay, no matter what I did, it would come back as chinese characters when viewed in the browser (obs and locally via python server). I could absolutely NOT figure it out. There were no non-UTF8 characters in the file. Going over the code it looked fine and should default to UTF8.

Then I figured it out.

The root files of HitCounterGui.html and javascript.js are both in UTF16 LE BOM encoding. This means the browser is expecting all files to be in that same encoding. Almost no developers will use that encoding by default, especially if coding in english like most are.

Now it's not JUST that. For some reason when I keep the MIT notice on the top of the page, it also came back with encoding issues, despite there being no characters that I could find. I have no idea what's going on with THAT, but if I remove the MIT license (sorry for personal use only though) and I change the encoding on all files to UTF8, my custom CSS is correctly used at UTF8 and doesn't get read as chinese characters on import.

Fix this how you see fit, but it's definitely taken two hours of my life I'll never get back to figure this out.

@topeterk
Copy link
Owner

topeterk commented Nov 3, 2024

As of today there was no other negative feedback about that.

Originally this was by design as this format tends to be more efficient even when file size might be a little more, so I have used that format. https://github.com/topeterk/HitCounterManager/blob/master/.gitattributes
Afaik it also was recommended since then but it seems to have shifted back to UTF-8 for compatibility reasons:
https://learn.microsoft.com/en-us/windows/win32/intl/using-byte-order-marks?redirectedfrom=MSDN

Does your file have any format specified, e.g. beginning with bytes "EF BB BF" for UTF8 encoding?
Then I guess the browser tries to guess the encoding and looks like it chose the wrong one (like assuming the 3rd file from same origin keeps using same format as the other two files)?
Afaik there is no rule in any browser that all files must follow the same enconding as most websites are fetching sources from multiple entities that all have different file encodings.

I am not sure yet but yes, I think I will change it back to UTF-8.

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

2 participants