|
| 1 | + |
| 2 | +// library types, functions etc |
| 3 | +typedef unsigned long size_t; |
| 4 | +void *malloc(size_t size); |
| 5 | +void *realloc(void *ptr, size_t size); |
| 6 | +void *calloc(size_t nmemb, size_t size); |
| 7 | +void free(void *ptr); |
| 8 | +wchar_t *wcscpy(wchar_t *s1, const wchar_t *s2); |
| 9 | + |
| 10 | +// --- Semmle tests --- |
| 11 | + |
| 12 | +void tests2() { |
| 13 | + wchar_t *buffer; |
| 14 | + |
| 15 | + buffer = (wchar_t *)malloc(2 * sizeof(wchar_t)); |
| 16 | + wcscpy(buffer, L"1"); // GOOD |
| 17 | + wcscpy(buffer, L"12"); // BAD: buffer overflow |
| 18 | + free(buffer); |
| 19 | + |
| 20 | + buffer = (wchar_t *)malloc(3 * sizeof(wchar_t)); |
| 21 | + wcscpy(buffer, L"12"); // GOOD |
| 22 | + wcscpy(buffer, L"123"); // BAD: buffer overflow |
| 23 | + free(buffer); |
| 24 | + |
| 25 | + buffer = (wchar_t *)realloc(0, 4 * sizeof(wchar_t)); |
| 26 | + wcscpy(buffer, L"123"); // GOOD |
| 27 | + wcscpy(buffer, L"1234"); // BAD: buffer overflow |
| 28 | + |
| 29 | + buffer = (wchar_t *)realloc(buffer, 5 * sizeof(wchar_t)); |
| 30 | + wcscpy(buffer, L"1234"); // GOOD |
| 31 | + wcscpy(buffer, L"12345"); // BAD: buffer overflow |
| 32 | + free(buffer); |
| 33 | + |
| 34 | + buffer = (wchar_t *)calloc(6, sizeof(wchar_t)); |
| 35 | + wcscpy(buffer, L"12345"); // GOOD |
| 36 | + wcscpy(buffer, L"123456"); // BAD: buffer overflow |
| 37 | + free(buffer); |
| 38 | + |
| 39 | + buffer = (wchar_t *)calloc(sizeof(wchar_t), 7); |
| 40 | + wcscpy(buffer, L"123456"); // GOOD |
| 41 | + wcscpy(buffer, L"1234567"); // BAD: buffer overflow |
| 42 | + free(buffer); |
| 43 | + |
| 44 | + buffer = new wchar_t[8]; |
| 45 | + wcscpy(buffer, L"1234567"); // GOOD |
| 46 | + wcscpy(buffer, L"12345678"); // BAD: buffer overflow |
| 47 | + delete [] buffer; |
| 48 | +} |
0 commit comments