* [PATCH] perf tools: Correct typing errors about '-' or '_' in config variable.
@ 2015-11-09 10:54 Taeung Song
2015-11-09 14:16 ` Arnaldo Carvalho de Melo
0 siblings, 1 reply; 2+ messages in thread
From: Taeung Song @ 2015-11-09 10:54 UTC (permalink / raw)
To: Arnaldo Carvalho de Melo
Cc: linux-kernel, Ingo Molnar, Taeung Song, Namhyung Kim, Jiri Olsa
To improve perf config usability, we should probably also recognize
underscores in perf config entries, i.e. the following variants
should both work: as suggested by Ingo Molnar
print_percent = 1
print-percent = 1
So, add functionality for it.
'annotate' section has variables that contain '_' underscores like:
hide_src_code
use_offset
jump_arrows
show_nr_jumps
However other sections has variables that contain a '-' dash
or neither it or underscore i.e.
ui.show-headers
call-graph.print-limit
tui.report
So, convert the characters if typing errors about underscores
or a dash when parsing the config file.
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Jiri Olsa <jolsa@redhat.com>
Signed-off-by: Taeung Song <treeze.taeung@gmail.com>
---
tools/perf/util/config.c | 8 ++++++++
1 file changed, 8 insertions(+)
diff --git a/tools/perf/util/config.c b/tools/perf/util/config.c
index 2e452ac..69db606 100644
--- a/tools/perf/util/config.c
+++ b/tools/perf/util/config.c
@@ -129,7 +129,10 @@ static int get_value(config_fn_t fn, void *data, char *name, unsigned int len)
{
int c;
char *value;
+ bool has_underscore = false;
+ if (prefixcmp(name, "annotate.") == 0)
+ has_underscore = true;
/* Get the full name */
for (;;) {
c = get_next_char();
@@ -137,6 +140,11 @@ static int get_value(config_fn_t fn, void *data, char *name, unsigned int len)
break;
if (!iskeychar(c))
break;
+ /* Correct typing errors about dash or underscore */
+ if (has_underscore && c == '-')
+ c = '_';
+ else if (!has_underscore && c == '_')
+ c = '-';
name[len++] = c;
if (len >= MAXNAME)
return -1;
--
1.9.1
^ permalink raw reply related [flat|nested] 2+ messages in thread* Re: [PATCH] perf tools: Correct typing errors about '-' or '_' in config variable.
2015-11-09 10:54 [PATCH] perf tools: Correct typing errors about '-' or '_' in config variable Taeung Song
@ 2015-11-09 14:16 ` Arnaldo Carvalho de Melo
0 siblings, 0 replies; 2+ messages in thread
From: Arnaldo Carvalho de Melo @ 2015-11-09 14:16 UTC (permalink / raw)
To: Taeung Song; +Cc: linux-kernel, Ingo Molnar, Namhyung Kim, Jiri Olsa
Em Mon, Nov 09, 2015 at 07:54:35PM +0900, Taeung Song escreveu:
> To improve perf config usability, we should probably also recognize
> underscores in perf config entries, i.e. the following variants
> should both work: as suggested by Ingo Molnar
>
> print_percent = 1
> print-percent = 1
>
> So, add functionality for it.
> 'annotate' section has variables that contain '_' underscores like:
>
> hide_src_code
> use_offset
> jump_arrows
> show_nr_jumps
>
> However other sections has variables that contain a '-' dash
> or neither it or underscore i.e.
>
> ui.show-headers
> call-graph.print-limit
> tui.report
There is no need to single our a section just because nowadays it
contains underscores so that we would convert them to dashes, do it for
all sections, so that if in the future we get underscores in them, then
it wild be dash/underscore "insensitive".
In fact, this would be a strcasecmp_() routine, i.e. one that would, in
addition to being case insensitive, also consider - and _ the same
character.
- Arnaldo
> So, convert the characters if typing errors about underscores
> or a dash when parsing the config file.
>
> Cc: Namhyung Kim <namhyung@kernel.org>
> Cc: Jiri Olsa <jolsa@redhat.com>
> Signed-off-by: Taeung Song <treeze.taeung@gmail.com>
> ---
> tools/perf/util/config.c | 8 ++++++++
> 1 file changed, 8 insertions(+)
>
> diff --git a/tools/perf/util/config.c b/tools/perf/util/config.c
> index 2e452ac..69db606 100644
> --- a/tools/perf/util/config.c
> +++ b/tools/perf/util/config.c
> @@ -129,7 +129,10 @@ static int get_value(config_fn_t fn, void *data, char *name, unsigned int len)
> {
> int c;
> char *value;
> + bool has_underscore = false;
>
> + if (prefixcmp(name, "annotate.") == 0)
> + has_underscore = true;
> /* Get the full name */
> for (;;) {
> c = get_next_char();
> @@ -137,6 +140,11 @@ static int get_value(config_fn_t fn, void *data, char *name, unsigned int len)
> break;
> if (!iskeychar(c))
> break;
> + /* Correct typing errors about dash or underscore */
> + if (has_underscore && c == '-')
> + c = '_';
> + else if (!has_underscore && c == '_')
> + c = '-';
> name[len++] = c;
> if (len >= MAXNAME)
> return -1;
> --
> 1.9.1
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2015-11-09 14:16 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-11-09 10:54 [PATCH] perf tools: Correct typing errors about '-' or '_' in config variable Taeung Song
2015-11-09 14:16 ` Arnaldo Carvalho de Melo
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.