[Pdbg] [PATCH 6/8] pdbg: Define common command/flag argument parsers

rashmica rashmica.g at gmail.com
Fri Jun 22 13:30:05 AEST 2018



On 20/06/18 15:34, Alistair Popple wrote:
> Parsers need to take a string argument and convert it into a specific type,
> returning the value as a pointer to memory allocated by the parser (or NULL in
> the case of an error). This just defines a couple of common parsers useful for
> various commands.
>
> It also defines a couple of convenience macros for easier usage of these
> parsers.
>
> Signed-off-by: Alistair Popple <alistair at popple.id.au>
> ---
>  src/parsers.c | 85 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>  src/parsers.h | 21 +++++++++++++++
>  2 files changed, 106 insertions(+)
>  create mode 100644 src/parsers.c
>  create mode 100644 src/parsers.h
>
> diff --git a/src/parsers.c b/src/parsers.c
> new file mode 100644
> index 0000000..0399933
> --- /dev/null
> +++ b/src/parsers.c
> @@ -0,0 +1,85 @@
> +#include <stdlib.h>
> +#include <stdint.h>
> +#include <stdbool.h>
> +#include <errno.h>
> +
> +uint64_t *parse_number64(const char *argv)
> +{
> +	uint64_t *n = malloc(sizeof(*n));
> +	char *endptr;
> +
> +	if (!argv)
> +		return NULL;
> +
> +	errno = 0;
> +	*n = strtoull(argv, &endptr, 0);
> +	if (errno || *endptr != '\0')
> +		return NULL;
> +
> +	return n;
> +}
> +
> +uint32_t *parse_number32(const char *argv)
> +{
> +	unsigned long long tmp;
> +	uint32_t *n = malloc(sizeof(*n));
> +	char *endptr;
> +
> +	if (!argv)
> +		return NULL;
> +
> +	errno = 0;
> +	tmp = strtoul(argv, &endptr, 0);
> +	if (errno || *endptr != '\0' || tmp > (uint32_t) -1UL)

What about using UINT32_MAX instead of '(uint32_t)  -1UL'?

> +		return NULL;
> +
> +	*n = tmp;
> +	return n;
> +}
> +
> +/* Parse a GPR number, returning an error if it's greater than 32 */
> +int *parse_gpr(const char *argv)
> +{
> +	int *gpr = malloc(sizeof(*gpr));
> +	char *endptr;
> +
> +	if (!argv)
> +		return NULL;
> +
> +	errno = 0;
> +	*gpr = strtoul(argv, &endptr, 0);
> +	if (errno || *endptr != '\0' || *gpr > 32)
> +		return NULL;
> +
> +	return gpr;
> +}
> +
> +/* Parse an SPR. Currently only supports SPR by numbers but could be extended to
> + * support names (eg. lr) */
> +int *parse_spr(const char *argv)
> +{
> +	int *spr = malloc(sizeof(*spr));
> +	char *endptr;
> +
> +	if (!argv)
> +		return NULL;
> +
> +	errno = 0;
> +	*spr = strtoul(argv, &endptr, 0);
> +	if (errno || *endptr != '\0' || *spr > 0x3ff)
> +		return NULL;
> +
> +	return spr;
> +}
> +
> +
> +/* A special parser that always returns true. Allows for boolean flags which
> + * don't take arguments. Sets the associated field to true if specified,
> + * otherwise sets it to the default value (usually false). */
> +bool *parse_flag_noarg(const char *argv)
> +{
> +	bool *result = malloc(sizeof(*result));
> +
> +	*result = true;
> +	return result;
> +}
> diff --git a/src/parsers.h b/src/parsers.h
> new file mode 100644
> index 0000000..b5f23cf
> --- /dev/null
> +++ b/src/parsers.h
> @@ -0,0 +1,21 @@
> +#ifndef __PARSERS_H
> +#define __PARSERS_H
> +
> +#include <stdint.h>
> +#include <stdbool.h>
> +
> +#define ADDRESS (parse_number64, NULL)
> +#define ADDRESS32 (parse_number32, NULL)
> +#define DATA (parse_number64, NULL)
> +#define DATA32 (parse_number32, NULL)
> +#define DEFAULT_DATA(default) (parse_number64, default)
> +#define GPR (parse_gpr, NULL)
> +#define SPR (parse_spr, NULL)
> +
> +uint64_t *parse_number64(const char *argv);
> +uint32_t *parse_number32(const char *argv);
> +int *parse_gpr(const char *argv);
> +int *parse_spr(const char *argv);
> +bool *parse_flag_noarg(const char *argv);
> +
> +#endif



More information about the Pdbg mailing list