view target-utils/libcommon/parseargs.c @ 965:2969032bdfac

fcup-smsend[mult]: fix buglet in K&R C NULL pointer passing The only 100% safe way to pass a NULL pointer as a function argument in K&R C is to cast 0 to a pointer type; failing to do so may cause mysterious bugs (invalid stack frames or garbage in argument registers) on 64-bit machines. This issue has already been fixed in most of FC host tools, but I just found some missed spots: passing of NULL UDH to PDU encoding functions in fcup-smsend[mult] in the case of single (not concatenated) SMS.
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 01 Sep 2023 07:33:51 +0000
parents e7502631a0f9
children
line wrap: on
line source

/*
 * This module contains the parse_args() function, which parses the "rest"
 * part of an entered command into an argc/argv-style argument array.
 */

parse_args(unparsed, minargs, maxargs, argv, argcp)
	char *unparsed;
	int minargs, maxargs;
	char **argv;
	int *argcp;
{
	int argc;
	char *cp;

	argc = 0;
	for (cp = unparsed; ; ) {
		while (*cp == ' ')
			cp++;
		if (!*cp)
			break;
		if (argc >= maxargs) {
			printf("ERROR: too many arguments\n");
			return(-1);
		}
		argv[argc++] = cp;
		while (*cp && *cp != ' ')
			cp++;
		if (*cp)
			*cp++ = '\0';
	}
	if (argc < minargs) {
		printf("ERROR: too few arguments\n");
		return(-1);
	}
	argv[argc] = 0;
	if (argcp)
		*argcp = argc;
	return(0);
}