diff options
| author | Josh Poimboeuf <jpoimboe@redhat.com> | 2015-12-15 09:39:36 -0600 | 
|---|---|---|
| committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2015-12-16 21:33:13 -0300 | 
| commit | 901421a5bdf605d24c278825cdd032cd6038bcb8 (patch) | |
| tree | e38d011aa6ff9c348a6ea7d3c9e664fef54b237f /tools/perf/util/parse-options.c | |
| parent | 096d35585b4fce7d3ee9b8b34314f39f49491ab1 (diff) | |
perf tools: Remove subcmd dependencies on strbuf
Introduce and use new astrcat() and astrcatf() functions which replace
the strbuf functionality for subcmd.
For now they duplicate strbuf's die-on-allocation-error policy.
Signed-off-by: Josh Poimboeuf <jpoimboe@redhat.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/957d207e1254406fa11fc2e405e75a7e405aad8f.1450193761.git.jpoimboe@redhat.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util/parse-options.c')
| -rw-r--r-- | tools/perf/util/parse-options.c | 42 | 
1 files changed, 22 insertions, 20 deletions
| diff --git a/tools/perf/util/parse-options.c b/tools/perf/util/parse-options.c index da4ba21cad21..c1da2a53ed4e 100644 --- a/tools/perf/util/parse-options.c +++ b/tools/perf/util/parse-options.c @@ -1,4 +1,5 @@  #include "util.h" +#include "subcmd-util.h"  #include "parse-options.h"  #include "cache.h"  #include "header.h" @@ -8,7 +9,7 @@  #define OPT_SHORT 1  #define OPT_UNSET 2 -static struct strbuf error_buf = STRBUF_INIT; +char *error_buf;  static int opterror(const struct option *opt, const char *reason, int flags)  { @@ -576,19 +577,18 @@ int parse_options_subcommand(int argc, const char **argv, const struct option *o  	/* build usage string if it's not provided */  	if (subcommands && !usagestr[0]) { -		struct strbuf buf = STRBUF_INIT; +		char *buf = NULL; + +		astrcatf(&buf, "%s %s [<options>] {", subcmd_config.exec_name, argv[0]); -		strbuf_addf(&buf, "%s %s [<options>] {", -			    subcmd_config.exec_name, argv[0]);  		for (int i = 0; subcommands[i]; i++) {  			if (i) -				strbuf_addstr(&buf, "|"); -			strbuf_addstr(&buf, subcommands[i]); +				astrcat(&buf, "|"); +			astrcat(&buf, subcommands[i]);  		} -		strbuf_addstr(&buf, "}"); +		astrcat(&buf, "}"); -		usagestr[0] = strdup(buf.buf); -		strbuf_release(&buf); +		usagestr[0] = buf;  	}  	parse_options_start(&ctx, argc, argv, flags); @@ -613,13 +613,11 @@ int parse_options_subcommand(int argc, const char **argv, const struct option *o  		putchar('\n');  		exit(130);  	default: /* PARSE_OPT_UNKNOWN */ -		if (ctx.argv[0][1] == '-') { -			strbuf_addf(&error_buf, "unknown option `%s'", -				    ctx.argv[0] + 2); -		} else { -			strbuf_addf(&error_buf, "unknown switch `%c'", -				    *ctx.opt); -		} +		if (ctx.argv[0][1] == '-') +			astrcatf(&error_buf, "unknown option `%s'", +				 ctx.argv[0] + 2); +		else +			astrcatf(&error_buf, "unknown switch `%c'", *ctx.opt);  		usage_with_options(usagestr, options);  	} @@ -806,9 +804,9 @@ static int usage_with_options_internal(const char * const *usagestr,  	setup_pager(); -	if (strbuf_avail(&error_buf)) { -		fprintf(stderr, "  Error: %s\n", error_buf.buf); -		strbuf_release(&error_buf); +	if (error_buf) { +		fprintf(stderr, "  Error: %s\n", error_buf); +		zfree(&error_buf);  	}  	fprintf(stderr, "\n Usage: %s\n", *usagestr++); @@ -852,11 +850,15 @@ void usage_with_options_msg(const char * const *usagestr,  			    const struct option *opts, const char *fmt, ...)  {  	va_list ap; +	char *tmp = error_buf;  	va_start(ap, fmt); -	strbuf_addv(&error_buf, fmt, ap); +	if (vasprintf(&error_buf, fmt, ap) == -1) +		die("vasprintf failed");  	va_end(ap); +	free(tmp); +  	usage_with_options_internal(usagestr, opts, 0, NULL);  	exit(129);  } | 
