mirror of
https://github.com/Relintai/sdl2_frt.git
synced 2024-12-20 22:16:49 +01:00
b72938c861
An existing hint lets apps that don't need the timer resolution changed avoid this, to save battery, etc, but this fixes several problems in timing, audio callbacks not firing fast enough, etc. Fixes Bugzilla #2944.
225 lines
6.0 KiB
C
225 lines
6.0 KiB
C
/* See COPYING.txt for the full license governing this code. */
|
|
/**
|
|
* \file variator_common.c
|
|
*
|
|
* Source file for some common functionality used by variators.
|
|
*/
|
|
|
|
#include <SDL_test.h>
|
|
#include "SDL_visualtest_variator_common.h"
|
|
|
|
int
|
|
SDLVisualTest_NextValue(SDLVisualTest_SUTOptionValue* var,
|
|
SDLVisualTest_SUTOption* opt)
|
|
{
|
|
if(!var)
|
|
{
|
|
SDLTest_LogError("var argument cannot be NULL");
|
|
return -1;
|
|
}
|
|
if(!opt)
|
|
{
|
|
SDLTest_LogError("opt argument cannot be NULL");
|
|
return -1;
|
|
}
|
|
|
|
switch(opt->type)
|
|
{
|
|
case SDL_SUT_OPTIONTYPE_BOOL:
|
|
if(var->bool_value)
|
|
{
|
|
var->bool_value = SDL_FALSE;
|
|
return 1;
|
|
}
|
|
else
|
|
{
|
|
var->bool_value = SDL_TRUE;
|
|
return 0;
|
|
}
|
|
break;
|
|
|
|
case SDL_SUT_OPTIONTYPE_ENUM:
|
|
var->enumerated.index++;
|
|
if(!opt->data.enum_values[var->enumerated.index])
|
|
{
|
|
var->enumerated.index = 0;
|
|
return 1;
|
|
}
|
|
return 0;
|
|
break;
|
|
|
|
case SDL_SUT_OPTIONTYPE_INT:
|
|
{
|
|
int increment = (opt->data.range.max - opt->data.range.min) /
|
|
SDL_SUT_INTEGER_OPTION_TEST_STEPS;
|
|
/* prevents infinite loop when rounding */
|
|
if(increment == 0)
|
|
increment = 1;
|
|
var->integer.value += increment;
|
|
if(var->integer.value > opt->data.range.max)
|
|
{
|
|
var->integer.value = opt->data.range.min;
|
|
return 1;
|
|
}
|
|
return 0;
|
|
}
|
|
break;
|
|
|
|
case SDL_SUT_OPTIONTYPE_STRING:
|
|
return 1;
|
|
break;
|
|
}
|
|
return -1;
|
|
}
|
|
|
|
int
|
|
SDLVisualTest_MakeStrFromVariation(SDLVisualTest_Variation* variation,
|
|
SDLVisualTest_SUTConfig* config,
|
|
char* buffer, int size)
|
|
{
|
|
int i, index;
|
|
SDLVisualTest_SUTOptionValue* vars;
|
|
SDLVisualTest_SUTOption* options;
|
|
if(!variation)
|
|
{
|
|
SDLTest_LogError("variation argument cannot be NULL");
|
|
return 0;
|
|
}
|
|
if(!config)
|
|
{
|
|
SDLTest_LogError("config argument cannot be NULL");
|
|
return 0;
|
|
}
|
|
if(!buffer)
|
|
{
|
|
SDLTest_LogError("buffer argument cannot be NULL");
|
|
return 0;
|
|
}
|
|
if(size <= 0)
|
|
{
|
|
SDLTest_LogError("size argument should be positive");
|
|
return 0;
|
|
}
|
|
|
|
index = 0;
|
|
buffer[0] = '\0';
|
|
options = config->options;
|
|
vars = variation->vars;
|
|
for(i = 0; i < variation->num_vars; i++)
|
|
{
|
|
int n, enum_index;
|
|
if(index >= size - 1)
|
|
{
|
|
SDLTest_LogError("String did not fit in buffer size");
|
|
return 0;
|
|
}
|
|
switch(options[i].type)
|
|
{
|
|
case SDL_SUT_OPTIONTYPE_BOOL:
|
|
if(vars[i].bool_value)
|
|
{
|
|
n = SDL_snprintf(buffer + index, size - index, "%s ",
|
|
options[i].name);
|
|
if(n <= 0)
|
|
{
|
|
SDLTest_LogError("SDL_snprintf() failed");
|
|
return 0;
|
|
}
|
|
index += n;
|
|
}
|
|
break;
|
|
|
|
case SDL_SUT_OPTIONTYPE_ENUM:
|
|
if(vars[i].enumerated.on)
|
|
{
|
|
enum_index = vars[i].enumerated.index;
|
|
n = SDL_snprintf(buffer + index, size - index, "%s %s ",
|
|
options[i].name, options[i].data.enum_values[enum_index]);
|
|
index += n;
|
|
}
|
|
break;
|
|
|
|
case SDL_SUT_OPTIONTYPE_INT:
|
|
if(vars[i].integer.on)
|
|
{
|
|
n = SDL_snprintf(buffer + index, size - index, "%s %d ",
|
|
options[i].name, vars[i].integer.value);
|
|
index += n;
|
|
}
|
|
break;
|
|
|
|
case SDL_SUT_OPTIONTYPE_STRING:
|
|
if(vars[i].string.on)
|
|
{
|
|
n = SDL_snprintf(buffer + index, size - index, "%s %s ",
|
|
options[i].name, vars[i].string.value);
|
|
index += n;
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
int
|
|
SDLVisualTest_InitVariation(SDLVisualTest_Variation* variation,
|
|
SDLVisualTest_SUTConfig* config)
|
|
{
|
|
int i;
|
|
SDLVisualTest_SUTOptionValue* vars;
|
|
SDLVisualTest_SUTOption* options;
|
|
if(!variation)
|
|
{
|
|
SDLTest_LogError("variation argument cannot be NULL");
|
|
return 0;
|
|
}
|
|
if(!config)
|
|
{
|
|
SDLTest_LogError("config argument cannot be NULL");
|
|
return 0;
|
|
}
|
|
|
|
/* initialize the first variation */
|
|
if(config->num_options <= 0)
|
|
{
|
|
SDLTest_LogError("config->num_options must be positive");
|
|
return 0;
|
|
}
|
|
variation->vars = (SDLVisualTest_SUTOptionValue*)SDL_malloc(config->num_options *
|
|
sizeof(SDLVisualTest_SUTOptionValue));
|
|
if(!variation->vars)
|
|
{
|
|
SDLTest_LogError("malloc() failed");
|
|
return 0;
|
|
}
|
|
variation->num_vars = config->num_options;
|
|
vars = variation->vars;
|
|
options = config->options;
|
|
for(i = 0; i < variation->num_vars; i++)
|
|
{
|
|
switch(options[i].type)
|
|
{
|
|
case SDL_SUT_OPTIONTYPE_BOOL:
|
|
vars[i].bool_value = SDL_FALSE;
|
|
break;
|
|
|
|
case SDL_SUT_OPTIONTYPE_ENUM:
|
|
vars[i].enumerated.on = SDL_TRUE;
|
|
vars[i].enumerated.index = 0;
|
|
break;
|
|
|
|
case SDL_SUT_OPTIONTYPE_INT:
|
|
{
|
|
vars[i].integer.on = SDL_TRUE;
|
|
vars[i].integer.value = options[i].data.range.min;
|
|
}
|
|
break;
|
|
|
|
case SDL_SUT_OPTIONTYPE_STRING:
|
|
vars[i].string.on = SDL_TRUE;
|
|
vars[i].string.value = options[i].name;
|
|
break;
|
|
}
|
|
}
|
|
return 1;
|
|
} |