2019-05-09 12:06:58 +00:00
|
|
|
/*
|
|
|
|
KVMGFX Client - A KVM Client for VGA Passthrough
|
|
|
|
Copyright (C) 2017-2019 Geoffrey McRae <geoff@hostfission.com>
|
|
|
|
https://looking-glass.hostfission.com
|
|
|
|
|
|
|
|
This program 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
|
|
|
|
Foundation; either version 2 of the License, or (at your option) any later
|
|
|
|
version.
|
|
|
|
|
|
|
|
This program 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
|
|
|
|
this program; if not, write to the Free Software Foundation, Inc., 59 Temple
|
|
|
|
Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*/
|
|
|
|
|
2021-01-25 08:58:36 +00:00
|
|
|
#ifndef _H_COMMON_OPTION_
|
|
|
|
#define _H_COMMON_OPTION_
|
|
|
|
|
2019-05-09 12:06:58 +00:00
|
|
|
#include <stdbool.h>
|
2019-05-12 06:13:50 +00:00
|
|
|
#include "common/stringlist.h"
|
2019-05-09 12:06:58 +00:00
|
|
|
|
|
|
|
enum OptionType
|
|
|
|
{
|
|
|
|
OPTION_TYPE_NONE = 0,
|
|
|
|
OPTION_TYPE_INT,
|
|
|
|
OPTION_TYPE_STRING,
|
2019-05-11 10:58:49 +00:00
|
|
|
OPTION_TYPE_BOOL,
|
|
|
|
OPTION_TYPE_CUSTOM
|
2019-05-09 12:06:58 +00:00
|
|
|
};
|
|
|
|
|
2019-05-11 10:58:49 +00:00
|
|
|
struct Option;
|
2019-05-09 12:06:58 +00:00
|
|
|
|
2019-05-11 10:58:49 +00:00
|
|
|
struct Option
|
2019-05-09 12:06:58 +00:00
|
|
|
{
|
2019-05-16 23:25:57 +00:00
|
|
|
char * module;
|
|
|
|
char * name;
|
|
|
|
char * description;
|
2019-05-21 01:31:31 +00:00
|
|
|
const char shortopt;
|
2019-05-11 10:58:49 +00:00
|
|
|
|
2019-05-09 12:06:58 +00:00
|
|
|
enum OptionType type;
|
|
|
|
union
|
|
|
|
{
|
|
|
|
int x_int;
|
|
|
|
char * x_string;
|
|
|
|
bool x_bool;
|
2019-05-11 10:58:49 +00:00
|
|
|
void * x_custom;
|
2019-05-09 12:06:58 +00:00
|
|
|
}
|
2019-05-11 10:58:49 +00:00
|
|
|
value;
|
2019-05-09 12:06:58 +00:00
|
|
|
|
2019-05-12 06:13:50 +00:00
|
|
|
bool (*parser )(struct Option * opt, const char * str);
|
|
|
|
bool (*validator)(struct Option * opt, const char ** error);
|
|
|
|
char * (*toString )(struct Option * opt);
|
|
|
|
StringList (*getValues)(struct Option * opt);
|
2019-05-12 06:51:37 +00:00
|
|
|
|
2021-01-25 08:58:36 +00:00
|
|
|
void (*printHelp)(void);
|
2019-05-12 06:51:37 +00:00
|
|
|
|
|
|
|
// internal use only
|
|
|
|
bool failed_set;
|
2019-05-09 12:06:58 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// register an NULL terminated array of options
|
|
|
|
bool option_register(struct Option options[]);
|
|
|
|
|
|
|
|
// lookup the value of an option
|
2019-05-11 10:58:49 +00:00
|
|
|
struct Option * option_get (const char * module, const char * name);
|
|
|
|
int option_get_int (const char * module, const char * name);
|
|
|
|
const char * option_get_string(const char * module, const char * name);
|
|
|
|
bool option_get_bool (const char * module, const char * name);
|
2019-05-09 12:06:58 +00:00
|
|
|
|
|
|
|
// called by the main application to parse the command line arguments
|
|
|
|
bool option_parse(int argc, char * argv[]);
|
|
|
|
|
2019-05-11 08:22:01 +00:00
|
|
|
// called by the main application to load configuration from a file
|
|
|
|
bool option_load(const char * filename);
|
|
|
|
|
2019-05-11 01:35:17 +00:00
|
|
|
// called by the main application to validate the option values
|
2021-01-25 08:58:36 +00:00
|
|
|
bool option_validate(void);
|
2019-05-11 01:35:17 +00:00
|
|
|
|
2019-05-09 12:06:58 +00:00
|
|
|
// print out the options, help, and their current values
|
2021-01-25 08:58:36 +00:00
|
|
|
void option_print(void);
|
2019-05-09 12:06:58 +00:00
|
|
|
|
|
|
|
// final cleanup
|
2021-01-25 08:58:36 +00:00
|
|
|
void option_free(void);
|
|
|
|
|
|
|
|
#endif
|