-
Notifications
You must be signed in to change notification settings - Fork 126
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
Fix for resource data alignment. #32
Conversation
Wow, thanks! Is there a chance you could add one tiny thing to this PR - one line in AUTHORS with your preferred name and email? I'd love to immediately merge it then ❤️ |
Thank you, I didn't think such a small fix would deserve credits. |
Thank you! Hmmm, interesting: I added some simple test, hoping to try and make merging easier by testing PRs - but the test seems to fail with this PR :( any idea what could be going on? I intended to merge this, but now it doesn't seem so straightforward :( sorry for that :( |
My PR worked with goversioninfo. |
Hm, I searched for where |
I've fixed it, though I am not comfortable enough with the code to say it will work in any case... |
Hello, |
Aligned the icon group too. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I continue to have my breath taken away by amazement at your will to help. Thanks again! All the comments here are fully optional on your side, I'm perfectly OK with tweaking the PR myself if you care enough to put in some cool test case/cases (esp. with unaligned data).
binutil/writer.go
Outdated
@@ -6,6 +6,8 @@ import ( | |||
"reflect" | |||
) | |||
|
|||
var pad [8]byte |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[optional] I'd prefer this to be declared locally only where it's used (i.e. above l.39), if possible, to minimize the context a person reading this codebase has to keep in mind
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Agreed.
@@ -17,6 +17,7 @@ type SizedFile struct { | |||
|
|||
func (r *SizedFile) Read(p []byte) (n int, err error) { return r.s.Read(p) } | |||
func (r *SizedFile) Size() int64 { return r.s.Size() } | |||
func (r *SizedFile) AlignedSize() int64 { return Align(r.s.Size()) } |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[optional] I'm tempted to try introducing just a single helper struct:
struct Aligned { SizedReader }
func (a *Aligned) Padding() []byte {
s := a.Size()
aligned := (s-1)&^7 + 8
pad := [8]byte{}
return pad[aligned-s]
}
and special-casing it where needed (with len(a.Padding())
when just size is needed). Then wrapping any objects that need to be aligned at the place where they're used - instead of adding .AlignedSize() to SizedFile and __GRPICONDIR. I would assume it's the use site that determines if we need to align a particular object, instead of alignment being the object's intrinsic quality. But I'm more than happy to take a stab at this refactoring once you're done with your awesome work and once you've added some tests. I'm thus adding this comment more as a note to myself to not forget about that idea later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, I agree too, my fix is illogical for sure.
I've never taken time to fully understand the code, as I am uncomfortable with its generic nature (and I'm new to Go).
It is still unclear to me where the call site is, so I'd rather let you fix that :)
(should I click on "Resolve conversation" ? I'm new to github too!)
Also, sorry for the tests failing, I forgot to commit |
OK, sorry, I've just understood there was a |
Don't worry too much about my suggestions above now :D honestly, the main thing I'm kinda unsure now if you're still planning to add the tests you mentioned, with some unaligned files maybe? or not? that would be really great if you had some sweet reproducer that fails without your fixes that you could share! :) EDIT: Ah, though I only now just realized, that given the existing tests pass, it should be ok to merge this PR anyway. Sorry that it took me so long 😞 That said, if you'd be able to give some test files/cases, that would be really cool, as it would help us make sure this doesn't break again at some point in the future! |
I'm a little busy at work, I'll try to test this a little more at the end of the week. |
Co-authored-by: Mateusz Czapliński <[email protected]>
Co-authored-by: Mateusz Czapliński <[email protected]>
Co-authored-by: Mateusz Czapliński <[email protected]>
@tc-hib got it, and totally understand. I am also not really sure how to test it well, that's part of my problem with this whole app now, so I don't expect you to do that and magically fix my problems for me 😆 it was honestly just a question, given that you wrote "I will add tests", I got kinda excited 😁 anyway now that I realized I can merge this anyway, I'm gonna merge this anyway, just will try to take a bit more time to refactor it slightly to be more comfortable with that. Hopefully today evening. If not, I'll probably merge it as-is anyway. In the meantime I'm gonna push a somewhat rebased PR to cleanup the history a bit. According to the diffs I did afterwards, it seems to me I didn't lose anything from this PR while rebasing 😅 So, if you manage to find some time at any point to try and wrestle a bit with my problems of testing, that'd be more than awesome 😁 if not, I totally understand it, and for sure am already immensely grateful for your contribution here. |
I forgot to fix the silly formula I used to align: Can you please fix it before merging? Thanks. |
Could you send me the sample icons that produce bugs for you? and also if possible, some link describing what exactly needs to be aligned, if you found one? or did you track it by manually comparing rsrc output with windres output, similar as I did originally? I'm trying to run upx locally as part of the tests, and it does fail for (only) the |
Ehhh, ok, I found your highly informative comments from May... now that took me some time didn't it.... so based on your note that "in resource data entry you should only find offsets that are multiples of 4", I think I'll try to simplify this code to just do that... seems to help in the |
Simpler approach to achieve the main goal of #32. Based esp. on a comment by @tc-hib: > in [resource data entry]( > https://docs.microsoft.com/en-us/windows/win32/debug/pe-format#resource-data-entry) > you should only find offsets that are multiples of 4. (#12 (comment)) HUUUUUUGE THANKS to @tc-hib, for his work with PR #32, for his patience, perseverance and replies, and for the invaluable comment quoted above.
Probably fixes #12 and #26
Resource data has to be aligned, otherwise Windows and other tools might not read them properly.
I checked that with Resource Hacker, UPX and Windows.
windres does align resources too.
People are starting to use my fork, which is wrong because I'd never maintain it, so I'm making this pull request even though I'm not sure my fix is "right". I hope you'll find some time to review and pull it.
Thanks.