The FreeRADIUS server $Id: 15bac2a4c627c01d1aa2047687b3418955ac7f00 $
|
Structures and prototypes command functions. More...
#include <freeradius-devel/util/value.h>
Go to the source code of this file.
Data Structures | |
struct | fr_cmd_info_t |
struct | fr_cmd_table_t |
struct | fr_cmd_walk_info_t |
Macros | |
#define | CMD_MAX_ARGV (32) |
#define | CMD_TABLE_END { .help = NULL } |
#define | FR_COMMAND_OPTION_HELP (1 << 2) |
#define | FR_COMMAND_OPTION_LIST_CHILD (1 << 0) |
#define | FR_COMMAND_OPTION_NAME (1 << 1) |
#define | FR_COMMAND_OPTION_NONE (0) |
Typedefs | |
typedef int(* | fr_cmd_func_t) (FILE *fp, FILE *fp_err, void *ctx, fr_cmd_info_t const *info) |
typedef struct fr_cmd_s | fr_cmd_t |
typedef int(* | fr_cmd_tab_t) (TALLOC_CTX *talloc_ctx, void *ctx, fr_cmd_info_t *info, int max_expansions, char const **expansions) |
typedef int(* | fr_cmd_walk_t) (void *ctx, fr_cmd_walk_info_t *) |
typedef int(* | fr_command_register_hook_t) (TALLOC_CTX *talloc_ctx, char const *name, void *ctx, fr_cmd_table_t *table) |
Functions | |
int | fr_command_add (TALLOC_CTX *talloc_ctx, fr_cmd_t **head_p, char const *name, void *ctx, fr_cmd_table_t const *table) |
Add one command to the global command tree. | |
int | fr_command_add_multi (TALLOC_CTX *talloc_ctx, fr_cmd_t **heap_p, char const *name, void *ctx, fr_cmd_table_t const *table) |
Add multiple commands to the global command tree. | |
int | fr_command_clear (int new_argc, fr_cmd_info_t *info) |
Clear out any value boxes etc. | |
int | fr_command_complete (fr_cmd_t *head, char const *text, int start, int max_expansions, char const **expansions) |
Do readline-style command completions. | |
void | fr_command_debug (FILE *fp, fr_cmd_t *head) |
char const * | fr_command_help (fr_cmd_t *head, int argc, char *argv[]) |
Get help text for a particular command. | |
void | fr_command_info_init (TALLOC_CTX *ctx, fr_cmd_info_t *info) |
Initialize an fr_cmd_info_t structure. | |
void | fr_command_list (FILE *fp, int max_depth, fr_cmd_t *head, int options) |
int | fr_command_print_help (FILE *fp, fr_cmd_t *head, char const *text) |
Do readline-style help completions. | |
int | fr_command_run (FILE *fp, FILE *fp_err, fr_cmd_info_t *info, bool read_only) |
Run a particular command. | |
int | fr_command_str_to_argv (fr_cmd_t *head, fr_cmd_info_t *info, char const *str) |
Split a string in-place, updating argv[]. | |
bool | fr_command_strncmp (const char *text, const char *name) |
int | fr_command_tab_expand (TALLOC_CTX *ctx, fr_cmd_t *head, fr_cmd_info_t *info, int max_expansions, char const **expansions) |
Get the commands && help at a particular level. | |
int | fr_command_walk (fr_cmd_t *head, void **walk_ctx, void *ctx, fr_cmd_walk_t callback) |
Walk over a command hierarchy. | |
Variables | |
fr_command_register_hook_t | fr_command_register_hook |
Structures and prototypes command functions.
Definition in file command.h.
struct fr_cmd_info_t |
Data Fields | ||
---|---|---|
int | argc | current argument count |
char const ** | argv | text version of commands |
fr_value_box_t ** | box | value_box version of commands. |
fr_cmd_t ** | cmd | cached commands at each offset |
int | max_argc | maximum number of arguments |
bool | runnable | is the command runnable? |
struct fr_cmd_table_t |
Data Fields | ||
---|---|---|
bool | add_name | do we add a name here? |
fr_cmd_func_t | func | function to process this command |
char const * | help | help text |
char const * | name | e.g. "stats" |
char const * | parent | e.g. "show module" |
bool | read_only | |
char const * | syntax | e.g. "STRING" |
fr_cmd_tab_t | tab_expand | tab expand things in the syntax string |
struct fr_cmd_walk_info_t |
typedef int(* fr_cmd_func_t) (FILE *fp, FILE *fp_err, void *ctx, fr_cmd_info_t const *info) |
typedef int(* fr_cmd_tab_t) (TALLOC_CTX *talloc_ctx, void *ctx, fr_cmd_info_t *info, int max_expansions, char const **expansions) |
typedef int(* fr_cmd_walk_t) (void *ctx, fr_cmd_walk_info_t *) |
typedef int(* fr_command_register_hook_t) (TALLOC_CTX *talloc_ctx, char const *name, void *ctx, fr_cmd_table_t *table) |
int fr_command_add | ( | TALLOC_CTX * | talloc_ctx, |
fr_cmd_t ** | head, | ||
char const * | name, | ||
void * | ctx, | ||
fr_cmd_table_t const * | table | ||
) |
Add one command to the global command tree.
We do not do any sanity checks on "name". If it has spaces in it, or "special" characters, that's up to you. We assume that other things in the server will sanity check them.
talloc_ctx | the talloc context |
head | pointer to the head of the command table. |
name | of the command to allocate. Can be NULL for "top level" commands |
ctx | for any callback function |
table | of information about the current command |
Definition at line 725 of file command.c.
int fr_command_add_multi | ( | TALLOC_CTX * | talloc_ctx, |
fr_cmd_t ** | head, | ||
char const * | name, | ||
void * | ctx, | ||
fr_cmd_table_t const * | table | ||
) |
Add multiple commands to the global command tree.
e.g. for module "foo", add "show module foo", "set module foo", etc.
talloc_ctx | the talloc context |
head | pointer to the head of the command table. |
name | of the command to allocate |
ctx | for any callback function |
table | array of tables, terminated by "help == NULL" |
Definition at line 985 of file command.c.
int fr_command_clear | ( | int | new_argc, |
fr_cmd_info_t * | info | ||
) |
int fr_command_complete | ( | fr_cmd_t * | head, |
char const * | text, | ||
int | start, | ||
int | max_expansions, | ||
char const ** | expansions | ||
) |
Do readline-style command completions.
Most useful as part of readline tab expansions. The expansions are strdup() strings, and MUST be free'd by the caller.
head | of the command tree | |
text | the text to check | |
start | offset in the text where the completions should start | |
max_expansions | how many entries in the "expansions" array. | |
[in,out] | expansions | where the expansions are stored. |
Definition at line 2659 of file command.c.
void fr_command_debug | ( | FILE * | fp, |
fr_cmd_t * | head | ||
) |
char const * fr_command_help | ( | fr_cmd_t * | head, |
int | argc, | ||
char * | argv[] | ||
) |
Get help text for a particular command.
head | the head of the hierarchy. |
argc | the number of arguments in argv |
argv | the arguments |
Definition at line 1553 of file command.c.
void fr_command_info_init | ( | TALLOC_CTX * | ctx, |
fr_cmd_info_t * | info | ||
) |
Initialize an fr_cmd_info_t structure.
Definition at line 2397 of file command.c.
void fr_command_list | ( | FILE * | fp, |
int | max_depth, | ||
fr_cmd_t * | head, | ||
int | options | ||
) |
int fr_command_print_help | ( | FILE * | fp, |
fr_cmd_t * | head, | ||
char const * | text | ||
) |
int fr_command_run | ( | FILE * | fp, |
FILE * | fp_err, | ||
fr_cmd_info_t * | info, | ||
bool | read_only | ||
) |
Run a particular command.
info->argc is left alone, as are all other fields. If you want to run multiple commands, call fr_command_clear(0, info) to zero out the relevant information.
fp | where the output is sent |
fp_err | where the error output is sent |
info | the structure describing the command to expand |
read_only | whether or not this command should be run in read-only mode. |
Definition at line 1473 of file command.c.
int fr_command_str_to_argv | ( | fr_cmd_t * | head, |
fr_cmd_info_t * | info, | ||
char const * | text | ||
) |
Split a string in-place, updating argv[].
This function also respects the various data types (mostly). Strings can have quotes. Nothing else can have quotes. Non-string data types are skipped and only parsed to data types by fr_command_run().
head | the head of the hierarchy. |
info | the structure describing the command to expand |
text | the string to split |
Definition at line 2141 of file command.c.
bool fr_command_strncmp | ( | const char * | text, |
const char * | name | ||
) |
int fr_command_tab_expand | ( | TALLOC_CTX * | ctx, |
fr_cmd_t * | head, | ||
fr_cmd_info_t * | info, | ||
int | max_expansions, | ||
char const ** | expansions | ||
) |
Get the commands && help at a particular level.
ctx | talloc context for dynamically allocated expansions. The caller should free it to free all expansions it created. Expansions added by this function are "const char *", and are managed by the command hierarchy. |
head | the head of the hierarchy. |
info | the structure describing the command to expand |
max_expansions | the maximum number of entries in the expansions array |
expansions | where the expansions will be stored. |
Definition at line 1290 of file command.c.
int fr_command_walk | ( | fr_cmd_t * | head, |
void ** | walk_ctx, | ||
void * | ctx, | ||
fr_cmd_walk_t | callback | ||
) |
Walk over a command hierarchy.
head | the head of the hierarchy. Call it with NULL to clean up walk_ctx | |
[in,out] | walk_ctx | to track across multiple function calls. MUST point to a void* when starting |
ctx | for the callback | |
callback | to call with fr_walk_info_t about each command |
Definition at line 1019 of file command.c.
|
extern |