|   | 3f1fd5ab | 2023-05-23T10:59:03 |  | Updated source to match SDL function prototype style | 
            
              |   | 0479df53 | 2023-01-09T09:48:21 |  | Updated copyright for 2023 | 
            
              |   | 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) | 
            
              |   | f317d619 | 2022-07-01T13:59:14 |  | Xbox GDKX support (#5869)
* Xbox GDK support (14 squashed commits)
* Added basic keyboard testing
* Update readme
* Code review fixes
* Fixed issue where controller add/removal wasn't working (since the device notification events don't work on Xbox, have to use the joystick thread to poll XInput) | 
            
              |   | 120c76c8 | 2022-01-03T09:40:00 |  | Updated copyright for 2022 | 
            
              |   | 99c9727d | 2021-10-23T15:00:31 |  | timer: Added SDL_GetTicks64(), for a timer that doesn't wrap every ~49 days.
Note that this removes the timeGetTime() fallback on Windows; it is a
32-bit counter and SDL2 should never choose to use it, as it only is needed
if QueryPerformanceCounter() isn't available, and QPC is _always_ available
on Windows XP and later.
OS/2 has a similar situation, but since it isn't clear to me that similar
promises can be made about DosTmrQueryTime() even in modern times, I decided
to leave the fallback in, with some heroic measures added to try to provide a
true 64-bit tick counter despite the 49-day wraparound. That approach can
migrate to Windows too, if we discover some truly broken install that doesn't
have QPC and still depends on timeGetTime().
Fixes #4870. | 
            
              |   | 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 | 
            
              |   | de91b124 | 2017-08-14T06:28:21 |  | Fixed bug 3745 - specify SDLCALL as the calling convention for API callbacks
Patches contributed by Ozkan Sezer | 
            
              |   | 45b774e3 | 2017-01-01T18:33:28 |  | Updated copyright for 2017 | 
            
              |   | f31ce3fb | 2016-10-16T22:47:37 |  | Windows: Fixed not removing the always added hint callback on quit.
This was no real problem because SDL_Quit() also calls SDL_ClearHints(). | 
            
              |   | 33af421d | 2016-02-14T21:17:25 |  | Windows: make sure SDL_TicksInit has been called before calling Sleep(ms) in SDL_Delay. This ensures the Windows system timer resolution is properly set before Sleep is called. | 
            
              |   | 42065e78 | 2016-01-02T10:10:34 |  | Updated copyright to 2016 | 
            
              |   | 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 | 
            
              |   | 69f6f646 | 2015-04-20T13:43:24 |  | Cleaned up the macro salsa in the Windows timer code.
- Removed USE_GETTICKCOUNT code; it's never used now.
- Reduced the number of preprocessor checks for WinRT.
- Renamed timeSetPeriod() so it doesn't look like a Win32 API call. | 
            
              |   | 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. | 
            
              |   | 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. | 
            
              |   | e6cca5e9 | 2014-11-15T10:12:36 |  | WinRT: build fix for Visual C++ 2013 Update 4
Visual C++ 2013 Update 4 re-introduced the Sleep() function to WinRT apps (for
code that targets Windows 8.1 and Windows Phone 8.1).  This led to a build
error, as SDL was defining it's own Sleep() function (to make up for the lack
of a public Sleep() function).  The fix makes sure that SDL's custom Sleep()
function is only used when Windows' Sleep() is not available.
Many thanks go out to Sergiu Marian Gaina for the fix! | 
            
              |   | 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 | 
            
              |   | 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. | 
            
              |   | 1367bf87 | 2014-03-09T11:36:47 |  | Integrated David Ludwig's support for Windows RT | 
            
              |   | 05c23063 | 2014-03-09T11:06:11 |  | Fixed line endings on WinRT source code | 
            
              |   | e663b4eb | 2014-03-01T09:50:52 |  | Fixed bug 2423 - timeBeginPeriod & timeEndPeriod mismatch
Coriiander
In src\timer\windows\SDL_systimer.c there is an error with regards to timeBeginPeriod and timeEndPeriod. These functions typically get called when no high resolution timer is available, and GetTickCount is not used.
According to MSDN (link: http://msdn.microsoft.com/en-us/library/windows/desktop/dd757624(v=vs.85).aspx), for every call to timeBeginPeriod a subsequent call to timeEndPeriod is required. While SDL is currently doing this, it fails to call timeEndPeriod when cleaning up/shutting down SDL. Please note that these functions affect things on a system level. Failing to call timeEndPeriod, disables applications for using WINMM-timers after usage&shutdown of SDL, as effectively they the mechanism is now broken.
Solution:
Ensure this code gets called when shutting down the timer subsystem:
#ifndef USE_GETTICKCOUNT
if (!hires_timer_available)
{
    timeSetPeriod(0);
}
#endif | 
            
              |   | 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. | 
            
              |   | 7e1289af | 2013-11-24T23:56:17 |  | Make internal SDL sources include SDL_internal.h instead of SDL_config.h
The new header will include SDL_config.h, but allows for other global stuff. | 
            
              |   | 69c5d21d | 2013-10-27T21:26:46 |  | WinRT: merged with SDL 2.0.1 codebase | 
            
              |   | 7e3b7dbc | 2013-08-17T20:46:34 |  | Patched to compile with Visual Studio. | 
            
              |   | d7817f42 | 2013-08-17T17:04:14 |  | Fixed for consistency with the other platforms | 
            
              |   | e187810e | 2013-08-17T18:07:29 |  | auto init the ticks if the GetTicks and the like methods are called before SDL_Init().. This prevents annoying game bugs such as caching SDL_GetPerformanceFrequency in a static initializer | 
            
              |   | d41fdc94 | 2013-08-13T20:09:52 |  | WinRT: build fixes and additional WinRT-related integrations with SDL 2.0.0 | 
            
              |   | 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. |