/* RetroArch - A frontend for libretro. * Copyright (C) 2013-2014 - Jason Fetters * Copyright (C) 2011-2014 - Daniel De Matteis * * RetroArch is free software: you can redistribute it and/or modify it under the terms * of the GNU General Public License as published by the Free Software Found- * ation, either version 3 of the License, or (at your option) any later version. * * RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR * PURPOSE. See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along with RetroArch. * If not, see . */ #include "settings_list.h" void settings_info_list_free(rarch_setting_info_t *list_info) { if (list_info) free(list_info); list_info = NULL; } rarch_setting_info_t *settings_info_list_new(void) { rarch_setting_info_t *list_info = (rarch_setting_info_t*) calloc(1, sizeof(*list_info)); if (!list_info) return NULL; list_info->index = 0; list_info->size = 32; return list_info; } bool settings_list_append(rarch_setting_t **list, rarch_setting_info_t *list_info, rarch_setting_t value) { if (!list || !*list || !list_info) return false; if (list_info->index == list_info->size) { list_info->size *= 2; *list = (rarch_setting_t*) realloc(*list, sizeof(rarch_setting_t) * list_info->size); if (!*list) return false; } (*list)[list_info->index++] = value; return true; } static void null_write_handler(void *data) { (void)data; } void settings_list_current_add_bind_type( rarch_setting_t **list, rarch_setting_info_t *list_info, unsigned type) { unsigned index = list_info->index - 1; (*list)[index].bind_type = type; } void settings_list_current_add_flags( rarch_setting_t **list, rarch_setting_info_t *list_info, unsigned values) { unsigned index = list_info->index - 1; (*list)[index].flags |= values; if (values & SD_FLAG_IS_DEFERRED) { (*list)[index].deferred_handler = (*list)[index].change_handler; (*list)[index].change_handler = null_write_handler; } } void settings_list_current_add_range( rarch_setting_t **list, rarch_setting_info_t *list_info, float min, float max, float step, bool enforce_minrange_enable, bool enforce_maxrange_enable) { unsigned index = list_info->index - 1; (*list)[index].min = min; (*list)[index].step = step; (*list)[index].max = max; (*list)[index].enforce_minrange = enforce_minrange_enable; (*list)[index].enforce_maxrange = enforce_maxrange_enable; settings_list_current_add_flags(list, list_info, SD_FLAG_HAS_RANGE); } void settings_list_current_add_values( rarch_setting_t **list, rarch_setting_info_t *list_info, const char *values) { unsigned index = list_info->index - 1; (*list)[index].values = values; } void settings_list_current_add_cmd( rarch_setting_t **list, rarch_setting_info_t *list_info, unsigned values) { unsigned index = list_info->index - 1; (*list)[index].cmd_trigger.idx = values; } void settings_list_free(rarch_setting_t *list) { if (list) free(list); } rarch_setting_t *settings_list_new(unsigned size) { rarch_setting_t *list = (rarch_setting_t*)calloc(size, sizeof(*list)); if (!list) return NULL; return list; }