123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- /*
- Copyright (c) 2017-2018, Feral Interactive
- All rights reserved.
- Redistribution and use in source and binary forms, with or without
- modification, are permitted provided that the following conditions are met:
- * Redistributions of source code must retain the above copyright notice,
- this list of conditions and the following disclaimer.
- * Redistributions in binary form must reproduce the above copyright
- notice, this list of conditions and the following disclaimer in the
- documentation and/or other materials provided with the distribution.
- * Neither the name of Feral Interactive nor the names of its contributors
- may be used to endorse or promote products derived from this software
- without specific prior written permission.
- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
- AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
- LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
- CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
- CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
- POSSIBILITY OF SUCH DAMAGE.
- */
- #pragma once
- #include <stdbool.h>
- /*
- * Maximum sizes values in a config list
- * In practice inih has a INI_MAX_LINE value of 200 so the length is just a safeguard
- */
- #define CONFIG_LIST_MAX 32
- #define CONFIG_VALUE_MAX 256
- /*
- * Opaque config context type
- */
- typedef struct GameModeConfig GameModeConfig;
- /*
- * Initialise a config
- */
- GameModeConfig *config_create(void);
- /*
- * Initialise a config
- * Must be called before using any config later config functions
- */
- void config_init(GameModeConfig *self);
- /*
- * Reload a config from disk
- * Thread safe to call
- */
- void config_reload(GameModeConfig *self);
- /*
- * Destroy a config
- * Invalidates the config
- */
- void config_destroy(GameModeConfig *self);
- /*
- * Get if the client is in the whitelist
- * returns false for an empty whitelist
- */
- bool config_get_client_whitelisted(GameModeConfig *self, const char *client);
- /*
- * Get if the client is in the blacklist
- */
- bool config_get_client_blacklisted(GameModeConfig *self, const char *client);
- /*
- * Get the frequency (in seconds) for the reaper thread
- */
- void config_get_reaper_thread_frequency(GameModeConfig *self, long *value);
- /*
- * Get a set of scripts to call when gamemode starts
- */
- void config_get_gamemode_start_scripts(GameModeConfig *self,
- char scripts[CONFIG_LIST_MAX][CONFIG_VALUE_MAX]);
- /*
- * Get a set of scripts to call when gamemode ends
- */
- void config_get_gamemode_end_scripts(GameModeConfig *self,
- char scripts[CONFIG_LIST_MAX][CONFIG_VALUE_MAX]);
- /*
- * Get the chosen default governor
- */
- void config_get_default_governor(GameModeConfig *self, char governor[CONFIG_VALUE_MAX]);
- /*
- * Get the chosen desired governor
- */
- void config_get_desired_governor(GameModeConfig *self, char governor[CONFIG_VALUE_MAX]);
|