mirror of https://github.com/encounter/SDL.git
Fix bug 2034: replace printf by SDL_Log in tests; update loopwave VS solution: copy missing dependency
This commit is contained in:
parent
67367be019
commit
65728477af
|
@ -1,4 +1,4 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
<ItemGroup Label="ProjectConfigurations">
|
<ItemGroup Label="ProjectConfigurations">
|
||||||
<ProjectConfiguration Include="Debug|Win32">
|
<ProjectConfiguration Include="Debug|Win32">
|
||||||
|
@ -105,7 +105,8 @@
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
</Link>
|
</Link>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"</Command>
|
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"
|
||||||
|
copy "$(SolutionDir)\..\test\sample.wav" "$(TargetDir)\sample.wav"</Command>
|
||||||
</PostBuildEvent>
|
</PostBuildEvent>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Message>Copy SDL</Message>
|
<Message>Copy SDL</Message>
|
||||||
|
@ -139,7 +140,8 @@
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
</Link>
|
</Link>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"</Command>
|
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"
|
||||||
|
copy "$(SolutionDir)\..\test\sample.wav" "$(TargetDir)\sample.wav"</Command>
|
||||||
</PostBuildEvent>
|
</PostBuildEvent>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Message>Copy SDL</Message>
|
<Message>Copy SDL</Message>
|
||||||
|
@ -174,7 +176,8 @@
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
</Link>
|
</Link>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"</Command>
|
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"
|
||||||
|
copy "$(SolutionDir)\..\test\sample.wav" "$(TargetDir)\sample.wav"</Command>
|
||||||
</PostBuildEvent>
|
</PostBuildEvent>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Message>Copy SDL</Message>
|
<Message>Copy SDL</Message>
|
||||||
|
@ -208,7 +211,8 @@
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
</Link>
|
</Link>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"</Command>
|
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"
|
||||||
|
copy "$(SolutionDir)\..\test\sample.wav" "$(TargetDir)\sample.wav"</Command>
|
||||||
</PostBuildEvent>
|
</PostBuildEvent>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Message>Copy SDL</Message>
|
<Message>Copy SDL</Message>
|
||||||
|
|
|
@ -109,7 +109,8 @@
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
</Link>
|
</Link>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"</Command>
|
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"
|
||||||
|
copy "$(SolutionDir)\..\test\sample.wav" "$(TargetDir)\sample.wav"</Command>
|
||||||
</PostBuildEvent>
|
</PostBuildEvent>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Message>Copy SDL</Message>
|
<Message>Copy SDL</Message>
|
||||||
|
@ -143,7 +144,8 @@
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
</Link>
|
</Link>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"</Command>
|
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"
|
||||||
|
copy "$(SolutionDir)\..\test\sample.wav" "$(TargetDir)\sample.wav"</Command>
|
||||||
</PostBuildEvent>
|
</PostBuildEvent>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Message>Copy SDL</Message>
|
<Message>Copy SDL</Message>
|
||||||
|
@ -178,7 +180,8 @@
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
</Link>
|
</Link>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"</Command>
|
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"
|
||||||
|
copy "$(SolutionDir)\..\test\sample.wav" "$(TargetDir)\sample.wav"</Command>
|
||||||
</PostBuildEvent>
|
</PostBuildEvent>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Message>Copy SDL</Message>
|
<Message>Copy SDL</Message>
|
||||||
|
@ -212,7 +215,8 @@
|
||||||
<SubSystem>Windows</SubSystem>
|
<SubSystem>Windows</SubSystem>
|
||||||
</Link>
|
</Link>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"</Command>
|
<Command>copy "$(SolutionDir)\SDL\$(Platform)\$(Configuration)\SDL2.dll" "$(TargetDir)\SDL2.dll"
|
||||||
|
copy "$(SolutionDir)\..\test\sample.wav" "$(TargetDir)\sample.wav"</Command>
|
||||||
</PostBuildEvent>
|
</PostBuildEvent>
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
<Message>Copy SDL</Message>
|
<Message>Copy SDL</Message>
|
||||||
|
|
|
@ -117,13 +117,13 @@ PrintKey(SDL_Keysym * sym, SDL_bool pressed, SDL_bool repeat)
|
||||||
static void
|
static void
|
||||||
PrintText(char *text)
|
PrintText(char *text)
|
||||||
{
|
{
|
||||||
unsigned char *spot, expanded[1024];
|
char *spot, expanded[1024];
|
||||||
|
|
||||||
expanded[0] = '\0';
|
expanded[0] = '\0';
|
||||||
for ( spot = text; *spot; ++spot )
|
for ( spot = text; *spot; ++spot )
|
||||||
{
|
{
|
||||||
size_t length = SDL_strlen(expanded);
|
size_t length = SDL_strlen(expanded);
|
||||||
SDL_snprintf(expanded + length, sizeof(expanded) - length, "\\x%.2x", *spot);
|
SDL_snprintf(expanded + length, sizeof(expanded) - length, "\\x%.2x", (unsigned char)*spot);
|
||||||
}
|
}
|
||||||
SDL_Log("Text (%s): \"%s%s\"\n", expanded, *text == '"' ? "\\" : "", text);
|
SDL_Log("Text (%s): \"%s%s\"\n", expanded, *text == '"' ? "\\" : "", text);
|
||||||
}
|
}
|
||||||
|
@ -135,9 +135,12 @@ main(int argc, char *argv[])
|
||||||
SDL_Event event;
|
SDL_Event event;
|
||||||
int done;
|
int done;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Initialize SDL */
|
/* Initialize SDL */
|
||||||
if (SDL_Init(SDL_INIT_VIDEO) < 0) {
|
if (SDL_Init(SDL_INIT_VIDEO) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -146,7 +149,7 @@ main(int argc, char *argv[])
|
||||||
SDL_WINDOWPOS_CENTERED, SDL_WINDOWPOS_CENTERED,
|
SDL_WINDOWPOS_CENTERED, SDL_WINDOWPOS_CENTERED,
|
||||||
640, 480, 0);
|
640, 480, 0);
|
||||||
if (!window) {
|
if (!window) {
|
||||||
fprintf(stderr, "Couldn't create 640x480 window: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create 640x480 window: %s\n",
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
quit(2);
|
quit(2);
|
||||||
}
|
}
|
||||||
|
@ -166,7 +169,7 @@ main(int argc, char *argv[])
|
||||||
switch (event.type) {
|
switch (event.type) {
|
||||||
case SDL_KEYDOWN:
|
case SDL_KEYDOWN:
|
||||||
case SDL_KEYUP:
|
case SDL_KEYUP:
|
||||||
PrintKey(&event.key.keysym, event.key.state, event.key.repeat);
|
PrintKey(&event.key.keysym, (event.key.state == SDL_PRESSED) ? SDL_TRUE : SDL_FALSE, (event.key.repeat) ? SDL_TRUE : SDL_FALSE);
|
||||||
break;
|
break;
|
||||||
case SDL_TEXTINPUT:
|
case SDL_TEXTINPUT:
|
||||||
PrintText(event.text.text);
|
PrintText(event.text.text);
|
||||||
|
|
|
@ -80,9 +80,12 @@ main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Load the SDL library */
|
/* Load the SDL library */
|
||||||
if (SDL_Init(SDL_INIT_AUDIO) < 0) {
|
if (SDL_Init(SDL_INIT_AUDIO) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -91,7 +94,7 @@ main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
/* Load the wave file into memory */
|
/* Load the wave file into memory */
|
||||||
if (SDL_LoadWAV(argv[1], &wave.spec, &wave.sound, &wave.soundlen) == NULL) {
|
if (SDL_LoadWAV(argv[1], &wave.spec, &wave.sound, &wave.soundlen) == NULL) {
|
||||||
fprintf(stderr, "Couldn't load %s: %s\n", argv[1], SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't load %s: %s\n", argv[1], SDL_GetError());
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -109,24 +112,19 @@ main(int argc, char *argv[])
|
||||||
#endif /* HAVE_SIGNAL_H */
|
#endif /* HAVE_SIGNAL_H */
|
||||||
|
|
||||||
/* Show the list of available drivers */
|
/* Show the list of available drivers */
|
||||||
printf("Available audio drivers: ");
|
SDL_Log("Available audio drivers:");
|
||||||
for (i = 0; i < SDL_GetNumAudioDrivers(); ++i) {
|
for (i = 0; i < SDL_GetNumAudioDrivers(); ++i) {
|
||||||
if (i == 0) {
|
SDL_Log("%i: %s", i, SDL_GetAudioDriver(i));
|
||||||
printf("%s", SDL_GetAudioDriver(i));
|
|
||||||
} else {
|
|
||||||
printf(", %s", SDL_GetAudioDriver(i));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
printf("\n");
|
|
||||||
|
|
||||||
/* Initialize fillerup() variables */
|
/* Initialize fillerup() variables */
|
||||||
if (SDL_OpenAudio(&wave.spec, NULL) < 0) {
|
if (SDL_OpenAudio(&wave.spec, NULL) < 0) {
|
||||||
fprintf(stderr, "Couldn't open audio: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't open audio: %s\n", SDL_GetError());
|
||||||
SDL_FreeWAV(wave.sound);
|
SDL_FreeWAV(wave.sound);
|
||||||
quit(2);
|
quit(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("Using audio driver: %s\n", SDL_GetCurrentAudioDriver());
|
SDL_Log("Using audio driver: %s\n", SDL_GetCurrentAudioDriver());
|
||||||
|
|
||||||
/* Let the audio run */
|
/* Let the audio run */
|
||||||
SDL_PauseAudio(0);
|
SDL_PauseAudio(0);
|
||||||
|
|
|
@ -45,39 +45,39 @@ void RunBasicTest()
|
||||||
SDL_atomic_t v;
|
SDL_atomic_t v;
|
||||||
SDL_bool tfret = SDL_FALSE;
|
SDL_bool tfret = SDL_FALSE;
|
||||||
|
|
||||||
printf("\nspin lock---------------------------------------\n\n");
|
SDL_Log("\nspin lock---------------------------------------\n\n");
|
||||||
|
|
||||||
SDL_AtomicLock(&lock);
|
SDL_AtomicLock(&lock);
|
||||||
printf("AtomicLock lock=%d\n", lock);
|
SDL_Log("AtomicLock lock=%d\n", lock);
|
||||||
SDL_AtomicUnlock(&lock);
|
SDL_AtomicUnlock(&lock);
|
||||||
printf("AtomicUnlock lock=%d\n", lock);
|
SDL_Log("AtomicUnlock lock=%d\n", lock);
|
||||||
|
|
||||||
printf("\natomic -----------------------------------------\n\n");
|
SDL_Log("\natomic -----------------------------------------\n\n");
|
||||||
|
|
||||||
SDL_AtomicSet(&v, 0);
|
SDL_AtomicSet(&v, 0);
|
||||||
tfret = SDL_AtomicSet(&v, 10) == 0;
|
tfret = SDL_AtomicSet(&v, 10) == 0 ? SDL_TRUE : SDL_FALSE;
|
||||||
printf("AtomicSet(10) tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
SDL_Log("AtomicSet(10) tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
||||||
tfret = SDL_AtomicAdd(&v, 10) == 10;
|
tfret = SDL_AtomicAdd(&v, 10) == 10 ? SDL_TRUE : SDL_FALSE;
|
||||||
printf("AtomicAdd(10) tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
SDL_Log("AtomicAdd(10) tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
||||||
|
|
||||||
SDL_AtomicSet(&v, 0);
|
SDL_AtomicSet(&v, 0);
|
||||||
SDL_AtomicIncRef(&v);
|
SDL_AtomicIncRef(&v);
|
||||||
tfret = (SDL_AtomicGet(&v) == 1);
|
tfret = (SDL_AtomicGet(&v) == 1) ? SDL_TRUE : SDL_FALSE;
|
||||||
printf("AtomicIncRef() tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
SDL_Log("AtomicIncRef() tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
||||||
SDL_AtomicIncRef(&v);
|
SDL_AtomicIncRef(&v);
|
||||||
tfret = (SDL_AtomicGet(&v) == 2);
|
tfret = (SDL_AtomicGet(&v) == 2) ? SDL_TRUE : SDL_FALSE;
|
||||||
printf("AtomicIncRef() tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
SDL_Log("AtomicIncRef() tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
||||||
tfret = (SDL_AtomicDecRef(&v) == SDL_FALSE);
|
tfret = (SDL_AtomicDecRef(&v) == SDL_FALSE) ? SDL_TRUE : SDL_FALSE;
|
||||||
printf("AtomicDecRef() tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
SDL_Log("AtomicDecRef() tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
||||||
tfret = (SDL_AtomicDecRef(&v) == SDL_TRUE);
|
tfret = (SDL_AtomicDecRef(&v) == SDL_TRUE) ? SDL_TRUE : SDL_FALSE;
|
||||||
printf("AtomicDecRef() tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
SDL_Log("AtomicDecRef() tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
||||||
|
|
||||||
SDL_AtomicSet(&v, 10);
|
SDL_AtomicSet(&v, 10);
|
||||||
tfret = (SDL_AtomicCAS(&v, 0, 20) == SDL_FALSE);
|
tfret = (SDL_AtomicCAS(&v, 0, 20) == SDL_FALSE) ? SDL_TRUE : SDL_FALSE;
|
||||||
printf("AtomicCAS() tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
SDL_Log("AtomicCAS() tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
||||||
value = SDL_AtomicGet(&v);
|
value = SDL_AtomicGet(&v);
|
||||||
tfret = (SDL_AtomicCAS(&v, value, 20) == SDL_TRUE);
|
tfret = (SDL_AtomicCAS(&v, value, 20) == SDL_TRUE) ? SDL_TRUE : SDL_FALSE;
|
||||||
printf("AtomicCAS() tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
SDL_Log("AtomicCAS() tfret=%s val=%d\n", tf(tfret), SDL_AtomicGet(&v));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**************************************************************************/
|
/**************************************************************************/
|
||||||
|
@ -120,7 +120,7 @@ static
|
||||||
int adder(void* junk)
|
int adder(void* junk)
|
||||||
{
|
{
|
||||||
unsigned long N=NInter;
|
unsigned long N=NInter;
|
||||||
printf("Thread subtracting %d %lu times\n",CountInc,N);
|
SDL_Log("Thread subtracting %d %lu times\n",CountInc,N);
|
||||||
while (N--) {
|
while (N--) {
|
||||||
SDL_AtomicAdd(&good, -CountInc);
|
SDL_AtomicAdd(&good, -CountInc);
|
||||||
bad-=CountInc;
|
bad-=CountInc;
|
||||||
|
@ -152,7 +152,7 @@ void runAdder(void)
|
||||||
|
|
||||||
end = SDL_GetTicks();
|
end = SDL_GetTicks();
|
||||||
|
|
||||||
printf("Finished in %f sec\n", (end - start) / 1000.f);
|
SDL_Log("Finished in %f sec\n", (end - start) / 1000.f);
|
||||||
}
|
}
|
||||||
|
|
||||||
static
|
static
|
||||||
|
@ -161,28 +161,28 @@ void RunEpicTest()
|
||||||
int b;
|
int b;
|
||||||
atomicValue v;
|
atomicValue v;
|
||||||
|
|
||||||
printf("\nepic test---------------------------------------\n\n");
|
SDL_Log("\nepic test---------------------------------------\n\n");
|
||||||
|
|
||||||
printf("Size asserted to be >= 32-bit\n");
|
SDL_Log("Size asserted to be >= 32-bit\n");
|
||||||
SDL_assert(sizeof(atomicValue)>=4);
|
SDL_assert(sizeof(atomicValue)>=4);
|
||||||
|
|
||||||
printf("Check static initializer\n");
|
SDL_Log("Check static initializer\n");
|
||||||
v=SDL_AtomicGet(&good);
|
v=SDL_AtomicGet(&good);
|
||||||
SDL_assert(v==42);
|
SDL_assert(v==42);
|
||||||
|
|
||||||
SDL_assert(bad==42);
|
SDL_assert(bad==42);
|
||||||
|
|
||||||
printf("Test negative values\n");
|
SDL_Log("Test negative values\n");
|
||||||
SDL_AtomicSet(&good, -5);
|
SDL_AtomicSet(&good, -5);
|
||||||
v=SDL_AtomicGet(&good);
|
v=SDL_AtomicGet(&good);
|
||||||
SDL_assert(v==-5);
|
SDL_assert(v==-5);
|
||||||
|
|
||||||
printf("Verify maximum value\n");
|
SDL_Log("Verify maximum value\n");
|
||||||
SDL_AtomicSet(&good, CountTo);
|
SDL_AtomicSet(&good, CountTo);
|
||||||
v=SDL_AtomicGet(&good);
|
v=SDL_AtomicGet(&good);
|
||||||
SDL_assert(v==CountTo);
|
SDL_assert(v==CountTo);
|
||||||
|
|
||||||
printf("Test compare and exchange\n");
|
SDL_Log("Test compare and exchange\n");
|
||||||
|
|
||||||
b=SDL_AtomicCAS(&good, 500, 43);
|
b=SDL_AtomicCAS(&good, 500, 43);
|
||||||
SDL_assert(!b); /* no swap since CountTo!=500 */
|
SDL_assert(!b); /* no swap since CountTo!=500 */
|
||||||
|
@ -194,7 +194,7 @@ void RunEpicTest()
|
||||||
v=SDL_AtomicGet(&good);
|
v=SDL_AtomicGet(&good);
|
||||||
SDL_assert(v==44);
|
SDL_assert(v==44);
|
||||||
|
|
||||||
printf("Test Add\n");
|
SDL_Log("Test Add\n");
|
||||||
|
|
||||||
v=SDL_AtomicAdd(&good, 1);
|
v=SDL_AtomicAdd(&good, 1);
|
||||||
SDL_assert(v==44);
|
SDL_assert(v==44);
|
||||||
|
@ -206,7 +206,7 @@ void RunEpicTest()
|
||||||
v=SDL_AtomicGet(&good);
|
v=SDL_AtomicGet(&good);
|
||||||
SDL_assert(v==55);
|
SDL_assert(v==55);
|
||||||
|
|
||||||
printf("Test Add (Negative values)\n");
|
SDL_Log("Test Add (Negative values)\n");
|
||||||
|
|
||||||
v=SDL_AtomicAdd(&good, -20);
|
v=SDL_AtomicAdd(&good, -20);
|
||||||
SDL_assert(v==55);
|
SDL_assert(v==55);
|
||||||
|
@ -223,7 +223,7 @@ void RunEpicTest()
|
||||||
v=SDL_AtomicGet(&good);
|
v=SDL_AtomicGet(&good);
|
||||||
SDL_assert(v==15);
|
SDL_assert(v==15);
|
||||||
|
|
||||||
printf("Reset before count down test\n");
|
SDL_Log("Reset before count down test\n");
|
||||||
SDL_AtomicSet(&good, CountTo);
|
SDL_AtomicSet(&good, CountTo);
|
||||||
v=SDL_AtomicGet(&good);
|
v=SDL_AtomicGet(&good);
|
||||||
SDL_assert(v==CountTo);
|
SDL_assert(v==CountTo);
|
||||||
|
@ -231,11 +231,11 @@ void RunEpicTest()
|
||||||
bad=CountTo;
|
bad=CountTo;
|
||||||
SDL_assert(bad==CountTo);
|
SDL_assert(bad==CountTo);
|
||||||
|
|
||||||
printf("Counting down from %d, Expect %d remaining\n",CountTo,Expect);
|
SDL_Log("Counting down from %d, Expect %d remaining\n",CountTo,Expect);
|
||||||
runAdder();
|
runAdder();
|
||||||
|
|
||||||
v=SDL_AtomicGet(&good);
|
v=SDL_AtomicGet(&good);
|
||||||
printf("Atomic %d Non-Atomic %d\n",v,bad);
|
SDL_Log("Atomic %d Non-Atomic %d\n",v,bad);
|
||||||
SDL_assert(v==Expect);
|
SDL_assert(v==Expect);
|
||||||
SDL_assert(bad!=Expect);
|
SDL_assert(bad!=Expect);
|
||||||
}
|
}
|
||||||
|
@ -429,7 +429,7 @@ static SDL_bool EnqueueEvent_Mutex(SDL_EventQueue *queue, const SDL_Event *event
|
||||||
} else if (delta < 0) {
|
} else if (delta < 0) {
|
||||||
/* We ran into an old queue entry, which means it still needs to be dequeued */
|
/* We ran into an old queue entry, which means it still needs to be dequeued */
|
||||||
} else {
|
} else {
|
||||||
printf("ERROR: mutex failed!\n");
|
SDL_Log("ERROR: mutex failed!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_UnlockMutex(queue->mutex);
|
SDL_UnlockMutex(queue->mutex);
|
||||||
|
@ -462,7 +462,7 @@ static SDL_bool DequeueEvent_Mutex(SDL_EventQueue *queue, SDL_Event *event)
|
||||||
} else if (delta < 0) {
|
} else if (delta < 0) {
|
||||||
/* We ran into an old queue entry, which means we've hit empty */
|
/* We ran into an old queue entry, which means we've hit empty */
|
||||||
} else {
|
} else {
|
||||||
printf("ERROR: mutex failed!\n");
|
SDL_Log("ERROR: mutex failed!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_UnlockMutex(queue->mutex);
|
SDL_UnlockMutex(queue->mutex);
|
||||||
|
@ -598,9 +598,11 @@ static void RunFIFOTest(SDL_bool lock_free)
|
||||||
Uint32 start, end;
|
Uint32 start, end;
|
||||||
int i, j;
|
int i, j;
|
||||||
int grand_total;
|
int grand_total;
|
||||||
|
char textBuffer[1024];
|
||||||
|
int len;
|
||||||
|
|
||||||
printf("\nFIFO test---------------------------------------\n\n");
|
SDL_Log("\nFIFO test---------------------------------------\n\n");
|
||||||
printf("Mode: %s\n", lock_free ? "LockFree" : "Mutex");
|
SDL_Log("Mode: %s\n", lock_free ? "LockFree" : "Mutex");
|
||||||
|
|
||||||
readersDone = SDL_CreateSemaphore(0);
|
readersDone = SDL_CreateSemaphore(0);
|
||||||
writersDone = SDL_CreateSemaphore(0);
|
writersDone = SDL_CreateSemaphore(0);
|
||||||
|
@ -622,7 +624,7 @@ static void RunFIFOTest(SDL_bool lock_free)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Start the readers first */
|
/* Start the readers first */
|
||||||
printf("Starting %d readers\n", NUM_READERS);
|
SDL_Log("Starting %d readers\n", NUM_READERS);
|
||||||
SDL_zero(readerData);
|
SDL_zero(readerData);
|
||||||
SDL_AtomicSet(&readersRunning, NUM_READERS);
|
SDL_AtomicSet(&readersRunning, NUM_READERS);
|
||||||
for (i = 0; i < NUM_READERS; ++i) {
|
for (i = 0; i < NUM_READERS; ++i) {
|
||||||
|
@ -634,7 +636,7 @@ static void RunFIFOTest(SDL_bool lock_free)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Start up the writers */
|
/* Start up the writers */
|
||||||
printf("Starting %d writers\n", NUM_WRITERS);
|
SDL_Log("Starting %d writers\n", NUM_WRITERS);
|
||||||
SDL_zero(writerData);
|
SDL_zero(writerData);
|
||||||
SDL_AtomicSet(&writersRunning, NUM_WRITERS);
|
SDL_AtomicSet(&writersRunning, NUM_WRITERS);
|
||||||
for (i = 0; i < NUM_WRITERS; ++i) {
|
for (i = 0; i < NUM_WRITERS; ++i) {
|
||||||
|
@ -668,16 +670,16 @@ static void RunFIFOTest(SDL_bool lock_free)
|
||||||
SDL_DestroyMutex(queue.mutex);
|
SDL_DestroyMutex(queue.mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("Finished in %f sec\n", (end - start) / 1000.f);
|
SDL_Log("Finished in %f sec\n", (end - start) / 1000.f);
|
||||||
|
|
||||||
printf("\n");
|
SDL_Log("\n");
|
||||||
for (i = 0; i < NUM_WRITERS; ++i) {
|
for (i = 0; i < NUM_WRITERS; ++i) {
|
||||||
printf("Writer %d wrote %d events, had %d waits\n", i, EVENTS_PER_WRITER, writerData[i].waits);
|
SDL_Log("Writer %d wrote %d events, had %d waits\n", i, EVENTS_PER_WRITER, writerData[i].waits);
|
||||||
}
|
}
|
||||||
printf("Writers wrote %d total events\n", NUM_WRITERS*EVENTS_PER_WRITER);
|
SDL_Log("Writers wrote %d total events\n", NUM_WRITERS*EVENTS_PER_WRITER);
|
||||||
|
|
||||||
/* Print a breakdown of which readers read messages from which writer */
|
/* Print a breakdown of which readers read messages from which writer */
|
||||||
printf("\n");
|
SDL_Log("\n");
|
||||||
grand_total = 0;
|
grand_total = 0;
|
||||||
for (i = 0; i < NUM_READERS; ++i) {
|
for (i = 0; i < NUM_READERS; ++i) {
|
||||||
int total = 0;
|
int total = 0;
|
||||||
|
@ -685,17 +687,21 @@ static void RunFIFOTest(SDL_bool lock_free)
|
||||||
total += readerData[i].counters[j];
|
total += readerData[i].counters[j];
|
||||||
}
|
}
|
||||||
grand_total += total;
|
grand_total += total;
|
||||||
printf("Reader %d read %d events, had %d waits\n", i, total, readerData[i].waits);
|
SDL_Log("Reader %d read %d events, had %d waits\n", i, total, readerData[i].waits);
|
||||||
printf(" { ");
|
SDL_snprintf(textBuffer, sizeof(textBuffer), " { ");
|
||||||
for (j = 0; j < NUM_WRITERS; ++j) {
|
for (j = 0; j < NUM_WRITERS; ++j) {
|
||||||
if (j > 0) {
|
if (j > 0) {
|
||||||
printf(", ");
|
len = SDL_strlen(textBuffer);
|
||||||
|
SDL_snprintf(textBuffer + len, sizeof(textBuffer) - len, ", ");
|
||||||
}
|
}
|
||||||
printf("%d", readerData[i].counters[j]);
|
len = SDL_strlen(textBuffer);
|
||||||
|
SDL_snprintf(textBuffer + len, sizeof(textBuffer) - len, "%d", readerData[i].counters[j]);
|
||||||
}
|
}
|
||||||
printf(" }\n");
|
len = SDL_strlen(textBuffer);
|
||||||
|
SDL_snprintf(textBuffer + len, sizeof(textBuffer) - len, " }\n");
|
||||||
|
SDL_Log(textBuffer);
|
||||||
}
|
}
|
||||||
printf("Readers read %d total events\n", grand_total);
|
SDL_Log("Readers read %d total events\n", grand_total);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* End FIFO test */
|
/* End FIFO test */
|
||||||
|
@ -704,6 +710,9 @@ static void RunFIFOTest(SDL_bool lock_free)
|
||||||
int
|
int
|
||||||
main(int argc, char *argv[])
|
main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
RunBasicTest();
|
RunBasicTest();
|
||||||
RunEpicTest();
|
RunEpicTest();
|
||||||
/* This test is really slow, so don't run it by default */
|
/* This test is really slow, so don't run it by default */
|
||||||
|
|
|
@ -18,18 +18,18 @@ print_devices(int iscapture)
|
||||||
const char *typestr = ((iscapture) ? "capture" : "output");
|
const char *typestr = ((iscapture) ? "capture" : "output");
|
||||||
int n = SDL_GetNumAudioDevices(iscapture);
|
int n = SDL_GetNumAudioDevices(iscapture);
|
||||||
|
|
||||||
printf("%s devices:\n", typestr);
|
SDL_Log("%s devices:\n", typestr);
|
||||||
|
|
||||||
if (n == -1)
|
if (n == -1)
|
||||||
printf(" Driver can't detect specific %s devices.\n\n", typestr);
|
SDL_Log(" Driver can't detect specific %s devices.\n\n", typestr);
|
||||||
else if (n == 0)
|
else if (n == 0)
|
||||||
printf(" No %s devices found.\n\n", typestr);
|
SDL_Log(" No %s devices found.\n\n", typestr);
|
||||||
else {
|
else {
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < n; i++) {
|
for (i = 0; i < n; i++) {
|
||||||
printf(" %s\n", SDL_GetAudioDeviceName(i, iscapture));
|
SDL_Log(" %s\n", SDL_GetAudioDeviceName(i, iscapture));
|
||||||
}
|
}
|
||||||
printf("\n");
|
SDL_Log("\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -38,26 +38,29 @@ main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
int n;
|
int n;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Load the SDL library */
|
/* Load the SDL library */
|
||||||
if (SDL_Init(SDL_INIT_AUDIO) < 0) {
|
if (SDL_Init(SDL_INIT_AUDIO) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Print available audio drivers */
|
/* Print available audio drivers */
|
||||||
n = SDL_GetNumAudioDrivers();
|
n = SDL_GetNumAudioDrivers();
|
||||||
if (n == 0) {
|
if (n == 0) {
|
||||||
printf("No built-in audio drivers\n\n");
|
SDL_Log("No built-in audio drivers\n\n");
|
||||||
} else {
|
} else {
|
||||||
int i;
|
int i;
|
||||||
printf("Built-in audio drivers:\n");
|
SDL_Log("Built-in audio drivers:\n");
|
||||||
for (i = 0; i < n; ++i) {
|
for (i = 0; i < n; ++i) {
|
||||||
printf(" %s\n", SDL_GetAudioDriver(i));
|
SDL_Log(" %s\n", SDL_GetAudioDriver(i));
|
||||||
}
|
}
|
||||||
printf("\n");
|
SDL_Log("\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("Using audio driver: %s\n\n", SDL_GetCurrentAudioDriver());
|
SDL_Log("Using audio driver: %s\n\n", SDL_GetCurrentAudioDriver());
|
||||||
|
|
||||||
print_devices(0);
|
print_devices(0);
|
||||||
print_devices(1);
|
print_devices(1);
|
||||||
|
|
|
@ -80,8 +80,7 @@ main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (consumed < 0) {
|
if (consumed < 0) {
|
||||||
fprintf(stderr,
|
SDL_Log("Usage: %s %s [--iterations #] [--execKey #] [--seed string] [--filter suite_name|test_name]\n",
|
||||||
"Usage: %s %s [--iterations #] [--execKey #] [--seed string] [--filter suite_name|test_name]\n",
|
|
||||||
argv[0], SDLTest_CommonUsage(state));
|
argv[0], SDLTest_CommonUsage(state));
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
|
|
|
@ -360,8 +360,6 @@ surface_testCompleteSurfaceConversion(void *arg)
|
||||||
|
|
||||||
for ( i = 0; i < SDL_arraysize(pixel_formats); ++i ) {
|
for ( i = 0; i < SDL_arraysize(pixel_formats); ++i ) {
|
||||||
for ( j = 0; j < SDL_arraysize(pixel_formats); ++j ) {
|
for ( j = 0; j < SDL_arraysize(pixel_formats); ++j ) {
|
||||||
/*printf("Converting %s -> %s\n", SDL_GetPixelFormatName(pixel_formats[i]), SDL_GetPixelFormatName(pixel_formats[j]));*/
|
|
||||||
|
|
||||||
fmt1 = SDL_AllocFormat(pixel_formats[i]);
|
fmt1 = SDL_AllocFormat(pixel_formats[i]);
|
||||||
SDL_assert(fmt1 != NULL);
|
SDL_assert(fmt1 != NULL);
|
||||||
cvt1 = SDL_ConvertSurface(face, fmt1, 0);
|
cvt1 = SDL_ConvertSurface(face, fmt1, 0);
|
||||||
|
|
|
@ -176,6 +176,9 @@ main(int argc, char *argv[])
|
||||||
SDL_Event event;
|
SDL_Event event;
|
||||||
Uint32 then, now, frames;
|
Uint32 then, now, frames;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Initialize parameters */
|
/* Initialize parameters */
|
||||||
num_objects = NUM_OBJECTS;
|
num_objects = NUM_OBJECTS;
|
||||||
|
|
||||||
|
@ -218,8 +221,7 @@ main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (consumed < 0) {
|
if (consumed < 0) {
|
||||||
fprintf(stderr,
|
SDL_Log("Usage: %s %s [--blend none|blend|add|mod] [--cyclecolor] [--cyclealpha]\n",
|
||||||
"Usage: %s %s [--blend none|blend|add|mod] [--cyclecolor] [--cyclealpha]\n",
|
|
||||||
argv[0], SDLTest_CommonUsage(state));
|
argv[0], SDLTest_CommonUsage(state));
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -268,7 +270,7 @@ main(int argc, char *argv[])
|
||||||
now = SDL_GetTicks();
|
now = SDL_GetTicks();
|
||||||
if (now > then) {
|
if (now > then) {
|
||||||
double fps = ((double) frames * 1000) / (now - then);
|
double fps = ((double) frames * 1000) / (now - then);
|
||||||
printf("%2.2f frames per second\n", fps);
|
SDL_Log("%2.2f frames per second\n", fps);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -54,10 +54,13 @@ main(int argc, char *argv[])
|
||||||
SDL_Surface *surface;
|
SDL_Surface *surface;
|
||||||
SDL_Renderer *renderer;
|
SDL_Renderer *renderer;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Initialize SDL */
|
/* Initialize SDL */
|
||||||
if(SDL_Init(SDL_INIT_VIDEO) != 0)
|
if(SDL_Init(SDL_INIT_VIDEO) != 0)
|
||||||
{
|
{
|
||||||
fprintf(stderr,"SDL_Init fail : %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_Init fail : %s\n", SDL_GetError());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -66,14 +69,14 @@ main(int argc, char *argv[])
|
||||||
window = SDL_CreateWindow("Chess Board", SDL_WINDOWPOS_UNDEFINED, SDL_WINDOWPOS_UNDEFINED, 640, 480, SDL_WINDOW_SHOWN);
|
window = SDL_CreateWindow("Chess Board", SDL_WINDOWPOS_UNDEFINED, SDL_WINDOWPOS_UNDEFINED, 640, 480, SDL_WINDOW_SHOWN);
|
||||||
if(!window)
|
if(!window)
|
||||||
{
|
{
|
||||||
fprintf(stderr,"Window creation fail : %s\n",SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Window creation fail : %s\n",SDL_GetError());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
surface = SDL_GetWindowSurface(window);
|
surface = SDL_GetWindowSurface(window);
|
||||||
renderer = SDL_CreateSoftwareRenderer(surface);
|
renderer = SDL_CreateSoftwareRenderer(surface);
|
||||||
if(!renderer)
|
if(!renderer)
|
||||||
{
|
{
|
||||||
fprintf(stderr,"Render creation for surface fail : %s\n",SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Render creation for surface fail : %s\n",SDL_GetError());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -36,10 +36,10 @@ ThreadFunc(void *data)
|
||||||
SDL_SetError("Thread %s (%lu) had a problem: %s",
|
SDL_SetError("Thread %s (%lu) had a problem: %s",
|
||||||
(char *) data, SDL_ThreadID(), "nevermind");
|
(char *) data, SDL_ThreadID(), "nevermind");
|
||||||
while (alive) {
|
while (alive) {
|
||||||
printf("Thread '%s' is alive!\n", (char *) data);
|
SDL_Log("Thread '%s' is alive!\n", (char *) data);
|
||||||
SDL_Delay(1 * 1000);
|
SDL_Delay(1 * 1000);
|
||||||
}
|
}
|
||||||
printf("Child thread error string: %s\n", SDL_GetError());
|
SDL_Log("Child thread error string: %s\n", SDL_GetError());
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,9 +48,12 @@ main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
SDL_Thread *thread;
|
SDL_Thread *thread;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Load the SDL library */
|
/* Load the SDL library */
|
||||||
if (SDL_Init(0) < 0) {
|
if (SDL_Init(0) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -60,15 +63,15 @@ main(int argc, char *argv[])
|
||||||
alive = 1;
|
alive = 1;
|
||||||
thread = SDL_CreateThread(ThreadFunc, NULL, "#1");
|
thread = SDL_CreateThread(ThreadFunc, NULL, "#1");
|
||||||
if (thread == NULL) {
|
if (thread == NULL) {
|
||||||
fprintf(stderr, "Couldn't create thread: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create thread: %s\n", SDL_GetError());
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
SDL_Delay(5 * 1000);
|
SDL_Delay(5 * 1000);
|
||||||
printf("Waiting for thread #1\n");
|
SDL_Log("Waiting for thread #1\n");
|
||||||
alive = 0;
|
alive = 0;
|
||||||
SDL_WaitThread(thread, NULL);
|
SDL_WaitThread(thread, NULL);
|
||||||
|
|
||||||
printf("Main thread error string: %s\n", SDL_GetError());
|
SDL_Log("Main thread error string: %s\n", SDL_GetError());
|
||||||
|
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
return (0);
|
return (0);
|
||||||
|
|
|
@ -44,7 +44,6 @@
|
||||||
static void
|
static void
|
||||||
cleanup(void)
|
cleanup(void)
|
||||||
{
|
{
|
||||||
|
|
||||||
unlink(FBASENAME1);
|
unlink(FBASENAME1);
|
||||||
unlink(FBASENAME2);
|
unlink(FBASENAME2);
|
||||||
}
|
}
|
||||||
|
@ -52,8 +51,7 @@ cleanup(void)
|
||||||
static void
|
static void
|
||||||
rwops_error_quit(unsigned line, SDL_RWops * rwops)
|
rwops_error_quit(unsigned line, SDL_RWops * rwops)
|
||||||
{
|
{
|
||||||
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "testfile.c(%d): failed\n", line);
|
||||||
printf("testfile.c(%d): failed\n", line);
|
|
||||||
if (rwops) {
|
if (rwops) {
|
||||||
rwops->close(rwops); /* This calls SDL_FreeRW(rwops); */
|
rwops->close(rwops); /* This calls SDL_FreeRW(rwops); */
|
||||||
}
|
}
|
||||||
|
@ -71,6 +69,9 @@ main(int argc, char *argv[])
|
||||||
SDL_RWops *rwops = NULL;
|
SDL_RWops *rwops = NULL;
|
||||||
char test_buf[30];
|
char test_buf[30];
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
cleanup();
|
cleanup();
|
||||||
|
|
||||||
/* test 1 : basic argument test: all those calls to SDL_RWFromFile should fail */
|
/* test 1 : basic argument test: all those calls to SDL_RWFromFile should fail */
|
||||||
|
@ -90,7 +91,7 @@ main(int argc, char *argv[])
|
||||||
rwops = SDL_RWFromFile("something", NULL);
|
rwops = SDL_RWFromFile("something", NULL);
|
||||||
if (rwops)
|
if (rwops)
|
||||||
RWOP_ERR_QUIT(rwops);
|
RWOP_ERR_QUIT(rwops);
|
||||||
printf("test1 OK\n");
|
SDL_Log("test1 OK\n");
|
||||||
|
|
||||||
/* test 2 : check that inexistent file is not successfully opened/created when required */
|
/* test 2 : check that inexistent file is not successfully opened/created when required */
|
||||||
/* modes : r, r+ imply that file MUST exist
|
/* modes : r, r+ imply that file MUST exist
|
||||||
|
@ -123,7 +124,7 @@ main(int argc, char *argv[])
|
||||||
RWOP_ERR_QUIT(rwops);
|
RWOP_ERR_QUIT(rwops);
|
||||||
rwops->close(rwops);
|
rwops->close(rwops);
|
||||||
unlink(FBASENAME2);
|
unlink(FBASENAME2);
|
||||||
printf("test2 OK\n");
|
SDL_Log("test2 OK\n");
|
||||||
|
|
||||||
/* test 3 : creation, writing , reading, seeking,
|
/* test 3 : creation, writing , reading, seeking,
|
||||||
test : w mode, r mode, w+ mode
|
test : w mode, r mode, w+ mode
|
||||||
|
@ -201,7 +202,7 @@ main(int argc, char *argv[])
|
||||||
if (SDL_memcmp(test_buf, "12345678901234567890", 20))
|
if (SDL_memcmp(test_buf, "12345678901234567890", 20))
|
||||||
RWOP_ERR_QUIT(rwops);
|
RWOP_ERR_QUIT(rwops);
|
||||||
rwops->close(rwops);
|
rwops->close(rwops);
|
||||||
printf("test3 OK\n");
|
SDL_Log("test3 OK\n");
|
||||||
|
|
||||||
/* test 4: same in r+ mode */
|
/* test 4: same in r+ mode */
|
||||||
rwops = SDL_RWFromFile(FBASENAME1, "rb+"); /* write + read + file must exists, no truncation */
|
rwops = SDL_RWFromFile(FBASENAME1, "rb+"); /* write + read + file must exists, no truncation */
|
||||||
|
@ -236,7 +237,7 @@ main(int argc, char *argv[])
|
||||||
if (SDL_memcmp(test_buf, "12345678901234567890", 20))
|
if (SDL_memcmp(test_buf, "12345678901234567890", 20))
|
||||||
RWOP_ERR_QUIT(rwops);
|
RWOP_ERR_QUIT(rwops);
|
||||||
rwops->close(rwops);
|
rwops->close(rwops);
|
||||||
printf("test4 OK\n");
|
SDL_Log("test4 OK\n");
|
||||||
|
|
||||||
/* test5 : append mode */
|
/* test5 : append mode */
|
||||||
rwops = SDL_RWFromFile(FBASENAME1, "ab+"); /* write + read + append */
|
rwops = SDL_RWFromFile(FBASENAME1, "ab+"); /* write + read + append */
|
||||||
|
@ -277,7 +278,7 @@ main(int argc, char *argv[])
|
||||||
if (SDL_memcmp(test_buf, "123456789012345678901234567123", 30))
|
if (SDL_memcmp(test_buf, "123456789012345678901234567123", 30))
|
||||||
RWOP_ERR_QUIT(rwops);
|
RWOP_ERR_QUIT(rwops);
|
||||||
rwops->close(rwops);
|
rwops->close(rwops);
|
||||||
printf("test5 OK\n");
|
SDL_Log("test5 OK\n");
|
||||||
cleanup();
|
cleanup();
|
||||||
return 0; /* all ok */
|
return 0; /* all ok */
|
||||||
}
|
}
|
||||||
|
|
|
@ -91,7 +91,7 @@ WatchGameController(SDL_GameController * gamecontroller)
|
||||||
const char *name = SDL_GameControllerName(gamecontroller);
|
const char *name = SDL_GameControllerName(gamecontroller);
|
||||||
const char *basetitle = "Game Controller Test: ";
|
const char *basetitle = "Game Controller Test: ";
|
||||||
const size_t titlelen = SDL_strlen(basetitle) + SDL_strlen(name) + 1;
|
const size_t titlelen = SDL_strlen(basetitle) + SDL_strlen(name) + 1;
|
||||||
char *title = SDL_malloc(titlelen);
|
char *title = (char *)SDL_malloc(titlelen);
|
||||||
SDL_Window *window = NULL;
|
SDL_Window *window = NULL;
|
||||||
SDL_Renderer *screen = NULL;
|
SDL_Renderer *screen = NULL;
|
||||||
int done = 0;
|
int done = 0;
|
||||||
|
@ -107,13 +107,13 @@ WatchGameController(SDL_GameController * gamecontroller)
|
||||||
SDL_WINDOWPOS_CENTERED, SCREEN_WIDTH,
|
SDL_WINDOWPOS_CENTERED, SCREEN_WIDTH,
|
||||||
SCREEN_HEIGHT, 0);
|
SCREEN_HEIGHT, 0);
|
||||||
if (window == NULL) {
|
if (window == NULL) {
|
||||||
fprintf(stderr, "Couldn't create window: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create window: %s\n", SDL_GetError());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
screen = SDL_CreateRenderer(window, -1, 0);
|
screen = SDL_CreateRenderer(window, -1, 0);
|
||||||
if (screen == NULL) {
|
if (screen == NULL) {
|
||||||
fprintf(stderr, "Couldn't create renderer: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create renderer: %s\n", SDL_GetError());
|
||||||
SDL_DestroyWindow(window);
|
SDL_DestroyWindow(window);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -124,7 +124,7 @@ WatchGameController(SDL_GameController * gamecontroller)
|
||||||
SDL_RaiseWindow(window);
|
SDL_RaiseWindow(window);
|
||||||
|
|
||||||
/* Print info about the controller we are watching */
|
/* Print info about the controller we are watching */
|
||||||
printf("Watching controller %s\n", name ? name : "Unknown Controller");
|
SDL_Log("Watching controller %s\n", name ? name : "Unknown Controller");
|
||||||
|
|
||||||
/* Loop, getting controller events! */
|
/* Loop, getting controller events! */
|
||||||
while (!done) {
|
while (!done) {
|
||||||
|
@ -135,21 +135,21 @@ WatchGameController(SDL_GameController * gamecontroller)
|
||||||
while (SDL_PollEvent(&event)) {
|
while (SDL_PollEvent(&event)) {
|
||||||
switch (event.type) {
|
switch (event.type) {
|
||||||
case SDL_CONTROLLERAXISMOTION:
|
case SDL_CONTROLLERAXISMOTION:
|
||||||
printf("Controller %d axis %d ('%s') value: %d\n",
|
SDL_Log("Controller %d axis %d ('%s') value: %d\n",
|
||||||
event.caxis.which,
|
event.caxis.which,
|
||||||
event.caxis.axis,
|
event.caxis.axis,
|
||||||
ControllerAxisName(event.caxis.axis),
|
ControllerAxisName((SDL_GameControllerAxis)event.caxis.axis),
|
||||||
event.caxis.value);
|
event.caxis.value);
|
||||||
break;
|
break;
|
||||||
case SDL_CONTROLLERBUTTONDOWN:
|
case SDL_CONTROLLERBUTTONDOWN:
|
||||||
printf("Controller %d button %d ('%s') down\n",
|
SDL_Log("Controller %d button %d ('%s') down\n",
|
||||||
event.cbutton.which, event.cbutton.button,
|
event.cbutton.which, event.cbutton.button,
|
||||||
ControllerButtonName(event.cbutton.button));
|
ControllerButtonName((SDL_GameControllerButton)event.cbutton.button));
|
||||||
break;
|
break;
|
||||||
case SDL_CONTROLLERBUTTONUP:
|
case SDL_CONTROLLERBUTTONUP:
|
||||||
printf("Controller %d button %d ('%s') up\n",
|
SDL_Log("Controller %d button %d ('%s') up\n",
|
||||||
event.cbutton.which, event.cbutton.button,
|
event.cbutton.which, event.cbutton.button,
|
||||||
ControllerButtonName(event.cbutton.button));
|
ControllerButtonName((SDL_GameControllerButton)event.cbutton.button));
|
||||||
break;
|
break;
|
||||||
case SDL_KEYDOWN:
|
case SDL_KEYDOWN:
|
||||||
if (event.key.keysym.sym != SDLK_ESCAPE) {
|
if (event.key.keysym.sym != SDLK_ESCAPE) {
|
||||||
|
@ -167,7 +167,7 @@ WatchGameController(SDL_GameController * gamecontroller)
|
||||||
/* Update visual controller state */
|
/* Update visual controller state */
|
||||||
SDL_SetRenderDrawColor(screen, 0x00, 0xFF, 0x00, SDL_ALPHA_OPAQUE);
|
SDL_SetRenderDrawColor(screen, 0x00, 0xFF, 0x00, SDL_ALPHA_OPAQUE);
|
||||||
for (i = 0; i <SDL_CONTROLLER_BUTTON_MAX; ++i) {
|
for (i = 0; i <SDL_CONTROLLER_BUTTON_MAX; ++i) {
|
||||||
if (SDL_GameControllerGetButton(gamecontroller, i) == SDL_PRESSED) {
|
if (SDL_GameControllerGetButton(gamecontroller, (SDL_GameControllerButton)i) == SDL_PRESSED) {
|
||||||
DrawRect(screen, i * 34, SCREEN_HEIGHT - 34, 32, 32);
|
DrawRect(screen, i * 34, SCREEN_HEIGHT - 34, 32, 32);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -176,7 +176,7 @@ WatchGameController(SDL_GameController * gamecontroller)
|
||||||
for (i = 0; i < SDL_CONTROLLER_AXIS_MAX / 2; ++i) {
|
for (i = 0; i < SDL_CONTROLLER_AXIS_MAX / 2; ++i) {
|
||||||
/* Draw the X/Y axis */
|
/* Draw the X/Y axis */
|
||||||
int x, y;
|
int x, y;
|
||||||
x = (((int) SDL_GameControllerGetAxis(gamecontroller, i * 2 + 0)) + 32768);
|
x = (((int) SDL_GameControllerGetAxis(gamecontroller, (SDL_GameControllerAxis)(i * 2 + 0))) + 32768);
|
||||||
x *= SCREEN_WIDTH;
|
x *= SCREEN_WIDTH;
|
||||||
x /= 65535;
|
x /= 65535;
|
||||||
if (x < 0) {
|
if (x < 0) {
|
||||||
|
@ -184,7 +184,7 @@ WatchGameController(SDL_GameController * gamecontroller)
|
||||||
} else if (x > (SCREEN_WIDTH - 16)) {
|
} else if (x > (SCREEN_WIDTH - 16)) {
|
||||||
x = SCREEN_WIDTH - 16;
|
x = SCREEN_WIDTH - 16;
|
||||||
}
|
}
|
||||||
y = (((int) SDL_GameControllerGetAxis(gamecontroller, i * 2 + 1)) + 32768);
|
y = (((int) SDL_GameControllerGetAxis(gamecontroller, (SDL_GameControllerAxis)(i * 2 + 1))) + 32768);
|
||||||
y *= SCREEN_HEIGHT;
|
y *= SCREEN_HEIGHT;
|
||||||
y /= 65535;
|
y /= 65535;
|
||||||
if (y < 0) {
|
if (y < 0) {
|
||||||
|
@ -217,9 +217,12 @@ main(int argc, char *argv[])
|
||||||
char guid[64];
|
char guid[64];
|
||||||
SDL_GameController *gamecontroller;
|
SDL_GameController *gamecontroller;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Initialize SDL (Note: video is required to start event loop) */
|
/* Initialize SDL (Note: video is required to start event loop) */
|
||||||
if (SDL_Init(SDL_INIT_VIDEO | SDL_INIT_JOYSTICK | SDL_INIT_GAMECONTROLLER ) < 0) {
|
if (SDL_Init(SDL_INIT_VIDEO | SDL_INIT_JOYSTICK | SDL_INIT_GAMECONTROLLER ) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -238,22 +241,22 @@ main(int argc, char *argv[])
|
||||||
} else {
|
} else {
|
||||||
name = SDL_JoystickNameForIndex(i);
|
name = SDL_JoystickNameForIndex(i);
|
||||||
}
|
}
|
||||||
printf("%s %d: %s (guid %s)\n", description, i, name ? name : "Unknown", guid);
|
SDL_Log("%s %d: %s (guid %s)\n", description, i, name ? name : "Unknown", guid);
|
||||||
}
|
}
|
||||||
printf("There are %d game controller(s) attached (%d joystick(s))\n", nController, SDL_NumJoysticks());
|
SDL_Log("There are %d game controller(s) attached (%d joystick(s))\n", nController, SDL_NumJoysticks());
|
||||||
|
|
||||||
if (argv[1]) {
|
if (argv[1]) {
|
||||||
int device = atoi(argv[1]);
|
int device = atoi(argv[1]);
|
||||||
if (device >= SDL_NumJoysticks()) {
|
if (device >= SDL_NumJoysticks()) {
|
||||||
printf("%i is an invalid joystick index.\n", device);
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "%i is an invalid joystick index.\n", device);
|
||||||
retcode = 1;
|
retcode = 1;
|
||||||
} else {
|
} else {
|
||||||
SDL_JoystickGetGUIDString(SDL_JoystickGetDeviceGUID(device),
|
SDL_JoystickGetGUIDString(SDL_JoystickGetDeviceGUID(device),
|
||||||
guid, sizeof (guid));
|
guid, sizeof (guid));
|
||||||
printf("Attempting to open device %i, guid %s\n", device, guid);
|
SDL_Log("Attempting to open device %i, guid %s\n", device, guid);
|
||||||
gamecontroller = SDL_GameControllerOpen(device);
|
gamecontroller = SDL_GameControllerOpen(device);
|
||||||
if (gamecontroller == NULL) {
|
if (gamecontroller == NULL) {
|
||||||
printf("Couldn't open joystick %d: %s\n", device, SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't open joystick %d: %s\n", device, SDL_GetError());
|
||||||
retcode = 1;
|
retcode = 1;
|
||||||
} else {
|
} else {
|
||||||
WatchGameController(gamecontroller);
|
WatchGameController(gamecontroller);
|
||||||
|
@ -272,7 +275,7 @@ main(int argc, char *argv[])
|
||||||
int
|
int
|
||||||
main(int argc, char *argv[])
|
main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
fprintf(stderr, "SDL compiled without Joystick support.\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL compiled without Joystick support.\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -207,6 +207,9 @@ int main(int argc, char* argv[])
|
||||||
SDL_bool quitting = SDL_FALSE;
|
SDL_bool quitting = SDL_FALSE;
|
||||||
SDL_RWops *src;
|
SDL_RWops *src;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
//gesture variables
|
//gesture variables
|
||||||
knob.r = .1f;
|
knob.r = .1f;
|
||||||
knob.ang = 0;
|
knob.ang = 0;
|
||||||
|
|
|
@ -181,6 +181,9 @@ main(int argc, char *argv[])
|
||||||
Uint32 then, now, frames;
|
Uint32 then, now, frames;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Initialize parameters */
|
/* Initialize parameters */
|
||||||
fsaa = 0;
|
fsaa = 0;
|
||||||
accel = -1;
|
accel = -1;
|
||||||
|
@ -206,7 +209,7 @@ main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (consumed < 0) {
|
if (consumed < 0) {
|
||||||
fprintf(stderr, "Usage: %s %s [--fsaa n] [--accel n]\n", argv[0],
|
SDL_Log("Usage: %s %s [--fsaa n] [--accel n]\n", argv[0],
|
||||||
SDLTest_CommonUsage(state));
|
SDLTest_CommonUsage(state));
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
|
@ -235,7 +238,7 @@ main(int argc, char *argv[])
|
||||||
/* Create OpenGL context */
|
/* Create OpenGL context */
|
||||||
context = SDL_GL_CreateContext(state->windows[0]);
|
context = SDL_GL_CreateContext(state->windows[0]);
|
||||||
if (!context) {
|
if (!context) {
|
||||||
fprintf(stderr, "SDL_GL_CreateContext(): %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_GL_CreateContext(): %s\n", SDL_GetError());
|
||||||
quit(2);
|
quit(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -249,63 +252,63 @@ main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_GetCurrentDisplayMode(0, &mode);
|
SDL_GetCurrentDisplayMode(0, &mode);
|
||||||
printf("Screen BPP : %d\n", SDL_BITSPERPIXEL(mode.format));
|
SDL_Log("Screen BPP : %d\n", SDL_BITSPERPIXEL(mode.format));
|
||||||
printf("Swap Interval : %d\n", SDL_GL_GetSwapInterval());
|
SDL_Log("Swap Interval : %d\n", SDL_GL_GetSwapInterval());
|
||||||
printf("\n");
|
SDL_Log("\n");
|
||||||
printf("Vendor : %s\n", glGetString(GL_VENDOR));
|
SDL_Log("Vendor : %s\n", glGetString(GL_VENDOR));
|
||||||
printf("Renderer : %s\n", glGetString(GL_RENDERER));
|
SDL_Log("Renderer : %s\n", glGetString(GL_RENDERER));
|
||||||
printf("Version : %s\n", glGetString(GL_VERSION));
|
SDL_Log("Version : %s\n", glGetString(GL_VERSION));
|
||||||
printf("Extensions : %s\n", glGetString(GL_EXTENSIONS));
|
SDL_Log("Extensions : %s\n", glGetString(GL_EXTENSIONS));
|
||||||
printf("\n");
|
SDL_Log("\n");
|
||||||
|
|
||||||
status = SDL_GL_GetAttribute(SDL_GL_RED_SIZE, &value);
|
status = SDL_GL_GetAttribute(SDL_GL_RED_SIZE, &value);
|
||||||
if (!status) {
|
if (!status) {
|
||||||
printf("SDL_GL_RED_SIZE: requested %d, got %d\n", 5, value);
|
SDL_Log("SDL_GL_RED_SIZE: requested %d, got %d\n", 5, value);
|
||||||
} else {
|
} else {
|
||||||
printf("Failed to get SDL_GL_RED_SIZE: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to get SDL_GL_RED_SIZE: %s\n", SDL_GetError());
|
||||||
}
|
}
|
||||||
status = SDL_GL_GetAttribute(SDL_GL_GREEN_SIZE, &value);
|
status = SDL_GL_GetAttribute(SDL_GL_GREEN_SIZE, &value);
|
||||||
if (!status) {
|
if (!status) {
|
||||||
printf("SDL_GL_GREEN_SIZE: requested %d, got %d\n", 5, value);
|
SDL_Log("SDL_GL_GREEN_SIZE: requested %d, got %d\n", 5, value);
|
||||||
} else {
|
} else {
|
||||||
printf("Failed to get SDL_GL_GREEN_SIZE: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to get SDL_GL_GREEN_SIZE: %s\n", SDL_GetError());
|
||||||
}
|
}
|
||||||
status = SDL_GL_GetAttribute(SDL_GL_BLUE_SIZE, &value);
|
status = SDL_GL_GetAttribute(SDL_GL_BLUE_SIZE, &value);
|
||||||
if (!status) {
|
if (!status) {
|
||||||
printf("SDL_GL_BLUE_SIZE: requested %d, got %d\n", 5, value);
|
SDL_Log("SDL_GL_BLUE_SIZE: requested %d, got %d\n", 5, value);
|
||||||
} else {
|
} else {
|
||||||
printf("Failed to get SDL_GL_BLUE_SIZE: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to get SDL_GL_BLUE_SIZE: %s\n", SDL_GetError());
|
||||||
}
|
}
|
||||||
status = SDL_GL_GetAttribute(SDL_GL_DEPTH_SIZE, &value);
|
status = SDL_GL_GetAttribute(SDL_GL_DEPTH_SIZE, &value);
|
||||||
if (!status) {
|
if (!status) {
|
||||||
printf("SDL_GL_DEPTH_SIZE: requested %d, got %d\n", 16, value);
|
SDL_Log("SDL_GL_DEPTH_SIZE: requested %d, got %d\n", 16, value);
|
||||||
} else {
|
} else {
|
||||||
printf("Failed to get SDL_GL_DEPTH_SIZE: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to get SDL_GL_DEPTH_SIZE: %s\n", SDL_GetError());
|
||||||
}
|
}
|
||||||
if (fsaa) {
|
if (fsaa) {
|
||||||
status = SDL_GL_GetAttribute(SDL_GL_MULTISAMPLEBUFFERS, &value);
|
status = SDL_GL_GetAttribute(SDL_GL_MULTISAMPLEBUFFERS, &value);
|
||||||
if (!status) {
|
if (!status) {
|
||||||
printf("SDL_GL_MULTISAMPLEBUFFERS: requested 1, got %d\n", value);
|
SDL_Log("SDL_GL_MULTISAMPLEBUFFERS: requested 1, got %d\n", value);
|
||||||
} else {
|
} else {
|
||||||
printf("Failed to get SDL_GL_MULTISAMPLEBUFFERS: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to get SDL_GL_MULTISAMPLEBUFFERS: %s\n",
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
}
|
}
|
||||||
status = SDL_GL_GetAttribute(SDL_GL_MULTISAMPLESAMPLES, &value);
|
status = SDL_GL_GetAttribute(SDL_GL_MULTISAMPLESAMPLES, &value);
|
||||||
if (!status) {
|
if (!status) {
|
||||||
printf("SDL_GL_MULTISAMPLESAMPLES: requested %d, got %d\n", fsaa,
|
SDL_Log("SDL_GL_MULTISAMPLESAMPLES: requested %d, got %d\n", fsaa,
|
||||||
value);
|
value);
|
||||||
} else {
|
} else {
|
||||||
printf("Failed to get SDL_GL_MULTISAMPLESAMPLES: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to get SDL_GL_MULTISAMPLESAMPLES: %s\n",
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (accel >= 0) {
|
if (accel >= 0) {
|
||||||
status = SDL_GL_GetAttribute(SDL_GL_ACCELERATED_VISUAL, &value);
|
status = SDL_GL_GetAttribute(SDL_GL_ACCELERATED_VISUAL, &value);
|
||||||
if (!status) {
|
if (!status) {
|
||||||
printf("SDL_GL_ACCELERATED_VISUAL: requested %d, got %d\n", accel,
|
SDL_Log("SDL_GL_ACCELERATED_VISUAL: requested %d, got %d\n", accel,
|
||||||
value);
|
value);
|
||||||
} else {
|
} else {
|
||||||
printf("Failed to get SDL_GL_ACCELERATED_VISUAL: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to get SDL_GL_ACCELERATED_VISUAL: %s\n",
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -343,7 +346,7 @@ main(int argc, char *argv[])
|
||||||
/* Print out some timing information */
|
/* Print out some timing information */
|
||||||
now = SDL_GetTicks();
|
now = SDL_GetTicks();
|
||||||
if (now > then) {
|
if (now > then) {
|
||||||
printf("%2.2f frames per second\n",
|
SDL_Log("%2.2f frames per second\n",
|
||||||
((double) frames * 1000) / (now - then));
|
((double) frames * 1000) / (now - then));
|
||||||
}
|
}
|
||||||
quit(0);
|
quit(0);
|
||||||
|
@ -355,7 +358,7 @@ main(int argc, char *argv[])
|
||||||
int
|
int
|
||||||
main(int argc, char *argv[])
|
main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
printf("No OpenGL support on this system\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "No OpenGL support on this system\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -110,6 +110,9 @@ main(int argc, char *argv[])
|
||||||
Uint32 then, now, frames;
|
Uint32 then, now, frames;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Initialize parameters */
|
/* Initialize parameters */
|
||||||
fsaa = 0;
|
fsaa = 0;
|
||||||
accel = 0;
|
accel = 0;
|
||||||
|
@ -143,7 +146,7 @@ main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (consumed < 0) {
|
if (consumed < 0) {
|
||||||
fprintf(stderr, "Usage: %s %s [--fsaa] [--accel] [--zdepth %%d]\n", argv[0],
|
SDL_Log("Usage: %s %s [--fsaa] [--accel] [--zdepth %%d]\n", argv[0],
|
||||||
SDLTest_CommonUsage(state));
|
SDLTest_CommonUsage(state));
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
|
@ -169,7 +172,7 @@ main(int argc, char *argv[])
|
||||||
|
|
||||||
context = SDL_calloc(state->num_windows, sizeof(context));
|
context = SDL_calloc(state->num_windows, sizeof(context));
|
||||||
if (context == NULL) {
|
if (context == NULL) {
|
||||||
fprintf(stderr, "Out of memory!\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Out of memory!\n");
|
||||||
quit(2);
|
quit(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -177,7 +180,7 @@ main(int argc, char *argv[])
|
||||||
for (i = 0; i < state->num_windows; i++) {
|
for (i = 0; i < state->num_windows; i++) {
|
||||||
context[i] = SDL_GL_CreateContext(state->windows[i]);
|
context[i] = SDL_GL_CreateContext(state->windows[i]);
|
||||||
if (!context[i]) {
|
if (!context[i]) {
|
||||||
fprintf(stderr, "SDL_GL_CreateContext(): %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_GL_CreateContext(): %s\n", SDL_GetError());
|
||||||
quit(2);
|
quit(2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -189,65 +192,65 @@ main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_GetCurrentDisplayMode(0, &mode);
|
SDL_GetCurrentDisplayMode(0, &mode);
|
||||||
printf("Screen bpp: %d\n", SDL_BITSPERPIXEL(mode.format));
|
SDL_Log("Screen bpp: %d\n", SDL_BITSPERPIXEL(mode.format));
|
||||||
printf("\n");
|
SDL_Log("\n");
|
||||||
printf("Vendor : %s\n", glGetString(GL_VENDOR));
|
SDL_Log("Vendor : %s\n", glGetString(GL_VENDOR));
|
||||||
printf("Renderer : %s\n", glGetString(GL_RENDERER));
|
SDL_Log("Renderer : %s\n", glGetString(GL_RENDERER));
|
||||||
printf("Version : %s\n", glGetString(GL_VERSION));
|
SDL_Log("Version : %s\n", glGetString(GL_VERSION));
|
||||||
printf("Extensions : %s\n", glGetString(GL_EXTENSIONS));
|
SDL_Log("Extensions : %s\n", glGetString(GL_EXTENSIONS));
|
||||||
printf("\n");
|
SDL_Log("\n");
|
||||||
|
|
||||||
status = SDL_GL_GetAttribute(SDL_GL_RED_SIZE, &value);
|
status = SDL_GL_GetAttribute(SDL_GL_RED_SIZE, &value);
|
||||||
if (!status) {
|
if (!status) {
|
||||||
printf("SDL_GL_RED_SIZE: requested %d, got %d\n", 5, value);
|
SDL_Log("SDL_GL_RED_SIZE: requested %d, got %d\n", 5, value);
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "Failed to get SDL_GL_RED_SIZE: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to get SDL_GL_RED_SIZE: %s\n",
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
}
|
}
|
||||||
status = SDL_GL_GetAttribute(SDL_GL_GREEN_SIZE, &value);
|
status = SDL_GL_GetAttribute(SDL_GL_GREEN_SIZE, &value);
|
||||||
if (!status) {
|
if (!status) {
|
||||||
printf("SDL_GL_GREEN_SIZE: requested %d, got %d\n", 5, value);
|
SDL_Log("SDL_GL_GREEN_SIZE: requested %d, got %d\n", 5, value);
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "Failed to get SDL_GL_GREEN_SIZE: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to get SDL_GL_GREEN_SIZE: %s\n",
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
}
|
}
|
||||||
status = SDL_GL_GetAttribute(SDL_GL_BLUE_SIZE, &value);
|
status = SDL_GL_GetAttribute(SDL_GL_BLUE_SIZE, &value);
|
||||||
if (!status) {
|
if (!status) {
|
||||||
printf("SDL_GL_BLUE_SIZE: requested %d, got %d\n", 5, value);
|
SDL_Log("SDL_GL_BLUE_SIZE: requested %d, got %d\n", 5, value);
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "Failed to get SDL_GL_BLUE_SIZE: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to get SDL_GL_BLUE_SIZE: %s\n",
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
}
|
}
|
||||||
status = SDL_GL_GetAttribute(SDL_GL_DEPTH_SIZE, &value);
|
status = SDL_GL_GetAttribute(SDL_GL_DEPTH_SIZE, &value);
|
||||||
if (!status) {
|
if (!status) {
|
||||||
printf("SDL_GL_DEPTH_SIZE: requested %d, got %d\n", depth, value);
|
SDL_Log("SDL_GL_DEPTH_SIZE: requested %d, got %d\n", depth, value);
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "Failed to get SDL_GL_DEPTH_SIZE: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to get SDL_GL_DEPTH_SIZE: %s\n",
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
}
|
}
|
||||||
if (fsaa) {
|
if (fsaa) {
|
||||||
status = SDL_GL_GetAttribute(SDL_GL_MULTISAMPLEBUFFERS, &value);
|
status = SDL_GL_GetAttribute(SDL_GL_MULTISAMPLEBUFFERS, &value);
|
||||||
if (!status) {
|
if (!status) {
|
||||||
printf("SDL_GL_MULTISAMPLEBUFFERS: requested 1, got %d\n", value);
|
SDL_Log("SDL_GL_MULTISAMPLEBUFFERS: requested 1, got %d\n", value);
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "Failed to get SDL_GL_MULTISAMPLEBUFFERS: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to get SDL_GL_MULTISAMPLEBUFFERS: %s\n",
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
}
|
}
|
||||||
status = SDL_GL_GetAttribute(SDL_GL_MULTISAMPLESAMPLES, &value);
|
status = SDL_GL_GetAttribute(SDL_GL_MULTISAMPLESAMPLES, &value);
|
||||||
if (!status) {
|
if (!status) {
|
||||||
printf("SDL_GL_MULTISAMPLESAMPLES: requested %d, got %d\n", fsaa,
|
SDL_Log("SDL_GL_MULTISAMPLESAMPLES: requested %d, got %d\n", fsaa,
|
||||||
value);
|
value);
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "Failed to get SDL_GL_MULTISAMPLESAMPLES: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to get SDL_GL_MULTISAMPLESAMPLES: %s\n",
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (accel) {
|
if (accel) {
|
||||||
status = SDL_GL_GetAttribute(SDL_GL_ACCELERATED_VISUAL, &value);
|
status = SDL_GL_GetAttribute(SDL_GL_ACCELERATED_VISUAL, &value);
|
||||||
if (!status) {
|
if (!status) {
|
||||||
printf("SDL_GL_ACCELERATED_VISUAL: requested 1, got %d\n", value);
|
SDL_Log("SDL_GL_ACCELERATED_VISUAL: requested 1, got %d\n", value);
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "Failed to get SDL_GL_ACCELERATED_VISUAL: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to get SDL_GL_ACCELERATED_VISUAL: %s\n",
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -258,7 +261,7 @@ main(int argc, char *argv[])
|
||||||
|
|
||||||
status = SDL_GL_MakeCurrent(state->windows[i], context[i]);
|
status = SDL_GL_MakeCurrent(state->windows[i], context[i]);
|
||||||
if (status) {
|
if (status) {
|
||||||
printf("SDL_GL_MakeCurrent(): %s\n", SDL_GetError());
|
SDL_Log("SDL_GL_MakeCurrent(): %s\n", SDL_GetError());
|
||||||
|
|
||||||
/* Continue for next window */
|
/* Continue for next window */
|
||||||
continue;
|
continue;
|
||||||
|
@ -292,7 +295,7 @@ main(int argc, char *argv[])
|
||||||
if (event.window.windowID == SDL_GetWindowID(state->windows[i])) {
|
if (event.window.windowID == SDL_GetWindowID(state->windows[i])) {
|
||||||
status = SDL_GL_MakeCurrent(state->windows[i], context[i]);
|
status = SDL_GL_MakeCurrent(state->windows[i], context[i]);
|
||||||
if (status) {
|
if (status) {
|
||||||
printf("SDL_GL_MakeCurrent(): %s\n", SDL_GetError());
|
SDL_Log("SDL_GL_MakeCurrent(): %s\n", SDL_GetError());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
/* Change view port to the new window dimensions */
|
/* Change view port to the new window dimensions */
|
||||||
|
@ -311,7 +314,7 @@ main(int argc, char *argv[])
|
||||||
for (i = 0; i < state->num_windows; ++i) {
|
for (i = 0; i < state->num_windows; ++i) {
|
||||||
status = SDL_GL_MakeCurrent(state->windows[i], context[i]);
|
status = SDL_GL_MakeCurrent(state->windows[i], context[i]);
|
||||||
if (status) {
|
if (status) {
|
||||||
printf("SDL_GL_MakeCurrent(): %s\n", SDL_GetError());
|
SDL_Log("SDL_GL_MakeCurrent(): %s\n", SDL_GetError());
|
||||||
|
|
||||||
/* Continue for next window */
|
/* Continue for next window */
|
||||||
continue;
|
continue;
|
||||||
|
@ -324,7 +327,7 @@ main(int argc, char *argv[])
|
||||||
/* Print out some timing information */
|
/* Print out some timing information */
|
||||||
now = SDL_GetTicks();
|
now = SDL_GetTicks();
|
||||||
if (now > then) {
|
if (now > then) {
|
||||||
printf("%2.2f frames per second\n",
|
SDL_Log("%2.2f frames per second\n",
|
||||||
((double) frames * 1000) / (now - then));
|
((double) frames * 1000) / (now - then));
|
||||||
}
|
}
|
||||||
quit(0);
|
quit(0);
|
||||||
|
@ -336,7 +339,7 @@ main(int argc, char *argv[])
|
||||||
int
|
int
|
||||||
main(int argc, char *argv[])
|
main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
printf("No OpenGL ES support on this system\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "No OpenGL ES support on this system\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,6 @@ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||||
* includes
|
* includes
|
||||||
*/
|
*/
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdio.h> /* printf */
|
|
||||||
#include <string.h> /* strstr */
|
#include <string.h> /* strstr */
|
||||||
#include <ctype.h> /* isdigit */
|
#include <ctype.h> /* isdigit */
|
||||||
|
|
||||||
|
@ -62,12 +61,15 @@ main(int argc, char **argv)
|
||||||
int nefx;
|
int nefx;
|
||||||
unsigned int supported;
|
unsigned int supported;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
name = NULL;
|
name = NULL;
|
||||||
index = -1;
|
index = -1;
|
||||||
if (argc > 1) {
|
if (argc > 1) {
|
||||||
name = argv[1];
|
name = argv[1];
|
||||||
if ((strcmp(name, "--help") == 0) || (strcmp(name, "-h") == 0)) {
|
if ((strcmp(name, "--help") == 0) || (strcmp(name, "-h") == 0)) {
|
||||||
printf("USAGE: %s [device]\n"
|
SDL_Log("USAGE: %s [device]\n"
|
||||||
"If device is a two-digit number it'll use it as an index, otherwise\n"
|
"If device is a two-digit number it'll use it as an index, otherwise\n"
|
||||||
"it'll use it as if it were part of the device's name.\n",
|
"it'll use it as if it were part of the device's name.\n",
|
||||||
argv[0]);
|
argv[0]);
|
||||||
|
@ -84,7 +86,7 @@ main(int argc, char **argv)
|
||||||
/* Initialize the force feedbackness */
|
/* Initialize the force feedbackness */
|
||||||
SDL_Init(SDL_INIT_VIDEO | SDL_INIT_TIMER | SDL_INIT_JOYSTICK |
|
SDL_Init(SDL_INIT_VIDEO | SDL_INIT_TIMER | SDL_INIT_JOYSTICK |
|
||||||
SDL_INIT_HAPTIC);
|
SDL_INIT_HAPTIC);
|
||||||
printf("%d Haptic devices detected.\n", SDL_NumHaptics());
|
SDL_Log("%d Haptic devices detected.\n", SDL_NumHaptics());
|
||||||
if (SDL_NumHaptics() > 0) {
|
if (SDL_NumHaptics() > 0) {
|
||||||
/* We'll just use index or the first force feedback device found */
|
/* We'll just use index or the first force feedback device found */
|
||||||
if (name == NULL) {
|
if (name == NULL) {
|
||||||
|
@ -98,7 +100,7 @@ main(int argc, char **argv)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (i >= SDL_NumHaptics()) {
|
if (i >= SDL_NumHaptics()) {
|
||||||
printf("Unable to find device matching '%s', aborting.\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Unable to find device matching '%s', aborting.\n",
|
||||||
name);
|
name);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -106,14 +108,14 @@ main(int argc, char **argv)
|
||||||
|
|
||||||
haptic = SDL_HapticOpen(i);
|
haptic = SDL_HapticOpen(i);
|
||||||
if (haptic == NULL) {
|
if (haptic == NULL) {
|
||||||
printf("Unable to create the haptic device: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Unable to create the haptic device: %s\n",
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
printf("Device: %s\n", SDL_HapticName(i));
|
SDL_Log("Device: %s\n", SDL_HapticName(i));
|
||||||
HapticPrintSupported(haptic);
|
HapticPrintSupported(haptic);
|
||||||
} else {
|
} else {
|
||||||
printf("No Haptic devices found!\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "No Haptic devices found!\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -125,10 +127,10 @@ main(int argc, char **argv)
|
||||||
nefx = 0;
|
nefx = 0;
|
||||||
supported = SDL_HapticQuery(haptic);
|
supported = SDL_HapticQuery(haptic);
|
||||||
|
|
||||||
printf("\nUploading effects\n");
|
SDL_Log("\nUploading effects\n");
|
||||||
/* First we'll try a SINE effect. */
|
/* First we'll try a SINE effect. */
|
||||||
if (supported & SDL_HAPTIC_SINE) {
|
if (supported & SDL_HAPTIC_SINE) {
|
||||||
printf(" effect %d: Sine Wave\n", nefx);
|
SDL_Log(" effect %d: Sine Wave\n", nefx);
|
||||||
efx[nefx].type = SDL_HAPTIC_SINE;
|
efx[nefx].type = SDL_HAPTIC_SINE;
|
||||||
efx[nefx].periodic.period = 1000;
|
efx[nefx].periodic.period = 1000;
|
||||||
efx[nefx].periodic.magnitude = 0x4000;
|
efx[nefx].periodic.magnitude = 0x4000;
|
||||||
|
@ -137,14 +139,14 @@ main(int argc, char **argv)
|
||||||
efx[nefx].periodic.fade_length = 1000;
|
efx[nefx].periodic.fade_length = 1000;
|
||||||
id[nefx] = SDL_HapticNewEffect(haptic, &efx[nefx]);
|
id[nefx] = SDL_HapticNewEffect(haptic, &efx[nefx]);
|
||||||
if (id[nefx] < 0) {
|
if (id[nefx] < 0) {
|
||||||
printf("UPLOADING EFFECT ERROR: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "UPLOADING EFFECT ERROR: %s\n", SDL_GetError());
|
||||||
abort_execution();
|
abort_execution();
|
||||||
}
|
}
|
||||||
nefx++;
|
nefx++;
|
||||||
}
|
}
|
||||||
/* Now we'll try a SAWTOOTHUP */
|
/* Now we'll try a SAWTOOTHUP */
|
||||||
if (supported & SDL_HAPTIC_SAWTOOTHUP) {
|
if (supported & SDL_HAPTIC_SAWTOOTHUP) {
|
||||||
printf(" effect %d: Sawtooth Up\n", nefx);
|
SDL_Log(" effect %d: Sawtooth Up\n", nefx);
|
||||||
efx[nefx].type = SDL_HAPTIC_SAWTOOTHUP;
|
efx[nefx].type = SDL_HAPTIC_SAWTOOTHUP;
|
||||||
efx[nefx].periodic.period = 500;
|
efx[nefx].periodic.period = 500;
|
||||||
efx[nefx].periodic.magnitude = 0x5000;
|
efx[nefx].periodic.magnitude = 0x5000;
|
||||||
|
@ -153,14 +155,14 @@ main(int argc, char **argv)
|
||||||
efx[nefx].periodic.fade_length = 1000;
|
efx[nefx].periodic.fade_length = 1000;
|
||||||
id[nefx] = SDL_HapticNewEffect(haptic, &efx[nefx]);
|
id[nefx] = SDL_HapticNewEffect(haptic, &efx[nefx]);
|
||||||
if (id[nefx] < 0) {
|
if (id[nefx] < 0) {
|
||||||
printf("UPLOADING EFFECT ERROR: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "UPLOADING EFFECT ERROR: %s\n", SDL_GetError());
|
||||||
abort_execution();
|
abort_execution();
|
||||||
}
|
}
|
||||||
nefx++;
|
nefx++;
|
||||||
}
|
}
|
||||||
/* Now the classical constant effect. */
|
/* Now the classical constant effect. */
|
||||||
if (supported & SDL_HAPTIC_CONSTANT) {
|
if (supported & SDL_HAPTIC_CONSTANT) {
|
||||||
printf(" effect %d: Constant Force\n", nefx);
|
SDL_Log(" effect %d: Constant Force\n", nefx);
|
||||||
efx[nefx].type = SDL_HAPTIC_CONSTANT;
|
efx[nefx].type = SDL_HAPTIC_CONSTANT;
|
||||||
efx[nefx].constant.direction.type = SDL_HAPTIC_POLAR;
|
efx[nefx].constant.direction.type = SDL_HAPTIC_POLAR;
|
||||||
efx[nefx].constant.direction.dir[0] = 20000; /* Force comes from the south-west. */
|
efx[nefx].constant.direction.dir[0] = 20000; /* Force comes from the south-west. */
|
||||||
|
@ -170,14 +172,14 @@ main(int argc, char **argv)
|
||||||
efx[nefx].constant.fade_length = 1000;
|
efx[nefx].constant.fade_length = 1000;
|
||||||
id[nefx] = SDL_HapticNewEffect(haptic, &efx[nefx]);
|
id[nefx] = SDL_HapticNewEffect(haptic, &efx[nefx]);
|
||||||
if (id[nefx] < 0) {
|
if (id[nefx] < 0) {
|
||||||
printf("UPLOADING EFFECT ERROR: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "UPLOADING EFFECT ERROR: %s\n", SDL_GetError());
|
||||||
abort_execution();
|
abort_execution();
|
||||||
}
|
}
|
||||||
nefx++;
|
nefx++;
|
||||||
}
|
}
|
||||||
/* The cute spring effect. */
|
/* The cute spring effect. */
|
||||||
if (supported & SDL_HAPTIC_SPRING) {
|
if (supported & SDL_HAPTIC_SPRING) {
|
||||||
printf(" effect %d: Condition Spring\n", nefx);
|
SDL_Log(" effect %d: Condition Spring\n", nefx);
|
||||||
efx[nefx].type = SDL_HAPTIC_SPRING;
|
efx[nefx].type = SDL_HAPTIC_SPRING;
|
||||||
efx[nefx].condition.length = 5000;
|
efx[nefx].condition.length = 5000;
|
||||||
for (i = 0; i < SDL_HapticNumAxes(haptic); i++) {
|
for (i = 0; i < SDL_HapticNumAxes(haptic); i++) {
|
||||||
|
@ -189,14 +191,14 @@ main(int argc, char **argv)
|
||||||
}
|
}
|
||||||
id[nefx] = SDL_HapticNewEffect(haptic, &efx[nefx]);
|
id[nefx] = SDL_HapticNewEffect(haptic, &efx[nefx]);
|
||||||
if (id[nefx] < 0) {
|
if (id[nefx] < 0) {
|
||||||
printf("UPLOADING EFFECT ERROR: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "UPLOADING EFFECT ERROR: %s\n", SDL_GetError());
|
||||||
abort_execution();
|
abort_execution();
|
||||||
}
|
}
|
||||||
nefx++;
|
nefx++;
|
||||||
}
|
}
|
||||||
/* The pretty awesome inertia effect. */
|
/* The pretty awesome inertia effect. */
|
||||||
if (supported & SDL_HAPTIC_INERTIA) {
|
if (supported & SDL_HAPTIC_INERTIA) {
|
||||||
printf(" effect %d: Condition Inertia\n", nefx);
|
SDL_Log(" effect %d: Condition Inertia\n", nefx);
|
||||||
efx[nefx].type = SDL_HAPTIC_SPRING;
|
efx[nefx].type = SDL_HAPTIC_SPRING;
|
||||||
efx[nefx].condition.length = 5000;
|
efx[nefx].condition.length = 5000;
|
||||||
for (i = 0; i < SDL_HapticNumAxes(haptic); i++) {
|
for (i = 0; i < SDL_HapticNumAxes(haptic); i++) {
|
||||||
|
@ -207,7 +209,7 @@ main(int argc, char **argv)
|
||||||
}
|
}
|
||||||
id[nefx] = SDL_HapticNewEffect(haptic, &efx[nefx]);
|
id[nefx] = SDL_HapticNewEffect(haptic, &efx[nefx]);
|
||||||
if (id[nefx] < 0) {
|
if (id[nefx] < 0) {
|
||||||
printf("UPLOADING EFFECT ERROR: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "UPLOADING EFFECT ERROR: %s\n", SDL_GetError());
|
||||||
abort_execution();
|
abort_execution();
|
||||||
}
|
}
|
||||||
nefx++;
|
nefx++;
|
||||||
|
@ -215,24 +217,24 @@ main(int argc, char **argv)
|
||||||
|
|
||||||
/* Finally we'll try a left/right effect. */
|
/* Finally we'll try a left/right effect. */
|
||||||
if (supported & SDL_HAPTIC_LEFTRIGHT) {
|
if (supported & SDL_HAPTIC_LEFTRIGHT) {
|
||||||
printf(" effect %d: Left/Right\n", nefx);
|
SDL_Log(" effect %d: Left/Right\n", nefx);
|
||||||
efx[nefx].type = SDL_HAPTIC_LEFTRIGHT;
|
efx[nefx].type = SDL_HAPTIC_LEFTRIGHT;
|
||||||
efx[nefx].leftright.length = 5000;
|
efx[nefx].leftright.length = 5000;
|
||||||
efx[nefx].leftright.large_magnitude = 0x3000;
|
efx[nefx].leftright.large_magnitude = 0x3000;
|
||||||
efx[nefx].leftright.small_magnitude = 0xFFFF;
|
efx[nefx].leftright.small_magnitude = 0xFFFF;
|
||||||
id[nefx] = SDL_HapticNewEffect(haptic, &efx[nefx]);
|
id[nefx] = SDL_HapticNewEffect(haptic, &efx[nefx]);
|
||||||
if (id[nefx] < 0) {
|
if (id[nefx] < 0) {
|
||||||
printf("UPLOADING EFFECT ERROR: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "UPLOADING EFFECT ERROR: %s\n", SDL_GetError());
|
||||||
abort_execution();
|
abort_execution();
|
||||||
}
|
}
|
||||||
nefx++;
|
nefx++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
printf
|
SDL_Log
|
||||||
("\nNow playing effects for 5 seconds each with 1 second delay between\n");
|
("\nNow playing effects for 5 seconds each with 1 second delay between\n");
|
||||||
for (i = 0; i < nefx; i++) {
|
for (i = 0; i < nefx; i++) {
|
||||||
printf(" Playing effect %d\n", i);
|
SDL_Log(" Playing effect %d\n", i);
|
||||||
SDL_HapticRunEffect(haptic, id[i], 1);
|
SDL_HapticRunEffect(haptic, id[i], 1);
|
||||||
SDL_Delay(6000); /* Effects only have length 5000 */
|
SDL_Delay(6000); /* Effects only have length 5000 */
|
||||||
}
|
}
|
||||||
|
@ -252,7 +254,7 @@ main(int argc, char **argv)
|
||||||
static void
|
static void
|
||||||
abort_execution(void)
|
abort_execution(void)
|
||||||
{
|
{
|
||||||
printf("\nAborting program execution.\n");
|
SDL_Log("\nAborting program execution.\n");
|
||||||
|
|
||||||
SDL_HapticClose(haptic);
|
SDL_HapticClose(haptic);
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
|
@ -270,42 +272,42 @@ HapticPrintSupported(SDL_Haptic * haptic)
|
||||||
unsigned int supported;
|
unsigned int supported;
|
||||||
|
|
||||||
supported = SDL_HapticQuery(haptic);
|
supported = SDL_HapticQuery(haptic);
|
||||||
printf(" Supported effects [%d effects, %d playing]:\n",
|
SDL_Log(" Supported effects [%d effects, %d playing]:\n",
|
||||||
SDL_HapticNumEffects(haptic), SDL_HapticNumEffectsPlaying(haptic));
|
SDL_HapticNumEffects(haptic), SDL_HapticNumEffectsPlaying(haptic));
|
||||||
if (supported & SDL_HAPTIC_CONSTANT)
|
if (supported & SDL_HAPTIC_CONSTANT)
|
||||||
printf(" constant\n");
|
SDL_Log(" constant\n");
|
||||||
if (supported & SDL_HAPTIC_SINE)
|
if (supported & SDL_HAPTIC_SINE)
|
||||||
printf(" sine\n");
|
SDL_Log(" sine\n");
|
||||||
/* !!! FIXME: put this back when we have more bits in 2.1 */
|
/* !!! FIXME: put this back when we have more bits in 2.1 */
|
||||||
/*if (supported & SDL_HAPTIC_SQUARE)
|
/*if (supported & SDL_HAPTIC_SQUARE)
|
||||||
printf(" square\n");*/
|
SDL_Log(" square\n");*/
|
||||||
if (supported & SDL_HAPTIC_TRIANGLE)
|
if (supported & SDL_HAPTIC_TRIANGLE)
|
||||||
printf(" triangle\n");
|
SDL_Log(" triangle\n");
|
||||||
if (supported & SDL_HAPTIC_SAWTOOTHUP)
|
if (supported & SDL_HAPTIC_SAWTOOTHUP)
|
||||||
printf(" sawtoothup\n");
|
SDL_Log(" sawtoothup\n");
|
||||||
if (supported & SDL_HAPTIC_SAWTOOTHDOWN)
|
if (supported & SDL_HAPTIC_SAWTOOTHDOWN)
|
||||||
printf(" sawtoothdown\n");
|
SDL_Log(" sawtoothdown\n");
|
||||||
if (supported & SDL_HAPTIC_RAMP)
|
if (supported & SDL_HAPTIC_RAMP)
|
||||||
printf(" ramp\n");
|
SDL_Log(" ramp\n");
|
||||||
if (supported & SDL_HAPTIC_FRICTION)
|
if (supported & SDL_HAPTIC_FRICTION)
|
||||||
printf(" friction\n");
|
SDL_Log(" friction\n");
|
||||||
if (supported & SDL_HAPTIC_SPRING)
|
if (supported & SDL_HAPTIC_SPRING)
|
||||||
printf(" spring\n");
|
SDL_Log(" spring\n");
|
||||||
if (supported & SDL_HAPTIC_DAMPER)
|
if (supported & SDL_HAPTIC_DAMPER)
|
||||||
printf(" damper\n");
|
SDL_Log(" damper\n");
|
||||||
if (supported & SDL_HAPTIC_INERTIA)
|
if (supported & SDL_HAPTIC_INERTIA)
|
||||||
printf(" intertia\n");
|
SDL_Log(" inertia\n");
|
||||||
if (supported & SDL_HAPTIC_CUSTOM)
|
if (supported & SDL_HAPTIC_CUSTOM)
|
||||||
printf(" custom\n");
|
SDL_Log(" custom\n");
|
||||||
if (supported & SDL_HAPTIC_LEFTRIGHT)
|
if (supported & SDL_HAPTIC_LEFTRIGHT)
|
||||||
printf(" left/right\n");
|
SDL_Log(" left/right\n");
|
||||||
printf(" Supported capabilities:\n");
|
SDL_Log(" Supported capabilities:\n");
|
||||||
if (supported & SDL_HAPTIC_GAIN)
|
if (supported & SDL_HAPTIC_GAIN)
|
||||||
printf(" gain\n");
|
SDL_Log(" gain\n");
|
||||||
if (supported & SDL_HAPTIC_AUTOCENTER)
|
if (supported & SDL_HAPTIC_AUTOCENTER)
|
||||||
printf(" autocenter\n");
|
SDL_Log(" autocenter\n");
|
||||||
if (supported & SDL_HAPTIC_STATUS)
|
if (supported & SDL_HAPTIC_STATUS)
|
||||||
printf(" status\n");
|
SDL_Log(" status\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
@ -313,7 +315,7 @@ HapticPrintSupported(SDL_Haptic * haptic)
|
||||||
int
|
int
|
||||||
main(int argc, char *argv[])
|
main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
fprintf(stderr, "SDL compiled without Haptic support.\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL compiled without Haptic support.\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -49,12 +49,15 @@ main(int argc, char *argv[])
|
||||||
FILE *file;
|
FILE *file;
|
||||||
int errors = 0;
|
int errors = 0;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
if (!argv[1]) {
|
if (!argv[1]) {
|
||||||
argv[1] = "utf8.txt";
|
argv[1] = "utf8.txt";
|
||||||
}
|
}
|
||||||
file = fopen(argv[1], "rb");
|
file = fopen(argv[1], "rb");
|
||||||
if (!file) {
|
if (!file) {
|
||||||
fprintf(stderr, "Unable to open %s\n", argv[1]);
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Unable to open %s\n", argv[1]);
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -69,7 +72,7 @@ main(int argc, char *argv[])
|
||||||
test[0] = SDL_iconv_string(formats[i], "UCS-4", ucs4, len);
|
test[0] = SDL_iconv_string(formats[i], "UCS-4", ucs4, len);
|
||||||
test[1] = SDL_iconv_string("UCS-4", formats[i], test[0], len);
|
test[1] = SDL_iconv_string("UCS-4", formats[i], test[0], len);
|
||||||
if (!test[1] || SDL_memcmp(test[1], ucs4, len) != 0) {
|
if (!test[1] || SDL_memcmp(test[1], ucs4, len) != 0) {
|
||||||
fprintf(stderr, "FAIL: %s\n", formats[i]);
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "FAIL: %s\n", formats[i]);
|
||||||
++errors;
|
++errors;
|
||||||
}
|
}
|
||||||
if (test[0]) {
|
if (test[0]) {
|
||||||
|
|
|
@ -80,7 +80,7 @@ char *utf8_advance(char *p, size_t distance)
|
||||||
|
|
||||||
void usage()
|
void usage()
|
||||||
{
|
{
|
||||||
printf("usage: testime [--font fontfile]\n");
|
SDL_Log("usage: testime [--font fontfile]\n");
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -210,6 +210,9 @@ int main(int argc, char *argv[]) {
|
||||||
SDL_Event event;
|
SDL_Event event;
|
||||||
const char *fontname = DEFAULT_FONT;
|
const char *fontname = DEFAULT_FONT;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Initialize test framework */
|
/* Initialize test framework */
|
||||||
state = SDLTest_CommonCreateState(argv, SDL_INIT_VIDEO);
|
state = SDLTest_CommonCreateState(argv, SDL_INIT_VIDEO);
|
||||||
if (!state) {
|
if (!state) {
|
||||||
|
@ -251,12 +254,12 @@ int main(int argc, char *argv[]) {
|
||||||
font = TTF_OpenFont(fontname, DEFAULT_PTSIZE);
|
font = TTF_OpenFont(fontname, DEFAULT_PTSIZE);
|
||||||
if (! font)
|
if (! font)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Failed to find font: %s\n", TTF_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to find font: %s\n", TTF_GetError());
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
printf("Using font: %s\n", fontname);
|
SDL_Log("Using font: %s\n", fontname);
|
||||||
atexit(SDL_Quit);
|
atexit(SDL_Quit);
|
||||||
|
|
||||||
InitInput();
|
InitInput();
|
||||||
|
@ -321,8 +324,7 @@ int main(int argc, char *argv[]) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(stderr,
|
SDL_Log("Keyboard: scancode 0x%08X = %s, keycode 0x%08X = %s\n",
|
||||||
"Keyboard: scancode 0x%08X = %s, keycode 0x%08X = %s\n",
|
|
||||||
event.key.keysym.scancode,
|
event.key.keysym.scancode,
|
||||||
SDL_GetScancodeName(event.key.keysym.scancode),
|
SDL_GetScancodeName(event.key.keysym.scancode),
|
||||||
event.key.keysym.sym, SDL_GetKeyName(event.key.keysym.sym));
|
event.key.keysym.sym, SDL_GetKeyName(event.key.keysym.sym));
|
||||||
|
@ -333,12 +335,12 @@ int main(int argc, char *argv[]) {
|
||||||
markedRect.w < 0)
|
markedRect.w < 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
fprintf(stderr, "Keyboard: text input \"%s\"\n", event.text.text);
|
SDL_Log("Keyboard: text input \"%s\"\n", event.text.text);
|
||||||
|
|
||||||
if (SDL_strlen(text) + SDL_strlen(event.text.text) < sizeof(text))
|
if (SDL_strlen(text) + SDL_strlen(event.text.text) < sizeof(text))
|
||||||
SDL_strlcat(text, event.text.text, sizeof(text));
|
SDL_strlcat(text, event.text.text, sizeof(text));
|
||||||
|
|
||||||
fprintf(stderr, "text inputed: %s\n", text);
|
SDL_Log("text inputed: %s\n", text);
|
||||||
|
|
||||||
// After text inputed, we can clear up markedText because it
|
// After text inputed, we can clear up markedText because it
|
||||||
// is committed
|
// is committed
|
||||||
|
@ -347,7 +349,7 @@ int main(int argc, char *argv[]) {
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SDL_TEXTEDITING:
|
case SDL_TEXTEDITING:
|
||||||
fprintf(stderr, "text editing \"%s\", selected range (%d, %d)\n",
|
SDL_Log("text editing \"%s\", selected range (%d, %d)\n",
|
||||||
event.edit.text, event.edit.start, event.edit.length);
|
event.edit.text, event.edit.start, event.edit.length);
|
||||||
|
|
||||||
strcpy(markedText, event.edit.text);
|
strcpy(markedText, event.edit.text);
|
||||||
|
|
|
@ -84,7 +84,7 @@ add_line(int x1, int y1, int x2, int y2)
|
||||||
if ((x1 == x2) && (y1 == y2))
|
if ((x1 == x2) && (y1 == y2))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
printf("adding line (%d, %d), (%d, %d)\n", x1, y1, x2, y2);
|
SDL_Log("adding line (%d, %d), (%d, %d)\n", x1, y1, x2, y2);
|
||||||
lines[num_lines].x = x1;
|
lines[num_lines].x = x1;
|
||||||
lines[num_lines].y = y1;
|
lines[num_lines].y = y1;
|
||||||
lines[num_lines].w = x2;
|
lines[num_lines].w = x2;
|
||||||
|
@ -133,7 +133,7 @@ add_rect(int x1, int y1, int x2, int y2)
|
||||||
if (y1 > y2)
|
if (y1 > y2)
|
||||||
SWAP(int, y1, y2);
|
SWAP(int, y1, y2);
|
||||||
|
|
||||||
printf("adding rect (%d, %d), (%d, %d) [%dx%d]\n", x1, y1, x2, y2,
|
SDL_Log("adding rect (%d, %d), (%d, %d) [%dx%d]\n", x1, y1, x2, y2,
|
||||||
x2 - x1, y2 - y1);
|
x2 - x1, y2 - y1);
|
||||||
|
|
||||||
rects[num_rects].x = x1;
|
rects[num_rects].x = x1;
|
||||||
|
@ -199,6 +199,9 @@ main(int argc, char *argv[])
|
||||||
SDL_Event event;
|
SDL_Event event;
|
||||||
Uint32 then, now, frames;
|
Uint32 then, now, frames;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Initialize parameters */
|
/* Initialize parameters */
|
||||||
num_objects = NUM_OBJECTS;
|
num_objects = NUM_OBJECTS;
|
||||||
|
|
||||||
|
@ -241,8 +244,7 @@ main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (consumed < 0) {
|
if (consumed < 0) {
|
||||||
fprintf(stderr,
|
SDL_Log("Usage: %s %s [--blend none|blend|add|mod] [--cyclecolor] [--cyclealpha]\n",
|
||||||
"Usage: %s %s [--blend none|blend|add|mod] [--cyclecolor] [--cyclealpha]\n",
|
|
||||||
argv[0], SDLTest_CommonUsage(state));
|
argv[0], SDLTest_CommonUsage(state));
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -327,7 +329,7 @@ main(int argc, char *argv[])
|
||||||
now = SDL_GetTicks();
|
now = SDL_GetTicks();
|
||||||
if (now > then) {
|
if (now > then) {
|
||||||
double fps = ((double) frames * 1000) / (now - then);
|
double fps = ((double) frames * 1000) / (now - then);
|
||||||
printf("%2.2f frames per second\n", fps);
|
SDL_Log("%2.2f frames per second\n", fps);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,13 +52,13 @@ WatchJoystick(SDL_Joystick * joystick)
|
||||||
SDL_WINDOWPOS_CENTERED, SCREEN_WIDTH,
|
SDL_WINDOWPOS_CENTERED, SCREEN_WIDTH,
|
||||||
SCREEN_HEIGHT, 0);
|
SCREEN_HEIGHT, 0);
|
||||||
if (window == NULL) {
|
if (window == NULL) {
|
||||||
fprintf(stderr, "Couldn't create window: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create window: %s\n", SDL_GetError());
|
||||||
return SDL_FALSE;
|
return SDL_FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
screen = SDL_CreateRenderer(window, -1, 0);
|
screen = SDL_CreateRenderer(window, -1, 0);
|
||||||
if (screen == NULL) {
|
if (screen == NULL) {
|
||||||
fprintf(stderr, "Couldn't create renderer: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create renderer: %s\n", SDL_GetError());
|
||||||
SDL_DestroyWindow(window);
|
SDL_DestroyWindow(window);
|
||||||
return SDL_FALSE;
|
return SDL_FALSE;
|
||||||
}
|
}
|
||||||
|
@ -70,9 +70,9 @@ WatchJoystick(SDL_Joystick * joystick)
|
||||||
|
|
||||||
/* Print info about the joystick we are watching */
|
/* Print info about the joystick we are watching */
|
||||||
name = SDL_JoystickName(joystick);
|
name = SDL_JoystickName(joystick);
|
||||||
printf("Watching joystick %d: (%s)\n", SDL_JoystickInstanceID(joystick),
|
SDL_Log("Watching joystick %d: (%s)\n", SDL_JoystickInstanceID(joystick),
|
||||||
name ? name : "Unknown Joystick");
|
name ? name : "Unknown Joystick");
|
||||||
printf("Joystick has %d axes, %d hats, %d balls, and %d buttons\n",
|
SDL_Log("Joystick has %d axes, %d hats, %d balls, and %d buttons\n",
|
||||||
SDL_JoystickNumAxes(joystick), SDL_JoystickNumHats(joystick),
|
SDL_JoystickNumAxes(joystick), SDL_JoystickNumHats(joystick),
|
||||||
SDL_JoystickNumBalls(joystick), SDL_JoystickNumButtons(joystick));
|
SDL_JoystickNumBalls(joystick), SDL_JoystickNumButtons(joystick));
|
||||||
|
|
||||||
|
@ -85,36 +85,36 @@ WatchJoystick(SDL_Joystick * joystick)
|
||||||
while (SDL_PollEvent(&event)) {
|
while (SDL_PollEvent(&event)) {
|
||||||
switch (event.type) {
|
switch (event.type) {
|
||||||
case SDL_JOYAXISMOTION:
|
case SDL_JOYAXISMOTION:
|
||||||
printf("Joystick %d axis %d value: %d\n",
|
SDL_Log("Joystick %d axis %d value: %d\n",
|
||||||
event.jaxis.which,
|
event.jaxis.which,
|
||||||
event.jaxis.axis, event.jaxis.value);
|
event.jaxis.axis, event.jaxis.value);
|
||||||
break;
|
break;
|
||||||
case SDL_JOYHATMOTION:
|
case SDL_JOYHATMOTION:
|
||||||
printf("Joystick %d hat %d value:",
|
SDL_Log("Joystick %d hat %d value:",
|
||||||
event.jhat.which, event.jhat.hat);
|
event.jhat.which, event.jhat.hat);
|
||||||
if (event.jhat.value == SDL_HAT_CENTERED)
|
if (event.jhat.value == SDL_HAT_CENTERED)
|
||||||
printf(" centered");
|
SDL_Log(" centered");
|
||||||
if (event.jhat.value & SDL_HAT_UP)
|
if (event.jhat.value & SDL_HAT_UP)
|
||||||
printf(" up");
|
SDL_Log(" up");
|
||||||
if (event.jhat.value & SDL_HAT_RIGHT)
|
if (event.jhat.value & SDL_HAT_RIGHT)
|
||||||
printf(" right");
|
SDL_Log(" right");
|
||||||
if (event.jhat.value & SDL_HAT_DOWN)
|
if (event.jhat.value & SDL_HAT_DOWN)
|
||||||
printf(" down");
|
SDL_Log(" down");
|
||||||
if (event.jhat.value & SDL_HAT_LEFT)
|
if (event.jhat.value & SDL_HAT_LEFT)
|
||||||
printf(" left");
|
SDL_Log(" left");
|
||||||
printf("\n");
|
SDL_Log("\n");
|
||||||
break;
|
break;
|
||||||
case SDL_JOYBALLMOTION:
|
case SDL_JOYBALLMOTION:
|
||||||
printf("Joystick %d ball %d delta: (%d,%d)\n",
|
SDL_Log("Joystick %d ball %d delta: (%d,%d)\n",
|
||||||
event.jball.which,
|
event.jball.which,
|
||||||
event.jball.ball, event.jball.xrel, event.jball.yrel);
|
event.jball.ball, event.jball.xrel, event.jball.yrel);
|
||||||
break;
|
break;
|
||||||
case SDL_JOYBUTTONDOWN:
|
case SDL_JOYBUTTONDOWN:
|
||||||
printf("Joystick %d button %d down\n",
|
SDL_Log("Joystick %d button %d down\n",
|
||||||
event.jbutton.which, event.jbutton.button);
|
event.jbutton.which, event.jbutton.button);
|
||||||
break;
|
break;
|
||||||
case SDL_JOYBUTTONUP:
|
case SDL_JOYBUTTONUP:
|
||||||
printf("Joystick %d button %d up\n",
|
SDL_Log("Joystick %d button %d up\n",
|
||||||
event.jbutton.which, event.jbutton.button);
|
event.jbutton.which, event.jbutton.button);
|
||||||
break;
|
break;
|
||||||
case SDL_KEYDOWN:
|
case SDL_KEYDOWN:
|
||||||
|
@ -211,31 +211,34 @@ main(int argc, char *argv[])
|
||||||
int i;
|
int i;
|
||||||
SDL_Joystick *joystick;
|
SDL_Joystick *joystick;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Initialize SDL (Note: video is required to start event loop) */
|
/* Initialize SDL (Note: video is required to start event loop) */
|
||||||
if (SDL_Init(SDL_INIT_VIDEO | SDL_INIT_JOYSTICK) < 0) {
|
if (SDL_Init(SDL_INIT_VIDEO | SDL_INIT_JOYSTICK) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Print information about the joysticks */
|
/* Print information about the joysticks */
|
||||||
printf("There are %d joysticks attached\n", SDL_NumJoysticks());
|
SDL_Log("There are %d joysticks attached\n", SDL_NumJoysticks());
|
||||||
for (i = 0; i < SDL_NumJoysticks(); ++i) {
|
for (i = 0; i < SDL_NumJoysticks(); ++i) {
|
||||||
name = SDL_JoystickNameForIndex(i);
|
name = SDL_JoystickNameForIndex(i);
|
||||||
printf("Joystick %d: %s\n", i, name ? name : "Unknown Joystick");
|
SDL_Log("Joystick %d: %s\n", i, name ? name : "Unknown Joystick");
|
||||||
joystick = SDL_JoystickOpen(i);
|
joystick = SDL_JoystickOpen(i);
|
||||||
if (joystick == NULL) {
|
if (joystick == NULL) {
|
||||||
fprintf(stderr, "SDL_JoystickOpen(%d) failed: %s\n", i,
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_JoystickOpen(%d) failed: %s\n", i,
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
} else {
|
} else {
|
||||||
char guid[64];
|
char guid[64];
|
||||||
SDL_JoystickGetGUIDString(SDL_JoystickGetGUID(joystick),
|
SDL_JoystickGetGUIDString(SDL_JoystickGetGUID(joystick),
|
||||||
guid, sizeof (guid));
|
guid, sizeof (guid));
|
||||||
printf(" axes: %d\n", SDL_JoystickNumAxes(joystick));
|
SDL_Log(" axes: %d\n", SDL_JoystickNumAxes(joystick));
|
||||||
printf(" balls: %d\n", SDL_JoystickNumBalls(joystick));
|
SDL_Log(" balls: %d\n", SDL_JoystickNumBalls(joystick));
|
||||||
printf(" hats: %d\n", SDL_JoystickNumHats(joystick));
|
SDL_Log(" hats: %d\n", SDL_JoystickNumHats(joystick));
|
||||||
printf(" buttons: %d\n", SDL_JoystickNumButtons(joystick));
|
SDL_Log(" buttons: %d\n", SDL_JoystickNumButtons(joystick));
|
||||||
printf("instance id: %d\n", SDL_JoystickInstanceID(joystick));
|
SDL_Log("instance id: %d\n", SDL_JoystickInstanceID(joystick));
|
||||||
printf(" guid: %s\n", guid);
|
SDL_Log(" guid: %s\n", guid);
|
||||||
SDL_JoystickClose(joystick);
|
SDL_JoystickClose(joystick);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -256,7 +259,7 @@ main(int argc, char *argv[])
|
||||||
while ( keepGoing ) {
|
while ( keepGoing ) {
|
||||||
if (joystick == NULL) {
|
if (joystick == NULL) {
|
||||||
if ( !reportederror ) {
|
if ( !reportederror ) {
|
||||||
printf("Couldn't open joystick %d: %s\n", atoi(argv[1]), SDL_GetError());
|
SDL_Log("Couldn't open joystick %d: %s\n", atoi(argv[1]), SDL_GetError());
|
||||||
keepGoing = SDL_FALSE;
|
keepGoing = SDL_FALSE;
|
||||||
reportederror = SDL_TRUE;
|
reportederror = SDL_TRUE;
|
||||||
}
|
}
|
||||||
|
@ -268,7 +271,7 @@ main(int argc, char *argv[])
|
||||||
|
|
||||||
joystick = NULL;
|
joystick = NULL;
|
||||||
if (keepGoing) {
|
if (keepGoing) {
|
||||||
printf("Waiting for attach\n");
|
SDL_Log("Waiting for attach\n");
|
||||||
}
|
}
|
||||||
while (keepGoing) {
|
while (keepGoing) {
|
||||||
SDL_WaitEvent(&event);
|
SDL_WaitEvent(&event);
|
||||||
|
@ -296,7 +299,7 @@ main(int argc, char *argv[])
|
||||||
int
|
int
|
||||||
main(int argc, char *argv[])
|
main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
fprintf(stderr, "SDL compiled without Joystick support.\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL compiled without Joystick support.\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,12 +24,15 @@ main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
SDL_Scancode scancode;
|
SDL_Scancode scancode;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
if (SDL_Init(SDL_INIT_VIDEO) < 0) {
|
if (SDL_Init(SDL_INIT_VIDEO) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
for (scancode = 0; scancode < SDL_NUM_SCANCODES; ++scancode) {
|
for (scancode = 0; scancode < SDL_NUM_SCANCODES; ++scancode) {
|
||||||
printf("Scancode #%d, \"%s\"\n", scancode,
|
SDL_Log("Scancode #%d, \"%s\"\n", scancode,
|
||||||
SDL_GetScancodeName(scancode));
|
SDL_GetScancodeName(scancode));
|
||||||
}
|
}
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
|
|
|
@ -33,14 +33,14 @@ main(int argc, char *argv[])
|
||||||
|
|
||||||
if (argc != 3) {
|
if (argc != 3) {
|
||||||
const char *app = argv[0];
|
const char *app = argv[0];
|
||||||
fprintf(stderr, "USAGE: %s <library> <functionname>\n", app);
|
SDL_Log("USAGE: %s <library> <functionname>\n", app);
|
||||||
fprintf(stderr, " %s --hello <lib with puts()>\n", app);
|
SDL_Log(" %s --hello <lib with puts()>\n", app);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Initialize SDL */
|
/* Initialize SDL */
|
||||||
if (SDL_Init(0) < 0) {
|
if (SDL_Init(0) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
return 2;
|
return 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -55,23 +55,23 @@ main(int argc, char *argv[])
|
||||||
|
|
||||||
lib = SDL_LoadObject(libname);
|
lib = SDL_LoadObject(libname);
|
||||||
if (lib == NULL) {
|
if (lib == NULL) {
|
||||||
fprintf(stderr, "SDL_LoadObject('%s') failed: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_LoadObject('%s') failed: %s\n",
|
||||||
libname, SDL_GetError());
|
libname, SDL_GetError());
|
||||||
retval = 3;
|
retval = 3;
|
||||||
} else {
|
} else {
|
||||||
fn = (fntype) SDL_LoadFunction(lib, symname);
|
fn = (fntype) SDL_LoadFunction(lib, symname);
|
||||||
if (fn == NULL) {
|
if (fn == NULL) {
|
||||||
fprintf(stderr, "SDL_LoadFunction('%s') failed: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_LoadFunction('%s') failed: %s\n",
|
||||||
symname, SDL_GetError());
|
symname, SDL_GetError());
|
||||||
retval = 4;
|
retval = 4;
|
||||||
} else {
|
} else {
|
||||||
printf("Found %s in %s at %p\n", symname, libname, fn);
|
SDL_Log("Found %s in %s at %p\n", symname, libname, fn);
|
||||||
if (hello) {
|
if (hello) {
|
||||||
printf("Calling function...\n");
|
SDL_Log("Calling function...\n");
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
fn(" HELLO, WORLD!\n");
|
fn(" HELLO, WORLD!\n");
|
||||||
printf("...apparently, we survived. :)\n");
|
SDL_Log("...apparently, we survived. :)\n");
|
||||||
printf("Unloading library...\n");
|
SDL_Log("Unloading library...\n");
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,7 +40,7 @@ SDL_Quit_Wrapper(void)
|
||||||
void
|
void
|
||||||
printid(void)
|
printid(void)
|
||||||
{
|
{
|
||||||
printf("Process %lu: exiting\n", SDL_ThreadID());
|
SDL_Log("Process %lu: exiting\n", SDL_ThreadID());
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -55,7 +55,7 @@ closemutex(int sig)
|
||||||
{
|
{
|
||||||
SDL_threadID id = SDL_ThreadID();
|
SDL_threadID id = SDL_ThreadID();
|
||||||
int i;
|
int i;
|
||||||
printf("Process %lu: Cleaning up...\n", id == mainthread ? 0 : id);
|
SDL_Log("Process %lu: Cleaning up...\n", id == mainthread ? 0 : id);
|
||||||
doterminate = 1;
|
doterminate = 1;
|
||||||
for (i = 0; i < 6; ++i)
|
for (i = 0; i < 6; ++i)
|
||||||
SDL_WaitThread(threads[i], NULL);
|
SDL_WaitThread(threads[i], NULL);
|
||||||
|
@ -69,23 +69,23 @@ Run(void *data)
|
||||||
if (SDL_ThreadID() == mainthread)
|
if (SDL_ThreadID() == mainthread)
|
||||||
signal(SIGTERM, closemutex);
|
signal(SIGTERM, closemutex);
|
||||||
while (!doterminate) {
|
while (!doterminate) {
|
||||||
printf("Process %lu ready to work\n", SDL_ThreadID());
|
SDL_Log("Process %lu ready to work\n", SDL_ThreadID());
|
||||||
if (SDL_LockMutex(mutex) < 0) {
|
if (SDL_LockMutex(mutex) < 0) {
|
||||||
fprintf(stderr, "Couldn't lock mutex: %s", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't lock mutex: %s", SDL_GetError());
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
printf("Process %lu, working!\n", SDL_ThreadID());
|
SDL_Log("Process %lu, working!\n", SDL_ThreadID());
|
||||||
SDL_Delay(1 * 1000);
|
SDL_Delay(1 * 1000);
|
||||||
printf("Process %lu, done!\n", SDL_ThreadID());
|
SDL_Log("Process %lu, done!\n", SDL_ThreadID());
|
||||||
if (SDL_UnlockMutex(mutex) < 0) {
|
if (SDL_UnlockMutex(mutex) < 0) {
|
||||||
fprintf(stderr, "Couldn't unlock mutex: %s", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't unlock mutex: %s", SDL_GetError());
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
/* If this sleep isn't done, then threads may starve */
|
/* If this sleep isn't done, then threads may starve */
|
||||||
SDL_Delay(10);
|
SDL_Delay(10);
|
||||||
}
|
}
|
||||||
if (SDL_ThreadID() == mainthread && doterminate) {
|
if (SDL_ThreadID() == mainthread && doterminate) {
|
||||||
printf("Process %lu: raising SIGTERM\n", SDL_ThreadID());
|
SDL_Log("Process %lu: raising SIGTERM\n", SDL_ThreadID());
|
||||||
raise(SIGTERM);
|
raise(SIGTERM);
|
||||||
}
|
}
|
||||||
return (0);
|
return (0);
|
||||||
|
@ -97,26 +97,29 @@ main(int argc, char *argv[])
|
||||||
int i;
|
int i;
|
||||||
int maxproc = 6;
|
int maxproc = 6;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Load the SDL library */
|
/* Load the SDL library */
|
||||||
if (SDL_Init(0) < 0) {
|
if (SDL_Init(0) < 0) {
|
||||||
fprintf(stderr, "%s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "%s\n", SDL_GetError());
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
atexit(SDL_Quit_Wrapper);
|
atexit(SDL_Quit_Wrapper);
|
||||||
|
|
||||||
if ((mutex = SDL_CreateMutex()) == NULL) {
|
if ((mutex = SDL_CreateMutex()) == NULL) {
|
||||||
fprintf(stderr, "Couldn't create mutex: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create mutex: %s\n", SDL_GetError());
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
mainthread = SDL_ThreadID();
|
mainthread = SDL_ThreadID();
|
||||||
printf("Main thread: %lu\n", mainthread);
|
SDL_Log("Main thread: %lu\n", mainthread);
|
||||||
atexit(printid);
|
atexit(printid);
|
||||||
for (i = 0; i < maxproc; ++i) {
|
for (i = 0; i < maxproc; ++i) {
|
||||||
char name[64];
|
char name[64];
|
||||||
SDL_snprintf(name, sizeof (name), "Worker%d", i);
|
SDL_snprintf(name, sizeof (name), "Worker%d", i);
|
||||||
if ((threads[i] = SDL_CreateThread(Run, name, NULL)) == NULL)
|
if ((threads[i] = SDL_CreateThread(Run, name, NULL)) == NULL)
|
||||||
fprintf(stderr, "Couldn't create thread!\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create thread!\n");
|
||||||
}
|
}
|
||||||
signal(SIGINT, terminate);
|
signal(SIGINT, terminate);
|
||||||
Run(NULL);
|
Run(NULL);
|
||||||
|
|
|
@ -62,7 +62,7 @@ button_messagebox(void *eventNumber)
|
||||||
|
|
||||||
success = SDL_ShowMessageBox(&data, &button);
|
success = SDL_ShowMessageBox(&data, &button);
|
||||||
if (success == -1) {
|
if (success == -1) {
|
||||||
printf("Error Presenting MessageBox: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Error Presenting MessageBox: %s\n", SDL_GetError());
|
||||||
if (eventNumber) {
|
if (eventNumber) {
|
||||||
SDL_UserEvent event;
|
SDL_UserEvent event;
|
||||||
event.type = (intptr_t)eventNumber;
|
event.type = (intptr_t)eventNumber;
|
||||||
|
@ -72,7 +72,7 @@ button_messagebox(void *eventNumber)
|
||||||
quit(2);
|
quit(2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
printf("Pressed button: %d, %s\n", button, button == 1 ? "Cancel" : "OK");
|
SDL_Log("Pressed button: %d, %s\n", button, button == 1 ? "Cancel" : "OK");
|
||||||
|
|
||||||
if (eventNumber) {
|
if (eventNumber) {
|
||||||
SDL_UserEvent event;
|
SDL_UserEvent event;
|
||||||
|
@ -88,12 +88,15 @@ main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
int success;
|
int success;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
success = SDL_ShowSimpleMessageBox(SDL_MESSAGEBOX_ERROR,
|
success = SDL_ShowSimpleMessageBox(SDL_MESSAGEBOX_ERROR,
|
||||||
"Simple MessageBox",
|
"Simple MessageBox",
|
||||||
"This is a simple error MessageBox",
|
"This is a simple error MessageBox",
|
||||||
NULL);
|
NULL);
|
||||||
if (success == -1) {
|
if (success == -1) {
|
||||||
printf("Error Presenting MessageBox: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Error Presenting MessageBox: %s\n", SDL_GetError());
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -102,7 +105,7 @@ main(int argc, char *argv[])
|
||||||
"This is a simple MessageBox with a newline:\r\nHello world!",
|
"This is a simple MessageBox with a newline:\r\nHello world!",
|
||||||
NULL);
|
NULL);
|
||||||
if (success == -1) {
|
if (success == -1) {
|
||||||
printf("Error Presenting MessageBox: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Error Presenting MessageBox: %s\n", SDL_GetError());
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,7 +115,7 @@ main(int argc, char *argv[])
|
||||||
"Unicode text: '牛肉西蘭花' ...",
|
"Unicode text: '牛肉西蘭花' ...",
|
||||||
NULL);
|
NULL);
|
||||||
if (success == -1) {
|
if (success == -1) {
|
||||||
printf("Error Presenting MessageBox: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Error Presenting MessageBox: %s\n", SDL_GetError());
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -122,7 +125,7 @@ main(int argc, char *argv[])
|
||||||
"Unicode text and newline:\r\n'牛肉西蘭花'\n'牛肉西蘭花'",
|
"Unicode text and newline:\r\n'牛肉西蘭花'\n'牛肉西蘭花'",
|
||||||
NULL);
|
NULL);
|
||||||
if (success == -1) {
|
if (success == -1) {
|
||||||
printf("Error Presenting MessageBox: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Error Presenting MessageBox: %s\n", SDL_GetError());
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -135,7 +138,7 @@ main(int argc, char *argv[])
|
||||||
subsystem on the main thread.
|
subsystem on the main thread.
|
||||||
*/
|
*/
|
||||||
if (SDL_Init(SDL_INIT_VIDEO) < 0) {
|
if (SDL_Init(SDL_INIT_VIDEO) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL video subsystem: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL video subsystem: %s\n", SDL_GetError());
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
|
@ -153,7 +156,7 @@ main(int argc, char *argv[])
|
||||||
|
|
||||||
SDL_WaitThread(thread, &status);
|
SDL_WaitThread(thread, &status);
|
||||||
|
|
||||||
printf("Message box thread return %i\n", status);
|
SDL_Log("Message box thread return %i\n", status);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Test showing a message box with a parent window */
|
/* Test showing a message box with a parent window */
|
||||||
|
@ -166,7 +169,7 @@ main(int argc, char *argv[])
|
||||||
"This is a simple error MessageBox with a parent window",
|
"This is a simple error MessageBox with a parent window",
|
||||||
window);
|
window);
|
||||||
if (success == -1) {
|
if (success == -1) {
|
||||||
printf("Error Presenting MessageBox: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Error Presenting MessageBox: %s\n", SDL_GetError());
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,6 @@
|
||||||
freely.
|
freely.
|
||||||
*/
|
*/
|
||||||
#include "SDL.h"
|
#include "SDL.h"
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
static SDL_AudioSpec spec;
|
static SDL_AudioSpec spec;
|
||||||
static Uint8 *sound = NULL; /* Pointer to wave data */
|
static Uint8 *sound = NULL; /* Pointer to wave data */
|
||||||
|
@ -51,7 +50,7 @@ test_multi_audio(int devcount)
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (devcount > 64) {
|
if (devcount > 64) {
|
||||||
fprintf(stderr, "Too many devices (%d), clamping to 64...\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Too many devices (%d), clamping to 64...\n",
|
||||||
devcount);
|
devcount);
|
||||||
devcount = 64;
|
devcount = 64;
|
||||||
}
|
}
|
||||||
|
@ -60,33 +59,33 @@ test_multi_audio(int devcount)
|
||||||
|
|
||||||
for (i = 0; i < devcount; i++) {
|
for (i = 0; i < devcount; i++) {
|
||||||
const char *devname = SDL_GetAudioDeviceName(i, 0);
|
const char *devname = SDL_GetAudioDeviceName(i, 0);
|
||||||
printf("playing on device #%d: ('%s')...", i, devname);
|
SDL_Log("playing on device #%d: ('%s')...", i, devname);
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
|
|
||||||
SDL_memset(&cbd[0], '\0', sizeof(callback_data));
|
SDL_memset(&cbd[0], '\0', sizeof(callback_data));
|
||||||
spec.userdata = &cbd[0];
|
spec.userdata = &cbd[0];
|
||||||
cbd[0].dev = SDL_OpenAudioDevice(devname, 0, &spec, NULL, 0);
|
cbd[0].dev = SDL_OpenAudioDevice(devname, 0, &spec, NULL, 0);
|
||||||
if (cbd[0].dev == 0) {
|
if (cbd[0].dev == 0) {
|
||||||
printf("\nOpen device failed: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Open device failed: %s\n", SDL_GetError());
|
||||||
} else {
|
} else {
|
||||||
SDL_PauseAudioDevice(cbd[0].dev, 0);
|
SDL_PauseAudioDevice(cbd[0].dev, 0);
|
||||||
while (!cbd[0].done)
|
while (!cbd[0].done)
|
||||||
SDL_Delay(100);
|
SDL_Delay(100);
|
||||||
SDL_PauseAudioDevice(cbd[0].dev, 1);
|
SDL_PauseAudioDevice(cbd[0].dev, 1);
|
||||||
printf("done.\n");
|
SDL_Log("done.\n");
|
||||||
SDL_CloseAudioDevice(cbd[0].dev);
|
SDL_CloseAudioDevice(cbd[0].dev);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_memset(cbd, '\0', sizeof(cbd));
|
SDL_memset(cbd, '\0', sizeof(cbd));
|
||||||
|
|
||||||
printf("playing on all devices...\n");
|
SDL_Log("playing on all devices...\n");
|
||||||
for (i = 0; i < devcount; i++) {
|
for (i = 0; i < devcount; i++) {
|
||||||
const char *devname = SDL_GetAudioDeviceName(i, 0);
|
const char *devname = SDL_GetAudioDeviceName(i, 0);
|
||||||
spec.userdata = &cbd[i];
|
spec.userdata = &cbd[i];
|
||||||
cbd[i].dev = SDL_OpenAudioDevice(devname, 0, &spec, NULL, 0);
|
cbd[i].dev = SDL_OpenAudioDevice(devname, 0, &spec, NULL, 0);
|
||||||
if (cbd[i].dev == 0) {
|
if (cbd[i].dev == 0) {
|
||||||
printf("Open device %d failed: %s\n", i, SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Open device %d failed: %s\n", i, SDL_GetError());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -113,7 +112,7 @@ test_multi_audio(int devcount)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("All done!\n");
|
SDL_Log("All done!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -122,17 +121,20 @@ main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
int devcount = 0;
|
int devcount = 0;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Load the SDL library */
|
/* Load the SDL library */
|
||||||
if (SDL_Init(SDL_INIT_AUDIO) < 0) {
|
if (SDL_Init(SDL_INIT_AUDIO) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("Using audio driver: %s\n", SDL_GetCurrentAudioDriver());
|
SDL_Log("Using audio driver: %s\n", SDL_GetCurrentAudioDriver());
|
||||||
|
|
||||||
devcount = SDL_GetNumAudioDevices(0);
|
devcount = SDL_GetNumAudioDevices(0);
|
||||||
if (devcount < 1) {
|
if (devcount < 1) {
|
||||||
fprintf(stderr, "Don't see any specific audio devices!\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Don't see any specific audio devices!\n");
|
||||||
} else {
|
} else {
|
||||||
if (argv[1] == NULL) {
|
if (argv[1] == NULL) {
|
||||||
argv[1] = "sample.wav";
|
argv[1] = "sample.wav";
|
||||||
|
@ -140,7 +142,7 @@ main(int argc, char **argv)
|
||||||
|
|
||||||
/* Load the wave file into memory */
|
/* Load the wave file into memory */
|
||||||
if (SDL_LoadWAV(argv[1], &spec, &sound, &soundlen) == NULL) {
|
if (SDL_LoadWAV(argv[1], &spec, &sound, &soundlen) == NULL) {
|
||||||
fprintf(stderr, "Couldn't load %s: %s\n", argv[1],
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't load %s: %s\n", argv[1],
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
} else {
|
} else {
|
||||||
test_multi_audio(devcount);
|
test_multi_audio(devcount);
|
||||||
|
|
|
@ -58,7 +58,7 @@ LoadSprite(SDL_Renderer *renderer, char *file)
|
||||||
/* Load the sprite image */
|
/* Load the sprite image */
|
||||||
temp = SDL_LoadBMP(file);
|
temp = SDL_LoadBMP(file);
|
||||||
if (temp == NULL) {
|
if (temp == NULL) {
|
||||||
fprintf(stderr, "Couldn't load %s: %s", file, SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't load %s: %s", file, SDL_GetError());
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,7 +70,7 @@ LoadSprite(SDL_Renderer *renderer, char *file)
|
||||||
/* Create textures from the image */
|
/* Create textures from the image */
|
||||||
sprite = SDL_CreateTextureFromSurface(renderer, temp);
|
sprite = SDL_CreateTextureFromSurface(renderer, temp);
|
||||||
if (!sprite) {
|
if (!sprite) {
|
||||||
fprintf(stderr, "Couldn't create texture: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create texture: %s\n", SDL_GetError());
|
||||||
SDL_FreeSurface(temp);
|
SDL_FreeSurface(temp);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -131,8 +131,11 @@ main(int argc, char *argv[])
|
||||||
int sprite_w, sprite_h;
|
int sprite_w, sprite_h;
|
||||||
SDL_Event event;
|
SDL_Event event;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
if (SDL_VideoInit(NULL) < 0) {
|
if (SDL_VideoInit(NULL) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL video: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL video: %s\n",
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
@ -146,19 +149,19 @@ main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!factory) {
|
if (!factory) {
|
||||||
fprintf(stderr, "Couldn't find native window code for %s driver\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't find native window code for %s driver\n",
|
||||||
driver);
|
driver);
|
||||||
quit(2);
|
quit(2);
|
||||||
}
|
}
|
||||||
printf("Creating native window for %s driver\n", driver);
|
SDL_Log("Creating native window for %s driver\n", driver);
|
||||||
native_window = factory->CreateNativeWindow(WINDOW_W, WINDOW_H);
|
native_window = factory->CreateNativeWindow(WINDOW_W, WINDOW_H);
|
||||||
if (!native_window) {
|
if (!native_window) {
|
||||||
fprintf(stderr, "Couldn't create native window\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create native window\n");
|
||||||
quit(3);
|
quit(3);
|
||||||
}
|
}
|
||||||
window = SDL_CreateWindowFrom(native_window);
|
window = SDL_CreateWindowFrom(native_window);
|
||||||
if (!window) {
|
if (!window) {
|
||||||
fprintf(stderr, "Couldn't create SDL window: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create SDL window: %s\n", SDL_GetError());
|
||||||
quit(4);
|
quit(4);
|
||||||
}
|
}
|
||||||
SDL_SetWindowTitle(window, "SDL Native Window Test");
|
SDL_SetWindowTitle(window, "SDL Native Window Test");
|
||||||
|
@ -166,7 +169,7 @@ main(int argc, char *argv[])
|
||||||
/* Create the renderer */
|
/* Create the renderer */
|
||||||
renderer = SDL_CreateRenderer(window, -1, 0);
|
renderer = SDL_CreateRenderer(window, -1, 0);
|
||||||
if (!renderer) {
|
if (!renderer) {
|
||||||
fprintf(stderr, "Couldn't create renderer: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create renderer: %s\n", SDL_GetError());
|
||||||
quit(5);
|
quit(5);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -185,7 +188,7 @@ main(int argc, char *argv[])
|
||||||
positions = (SDL_Rect *) SDL_malloc(NUM_SPRITES * sizeof(SDL_Rect));
|
positions = (SDL_Rect *) SDL_malloc(NUM_SPRITES * sizeof(SDL_Rect));
|
||||||
velocities = (SDL_Rect *) SDL_malloc(NUM_SPRITES * sizeof(SDL_Rect));
|
velocities = (SDL_Rect *) SDL_malloc(NUM_SPRITES * sizeof(SDL_Rect));
|
||||||
if (!positions || !velocities) {
|
if (!positions || !velocities) {
|
||||||
fprintf(stderr, "Out of memory!\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Out of memory!\n");
|
||||||
quit(2);
|
quit(2);
|
||||||
}
|
}
|
||||||
srand(time(NULL));
|
srand(time(NULL));
|
||||||
|
|
|
@ -209,19 +209,18 @@ ConvertRGBtoYV12(Uint8 *rgb, Uint8 *out, int w, int h,
|
||||||
static void
|
static void
|
||||||
PrintUsage(char *argv0)
|
PrintUsage(char *argv0)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Usage: %s [arg] [arg] [arg] ...\n", argv0);
|
SDL_Log("Usage: %s [arg] [arg] [arg] ...\n", argv0);
|
||||||
fprintf(stderr, "\n");
|
SDL_Log("\n");
|
||||||
fprintf(stderr, "Where 'arg' is any of the following options:\n");
|
SDL_Log("Where 'arg' is any of the following options:\n");
|
||||||
fprintf(stderr, "\n");
|
SDL_Log("\n");
|
||||||
fprintf(stderr, " -fps <frames per second>\n");
|
SDL_Log(" -fps <frames per second>\n");
|
||||||
fprintf(stderr, " -nodelay\n");
|
SDL_Log(" -nodelay\n");
|
||||||
fprintf(stderr, " -format <fmt> (one of the: YV12, IYUV, YUY2, UYVY, YVYU)\n");
|
SDL_Log(" -format <fmt> (one of the: YV12, IYUV, YUY2, UYVY, YVYU)\n");
|
||||||
fprintf(stderr, " -scale <scale factor> (initial scale of the overlay)\n");
|
SDL_Log(" -scale <scale factor> (initial scale of the overlay)\n");
|
||||||
fprintf(stderr, " -help (shows this help)\n");
|
SDL_Log(" -help (shows this help)\n");
|
||||||
fprintf(stderr, "\n");
|
SDL_Log("\n");
|
||||||
fprintf(stderr,
|
SDL_Log("Press ESC to exit, or SPACE to freeze the movie while application running.\n");
|
||||||
"Press ESC to exit, or SPACE to freeze the movie while application running.\n");
|
SDL_Log("\n");
|
||||||
fprintf(stderr, "\n");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
|
@ -246,8 +245,11 @@ main(int argc, char **argv)
|
||||||
int scale = 5;
|
int scale = 5;
|
||||||
SDL_bool done = SDL_FALSE;
|
SDL_bool done = SDL_FALSE;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
if (SDL_Init(SDL_INIT_VIDEO) < 0) {
|
if (SDL_Init(SDL_INIT_VIDEO) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
return 3;
|
return 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -256,19 +258,19 @@ main(int argc, char **argv)
|
||||||
if (argv[2]) {
|
if (argv[2]) {
|
||||||
fps = atoi(argv[2]);
|
fps = atoi(argv[2]);
|
||||||
if (fps == 0) {
|
if (fps == 0) {
|
||||||
fprintf(stderr,
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,
|
||||||
"The -fps option requires an argument [from 1 to 1000], default is 12.\n");
|
"The -fps option requires an argument [from 1 to 1000], default is 12.\n");
|
||||||
quit(10);
|
quit(10);
|
||||||
}
|
}
|
||||||
if ((fps < 0) || (fps > 1000)) {
|
if ((fps < 0) || (fps > 1000)) {
|
||||||
fprintf(stderr,
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,
|
||||||
"The -fps option must be in range from 1 to 1000, default is 12.\n");
|
"The -fps option must be in range from 1 to 1000, default is 12.\n");
|
||||||
quit(10);
|
quit(10);
|
||||||
}
|
}
|
||||||
argv += 2;
|
argv += 2;
|
||||||
argc -= 2;
|
argc -= 2;
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr,
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,
|
||||||
"The -fps option requires an argument [from 1 to 1000], default is 12.\n");
|
"The -fps option requires an argument [from 1 to 1000], default is 12.\n");
|
||||||
quit(10);
|
quit(10);
|
||||||
}
|
}
|
||||||
|
@ -280,19 +282,19 @@ main(int argc, char **argv)
|
||||||
if (argv[2]) {
|
if (argv[2]) {
|
||||||
scale = atoi(argv[2]);
|
scale = atoi(argv[2]);
|
||||||
if (scale == 0) {
|
if (scale == 0) {
|
||||||
fprintf(stderr,
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,
|
||||||
"The -scale option requires an argument [from 1 to 50], default is 5.\n");
|
"The -scale option requires an argument [from 1 to 50], default is 5.\n");
|
||||||
quit(10);
|
quit(10);
|
||||||
}
|
}
|
||||||
if ((scale < 0) || (scale > 50)) {
|
if ((scale < 0) || (scale > 50)) {
|
||||||
fprintf(stderr,
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,
|
||||||
"The -scale option must be in range from 1 to 50, default is 5.\n");
|
"The -scale option must be in range from 1 to 50, default is 5.\n");
|
||||||
quit(10);
|
quit(10);
|
||||||
}
|
}
|
||||||
argv += 2;
|
argv += 2;
|
||||||
argc -= 2;
|
argc -= 2;
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr,
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,
|
||||||
"The -fps option requires an argument [from 1 to 1000], default is 12.\n");
|
"The -fps option requires an argument [from 1 to 1000], default is 12.\n");
|
||||||
quit(10);
|
quit(10);
|
||||||
}
|
}
|
||||||
|
@ -301,7 +303,7 @@ main(int argc, char **argv)
|
||||||
PrintUsage(argv[0]);
|
PrintUsage(argv[0]);
|
||||||
quit(0);
|
quit(0);
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "Unrecognized option: %s.\n", argv[1]);
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Unrecognized option: %s.\n", argv[1]);
|
||||||
quit(10);
|
quit(10);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -309,7 +311,7 @@ main(int argc, char **argv)
|
||||||
|
|
||||||
RawMooseData = (Uint8 *) malloc(MOOSEFRAME_SIZE * MOOSEFRAMES_COUNT);
|
RawMooseData = (Uint8 *) malloc(MOOSEFRAME_SIZE * MOOSEFRAMES_COUNT);
|
||||||
if (RawMooseData == NULL) {
|
if (RawMooseData == NULL) {
|
||||||
fprintf(stderr, "Can't allocate memory for movie !\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Can't allocate memory for movie !\n");
|
||||||
free(RawMooseData);
|
free(RawMooseData);
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
|
@ -317,7 +319,7 @@ main(int argc, char **argv)
|
||||||
/* load the trojan moose images */
|
/* load the trojan moose images */
|
||||||
handle = SDL_RWFromFile("moose.dat", "rb");
|
handle = SDL_RWFromFile("moose.dat", "rb");
|
||||||
if (handle == NULL) {
|
if (handle == NULL) {
|
||||||
fprintf(stderr, "Can't find the file moose.dat !\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Can't find the file moose.dat !\n");
|
||||||
free(RawMooseData);
|
free(RawMooseData);
|
||||||
quit(2);
|
quit(2);
|
||||||
}
|
}
|
||||||
|
@ -335,21 +337,21 @@ main(int argc, char **argv)
|
||||||
window_w, window_h,
|
window_w, window_h,
|
||||||
SDL_WINDOW_RESIZABLE);
|
SDL_WINDOW_RESIZABLE);
|
||||||
if (!window) {
|
if (!window) {
|
||||||
fprintf(stderr, "Couldn't set create window: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't set create window: %s\n", SDL_GetError());
|
||||||
free(RawMooseData);
|
free(RawMooseData);
|
||||||
quit(4);
|
quit(4);
|
||||||
}
|
}
|
||||||
|
|
||||||
renderer = SDL_CreateRenderer(window, -1, 0);
|
renderer = SDL_CreateRenderer(window, -1, 0);
|
||||||
if (!renderer) {
|
if (!renderer) {
|
||||||
fprintf(stderr, "Couldn't set create renderer: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't set create renderer: %s\n", SDL_GetError());
|
||||||
free(RawMooseData);
|
free(RawMooseData);
|
||||||
quit(4);
|
quit(4);
|
||||||
}
|
}
|
||||||
|
|
||||||
MooseTexture = SDL_CreateTexture(renderer, pixel_format, SDL_TEXTUREACCESS_STREAMING, MOOSEPIC_W, MOOSEPIC_H);
|
MooseTexture = SDL_CreateTexture(renderer, pixel_format, SDL_TEXTUREACCESS_STREAMING, MOOSEPIC_W, MOOSEPIC_H);
|
||||||
if (!MooseTexture) {
|
if (!MooseTexture) {
|
||||||
fprintf(stderr, "Couldn't set create texture: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't set create texture: %s\n", SDL_GetError());
|
||||||
free(RawMooseData);
|
free(RawMooseData);
|
||||||
quit(5);
|
quit(5);
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,30 +35,30 @@ TestTypes(SDL_bool verbose)
|
||||||
|
|
||||||
if (badsize(sizeof(Uint8), 1)) {
|
if (badsize(sizeof(Uint8), 1)) {
|
||||||
if (verbose)
|
if (verbose)
|
||||||
printf("sizeof(Uint8) != 1, instead = %u\n",
|
SDL_Log("sizeof(Uint8) != 1, instead = %u\n",
|
||||||
(unsigned int)sizeof(Uint8));
|
(unsigned int)sizeof(Uint8));
|
||||||
++error;
|
++error;
|
||||||
}
|
}
|
||||||
if (badsize(sizeof(Uint16), 2)) {
|
if (badsize(sizeof(Uint16), 2)) {
|
||||||
if (verbose)
|
if (verbose)
|
||||||
printf("sizeof(Uint16) != 2, instead = %u\n",
|
SDL_Log("sizeof(Uint16) != 2, instead = %u\n",
|
||||||
(unsigned int)sizeof(Uint16));
|
(unsigned int)sizeof(Uint16));
|
||||||
++error;
|
++error;
|
||||||
}
|
}
|
||||||
if (badsize(sizeof(Uint32), 4)) {
|
if (badsize(sizeof(Uint32), 4)) {
|
||||||
if (verbose)
|
if (verbose)
|
||||||
printf("sizeof(Uint32) != 4, instead = %u\n",
|
SDL_Log("sizeof(Uint32) != 4, instead = %u\n",
|
||||||
(unsigned int)sizeof(Uint32));
|
(unsigned int)sizeof(Uint32));
|
||||||
++error;
|
++error;
|
||||||
}
|
}
|
||||||
if (badsize(sizeof(Uint64), 8)) {
|
if (badsize(sizeof(Uint64), 8)) {
|
||||||
if (verbose)
|
if (verbose)
|
||||||
printf("sizeof(Uint64) != 8, instead = %u\n",
|
SDL_Log("sizeof(Uint64) != 8, instead = %u\n",
|
||||||
(unsigned int)sizeof(Uint64));
|
(unsigned int)sizeof(Uint64));
|
||||||
++error;
|
++error;
|
||||||
}
|
}
|
||||||
if (verbose && !error)
|
if (verbose && !error)
|
||||||
printf("All data types are the expected size.\n");
|
SDL_Log("All data types are the expected size.\n");
|
||||||
|
|
||||||
return (error ? 1 : 0);
|
return (error ? 1 : 0);
|
||||||
}
|
}
|
||||||
|
@ -83,7 +83,7 @@ TestEndian(SDL_bool verbose)
|
||||||
swapped64 |= 0xDEADBEEF;
|
swapped64 |= 0xDEADBEEF;
|
||||||
|
|
||||||
if (verbose) {
|
if (verbose) {
|
||||||
printf("Detected a %s endian machine.\n",
|
SDL_Log("Detected a %s endian machine.\n",
|
||||||
(SDL_BYTEORDER == SDL_LIL_ENDIAN) ? "little" : "big");
|
(SDL_BYTEORDER == SDL_LIL_ENDIAN) ? "little" : "big");
|
||||||
}
|
}
|
||||||
if ((*((char *) &value) >> 4) == 0x1) {
|
if ((*((char *) &value) >> 4) == 0x1) {
|
||||||
|
@ -93,44 +93,44 @@ TestEndian(SDL_bool verbose)
|
||||||
}
|
}
|
||||||
if (real_byteorder != SDL_BYTEORDER) {
|
if (real_byteorder != SDL_BYTEORDER) {
|
||||||
if (verbose) {
|
if (verbose) {
|
||||||
printf("Actually a %s endian machine!\n",
|
SDL_Log("Actually a %s endian machine!\n",
|
||||||
(real_byteorder == SDL_LIL_ENDIAN) ? "little" : "big");
|
(real_byteorder == SDL_LIL_ENDIAN) ? "little" : "big");
|
||||||
}
|
}
|
||||||
++error;
|
++error;
|
||||||
}
|
}
|
||||||
if (verbose) {
|
if (verbose) {
|
||||||
printf("Value 16 = 0x%X, swapped = 0x%X\n", value16,
|
SDL_Log("Value 16 = 0x%X, swapped = 0x%X\n", value16,
|
||||||
SDL_Swap16(value16));
|
SDL_Swap16(value16));
|
||||||
}
|
}
|
||||||
if (SDL_Swap16(value16) != swapped16) {
|
if (SDL_Swap16(value16) != swapped16) {
|
||||||
if (verbose) {
|
if (verbose) {
|
||||||
printf("16 bit value swapped incorrectly!\n");
|
SDL_Log("16 bit value swapped incorrectly!\n");
|
||||||
}
|
}
|
||||||
++error;
|
++error;
|
||||||
}
|
}
|
||||||
if (verbose) {
|
if (verbose) {
|
||||||
printf("Value 32 = 0x%X, swapped = 0x%X\n", value32,
|
SDL_Log("Value 32 = 0x%X, swapped = 0x%X\n", value32,
|
||||||
SDL_Swap32(value32));
|
SDL_Swap32(value32));
|
||||||
}
|
}
|
||||||
if (SDL_Swap32(value32) != swapped32) {
|
if (SDL_Swap32(value32) != swapped32) {
|
||||||
if (verbose) {
|
if (verbose) {
|
||||||
printf("32 bit value swapped incorrectly!\n");
|
SDL_Log("32 bit value swapped incorrectly!\n");
|
||||||
}
|
}
|
||||||
++error;
|
++error;
|
||||||
}
|
}
|
||||||
if (verbose) {
|
if (verbose) {
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
printf("Value 64 = 0x%I64X, swapped = 0x%I64X\n", value64,
|
SDL_Log("Value 64 = 0x%I64X, swapped = 0x%I64X\n", value64,
|
||||||
SDL_Swap64(value64));
|
SDL_Swap64(value64));
|
||||||
#else
|
#else
|
||||||
printf("Value 64 = 0x%llX, swapped = 0x%llX\n",
|
SDL_Log("Value 64 = 0x%llX, swapped = 0x%llX\n",
|
||||||
(unsigned long long) value64,
|
(unsigned long long) value64,
|
||||||
(unsigned long long) SDL_Swap64(value64));
|
(unsigned long long) SDL_Swap64(value64));
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
if (SDL_Swap64(value64) != swapped64) {
|
if (SDL_Swap64(value64) != swapped64) {
|
||||||
if (verbose) {
|
if (verbose) {
|
||||||
printf("64 bit value swapped incorrectly!\n");
|
SDL_Log("64 bit value swapped incorrectly!\n");
|
||||||
}
|
}
|
||||||
++error;
|
++error;
|
||||||
}
|
}
|
||||||
|
@ -142,17 +142,17 @@ int
|
||||||
TestCPUInfo(SDL_bool verbose)
|
TestCPUInfo(SDL_bool verbose)
|
||||||
{
|
{
|
||||||
if (verbose) {
|
if (verbose) {
|
||||||
printf("CPU count: %d\n", SDL_GetCPUCount());
|
SDL_Log("CPU count: %d\n", SDL_GetCPUCount());
|
||||||
printf("CPU cache line size: %d\n", SDL_GetCPUCacheLineSize());
|
SDL_Log("CPU cache line size: %d\n", SDL_GetCPUCacheLineSize());
|
||||||
printf("RDTSC %s\n", SDL_HasRDTSC()? "detected" : "not detected");
|
SDL_Log("RDTSC %s\n", SDL_HasRDTSC()? "detected" : "not detected");
|
||||||
printf("AltiVec %s\n", SDL_HasAltiVec()? "detected" : "not detected");
|
SDL_Log("AltiVec %s\n", SDL_HasAltiVec()? "detected" : "not detected");
|
||||||
printf("MMX %s\n", SDL_HasMMX()? "detected" : "not detected");
|
SDL_Log("MMX %s\n", SDL_HasMMX()? "detected" : "not detected");
|
||||||
printf("3DNow! %s\n", SDL_Has3DNow()? "detected" : "not detected");
|
SDL_Log("3DNow! %s\n", SDL_Has3DNow()? "detected" : "not detected");
|
||||||
printf("SSE %s\n", SDL_HasSSE()? "detected" : "not detected");
|
SDL_Log("SSE %s\n", SDL_HasSSE()? "detected" : "not detected");
|
||||||
printf("SSE2 %s\n", SDL_HasSSE2()? "detected" : "not detected");
|
SDL_Log("SSE2 %s\n", SDL_HasSSE2()? "detected" : "not detected");
|
||||||
printf("SSE3 %s\n", SDL_HasSSE3()? "detected" : "not detected");
|
SDL_Log("SSE3 %s\n", SDL_HasSSE3()? "detected" : "not detected");
|
||||||
printf("SSE4.1 %s\n", SDL_HasSSE41()? "detected" : "not detected");
|
SDL_Log("SSE4.1 %s\n", SDL_HasSSE41()? "detected" : "not detected");
|
||||||
printf("SSE4.2 %s\n", SDL_HasSSE42()? "detected" : "not detected");
|
SDL_Log("SSE4.2 %s\n", SDL_HasSSE42()? "detected" : "not detected");
|
||||||
}
|
}
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
@ -176,7 +176,7 @@ TestAssertions(SDL_bool verbose)
|
||||||
{
|
{
|
||||||
const SDL_assert_data *item = SDL_GetAssertionReport();
|
const SDL_assert_data *item = SDL_GetAssertionReport();
|
||||||
while (item) {
|
while (item) {
|
||||||
printf("'%s', %s (%s:%d), triggered %u times, always ignore: %s.\n",
|
SDL_Log("'%s', %s (%s:%d), triggered %u times, always ignore: %s.\n",
|
||||||
item->condition, item->function, item->filename,
|
item->condition, item->function, item->filename,
|
||||||
item->linenum, item->trigger_count,
|
item->linenum, item->trigger_count,
|
||||||
item->always_ignore ? "yes" : "no");
|
item->always_ignore ? "yes" : "no");
|
||||||
|
@ -192,11 +192,14 @@ main(int argc, char *argv[])
|
||||||
SDL_bool verbose = SDL_TRUE;
|
SDL_bool verbose = SDL_TRUE;
|
||||||
int status = 0;
|
int status = 0;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
if (argv[1] && (SDL_strcmp(argv[1], "-q") == 0)) {
|
if (argv[1] && (SDL_strcmp(argv[1], "-q") == 0)) {
|
||||||
verbose = SDL_FALSE;
|
verbose = SDL_FALSE;
|
||||||
}
|
}
|
||||||
if (verbose) {
|
if (verbose) {
|
||||||
printf("This system is running %s\n", SDL_GetPlatform());
|
SDL_Log("This system is running %s\n", SDL_GetPlatform());
|
||||||
}
|
}
|
||||||
|
|
||||||
status += TestTypes(verbose);
|
status += TestTypes(verbose);
|
||||||
|
|
|
@ -21,7 +21,7 @@ report_power(void)
|
||||||
const SDL_PowerState state = SDL_GetPowerInfo(&seconds, &percent);
|
const SDL_PowerState state = SDL_GetPowerInfo(&seconds, &percent);
|
||||||
char *statestr = NULL;
|
char *statestr = NULL;
|
||||||
|
|
||||||
printf("SDL-reported power info...\n");
|
SDL_Log("SDL-reported power info...\n");
|
||||||
switch (state) {
|
switch (state) {
|
||||||
case SDL_POWERSTATE_UNKNOWN:
|
case SDL_POWERSTATE_UNKNOWN:
|
||||||
statestr = "Unknown";
|
statestr = "Unknown";
|
||||||
|
@ -43,18 +43,18 @@ report_power(void)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("State: %s\n", statestr);
|
SDL_Log("State: %s\n", statestr);
|
||||||
|
|
||||||
if (percent == -1) {
|
if (percent == -1) {
|
||||||
printf("Percent left: unknown\n");
|
SDL_Log("Percent left: unknown\n");
|
||||||
} else {
|
} else {
|
||||||
printf("Percent left: %d%%\n", percent);
|
SDL_Log("Percent left: %d%%\n", percent);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (seconds == -1) {
|
if (seconds == -1) {
|
||||||
printf("Time left: unknown\n");
|
SDL_Log("Time left: unknown\n");
|
||||||
} else {
|
} else {
|
||||||
printf("Time left: %d minutes, %d seconds\n", (int) (seconds / 60),
|
SDL_Log("Time left: %d minutes, %d seconds\n", (int) (seconds / 60),
|
||||||
(int) (seconds % 60));
|
(int) (seconds % 60));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -63,8 +63,11 @@ report_power(void)
|
||||||
int
|
int
|
||||||
main(int argc, char *argv[])
|
main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
if (SDL_Init(0) == -1) {
|
if (SDL_Init(0) == -1) {
|
||||||
fprintf(stderr, "SDL_Init() failed: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_Init() failed: %s\n", SDL_GetError());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -35,6 +35,8 @@ main(int argc, char *argv[])
|
||||||
int i, done;
|
int i, done;
|
||||||
SDL_Event event;
|
SDL_Event event;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Initialize test framework */
|
/* Initialize test framework */
|
||||||
state = SDLTest_CommonCreateState(argv, SDL_INIT_VIDEO);
|
state = SDLTest_CommonCreateState(argv, SDL_INIT_VIDEO);
|
||||||
|
@ -74,10 +76,8 @@ main(int argc, char *argv[])
|
||||||
switch(event.type) {
|
switch(event.type) {
|
||||||
case SDL_MOUSEMOTION:
|
case SDL_MOUSEMOTION:
|
||||||
{
|
{
|
||||||
/*printf("mouse motion ABS x %d y %d REL x %d y %d\n",event.motion.x,event.motion.y,event.motion.xrel,event.motion.yrel);*/
|
|
||||||
rect.x += event.motion.xrel;
|
rect.x += event.motion.xrel;
|
||||||
rect.y += event.motion.yrel;
|
rect.y += event.motion.yrel;
|
||||||
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,7 +46,7 @@ LoadTexture(SDL_Renderer *renderer, char *file, SDL_bool transparent)
|
||||||
/* Load the sprite image */
|
/* Load the sprite image */
|
||||||
temp = SDL_LoadBMP(file);
|
temp = SDL_LoadBMP(file);
|
||||||
if (temp == NULL) {
|
if (temp == NULL) {
|
||||||
fprintf(stderr, "Couldn't load %s: %s", file, SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't load %s: %s", file, SDL_GetError());
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -77,7 +77,7 @@ LoadTexture(SDL_Renderer *renderer, char *file, SDL_bool transparent)
|
||||||
/* Create textures from the image */
|
/* Create textures from the image */
|
||||||
texture = SDL_CreateTextureFromSurface(renderer, temp);
|
texture = SDL_CreateTextureFromSurface(renderer, temp);
|
||||||
if (!texture) {
|
if (!texture) {
|
||||||
fprintf(stderr, "Couldn't create texture: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create texture: %s\n", SDL_GetError());
|
||||||
SDL_FreeSurface(temp);
|
SDL_FreeSurface(temp);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -139,6 +139,9 @@ main(int argc, char *argv[])
|
||||||
int frames;
|
int frames;
|
||||||
Uint32 then, now;
|
Uint32 then, now;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Initialize test framework */
|
/* Initialize test framework */
|
||||||
state = SDLTest_CommonCreateState(argv, SDL_INIT_VIDEO);
|
state = SDLTest_CommonCreateState(argv, SDL_INIT_VIDEO);
|
||||||
if (!state) {
|
if (!state) {
|
||||||
|
@ -149,7 +152,7 @@ main(int argc, char *argv[])
|
||||||
|
|
||||||
consumed = SDLTest_CommonArg(state, i);
|
consumed = SDLTest_CommonArg(state, i);
|
||||||
if (consumed == 0) {
|
if (consumed == 0) {
|
||||||
fprintf(stderr, "Usage: %s %s\n", argv[0], SDLTest_CommonUsage(state));
|
SDL_Log("Usage: %s %s\n", argv[0], SDLTest_CommonUsage(state));
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
i += consumed;
|
i += consumed;
|
||||||
|
@ -193,7 +196,7 @@ main(int argc, char *argv[])
|
||||||
now = SDL_GetTicks();
|
now = SDL_GetTicks();
|
||||||
if (now > then) {
|
if (now > then) {
|
||||||
double fps = ((double) frames * 1000) / (now - then);
|
double fps = ((double) frames * 1000) / (now - then);
|
||||||
printf("%2.2f frames per second\n", fps);
|
SDL_Log("%2.2f frames per second\n", fps);
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_stack_free(drawstates);
|
SDL_stack_free(drawstates);
|
||||||
|
|
|
@ -46,7 +46,7 @@ LoadTexture(SDL_Renderer *renderer, char *file, SDL_bool transparent)
|
||||||
/* Load the sprite image */
|
/* Load the sprite image */
|
||||||
temp = SDL_LoadBMP(file);
|
temp = SDL_LoadBMP(file);
|
||||||
if (temp == NULL) {
|
if (temp == NULL) {
|
||||||
fprintf(stderr, "Couldn't load %s: %s", file, SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't load %s: %s", file, SDL_GetError());
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -77,7 +77,7 @@ LoadTexture(SDL_Renderer *renderer, char *file, SDL_bool transparent)
|
||||||
/* Create textures from the image */
|
/* Create textures from the image */
|
||||||
texture = SDL_CreateTextureFromSurface(renderer, temp);
|
texture = SDL_CreateTextureFromSurface(renderer, temp);
|
||||||
if (!texture) {
|
if (!texture) {
|
||||||
fprintf(stderr, "Couldn't create texture: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create texture: %s\n", SDL_GetError());
|
||||||
SDL_FreeSurface(temp);
|
SDL_FreeSurface(temp);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -114,7 +114,7 @@ DrawComposite(DrawState *s)
|
||||||
SDL_RenderCopy(s->renderer, A, NULL, NULL);
|
SDL_RenderCopy(s->renderer, A, NULL, NULL);
|
||||||
SDL_RenderReadPixels(s->renderer, NULL, SDL_PIXELFORMAT_ARGB8888, &P, sizeof(P));
|
SDL_RenderReadPixels(s->renderer, NULL, SDL_PIXELFORMAT_ARGB8888, &P, sizeof(P));
|
||||||
|
|
||||||
printf("Blended pixel: 0x%8.8X\n", P);
|
SDL_Log("Blended pixel: 0x%8.8X\n", P);
|
||||||
|
|
||||||
SDL_DestroyTexture(A);
|
SDL_DestroyTexture(A);
|
||||||
SDL_DestroyTexture(B);
|
SDL_DestroyTexture(B);
|
||||||
|
@ -218,6 +218,9 @@ main(int argc, char *argv[])
|
||||||
Uint32 then, now;
|
Uint32 then, now;
|
||||||
SDL_bool test_composite = SDL_FALSE;
|
SDL_bool test_composite = SDL_FALSE;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Initialize test framework */
|
/* Initialize test framework */
|
||||||
state = SDLTest_CommonCreateState(argv, SDL_INIT_VIDEO);
|
state = SDLTest_CommonCreateState(argv, SDL_INIT_VIDEO);
|
||||||
if (!state) {
|
if (!state) {
|
||||||
|
@ -235,8 +238,7 @@ main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (consumed < 0) {
|
if (consumed < 0) {
|
||||||
fprintf(stderr,
|
SDL_Log("Usage: %s %s [--composite]\n",
|
||||||
"Usage: %s %s [--composite]\n",
|
|
||||||
argv[0], SDLTest_CommonUsage(state));
|
argv[0], SDLTest_CommonUsage(state));
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
|
@ -289,7 +291,7 @@ main(int argc, char *argv[])
|
||||||
now = SDL_GetTicks();
|
now = SDL_GetTicks();
|
||||||
if (now > then) {
|
if (now > then) {
|
||||||
double fps = ((double) frames * 1000) / (now - then);
|
double fps = ((double) frames * 1000) / (now - then);
|
||||||
printf("%2.2f frames per second\n", fps);
|
SDL_Log("%2.2f frames per second\n", fps);
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_stack_free(drawstates);
|
SDL_stack_free(drawstates);
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
including commercial applications, and to alter it and redistribute it
|
including commercial applications, and to alter it and redistribute it
|
||||||
freely.
|
freely.
|
||||||
*/
|
*/
|
||||||
#include <stdio.h>
|
|
||||||
#include "SDL.h"
|
#include "SDL.h"
|
||||||
|
|
||||||
int
|
int
|
||||||
|
@ -25,27 +25,30 @@ main(int argc, char **argv)
|
||||||
int avgbytes = 0;
|
int avgbytes = 0;
|
||||||
SDL_RWops *io = NULL;
|
SDL_RWops *io = NULL;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
if (argc != 4) {
|
if (argc != 4) {
|
||||||
fprintf(stderr, "USAGE: %s in.wav out.wav newfreq\n", argv[0]);
|
SDL_Log("USAGE: %s in.wav out.wav newfreq\n", argv[0]);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
cvtfreq = SDL_atoi(argv[3]);
|
cvtfreq = SDL_atoi(argv[3]);
|
||||||
|
|
||||||
if (SDL_Init(SDL_INIT_AUDIO) == -1) {
|
if (SDL_Init(SDL_INIT_AUDIO) == -1) {
|
||||||
fprintf(stderr, "SDL_Init() failed: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_Init() failed: %s\n", SDL_GetError());
|
||||||
return 2;
|
return 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (SDL_LoadWAV(argv[1], &spec, &data, &len) == NULL) {
|
if (SDL_LoadWAV(argv[1], &spec, &data, &len) == NULL) {
|
||||||
fprintf(stderr, "failed to load %s: %s\n", argv[1], SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "failed to load %s: %s\n", argv[1], SDL_GetError());
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
return 3;
|
return 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (SDL_BuildAudioCVT(&cvt, spec.format, spec.channels, spec.freq,
|
if (SDL_BuildAudioCVT(&cvt, spec.format, spec.channels, spec.freq,
|
||||||
spec.format, spec.channels, cvtfreq) == -1) {
|
spec.format, spec.channels, cvtfreq) == -1) {
|
||||||
fprintf(stderr, "failed to build CVT: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "failed to build CVT: %s\n", SDL_GetError());
|
||||||
SDL_FreeWAV(data);
|
SDL_FreeWAV(data);
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
return 4;
|
return 4;
|
||||||
|
@ -54,7 +57,7 @@ main(int argc, char **argv)
|
||||||
cvt.len = len;
|
cvt.len = len;
|
||||||
cvt.buf = (Uint8 *) SDL_malloc(len * cvt.len_mult);
|
cvt.buf = (Uint8 *) SDL_malloc(len * cvt.len_mult);
|
||||||
if (cvt.buf == NULL) {
|
if (cvt.buf == NULL) {
|
||||||
fprintf(stderr, "Out of memory.\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Out of memory.\n");
|
||||||
SDL_FreeWAV(data);
|
SDL_FreeWAV(data);
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
return 5;
|
return 5;
|
||||||
|
@ -62,7 +65,7 @@ main(int argc, char **argv)
|
||||||
SDL_memcpy(cvt.buf, data, len);
|
SDL_memcpy(cvt.buf, data, len);
|
||||||
|
|
||||||
if (SDL_ConvertAudio(&cvt) == -1) {
|
if (SDL_ConvertAudio(&cvt) == -1) {
|
||||||
fprintf(stderr, "Conversion failed: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Conversion failed: %s\n", SDL_GetError());
|
||||||
SDL_free(cvt.buf);
|
SDL_free(cvt.buf);
|
||||||
SDL_FreeWAV(data);
|
SDL_FreeWAV(data);
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
|
@ -72,7 +75,7 @@ main(int argc, char **argv)
|
||||||
/* write out a WAV header... */
|
/* write out a WAV header... */
|
||||||
io = SDL_RWFromFile(argv[2], "wb");
|
io = SDL_RWFromFile(argv[2], "wb");
|
||||||
if (io == NULL) {
|
if (io == NULL) {
|
||||||
fprintf(stderr, "fopen('%s') failed: %s\n", argv[2], SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "fopen('%s') failed: %s\n", argv[2], SDL_GetError());
|
||||||
SDL_free(cvt.buf);
|
SDL_free(cvt.buf);
|
||||||
SDL_FreeWAV(data);
|
SDL_FreeWAV(data);
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
|
@ -99,7 +102,7 @@ main(int argc, char **argv)
|
||||||
SDL_RWwrite(io, cvt.buf, cvt.len_cvt, 1);
|
SDL_RWwrite(io, cvt.buf, cvt.len_cvt, 1);
|
||||||
|
|
||||||
if (SDL_RWclose(io) == -1) {
|
if (SDL_RWclose(io) == -1) {
|
||||||
fprintf(stderr, "fclose('%s') failed: %s\n", argv[2], SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "fclose('%s') failed: %s\n", argv[2], SDL_GetError());
|
||||||
SDL_free(cvt.buf);
|
SDL_free(cvt.buf);
|
||||||
SDL_FreeWAV(data);
|
SDL_FreeWAV(data);
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
|
|
|
@ -26,7 +26,6 @@ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||||
* includes
|
* includes
|
||||||
*/
|
*/
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdio.h> /* printf */
|
|
||||||
#include <string.h> /* strstr */
|
#include <string.h> /* strstr */
|
||||||
#include <ctype.h> /* isdigit */
|
#include <ctype.h> /* isdigit */
|
||||||
|
|
||||||
|
@ -51,12 +50,15 @@ main(int argc, char **argv)
|
||||||
char *name;
|
char *name;
|
||||||
int index;
|
int index;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
name = NULL;
|
name = NULL;
|
||||||
index = -1;
|
index = -1;
|
||||||
if (argc > 1) {
|
if (argc > 1) {
|
||||||
name = argv[1];
|
name = argv[1];
|
||||||
if ((strcmp(name, "--help") == 0) || (strcmp(name, "-h") == 0)) {
|
if ((strcmp(name, "--help") == 0) || (strcmp(name, "-h") == 0)) {
|
||||||
printf("USAGE: %s [device]\n"
|
SDL_Log("USAGE: %s [device]\n"
|
||||||
"If device is a two-digit number it'll use it as an index, otherwise\n"
|
"If device is a two-digit number it'll use it as an index, otherwise\n"
|
||||||
"it'll use it as if it were part of the device's name.\n",
|
"it'll use it as if it were part of the device's name.\n",
|
||||||
argv[0]);
|
argv[0]);
|
||||||
|
@ -73,7 +75,7 @@ main(int argc, char **argv)
|
||||||
/* Initialize the force feedbackness */
|
/* Initialize the force feedbackness */
|
||||||
SDL_Init(SDL_INIT_VIDEO | SDL_INIT_TIMER | SDL_INIT_JOYSTICK |
|
SDL_Init(SDL_INIT_VIDEO | SDL_INIT_TIMER | SDL_INIT_JOYSTICK |
|
||||||
SDL_INIT_HAPTIC);
|
SDL_INIT_HAPTIC);
|
||||||
printf("%d Haptic devices detected.\n", SDL_NumHaptics());
|
SDL_Log("%d Haptic devices detected.\n", SDL_NumHaptics());
|
||||||
if (SDL_NumHaptics() > 0) {
|
if (SDL_NumHaptics() > 0) {
|
||||||
/* We'll just use index or the first force feedback device found */
|
/* We'll just use index or the first force feedback device found */
|
||||||
if (name == NULL) {
|
if (name == NULL) {
|
||||||
|
@ -87,7 +89,7 @@ main(int argc, char **argv)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (i >= SDL_NumHaptics()) {
|
if (i >= SDL_NumHaptics()) {
|
||||||
printf("Unable to find device matching '%s', aborting.\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Unable to find device matching '%s', aborting.\n",
|
||||||
name);
|
name);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -95,13 +97,13 @@ main(int argc, char **argv)
|
||||||
|
|
||||||
haptic = SDL_HapticOpen(i);
|
haptic = SDL_HapticOpen(i);
|
||||||
if (haptic == NULL) {
|
if (haptic == NULL) {
|
||||||
printf("Unable to create the haptic device: %s\n",
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Unable to create the haptic device: %s\n",
|
||||||
SDL_GetError());
|
SDL_GetError());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
printf("Device: %s\n", SDL_HapticName(i));
|
SDL_Log("Device: %s\n", SDL_HapticName(i));
|
||||||
} else {
|
} else {
|
||||||
printf("No Haptic devices found!\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "No Haptic devices found!\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -109,25 +111,25 @@ main(int argc, char **argv)
|
||||||
SDL_ClearError();
|
SDL_ClearError();
|
||||||
|
|
||||||
if (SDL_HapticRumbleSupported(haptic) == SDL_FALSE) {
|
if (SDL_HapticRumbleSupported(haptic) == SDL_FALSE) {
|
||||||
printf("\nRumble not supported!\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Rumble not supported!\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
if (SDL_HapticRumbleInit(haptic) != 0) {
|
if (SDL_HapticRumbleInit(haptic) != 0) {
|
||||||
printf("\nFailed to initialize rumble: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to initialize rumble: %s\n", SDL_GetError());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
printf("Playing 2 second rumble at 0.5 magnitude.\n");
|
SDL_Log("Playing 2 second rumble at 0.5 magnitude.\n");
|
||||||
if (SDL_HapticRumblePlay(haptic, 0.5, 5000) != 0) {
|
if (SDL_HapticRumblePlay(haptic, 0.5, 5000) != 0) {
|
||||||
printf("\nFailed to play rumble: %s\n", SDL_GetError() );
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to play rumble: %s\n", SDL_GetError() );
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
SDL_Delay(2000);
|
SDL_Delay(2000);
|
||||||
printf("Stopping rumble.\n");
|
SDL_Log("Stopping rumble.\n");
|
||||||
SDL_HapticRumbleStop(haptic);
|
SDL_HapticRumbleStop(haptic);
|
||||||
SDL_Delay(2000);
|
SDL_Delay(2000);
|
||||||
printf("Playing 2 second rumble at 0.3 magnitude.\n");
|
SDL_Log("Playing 2 second rumble at 0.3 magnitude.\n");
|
||||||
if (SDL_HapticRumblePlay(haptic, 0.3f, 5000) != 0) {
|
if (SDL_HapticRumblePlay(haptic, 0.3f, 5000) != 0) {
|
||||||
printf("\nFailed to play rumble: %s\n", SDL_GetError() );
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to play rumble: %s\n", SDL_GetError() );
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
SDL_Delay(2000);
|
SDL_Delay(2000);
|
||||||
|
@ -145,7 +147,7 @@ main(int argc, char **argv)
|
||||||
int
|
int
|
||||||
main(int argc, char *argv[])
|
main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
fprintf(stderr, "SDL compiled without Haptic support.\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL compiled without Haptic support.\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -48,7 +48,7 @@ LoadTexture(SDL_Renderer *renderer, char *file, SDL_bool transparent)
|
||||||
/* Load the sprite image */
|
/* Load the sprite image */
|
||||||
temp = SDL_LoadBMP(file);
|
temp = SDL_LoadBMP(file);
|
||||||
if (temp == NULL) {
|
if (temp == NULL) {
|
||||||
fprintf(stderr, "Couldn't load %s: %s", file, SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't load %s: %s", file, SDL_GetError());
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -79,7 +79,7 @@ LoadTexture(SDL_Renderer *renderer, char *file, SDL_bool transparent)
|
||||||
/* Create textures from the image */
|
/* Create textures from the image */
|
||||||
texture = SDL_CreateTextureFromSurface(renderer, temp);
|
texture = SDL_CreateTextureFromSurface(renderer, temp);
|
||||||
if (!texture) {
|
if (!texture) {
|
||||||
fprintf(stderr, "Couldn't create texture: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create texture: %s\n", SDL_GetError());
|
||||||
SDL_FreeSurface(temp);
|
SDL_FreeSurface(temp);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -129,6 +129,9 @@ main(int argc, char *argv[])
|
||||||
int frames;
|
int frames;
|
||||||
Uint32 then, now;
|
Uint32 then, now;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Initialize test framework */
|
/* Initialize test framework */
|
||||||
state = SDLTest_CommonCreateState(argv, SDL_INIT_VIDEO);
|
state = SDLTest_CommonCreateState(argv, SDL_INIT_VIDEO);
|
||||||
if (!state) {
|
if (!state) {
|
||||||
|
@ -139,7 +142,7 @@ main(int argc, char *argv[])
|
||||||
|
|
||||||
consumed = SDLTest_CommonArg(state, i);
|
consumed = SDLTest_CommonArg(state, i);
|
||||||
if (consumed == 0) {
|
if (consumed == 0) {
|
||||||
fprintf(stderr, "Usage: %s %s\n", argv[0], SDLTest_CommonUsage(state));
|
SDL_Log("Usage: %s %s\n", argv[0], SDLTest_CommonUsage(state));
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
i += consumed;
|
i += consumed;
|
||||||
|
@ -183,7 +186,7 @@ main(int argc, char *argv[])
|
||||||
now = SDL_GetTicks();
|
now = SDL_GetTicks();
|
||||||
if (now > then) {
|
if (now > then) {
|
||||||
double fps = ((double) frames * 1000) / (now - then);
|
double fps = ((double) frames * 1000) / (now - then);
|
||||||
printf("%2.2f frames per second\n", fps);
|
SDL_Log("%2.2f frames per second\n", fps);
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_stack_free(drawstates);
|
SDL_stack_free(drawstates);
|
||||||
|
|
|
@ -30,17 +30,15 @@ ThreadFunc(void *data)
|
||||||
int threadnum = (int) (uintptr_t) data;
|
int threadnum = (int) (uintptr_t) data;
|
||||||
while (alive) {
|
while (alive) {
|
||||||
SDL_SemWait(sem);
|
SDL_SemWait(sem);
|
||||||
fprintf(stderr,
|
SDL_Log("Thread number %d has got the semaphore (value = %d)!\n",
|
||||||
"Thread number %d has got the semaphore (value = %d)!\n",
|
|
||||||
threadnum, SDL_SemValue(sem));
|
threadnum, SDL_SemValue(sem));
|
||||||
SDL_Delay(200);
|
SDL_Delay(200);
|
||||||
SDL_SemPost(sem);
|
SDL_SemPost(sem);
|
||||||
fprintf(stderr,
|
SDL_Log("Thread number %d has released the semaphore (value = %d)!\n",
|
||||||
"Thread number %d has released the semaphore (value = %d)!\n",
|
|
||||||
threadnum, SDL_SemValue(sem));
|
threadnum, SDL_SemValue(sem));
|
||||||
SDL_Delay(1); /* For the scheduler */
|
SDL_Delay(1); /* For the scheduler */
|
||||||
}
|
}
|
||||||
printf("Thread number %d exiting.\n", threadnum);
|
SDL_Log("Thread number %d exiting.\n", threadnum);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -59,7 +57,7 @@ TestWaitTimeout(void)
|
||||||
int retval;
|
int retval;
|
||||||
|
|
||||||
sem = SDL_CreateSemaphore(0);
|
sem = SDL_CreateSemaphore(0);
|
||||||
printf("Waiting 2 seconds on semaphore\n");
|
SDL_Log("Waiting 2 seconds on semaphore\n");
|
||||||
|
|
||||||
start_ticks = SDL_GetTicks();
|
start_ticks = SDL_GetTicks();
|
||||||
retval = SDL_SemWaitTimeout(sem, 2000);
|
retval = SDL_SemWaitTimeout(sem, 2000);
|
||||||
|
@ -69,13 +67,13 @@ TestWaitTimeout(void)
|
||||||
|
|
||||||
/* Accept a little offset in the effective wait */
|
/* Accept a little offset in the effective wait */
|
||||||
if (duration > 1900 && duration < 2050)
|
if (duration > 1900 && duration < 2050)
|
||||||
printf("Wait done.\n");
|
SDL_Log("Wait done.\n");
|
||||||
else
|
else
|
||||||
fprintf(stderr, "Wait took %d milliseconds\n", duration);
|
SDL_Log("Wait took %d milliseconds\n", duration);
|
||||||
|
|
||||||
/* Check to make sure the return value indicates timed out */
|
/* Check to make sure the return value indicates timed out */
|
||||||
if (retval != SDL_MUTEX_TIMEDOUT)
|
if (retval != SDL_MUTEX_TIMEDOUT)
|
||||||
fprintf(stderr, "SDL_SemWaitTimeout returned: %d; expected: %d\n", retval, SDL_MUTEX_TIMEDOUT);
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_SemWaitTimeout returned: %d; expected: %d\n", retval, SDL_MUTEX_TIMEDOUT);
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
|
@ -85,14 +83,17 @@ main(int argc, char **argv)
|
||||||
uintptr_t i;
|
uintptr_t i;
|
||||||
int init_sem;
|
int init_sem;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
if (argc < 2) {
|
if (argc < 2) {
|
||||||
fprintf(stderr, "Usage: %s init_value\n", argv[0]);
|
SDL_Log("Usage: %s init_value\n", argv[0]);
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Load the SDL library */
|
/* Load the SDL library */
|
||||||
if (SDL_Init(0) < 0) {
|
if (SDL_Init(0) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
signal(SIGTERM, killed);
|
signal(SIGTERM, killed);
|
||||||
|
@ -101,7 +102,7 @@ main(int argc, char **argv)
|
||||||
init_sem = atoi(argv[1]);
|
init_sem = atoi(argv[1]);
|
||||||
sem = SDL_CreateSemaphore(init_sem);
|
sem = SDL_CreateSemaphore(init_sem);
|
||||||
|
|
||||||
printf("Running %d threads, semaphore value = %d\n", NUM_THREADS,
|
SDL_Log("Running %d threads, semaphore value = %d\n", NUM_THREADS,
|
||||||
init_sem);
|
init_sem);
|
||||||
/* Create all the threads */
|
/* Create all the threads */
|
||||||
for (i = 0; i < NUM_THREADS; ++i) {
|
for (i = 0; i < NUM_THREADS; ++i) {
|
||||||
|
@ -114,12 +115,12 @@ main(int argc, char **argv)
|
||||||
SDL_Delay(10 * 1000);
|
SDL_Delay(10 * 1000);
|
||||||
|
|
||||||
/* Wait for all threads to finish */
|
/* Wait for all threads to finish */
|
||||||
printf("Waiting for threads to finish\n");
|
SDL_Log("Waiting for threads to finish\n");
|
||||||
alive = 0;
|
alive = 0;
|
||||||
for (i = 0; i < NUM_THREADS; ++i) {
|
for (i = 0; i < NUM_THREADS; ++i) {
|
||||||
SDL_WaitThread(threads[i], NULL);
|
SDL_WaitThread(threads[i], NULL);
|
||||||
}
|
}
|
||||||
printf("Finished waiting for threads\n");
|
SDL_Log("Finished waiting for threads\n");
|
||||||
|
|
||||||
SDL_DestroySemaphore(sem);
|
SDL_DestroySemaphore(sem);
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,6 @@
|
||||||
*/
|
*/
|
||||||
/* This is a simple example of using GLSL shaders with SDL */
|
/* This is a simple example of using GLSL shaders with SDL */
|
||||||
|
|
||||||
#include <stdio.h> /* for printf() */
|
|
||||||
#include "SDL.h"
|
#include "SDL.h"
|
||||||
|
|
||||||
#ifdef HAVE_OPENGL
|
#ifdef HAVE_OPENGL
|
||||||
|
@ -139,7 +138,7 @@ static SDL_bool CompileShader(GLhandleARB shader, const char *source)
|
||||||
glGetObjectParameterivARB(shader, GL_OBJECT_INFO_LOG_LENGTH_ARB, &length);
|
glGetObjectParameterivARB(shader, GL_OBJECT_INFO_LOG_LENGTH_ARB, &length);
|
||||||
info = SDL_stack_alloc(char, length+1);
|
info = SDL_stack_alloc(char, length+1);
|
||||||
glGetInfoLogARB(shader, length, NULL, info);
|
glGetInfoLogARB(shader, length, NULL, info);
|
||||||
fprintf(stderr, "Failed to compile shader:\n%s\n%s", source, info);
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Failed to compile shader:\n%s\n%s", source, info);
|
||||||
SDL_stack_free(info);
|
SDL_stack_free(info);
|
||||||
|
|
||||||
return SDL_FALSE;
|
return SDL_FALSE;
|
||||||
|
@ -245,7 +244,7 @@ static SDL_bool InitShaders()
|
||||||
/* Compile all the shaders */
|
/* Compile all the shaders */
|
||||||
for (i = 0; i < NUM_SHADERS; ++i) {
|
for (i = 0; i < NUM_SHADERS; ++i) {
|
||||||
if (!CompileShaderProgram(&shaders[i])) {
|
if (!CompileShaderProgram(&shaders[i])) {
|
||||||
fprintf(stderr, "Unable to compile shader!\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Unable to compile shader!\n");
|
||||||
return SDL_FALSE;
|
return SDL_FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -422,29 +421,32 @@ int main(int argc, char **argv)
|
||||||
GLuint texture;
|
GLuint texture;
|
||||||
GLfloat texcoords[4];
|
GLfloat texcoords[4];
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Initialize SDL for video output */
|
/* Initialize SDL for video output */
|
||||||
if ( SDL_Init(SDL_INIT_VIDEO) < 0 ) {
|
if ( SDL_Init(SDL_INIT_VIDEO) < 0 ) {
|
||||||
fprintf(stderr, "Unable to initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Unable to initialize SDL: %s\n", SDL_GetError());
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Create a 640x480 OpenGL screen */
|
/* Create a 640x480 OpenGL screen */
|
||||||
window = SDL_CreateWindow( "Shader Demo", SDL_WINDOWPOS_CENTERED, SDL_WINDOWPOS_CENTERED, 640, 480, SDL_WINDOW_OPENGL );
|
window = SDL_CreateWindow( "Shader Demo", SDL_WINDOWPOS_CENTERED, SDL_WINDOWPOS_CENTERED, 640, 480, SDL_WINDOW_OPENGL );
|
||||||
if ( !window ) {
|
if ( !window ) {
|
||||||
fprintf(stderr, "Unable to create OpenGL window: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Unable to create OpenGL window: %s\n", SDL_GetError());
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
exit(2);
|
exit(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( !SDL_GL_CreateContext(window)) {
|
if ( !SDL_GL_CreateContext(window)) {
|
||||||
fprintf(stderr, "Unable to create OpenGL context: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Unable to create OpenGL context: %s\n", SDL_GetError());
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
exit(2);
|
exit(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
surface = SDL_LoadBMP("icon.bmp");
|
surface = SDL_LoadBMP("icon.bmp");
|
||||||
if ( ! surface ) {
|
if ( ! surface ) {
|
||||||
fprintf(stderr, "Unable to load icon.bmp: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Unable to load icon.bmp: %s\n", SDL_GetError());
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
exit(3);
|
exit(3);
|
||||||
}
|
}
|
||||||
|
@ -454,9 +456,9 @@ int main(int argc, char **argv)
|
||||||
/* Loop, drawing and checking events */
|
/* Loop, drawing and checking events */
|
||||||
InitGL(640, 480);
|
InitGL(640, 480);
|
||||||
if (InitShaders()) {
|
if (InitShaders()) {
|
||||||
printf("Shaders supported, press SPACE to cycle them.\n");
|
SDL_Log("Shaders supported, press SPACE to cycle them.\n");
|
||||||
} else {
|
} else {
|
||||||
printf("Shaders not supported!\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Shaders not supported!\n");
|
||||||
}
|
}
|
||||||
done = 0;
|
done = 0;
|
||||||
while ( ! done ) {
|
while ( ! done ) {
|
||||||
|
@ -489,7 +491,7 @@ int main(int argc, char **argv)
|
||||||
int
|
int
|
||||||
main(int argc, char *argv[])
|
main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
printf("No OpenGL support on this system\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "No OpenGL support on this system\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -68,13 +68,16 @@ int main(int argc,char** argv)
|
||||||
int access = 0;
|
int access = 0;
|
||||||
SDL_Rect texture_dimensions;;
|
SDL_Rect texture_dimensions;;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
if(argc < 2) {
|
if(argc < 2) {
|
||||||
printf("SDL_Shape requires at least one bitmap file as argument.\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "SDL_Shape requires at least one bitmap file as argument.");
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(SDL_VideoInit(NULL) == -1) {
|
if(SDL_VideoInit(NULL) == -1) {
|
||||||
printf("Could not initialize SDL video.\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Could not initialize SDL video.");
|
||||||
exit(-2);
|
exit(-2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -91,7 +94,7 @@ int main(int argc,char** argv)
|
||||||
SDL_FreeSurface(pictures[j].surface);
|
SDL_FreeSurface(pictures[j].surface);
|
||||||
SDL_free(pictures);
|
SDL_free(pictures);
|
||||||
SDL_VideoQuit();
|
SDL_VideoQuit();
|
||||||
printf("Could not load surface from named bitmap file.\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Could not load surface from named bitmap file.");
|
||||||
exit(-3);
|
exit(-3);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,7 +115,7 @@ int main(int argc,char** argv)
|
||||||
SDL_FreeSurface(pictures[i].surface);
|
SDL_FreeSurface(pictures[i].surface);
|
||||||
SDL_free(pictures);
|
SDL_free(pictures);
|
||||||
SDL_VideoQuit();
|
SDL_VideoQuit();
|
||||||
printf("Could not create shaped window for SDL_Shape.\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Could not create shaped window for SDL_Shape.");
|
||||||
exit(-4);
|
exit(-4);
|
||||||
}
|
}
|
||||||
renderer = SDL_CreateRenderer(window,-1,0);
|
renderer = SDL_CreateRenderer(window,-1,0);
|
||||||
|
@ -122,7 +125,7 @@ int main(int argc,char** argv)
|
||||||
SDL_FreeSurface(pictures[i].surface);
|
SDL_FreeSurface(pictures[i].surface);
|
||||||
SDL_free(pictures);
|
SDL_free(pictures);
|
||||||
SDL_VideoQuit();
|
SDL_VideoQuit();
|
||||||
printf("Could not create rendering context for SDL_Shape window.\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Could not create rendering context for SDL_Shape window.");
|
||||||
exit(-5);
|
exit(-5);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -141,7 +144,7 @@ int main(int argc,char** argv)
|
||||||
SDL_DestroyRenderer(renderer);
|
SDL_DestroyRenderer(renderer);
|
||||||
SDL_DestroyWindow(window);
|
SDL_DestroyWindow(window);
|
||||||
SDL_VideoQuit();
|
SDL_VideoQuit();
|
||||||
printf("Could not create texture for SDL_shape.\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Could not create texture for SDL_shape.");
|
||||||
exit(-6);
|
exit(-6);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -64,7 +64,7 @@ LoadSprite(const char *file)
|
||||||
/* Load the sprite image */
|
/* Load the sprite image */
|
||||||
temp = SDL_LoadBMP(file);
|
temp = SDL_LoadBMP(file);
|
||||||
if (temp == NULL) {
|
if (temp == NULL) {
|
||||||
fprintf(stderr, "Couldn't load %s: %s", file, SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't load %s: %s", file, SDL_GetError());
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
sprite_w = temp->w;
|
sprite_w = temp->w;
|
||||||
|
@ -95,7 +95,7 @@ LoadSprite(const char *file)
|
||||||
SDL_Renderer *renderer = state->renderers[i];
|
SDL_Renderer *renderer = state->renderers[i];
|
||||||
sprites[i] = SDL_CreateTextureFromSurface(renderer, temp);
|
sprites[i] = SDL_CreateTextureFromSurface(renderer, temp);
|
||||||
if (!sprites[i]) {
|
if (!sprites[i]) {
|
||||||
fprintf(stderr, "Couldn't create texture: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create texture: %s\n", SDL_GetError());
|
||||||
SDL_FreeSurface(temp);
|
SDL_FreeSurface(temp);
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
|
@ -299,8 +299,7 @@ main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (consumed < 0) {
|
if (consumed < 0) {
|
||||||
fprintf(stderr,
|
SDL_Log("Usage: %s %s [--blend none|blend|add|mod] [--cyclecolor] [--cyclealpha] [--iterations N] [num_sprites] [icon.bmp]\n",
|
||||||
"Usage: %s %s [--blend none|blend|add|mod] [--cyclecolor] [--cyclealpha] [--iterations N] [num_sprites] [icon.bmp]\n",
|
|
||||||
argv[0], SDLTest_CommonUsage(state));
|
argv[0], SDLTest_CommonUsage(state));
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
|
@ -314,7 +313,7 @@ main(int argc, char *argv[])
|
||||||
sprites =
|
sprites =
|
||||||
(SDL_Texture **) SDL_malloc(state->num_windows * sizeof(*sprites));
|
(SDL_Texture **) SDL_malloc(state->num_windows * sizeof(*sprites));
|
||||||
if (!sprites) {
|
if (!sprites) {
|
||||||
fprintf(stderr, "Out of memory!\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Out of memory!\n");
|
||||||
quit(2);
|
quit(2);
|
||||||
}
|
}
|
||||||
for (i = 0; i < state->num_windows; ++i) {
|
for (i = 0; i < state->num_windows; ++i) {
|
||||||
|
@ -330,7 +329,7 @@ main(int argc, char *argv[])
|
||||||
positions = (SDL_Rect *) SDL_malloc(num_sprites * sizeof(SDL_Rect));
|
positions = (SDL_Rect *) SDL_malloc(num_sprites * sizeof(SDL_Rect));
|
||||||
velocities = (SDL_Rect *) SDL_malloc(num_sprites * sizeof(SDL_Rect));
|
velocities = (SDL_Rect *) SDL_malloc(num_sprites * sizeof(SDL_Rect));
|
||||||
if (!positions || !velocities) {
|
if (!positions || !velocities) {
|
||||||
fprintf(stderr, "Out of memory!\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Out of memory!\n");
|
||||||
quit(2);
|
quit(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -375,7 +374,7 @@ main(int argc, char *argv[])
|
||||||
now = SDL_GetTicks();
|
now = SDL_GetTicks();
|
||||||
if (now > then) {
|
if (now > then) {
|
||||||
double fps = ((double) frames * 1000) / (now - then);
|
double fps = ((double) frames * 1000) / (now - then);
|
||||||
printf("%2.2f frames per second\n", fps);
|
SDL_Log("%2.2f frames per second\n", fps);
|
||||||
}
|
}
|
||||||
quit(0);
|
quit(0);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -42,7 +42,7 @@ LoadSprite(char *file, SDL_Renderer *renderer)
|
||||||
/* Load the sprite image */
|
/* Load the sprite image */
|
||||||
temp = SDL_LoadBMP(file);
|
temp = SDL_LoadBMP(file);
|
||||||
if (temp == NULL) {
|
if (temp == NULL) {
|
||||||
fprintf(stderr, "Couldn't load %s: %s\n", file, SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't load %s: %s\n", file, SDL_GetError());
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
sprite_w = temp->w;
|
sprite_w = temp->w;
|
||||||
|
@ -73,7 +73,7 @@ LoadSprite(char *file, SDL_Renderer *renderer)
|
||||||
/* Create textures from the image */
|
/* Create textures from the image */
|
||||||
sprite = SDL_CreateTextureFromSurface(renderer, temp);
|
sprite = SDL_CreateTextureFromSurface(renderer, temp);
|
||||||
if (!sprite) {
|
if (!sprite) {
|
||||||
fprintf(stderr, "Couldn't create texture: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create texture: %s\n", SDL_GetError());
|
||||||
SDL_FreeSurface(temp);
|
SDL_FreeSurface(temp);
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
|
@ -126,6 +126,9 @@ main(int argc, char *argv[])
|
||||||
int i, done;
|
int i, done;
|
||||||
SDL_Event event;
|
SDL_Event event;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
if (SDL_CreateWindowAndRenderer(WINDOW_WIDTH, WINDOW_HEIGHT, 0, &window, &renderer) < 0) {
|
if (SDL_CreateWindowAndRenderer(WINDOW_WIDTH, WINDOW_HEIGHT, 0, &window, &renderer) < 0) {
|
||||||
quit(2);
|
quit(2);
|
||||||
}
|
}
|
||||||
|
|
|
@ -68,7 +68,7 @@ void UpdateTexture(SDL_Texture *texture, int frame)
|
||||||
int pitch;
|
int pitch;
|
||||||
|
|
||||||
if (SDL_LockTexture(texture, NULL, &pixels, &pitch) < 0) {
|
if (SDL_LockTexture(texture, NULL, &pixels, &pitch) < 0) {
|
||||||
fprintf(stderr, "Couldn't lock texture: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't lock texture: %s\n", SDL_GetError());
|
||||||
quit(5);
|
quit(5);
|
||||||
}
|
}
|
||||||
src = MooseFrames[frame];
|
src = MooseFrames[frame];
|
||||||
|
@ -93,15 +93,18 @@ main(int argc, char **argv)
|
||||||
SDL_bool done = SDL_FALSE;
|
SDL_bool done = SDL_FALSE;
|
||||||
int frame;
|
int frame;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
if (SDL_Init(SDL_INIT_VIDEO) < 0) {
|
if (SDL_Init(SDL_INIT_VIDEO) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* load the moose images */
|
/* load the moose images */
|
||||||
handle = SDL_RWFromFile("moose.dat", "rb");
|
handle = SDL_RWFromFile("moose.dat", "rb");
|
||||||
if (handle == NULL) {
|
if (handle == NULL) {
|
||||||
fprintf(stderr, "Can't find the file moose.dat !\n");
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Can't find the file moose.dat !\n");
|
||||||
quit(2);
|
quit(2);
|
||||||
}
|
}
|
||||||
SDL_RWread(handle, MooseFrames, MOOSEFRAME_SIZE, MOOSEFRAMES_COUNT);
|
SDL_RWread(handle, MooseFrames, MOOSEFRAME_SIZE, MOOSEFRAMES_COUNT);
|
||||||
|
@ -115,19 +118,19 @@ main(int argc, char **argv)
|
||||||
MOOSEPIC_W*4, MOOSEPIC_H*4,
|
MOOSEPIC_W*4, MOOSEPIC_H*4,
|
||||||
SDL_WINDOW_RESIZABLE);
|
SDL_WINDOW_RESIZABLE);
|
||||||
if (!window) {
|
if (!window) {
|
||||||
fprintf(stderr, "Couldn't set create window: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't set create window: %s\n", SDL_GetError());
|
||||||
quit(3);
|
quit(3);
|
||||||
}
|
}
|
||||||
|
|
||||||
renderer = SDL_CreateRenderer(window, -1, 0);
|
renderer = SDL_CreateRenderer(window, -1, 0);
|
||||||
if (!renderer) {
|
if (!renderer) {
|
||||||
fprintf(stderr, "Couldn't set create renderer: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't set create renderer: %s\n", SDL_GetError());
|
||||||
quit(4);
|
quit(4);
|
||||||
}
|
}
|
||||||
|
|
||||||
MooseTexture = SDL_CreateTexture(renderer, SDL_PIXELFORMAT_ARGB8888, SDL_TEXTUREACCESS_STREAMING, MOOSEPIC_W, MOOSEPIC_H);
|
MooseTexture = SDL_CreateTexture(renderer, SDL_PIXELFORMAT_ARGB8888, SDL_TEXTUREACCESS_STREAMING, MOOSEPIC_W, MOOSEPIC_H);
|
||||||
if (!MooseTexture) {
|
if (!MooseTexture) {
|
||||||
fprintf(stderr, "Couldn't set create texture: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't set create texture: %s\n", SDL_GetError());
|
||||||
quit(5);
|
quit(5);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -34,20 +34,20 @@ int SDLCALL
|
||||||
ThreadFunc(void *data)
|
ThreadFunc(void *data)
|
||||||
{
|
{
|
||||||
SDL_TLSSet(tls, "baby thread", NULL);
|
SDL_TLSSet(tls, "baby thread", NULL);
|
||||||
printf("Started thread %s: My thread id is %lu, thread data = %s\n",
|
SDL_Log("Started thread %s: My thread id is %lu, thread data = %s\n",
|
||||||
(char *) data, SDL_ThreadID(), (const char *)SDL_TLSGet(tls));
|
(char *) data, SDL_ThreadID(), (const char *)SDL_TLSGet(tls));
|
||||||
while (alive) {
|
while (alive) {
|
||||||
printf("Thread '%s' is alive!\n", (char *) data);
|
SDL_Log("Thread '%s' is alive!\n", (char *) data);
|
||||||
SDL_Delay(1 * 1000);
|
SDL_Delay(1 * 1000);
|
||||||
}
|
}
|
||||||
printf("Thread '%s' exiting!\n", (char *) data);
|
SDL_Log("Thread '%s' exiting!\n", (char *) data);
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
killed(int sig)
|
killed(int sig)
|
||||||
{
|
{
|
||||||
printf("Killed with SIGTERM, waiting 5 seconds to exit\n");
|
SDL_Log("Killed with SIGTERM, waiting 5 seconds to exit\n");
|
||||||
SDL_Delay(5 * 1000);
|
SDL_Delay(5 * 1000);
|
||||||
alive = 0;
|
alive = 0;
|
||||||
quit(0);
|
quit(0);
|
||||||
|
@ -58,35 +58,38 @@ main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
SDL_Thread *thread;
|
SDL_Thread *thread;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Load the SDL library */
|
/* Load the SDL library */
|
||||||
if (SDL_Init(0) < 0) {
|
if (SDL_Init(0) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
tls = SDL_TLSCreate();
|
tls = SDL_TLSCreate();
|
||||||
SDL_assert(tls);
|
SDL_assert(tls);
|
||||||
SDL_TLSSet(tls, "main thread", NULL);
|
SDL_TLSSet(tls, "main thread", NULL);
|
||||||
printf("Main thread data initially: %s\n", (const char *)SDL_TLSGet(tls));
|
SDL_Log("Main thread data initially: %s\n", (const char *)SDL_TLSGet(tls));
|
||||||
|
|
||||||
alive = 1;
|
alive = 1;
|
||||||
thread = SDL_CreateThread(ThreadFunc, "One", "#1");
|
thread = SDL_CreateThread(ThreadFunc, "One", "#1");
|
||||||
if (thread == NULL) {
|
if (thread == NULL) {
|
||||||
fprintf(stderr, "Couldn't create thread: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create thread: %s\n", SDL_GetError());
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
SDL_Delay(5 * 1000);
|
SDL_Delay(5 * 1000);
|
||||||
printf("Waiting for thread #1\n");
|
SDL_Log("Waiting for thread #1\n");
|
||||||
alive = 0;
|
alive = 0;
|
||||||
SDL_WaitThread(thread, NULL);
|
SDL_WaitThread(thread, NULL);
|
||||||
|
|
||||||
printf("Main thread data finally: %s\n", (const char *)SDL_TLSGet(tls));
|
SDL_Log("Main thread data finally: %s\n", (const char *)SDL_TLSGet(tls));
|
||||||
|
|
||||||
alive = 1;
|
alive = 1;
|
||||||
signal(SIGTERM, killed);
|
signal(SIGTERM, killed);
|
||||||
thread = SDL_CreateThread(ThreadFunc, "Two", "#2");
|
thread = SDL_CreateThread(ThreadFunc, "Two", "#2");
|
||||||
if (thread == NULL) {
|
if (thread == NULL) {
|
||||||
fprintf(stderr, "Couldn't create thread: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create thread: %s\n", SDL_GetError());
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
raise(SIGTERM);
|
raise(SIGTERM);
|
||||||
|
|
|
@ -33,7 +33,7 @@ ticktock(Uint32 interval, void *param)
|
||||||
static Uint32 SDLCALL
|
static Uint32 SDLCALL
|
||||||
callback(Uint32 interval, void *param)
|
callback(Uint32 interval, void *param)
|
||||||
{
|
{
|
||||||
printf("Timer %d : param = %d\n", interval, (int) (uintptr_t) param);
|
SDL_Log("Timer %d : param = %d\n", interval, (int) (uintptr_t) param);
|
||||||
return interval;
|
return interval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,8 +45,11 @@ main(int argc, char *argv[])
|
||||||
Uint32 start32, now32;
|
Uint32 start32, now32;
|
||||||
Uint64 start, now;
|
Uint64 start, now;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
if (SDL_Init(SDL_INIT_TIMER) < 0) {
|
if (SDL_Init(SDL_INIT_TIMER) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,7 +64,7 @@ main(int argc, char *argv[])
|
||||||
t1 = SDL_AddTimer(desired, ticktock, NULL);
|
t1 = SDL_AddTimer(desired, ticktock, NULL);
|
||||||
|
|
||||||
/* Wait 10 seconds */
|
/* Wait 10 seconds */
|
||||||
printf("Waiting 10 seconds\n");
|
SDL_Log("Waiting 10 seconds\n");
|
||||||
SDL_Delay(10 * 1000);
|
SDL_Delay(10 * 1000);
|
||||||
|
|
||||||
/* Stop the timer */
|
/* Stop the timer */
|
||||||
|
@ -69,28 +72,27 @@ main(int argc, char *argv[])
|
||||||
|
|
||||||
/* Print the results */
|
/* Print the results */
|
||||||
if (ticks) {
|
if (ticks) {
|
||||||
fprintf(stderr,
|
SDL_Log("Timer resolution: desired = %d ms, actual = %f ms\n",
|
||||||
"Timer resolution: desired = %d ms, actual = %f ms\n",
|
|
||||||
desired, (double) (10 * 1000) / ticks);
|
desired, (double) (10 * 1000) / ticks);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Test multiple timers */
|
/* Test multiple timers */
|
||||||
printf("Testing multiple timers...\n");
|
SDL_Log("Testing multiple timers...\n");
|
||||||
t1 = SDL_AddTimer(100, callback, (void *) 1);
|
t1 = SDL_AddTimer(100, callback, (void *) 1);
|
||||||
if (!t1)
|
if (!t1)
|
||||||
fprintf(stderr, "Could not create timer 1: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,"Could not create timer 1: %s\n", SDL_GetError());
|
||||||
t2 = SDL_AddTimer(50, callback, (void *) 2);
|
t2 = SDL_AddTimer(50, callback, (void *) 2);
|
||||||
if (!t2)
|
if (!t2)
|
||||||
fprintf(stderr, "Could not create timer 2: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,"Could not create timer 2: %s\n", SDL_GetError());
|
||||||
t3 = SDL_AddTimer(233, callback, (void *) 3);
|
t3 = SDL_AddTimer(233, callback, (void *) 3);
|
||||||
if (!t3)
|
if (!t3)
|
||||||
fprintf(stderr, "Could not create timer 3: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,"Could not create timer 3: %s\n", SDL_GetError());
|
||||||
|
|
||||||
/* Wait 10 seconds */
|
/* Wait 10 seconds */
|
||||||
printf("Waiting 10 seconds\n");
|
SDL_Log("Waiting 10 seconds\n");
|
||||||
SDL_Delay(10 * 1000);
|
SDL_Delay(10 * 1000);
|
||||||
|
|
||||||
printf("Removing timer 1 and waiting 5 more seconds\n");
|
SDL_Log("Removing timer 1 and waiting 5 more seconds\n");
|
||||||
SDL_RemoveTimer(t1);
|
SDL_RemoveTimer(t1);
|
||||||
|
|
||||||
SDL_Delay(5 * 1000);
|
SDL_Delay(5 * 1000);
|
||||||
|
@ -103,15 +105,15 @@ main(int argc, char *argv[])
|
||||||
ticktock(0, NULL);
|
ticktock(0, NULL);
|
||||||
}
|
}
|
||||||
now = SDL_GetPerformanceCounter();
|
now = SDL_GetPerformanceCounter();
|
||||||
printf("1 million iterations of ticktock took %f ms\n", (double)((now - start)*1000) / SDL_GetPerformanceFrequency());
|
SDL_Log("1 million iterations of ticktock took %f ms\n", (double)((now - start)*1000) / SDL_GetPerformanceFrequency());
|
||||||
|
|
||||||
printf("Performance counter frequency: %llu\n", (unsigned long long) SDL_GetPerformanceFrequency());
|
SDL_Log("Performance counter frequency: %llu\n", (unsigned long long) SDL_GetPerformanceFrequency());
|
||||||
start32 = SDL_GetTicks();
|
start32 = SDL_GetTicks();
|
||||||
start = SDL_GetPerformanceCounter();
|
start = SDL_GetPerformanceCounter();
|
||||||
SDL_Delay(1000);
|
SDL_Delay(1000);
|
||||||
now = SDL_GetPerformanceCounter();
|
now = SDL_GetPerformanceCounter();
|
||||||
now32 = SDL_GetTicks();
|
now32 = SDL_GetTicks();
|
||||||
printf("Delay 1 second = %d ms in ticks, %f ms according to performance counter\n", (now32-start32), (double)((now - start)*1000) / SDL_GetPerformanceFrequency());
|
SDL_Log("Delay 1 second = %d ms in ticks, %f ms according to performance counter\n", (now32-start32), (double)((now - start)*1000) / SDL_GetPerformanceFrequency());
|
||||||
|
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
return (0);
|
return (0);
|
||||||
|
|
|
@ -26,17 +26,20 @@ main(int argc, char *argv[])
|
||||||
SDL_version compiled;
|
SDL_version compiled;
|
||||||
SDL_version linked;
|
SDL_version linked;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
#if SDL_VERSION_ATLEAST(2, 0, 0)
|
#if SDL_VERSION_ATLEAST(2, 0, 0)
|
||||||
printf("Compiled with SDL 2.0 or newer\n");
|
SDL_Log("Compiled with SDL 2.0 or newer\n");
|
||||||
#else
|
#else
|
||||||
printf("Compiled with SDL older than 2.0\n");
|
SDL_Log("Compiled with SDL older than 2.0\n");
|
||||||
#endif
|
#endif
|
||||||
SDL_VERSION(&compiled);
|
SDL_VERSION(&compiled);
|
||||||
printf("Compiled version: %d.%d.%d.%d (%s)\n",
|
SDL_Log("Compiled version: %d.%d.%d.%d (%s)\n",
|
||||||
compiled.major, compiled.minor, compiled.patch,
|
compiled.major, compiled.minor, compiled.patch,
|
||||||
SDL_REVISION_NUMBER, SDL_REVISION);
|
SDL_REVISION_NUMBER, SDL_REVISION);
|
||||||
SDL_GetVersion(&linked);
|
SDL_GetVersion(&linked);
|
||||||
printf("Linked version: %d.%d.%d.%d (%s)\n",
|
SDL_Log("Linked version: %d.%d.%d.%d (%s)\n",
|
||||||
linked.major, linked.minor, linked.patch,
|
linked.major, linked.minor, linked.patch,
|
||||||
SDL_GetRevisionNumber(), SDL_GetRevision());
|
SDL_GetRevisionNumber(), SDL_GetRevision());
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
|
|
|
@ -48,6 +48,9 @@ main(int argc, char *argv[])
|
||||||
int system_cursor = -1;
|
int system_cursor = -1;
|
||||||
SDL_Cursor *cursor = NULL;
|
SDL_Cursor *cursor = NULL;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
SDL_assert(SDL_arraysize(cursorNames) == SDL_NUM_SYSTEM_CURSORS);
|
SDL_assert(SDL_arraysize(cursorNames) == SDL_NUM_SYSTEM_CURSORS);
|
||||||
|
|
||||||
/* Initialize test framework */
|
/* Initialize test framework */
|
||||||
|
@ -64,7 +67,7 @@ main(int argc, char *argv[])
|
||||||
consumed = -1;
|
consumed = -1;
|
||||||
}
|
}
|
||||||
if (consumed < 0) {
|
if (consumed < 0) {
|
||||||
fprintf(stderr, "Usage: %s %s\n", argv[0], SDLTest_CommonUsage(state));
|
SDL_Log("Usage: %s %s\n", argv[0], SDLTest_CommonUsage(state));
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
i += consumed;
|
i += consumed;
|
||||||
|
@ -84,7 +87,7 @@ main(int argc, char *argv[])
|
||||||
if (event.window.event == SDL_WINDOWEVENT_RESIZED) {
|
if (event.window.event == SDL_WINDOWEVENT_RESIZED) {
|
||||||
SDL_Window *window = SDL_GetWindowFromID(event.window.windowID);
|
SDL_Window *window = SDL_GetWindowFromID(event.window.windowID);
|
||||||
if (window) {
|
if (window) {
|
||||||
printf("Window %d resized to %dx%d\n",
|
SDL_Log("Window %d resized to %dx%d\n",
|
||||||
event.window.windowID,
|
event.window.windowID,
|
||||||
event.window.data1,
|
event.window.data1,
|
||||||
event.window.data2);
|
event.window.data2);
|
||||||
|
@ -93,7 +96,7 @@ main(int argc, char *argv[])
|
||||||
if (event.window.event == SDL_WINDOWEVENT_MOVED) {
|
if (event.window.event == SDL_WINDOWEVENT_MOVED) {
|
||||||
SDL_Window *window = SDL_GetWindowFromID(event.window.windowID);
|
SDL_Window *window = SDL_GetWindowFromID(event.window.windowID);
|
||||||
if (window) {
|
if (window) {
|
||||||
printf("Window %d moved to %d,%d (display %s)\n",
|
SDL_Log("Window %d moved to %d,%d (display %s)\n",
|
||||||
event.window.windowID,
|
event.window.windowID,
|
||||||
event.window.data1,
|
event.window.data1,
|
||||||
event.window.data2,
|
event.window.data2,
|
||||||
|
|
|
@ -49,7 +49,7 @@ ThreadFunc(void *data)
|
||||||
int i;
|
int i;
|
||||||
int tid = (int) (uintptr_t) data;
|
int tid = (int) (uintptr_t) data;
|
||||||
|
|
||||||
fprintf(stderr, "Creating Thread %d\n", tid);
|
SDL_Log("Creating Thread %d\n", tid);
|
||||||
|
|
||||||
for (i = 0; i < NUMTHREADS; i++) {
|
for (i = 0; i < NUMTHREADS; i++) {
|
||||||
char name[64];
|
char name[64];
|
||||||
|
@ -58,18 +58,18 @@ ThreadFunc(void *data)
|
||||||
sub_threads[i] = SDL_CreateThread(SubThreadFunc, name, &flags[i]);
|
sub_threads[i] = SDL_CreateThread(SubThreadFunc, name, &flags[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("Thread '%d' waiting for signal\n", tid);
|
SDL_Log("Thread '%d' waiting for signal\n", tid);
|
||||||
while (time_for_threads_to_die[tid] != 1) {
|
while (time_for_threads_to_die[tid] != 1) {
|
||||||
; /* do nothing */
|
; /* do nothing */
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("Thread '%d' sending signals to subthreads\n", tid);
|
SDL_Log("Thread '%d' sending signals to subthreads\n", tid);
|
||||||
for (i = 0; i < NUMTHREADS; i++) {
|
for (i = 0; i < NUMTHREADS; i++) {
|
||||||
flags[i] = 1;
|
flags[i] = 1;
|
||||||
SDL_WaitThread(sub_threads[i], NULL);
|
SDL_WaitThread(sub_threads[i], NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("Thread '%d' exiting!\n", tid);
|
SDL_Log("Thread '%d' exiting!\n", tid);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -80,9 +80,12 @@ main(int argc, char *argv[])
|
||||||
SDL_Thread *threads[NUMTHREADS];
|
SDL_Thread *threads[NUMTHREADS];
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
/* Enable standard application logging */
|
||||||
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
||||||
|
|
||||||
/* Load the SDL library */
|
/* Load the SDL library */
|
||||||
if (SDL_Init(0) < 0) {
|
if (SDL_Init(0) < 0) {
|
||||||
fprintf(stderr, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -94,7 +97,7 @@ main(int argc, char *argv[])
|
||||||
threads[i] = SDL_CreateThread(ThreadFunc, name, (void*) (uintptr_t) i);
|
threads[i] = SDL_CreateThread(ThreadFunc, name, (void*) (uintptr_t) i);
|
||||||
|
|
||||||
if (threads[i] == NULL) {
|
if (threads[i] == NULL) {
|
||||||
fprintf(stderr, "Couldn't create thread: %s\n", SDL_GetError());
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't create thread: %s\n", SDL_GetError());
|
||||||
quit(1);
|
quit(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue