Page MenuHomePhabricator

Fix some range issues and 32-bit issues with avatar generation
ClosedPublic

Authored by epriestley on Mar 23 2017, 5:48 PM.
Tags
None
Referenced Files
F18826225: D17543.id.diff
Fri, Oct 24, 2:59 AM
F18824658: D17543.diff
Thu, Oct 23, 5:05 PM
F18772136: D17543.id42194.diff
Thu, Oct 9, 12:31 AM
F18751309: D17543.id.diff
Sat, Oct 4, 10:28 AM
F18678710: D17543.diff
Thu, Sep 25, 11:11 PM
F18640013: D17543.diff
Sep 17 2025, 3:12 PM
F18465954: D17543.diff
Sep 2 2025, 8:16 AM
Unknown Object (File)
Jun 16 2025, 6:32 PM
Subscribers
None

Details

Summary

Ref T12444. A few issues:

  • x % (y - z) doesn't generate values in the full range: the largest value is never generated. Instead, use x % (1 + y - z).
  • digestToRange(1, count) never generates 0. After fixing the first bug, it could generate count. The range of the arrays is 0..(count-1), inclusive. Generate the correct range instead.
  • unpack('L', ...) can unpack a negative number on a 32-bit system. Use & 0x7FFFFFFF to mask off the sign bit so the result is always a positive integer.
  • FileFinder might return arbitrary keys, but we rely on sequential keys (0, 1, 2, ...)
Test Plan
  • Used bin/people profileimage ... --force to regenerate images.
  • Added some debugging to verify that the math seemed to be working.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

This revision is now accepted and ready to land.Mar 23 2017, 5:50 PM

Like 3/4ths of these were my fault, sorry I am so bad at math.

This revision was automatically updated to reflect the committed changes.