|
|
commit 12dccaf711991c574d9654923b271d3d1f905dfe
Author: Matthias Melcher <github@matthiasm.com>
AuthorDate: Thu Nov 24 12:44:08 2022 +0100
Commit: GitHub <noreply@github.com>
CommitDate: Thu Nov 24 12:44:08 2022 +0100
Check boundary conditions in Cocoa scroll code (#554)
src/drivers/Cocoa/Fl_Cocoa_Window_Driver.cxx | 18 +++++++++++-------
1 file changed, 11 insertions(+), 7 deletions(-)
diff --git src/drivers/Cocoa/Fl_Cocoa_Window_Driver.cxx src/drivers/Cocoa/Fl_Cocoa_Window_Driver.cxx
index 2515561..825056e 100644
--- src/drivers/Cocoa/Fl_Cocoa_Window_Driver.cxx
+++ src/drivers/Cocoa/Fl_Cocoa_Window_Driver.cxx
@@ -233,14 +233,18 @@ void Fl_Cocoa_Window_Driver::hide() {
int Fl_Cocoa_Window_Driver::scroll(int src_x, int src_y, int src_w, int src_h, int dest_x, int dest_y, void (*draw_area)(void*, int,int,int,int), void* data)
{
+ if ( (src_x < 0) || (src_y < 0) )
+ return 1;
+ if ( (src_x+src_w > pWindow->w()) || (src_y+src_h > pWindow->h()) )
+ return 1;
CGImageRef img = CGImage_from_window_rect(src_x, src_y, src_w, src_h);
- if (img) {
- // the current surface is generally the display, but is an Fl_Image_Surface when scrolling an Fl_Overlay_Window
- Fl_Quartz_Graphics_Driver *qgd = (Fl_Quartz_Graphics_Driver*)Fl_Surface_Device::surface()->driver();
- float s = qgd->scale();
- qgd->draw_CGImage(img, dest_x, dest_y, lround(s*src_w), lround(s*src_h), 0, 0, src_w, src_h);
- CFRelease(img);
- }
+ if (!img)
+ return 1;
+ // the current surface is generally the display, but is an Fl_Image_Surface when scrolling an Fl_Overlay_Window
+ Fl_Quartz_Graphics_Driver *qgd = (Fl_Quartz_Graphics_Driver*)Fl_Surface_Device::surface()->driver();
+ float s = qgd->scale();
+ qgd->draw_CGImage(img, dest_x, dest_y, lround(s*src_w), lround(s*src_h), 0, 0, src_w, src_h);
+ CFRelease(img);
return 0;
}
[ Direct Link to Message ] | |
|
| |