|   | 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) | 
            
              |   | 76a7b629 | 2022-04-12T13:07:18 |  | test: Add some common code to load test resources
As well as reducing duplication, this lets the tests load their resources
from the SDL_GetBasePath() on platforms that support it, which is useful
if the tests are compiled along with the rest of SDL and installed below
/usr as manual tests, similar to GNOME's installed-tests convention.
Thanks to Ozkan Sezer for the OS/2 build glue.
Co-authored-by: Ozkan Sezer <sezeroz@gmail.com>
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. | 
            
              |   | 570768f6 | 2021-03-26T22:52:30 |  | test: fix shadowing variables | 
            
              |   | 9130f7c3 | 2021-01-02T10:25:38 |  | Updated copyright for 2021 | 
            
              |   | a8780c6a | 2020-01-16T20:49:25 |  | Updated copyright date for 2020 | 
            
              |   | 5e13087b | 2019-01-04T22:01:14 |  | Updated copyright for 2019 | 
            
              |   | e3cc5b2c | 2018-01-03T10:03:25 |  | Updated copyright for 2018 | 
            
              |   | 45b774e3 | 2017-01-01T18:33:28 |  | Updated copyright for 2017 | 
            
              |   | 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. | 
            
              |   | 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. | 
            
              |   | 97e87667 | 2014-12-25T21:42:56 |  | Fixed compile errors in example programs. | 
            
              |   | fe40a172 | 2014-12-18T00:19:52 |  | Initial merge of Emscripten port!
With this commit, you can compile SDL2 with Emscripten
( http://emscripten.org/ ), and make your SDL-based C/C++ program
into a web app.
This port was due to the efforts of several people, including: Charlie Birks,
Sathyanarayanan Gunasekaran, Jukka Jyl?nki, Alon Zakai, Edward Rudd,
Bruce Mitchener, and Martin Gerhardy. (Thanks, everyone!) | 
            
              |   | 45fa5642 | 2014-12-10T21:10:55 |  | Added comments in example program. | 
            
              |   | 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. | 
            
              |   | 4544343b | 2014-09-17T11:41:12 |  | [Android] Fixes #2480, music does not pause when process backgrounded
This modifies SDL_PauseAudio behavior to pause all audio devices instead of
just the default one (required on Android, at least for testmultiaudio on my
Nexus 4 which reported 2 audio devices).
It also changes SDL_PauseAudioDevice to retain the device lock from pause until
resume in order to save battery in mobile devices. | 
            
              |   | 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 | 
            
              |   | efa2d058 | 2014-06-08T18:18:13 |  | Fixes audio for Native Client, and other fixes...
- SDL_NaClMount, SDL_NaClUmount
- Default mounting of https at / in SDL's main function
- More documentation in README-nacl.txt | 
            
              |   | 93aabd32 | 2014-06-06T18:33:17 |  | Adds missing Makefile for NACL test and a couple of smaller fixes | 
            
              |   | 8d11db2f | 2014-05-29T22:48:10 |  | Added missing stdio include in test program. | 
            
              |   | 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. |