X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;ds=sidebyside;f=bertos%2Fmware%2Fparser.h;h=ca7a7a2891f9fe627776fce6b6b85962587f54e7;hb=HEAD;hp=281db3964c05e51c8a85fe110daf8a670fb3947b;hpb=332a7970140d2af1b233d29c0316f51a6a54a637;p=bertos.git diff --git a/bertos/mware/parser.h b/bertos/mware/parser.h index 281db396..ca7a7a28 100644 --- a/bertos/mware/parser.h +++ b/bertos/mware/parser.h @@ -128,11 +128,18 @@ typedef enum RC_ERROR = -1, ///< Reply with error. RC_OK = 0, ///< No reply (ignore reply arguments). RC_REPLY = 1, ///< Reply command arguments. - RC_SKIP = 2 ///< Skip following commands + RC_SKIP = 2, ///< Skip following commands + RC_CLAMPED = 3, ///< argument values have been clamped. } ResultCode; +typedef struct +{ + const char *p; + int sz; +} str_parm; + /** union that contains parameters passed to and from commands */ -typedef union { long l; const char *s; } parms; +typedef union { long l; str_parm s; } parms; /** pointer to commands */ typedef ResultCode (*CmdFuncPtr)(parms args_results[]); @@ -257,6 +264,7 @@ INLINE bool parser_execute_cmd(const struct CmdTemplate* templ, parms args[CONFI const struct CmdTemplate* parser_get_cmd_template(const char* line); bool parser_get_cmd_arguments(const char* line, const struct CmdTemplate* templ, parms args[CONFIG_PARSER_MAX_ARGS]); +bool get_word(const char **begin, const char **end); #if CONFIG_ENABLE_COMPAT_BEHAVIOUR /**