|   | 0d763800 | 2023-03-09T15:10:00 |  | Code style: changed "sizeof foo" to "sizeof(foo)" (thanks @sezero!)
(cherry picked from commit c6443d86c92e962683a1efe5f123a144988875b5) | 
            
              |   | 0479df53 | 2023-01-09T09:48:21 |  | Updated copyright for 2023 | 
            
              |   | d0bbfdbf | 2022-12-01T16:07:03 |  | Clang-Tidy fixes (#6725)
(cherry picked from commit 3c501b963dd8f0605a6ce7978882df39ba76f9cd) | 
            
              |   | b8d85c69 | 2022-11-30T12:51:59 |  | Update for SDL3 coding style (#6717)
I updated .clang-format and ran clang-format 14 over the src and test directories to standardize the code base.
In general I let clang-format have it's way, and added markup to prevent formatting of code that would break or be completely unreadable if formatted.
The script I ran for the src directory is added as build-scripts/clang-format-src.sh
This fixes:
#6592
#6593
#6594
(cherry picked from commit 5750bcb174300011b91d1de20edb288fcca70f8c) | 
            
              |   | fb0ce375 | 2022-11-27T17:38:43 |  | Cleanup add brace (#6545)
* Add braces after if conditions
* More add braces after if conditions
* Add braces after while() conditions
* Fix compilation because of macro being modified
* Add braces to for loop
* Add braces after if/goto
* Move comments up
* Remove extra () in the 'return ...;' statements
* More remove extra () in the 'return ...;' statements
* More remove extra () in the 'return ...;' statements after merge
* Fix inconsistent patterns are xxx == NULL vs !xxx
* More "{}" for "if() break;"  and "if() continue;"
* More "{}" after if() short statement
* More "{}" after "if () return;" statement
* More fix inconsistent patterns are xxx == NULL vs !xxx
* Revert some modificaion on SDL_RLEaccel.c
* SDL_RLEaccel: no short statement
* Cleanup 'if' where the bracket is in a new line
* Cleanup 'while' where the bracket is in a new line
* Cleanup 'for' where the bracket is in a new line
* Cleanup 'else' where the bracket is in a new line
(cherry picked from commit 6a2200823c66e53bd3cda4a25f0206b834392652 to reduce conflicts merging between SDL2 and SDL3) | 
            
              |   | 345efdcb | 2022-06-03T08:46:08 |  | Wait for all the threads to actually finish before exiting
Fixes https://github.com/libsdl-org/SDL/issues/5748 | 
            
              |   | 40bef98f | 2022-05-04T19:16:01 |  | test: Add a mode to skip tests that involve arbitrary delays
This can be used as a quick acceptance test for CI workflows.
Signed-off-by: Simon McVittie <smcv@collabora.com> | 
            
              |   | 120c76c8 | 2022-01-03T09:40:00 |  | Updated copyright for 2022 | 
            
              |   | 990fb668 | 2021-11-20T01:02:02 |  | tests: several -Wwrite-strings fixes. | 
            
              |   | 9130f7c3 | 2021-01-02T10:25:38 |  | Updated copyright for 2021 | 
            
              |   | 2b040ceb | 2020-12-23T13:36:23 |  | Atomic test: Fix use after free
SDL_SemPost() was called by the FIFO threads after the semaphore was
freed because the main thread actually synchronized on the
`writerRunning`/`readersRunning` count and not the semaphores itself. | 
            
              |   | b064028c | 2020-12-24T00:25:40 |  | testatomic.c: fix warnings due to SDL_AtomicDecRef() use | 
            
              |   | a8780c6a | 2020-01-16T20:49:25 |  | Updated copyright date for 2020 | 
            
              |   | 4953e050 | 2019-07-31T05:11:40 |  | use SDL_zeroa at more places where the argument is an array. | 
            
              |   | 5e13087b | 2019-01-04T22:01:14 |  | Updated copyright for 2019 | 
            
              |   | e3cc5b2c | 2018-01-03T10:03:25 |  | Updated copyright for 2018 | 
            
              |   | ae667da6 | 2017-08-29T15:52:49 |  | Fixed a bunch of compiler warnings. | 
            
              |   | ca5c3048 | 2017-08-13T21:06:52 |  | Fixed bug 3744 - missing SDLCALL in several functions
Ozkan Sezer
The attached patch adds missing SDLCALL to several functions, so that
they properly match the headers as intended. | 
            
              |   | 45b774e3 | 2017-01-01T18:33:28 |  | Updated copyright for 2017 | 
            
              |   | 68d7be39 | 2016-12-06T00:40:09 |  | Fixed bug 3508 - variably modified ?SDL_dummy_size? at file scope in test/testatomic.c
Ciro Santilli
GCC 6, Ubuntu 16.10, cd test; ./configure; make
/bin/sh config.status Makefile
config.status: creating Makefile
gcc -o loopwave loopwave.c -g -O2 -D_REENTRANT -I/usr/include/SDL2 -DHAVE_OPENGLES2 -DHAVE_OPENGL -DHAVE_SDL_TTF -g -lSDL2_test -lSDL2
gcc -o testatomic testatomic.c -g -O2 -D_REENTRANT -I/usr/include/SDL2 -DHAVE_OPENGLES2 -DHAVE_OPENGL -DHAVE_SDL_TTF -g -lSDL2_test -lSDL2
In file included from /usr/include/SDL2/SDL_main.h:25:0,
                 from /usr/include/SDL2/SDL.h:32,
                 from testatomic.c:14:
/usr/include/SDL2/SDL_stdinc.h:261:20: error: variably modified ?SDL_dummy_size? at file scope
        typedef int SDL_dummy_ ## name[(x) * 2 - 1]
                    ^
testatomic.c:106:1: note: in expansion of macro ?SDL_COMPILE_TIME_ASSERT?
 SDL_COMPILE_TIME_ASSERT(size, CountTo>0); /* check for rollover */
 ^~~~~~~~~~~~~~~~~~~~~~~
Makefile:114: recipe for target 'testatomic' failed
make: *** [testatomic] Error 1
If I remove the line SDL_COMPILE_TIME_ASSERT(size, CountTo>0); /* check for rollover */ it works, lazy to figure out the best way to do this. | 
            
              |   | fa8c83c1 | 2016-01-03T06:50:50 |  | Remove almost all instances of "volatile" keyword.
As Tiffany pointed out in Bugzilla, volatile is not useful for thread safety:
https://software.intel.com/en-us/blogs/2007/11/30/volatile-almost-useless-for-multi-threaded-programming/
Some of these volatiles didn't need to be, some were otherwise protected by
spinlocks or mutexes, and some got moved over to SDL_atomic_t data, etc.
Fixes Bugzilla #3220. | 
            
              |   | 42065e78 | 2016-01-02T10:10:34 |  | Updated copyright to 2016 | 
            
              |   | 11d98995 | 2015-11-25T21:39:28 |  | Replaced tabs with spaces in test programs. | 
            
              |   | 0e45984f | 2015-06-21T17:33:46 |  | Fixed crash if initialization of EGL failed but was tried again later.
The internal function SDL_EGL_LoadLibrary() did not delete and remove a mostly
uninitialized data structure if loading the library first failed. A later try to
use EGL then skipped initialization and assumed it was previously successful
because the data structure now already existed. This led to at least one crash
in the internal function SDL_EGL_ChooseConfig() because a NULL pointer was
dereferenced to make a call to eglBindAPI(). | 
            
              |   | 2c4a6ea0 | 2015-05-26T06:27:46 |  | Updated the copyright year to 2015 | 
            
              |   | b72938c8 | 2015-04-20T12:22:44 |  | Windows: Always set the system timer resolution to 1ms by default.
An existing hint lets apps that don't need the timer resolution changed avoid
this, to save battery, etc, but this fixes several problems in timing, audio
callbacks not firing fast enough, etc.
Fixes Bugzilla #2944. | 
            
              |   | fe6c797c | 2015-04-10T23:30:31 |  | Fixed an iOS view orientation issue when SDL_GL_CreateContext or SDL_CreateRenderer is called. | 
            
              |   | f9adb453 | 2015-02-18T21:31:21 |  | Removed redundant include statements from test programs.
The needed header files are already included with SDL.h. Still including them in
the test programs is confusing because it somehow suggests they would be needed. | 
            
              |   | b88ca1b4 | 2015-02-10T16:28:56 |  | the last parameter of XChangeProperty is the number of elements.. and when the element format is 32.. the element is "long" so we have 5 long elements here.
Yes this seems confusing as on mac+linux Long is either 32 or 64bits depending on the architecture, but this is how the X11 protocol is defined. Thus 5 is the correct value for the nelts here.  Not 5 or 10 depending on the architecture.
More info on the confusion https://bugs.freedesktop.org/show_bug.cgi?id=16802 | 
            
              |   | b48e54aa | 2015-01-26T22:00:29 |  | Fixed bug 2802 - [patch] Fix android build compiling in wrong filesystem implementation
Jonas Kulla
The configure script didn't differentiate between Linux and Android, unconditionally compiling in the unix implementation of SDL_sysfilesystem.c.
I'm probably one of the very few people building SDL for android using classic configure + standalone toolchain, so this has gone undetected all along. | 
            
              |   | 70438be2 | 2014-12-03T10:55:23 |  | WinRT: fixed bug whereby SDL would override an app's default orientation
WinRT apps can set a default, preferred orientation via a .appxmanifest file.
SDL was overriding this on app startup, and making the app use all possible
orientations (landscape and portrait).
Thanks to Eric Wing for the heads up on this! | 
            
              |   | 9c398852 | 2014-11-22T22:20:40 |  | Corrected header file documentation comment. | 
            
              |   | 24c86b55 | 2014-09-11T19:24:42 |  | [X11] Reconcile logical keyboard state with physical state on FocusIn
since the window system doesn't do it for us like other platforms.
This prevents sticky keys and missed keys when going in and out
of focus, for example Alt would appear to stick if switching away
from an SDL app with Alt-Tab and had to be pressed again.
CR: Sam | 
            
              |   | de1b22e7 | 2014-07-07T10:39:02 |  | Fixed compiler warning | 
            
              |   | 0ddd252f | 2014-06-07T17:25:56 |  | Fixed initializing test event queue | 
            
              |   | 3dcb451f | 2014-04-09T21:29:19 |  | Added a README file regarding WinRT support
To note, this file is currently formatted with CRLF line endings, rather than
LF, to allow the file to be viewed with Notepad. | 
            
              |   | 58edac3e | 2014-02-02T00:53:27 |  | Fixed bug 2374 - Update copyright for 2014...
Is it that time already?? | 
            
              |   | f848adff | 2013-11-29T10:06:08 |  | Improve Android pause/resume behavior. | 
            
              |   | 65728477 | 2013-08-14T23:30:10 |  | Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency | 
            
              |   | dad42067 | 2013-08-12T11:13:50 |  | Fixes #2022, do not resume on Android when surfaceChanged
If the app is in landscape mode and the user presses the power button, a pause
is followed immediately by a surfaceChanged event because the lock screen
is shown in portrait mode. This triggers a "false" resume.
So, we just pause and resume following the onWindowFocusChanged events.
Also, wait for SDL_APP_WILLENTERBACKGROUND and SDL_APP_DIDENTERBACKGROUND before
blocking the event pump. | 
            
              |   | 1ad936eb | 2013-08-11T19:56:43 |  | Fixed bug 2027 - Full-screen appears to be broken - hang in SDL_DestroyWindow()
Rainer Deyke
I'm running Linux Mint 15 with the Cinnamon window manager.  SDL_DestroyWindow consistently locks up for me when the window if fullscreen. |