2013-12-24 15:54:06 +01:00
|
|
|
#ifndef CMDLINEOPTIONS_H
|
|
|
|
#define CMDLINEOPTIONS_H
|
|
|
|
|
2013-12-27 10:53:29 +00:00
|
|
|
typedef struct _Option {
|
2013-12-24 18:05:27 +01:00
|
|
|
char* name; // the name of this option
|
|
|
|
char** options; //dashed option name and alternatives
|
|
|
|
unsigned int optionscount; // count of option alternatives
|
|
|
|
char** possibleparameters; // possible parameters for this options
|
|
|
|
unsigned int possibleparametercount; // count of possible parameters
|
|
|
|
char* description; // description of this parameter
|
|
|
|
char** defaultparameters; // default parameters
|
|
|
|
unsigned int defaultparametercount; // count of default parameters
|
2013-12-24 15:54:06 +01:00
|
|
|
|
2013-12-24 18:05:27 +01:00
|
|
|
char** values; // values
|
|
|
|
unsigned int valuecount; // size of the values, if more than one...
|
2013-12-25 16:27:41 +00:00
|
|
|
char set; // boolean if this option has been set
|
|
|
|
} Option;
|
2013-12-24 18:05:27 +01:00
|
|
|
|
2013-12-25 16:27:41 +00:00
|
|
|
|
|
|
|
typedef struct _CONode {
|
|
|
|
//CONode* prev;
|
|
|
|
struct _CONode* next;
|
2013-12-25 13:29:54 +01:00
|
|
|
Option* option;
|
2013-12-25 16:27:41 +00:00
|
|
|
} CONode;
|
2013-12-25 13:29:54 +01:00
|
|
|
|
2013-12-27 10:53:29 +00:00
|
|
|
typedef struct _CmdOptions {
|
2013-12-25 16:27:41 +00:00
|
|
|
char init;
|
2013-12-25 13:29:54 +01:00
|
|
|
CONode* options;
|
2013-12-27 18:59:33 +00:00
|
|
|
char cmdchar;
|
2013-12-25 16:27:41 +00:00
|
|
|
} CmdOptions;
|
2013-12-24 18:05:27 +01:00
|
|
|
|
2013-12-27 18:59:33 +00:00
|
|
|
/**
|
2013-12-25 13:29:54 +01:00
|
|
|
* Main structure
|
|
|
|
*/
|
|
|
|
extern CmdOptions cmdoptions;
|
|
|
|
|
2013-12-27 18:59:33 +00:00
|
|
|
/** Init function.
|
2013-12-24 18:05:27 +01:00
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
void CmdLO_InitCmd(char addhelp, char cmdchar);
|
|
|
|
void CmdLO_Init(char addhelp);
|
2013-12-24 18:05:27 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The heart of this whole thing, the parsing of all options...
|
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
int CmdLO_Parse(int argc, char** argv);
|
|
|
|
CONode* CmdLO_SearchNode(char* cmdlineargument);
|
2013-12-24 18:05:27 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a new option with a new name, or a new option alternative to an existing one.
|
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
void CmdLO_Add(char* name, char* option);
|
2013-12-24 18:05:27 +01:00
|
|
|
/**
|
|
|
|
* Add a defaultparameter to an existing option, specified by name.
|
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
void CmdLO_AddDefaultParameter(char* name, char* defaultparameter);
|
2013-12-24 18:05:27 +01:00
|
|
|
/**
|
|
|
|
* Add a possible parameter to an existing option, specified by name.
|
|
|
|
* Keep in mind that you LIMIT that option to all possible parameters (?)
|
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
void CmdLO_AddPossibleParameter(char* name, char* possibleParameter);
|
2013-12-24 18:05:27 +01:00
|
|
|
/**
|
|
|
|
* Add a description to an existing option, specified by name.
|
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
void CmdLO_AddDescription(char* name, char* description);
|
2013-12-24 18:05:27 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if the option specified by name is set.
|
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
int CmdLO_IsSet(char* name);
|
2013-12-24 18:05:27 +01:00
|
|
|
/**
|
|
|
|
* Get first parameter of the option specified by name.
|
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
char* CmdLO_Get(char* name);
|
2013-12-24 18:05:27 +01:00
|
|
|
/**
|
|
|
|
* Get the first parameter of the option specified by name as integer.
|
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
int CmdLO_GetInt(char* name);
|
2013-12-24 18:05:27 +01:00
|
|
|
/**
|
|
|
|
* Get the first parameter of the option specified by name as long.
|
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
long CmdLO_GetLong(char* name);
|
2013-12-24 18:05:27 +01:00
|
|
|
/**
|
|
|
|
* Get the first parameter of the option specified by name as double.
|
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
double CmdLO_GetDouble(char* name);
|
2013-12-24 18:05:27 +01:00
|
|
|
/**
|
|
|
|
* Get all parameters of the given option name as string array.
|
|
|
|
* This is the 'Do It Yourself' retrieve function.
|
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
int CmdLO_GetAll(char* name, char** values, unsigned int* count);
|
2014-03-09 13:35:54 +00:00
|
|
|
/**
|
|
|
|
* Get the node with the given name or create a new one with that name.
|
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
CONode* CmdLO_Create(char* name);
|
2014-03-09 13:35:54 +00:00
|
|
|
/**
|
|
|
|
* Just get the node with the given name.
|
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
CONode* CmdLO_NodeGet(char* name);
|
2014-03-09 13:35:54 +00:00
|
|
|
/**
|
|
|
|
* Convenience function to add a string to a string array.
|
|
|
|
*/
|
2014-02-21 21:51:43 +00:00
|
|
|
void CmdLO_AddElement(char*** target,unsigned int* counter, char* element);
|
2014-03-09 13:35:54 +00:00
|
|
|
/**
|
|
|
|
* Clean up everything, like nothing ever happened...
|
|
|
|
*/
|
|
|
|
void CmdLO_Destroy();
|
|
|
|
|
|
|
|
|
2013-12-24 15:54:06 +01:00
|
|
|
#endif
|
|
|
|
|