summaryrefslogtreecommitdiffstatshomepage
path: root/py/asmarm.h
diff options
context:
space:
mode:
authorCorran Webster <cwebster@unital.dev>2024-11-14 10:15:10 +0000
committerDamien George <damien@micropython.org>2024-11-28 23:08:29 +1100
commit948863c0b8ab4937d11aadf4cbb1b688bf66bf8f (patch)
tree7c91a54e66664434ce6514c323845db26335737a /py/asmarm.h
parent33f50d4f20de3543f81a8404545eeeffb4aebbc0 (diff)
downloadmicropython-948863c0b8ab4937d11aadf4cbb1b688bf66bf8f.tar.gz
micropython-948863c0b8ab4937d11aadf4cbb1b688bf66bf8f.zip
extmod/modframebuf: Fix 0 radius bug in FrameBuffer.ellipse.
This fixes a bug in FrameBuffer.ellipse where it goes into an infinite loop if both radii are 0. This fixes the bug with a simple pre-check to see if both radii are 0, and in that case sets a single pixel at the center. This is consistent with the behaviour of the method when called with just one of the radii set to 0, where it will draw a horizontal or vertical line of 1 pixel width. The pixel is set with setpixel_checked so it should handle out-of-bounds drawing correctly. This fix also includes three new tests: one for the default behaviour, one for drawing out-of-bounds, and one for when the sector mask is 0. Fixes issue #16053. Signed-off-by: Corran Webster <cwebster@unital.dev>
Diffstat (limited to 'py/asmarm.h')
0 files changed, 0 insertions, 0 deletions