ApoorvaJ / Papaya

A GPU-powered image editor (in the making)
MIT License
373 stars 33 forks source link

fixed from PVS-Studio #27

Open ip-gpu opened 6 years ago

ip-gpu commented 6 years ago

I'm a member of the Pinguem.ru competition on finding errors in open source projects. A bug, found using PVS-Studio.

As you can see, save dialog returns filename with maximal length equals to MAX_PATH (260). But when you make sprintf it with \n into the buffer, which has 256 length, this may lead to buffer overflow. For example, if you select filename from dialog, which path is 256, 257, 258... characters long. In this case, the program will crashes. I set buffer size to MAX_PATH+2 for maximal path and \n and \0 at the end of the line.

V512 A call of the 'sprintf' function will lead to overflow of the buffer 'buffer'. windows_ui.cpp 110