summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPetr Vorel <petr.vorel@gmail.com>2018-01-25 04:46:35 -0500
committerMasahiro Yamada <yamada.masahiro@socionext.com>2018-01-25 07:53:00 -0500
commit1ccb27143360bd2390a9a970e50709f858b53761 (patch)
treecf5e766bdaca1c1976ad004a87e0d163f19b15da
parent312ee68752faaa553499775d2c191ff7a883826f (diff)
kconfig: make "Selected by:" and "Implied by:" readable
Reverse dependency expressions can get rather unwieldy, especially if a symbol is selected by more than a handful of other symbols. I.e. it's possible to have near endless expressions like: A && B && !C || D || F && (G || H) || [...] Chop these expressions into actually readable chunks: - A && B && !C - D - F && (G || H) - [...] I.e. transform the top level OR tokens into newlines and prepend each line with a minus. This makes the "Selected by:" and "Implied by:" blurb much easier to read. This is done only if there is more than one top level OR. "Depends on:" and "Range :" were deliberately left as they are. Based on idea from Paul Bolle. Suggested-by: Paul Bolle <pebolle@tiscali.nl> Signed-off-by: Petr Vorel <petr.vorel@gmail.com> Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
-rw-r--r--scripts/kconfig/expr.c28
-rw-r--r--scripts/kconfig/expr.h1
-rw-r--r--scripts/kconfig/menu.c4
3 files changed, 27 insertions, 6 deletions
diff --git a/scripts/kconfig/expr.c b/scripts/kconfig/expr.c
index fd8a416ceab7..04fa71e058b7 100644
--- a/scripts/kconfig/expr.c
+++ b/scripts/kconfig/expr.c
@@ -1176,7 +1176,7 @@ struct expr *expr_simplify_unmet_dep(struct expr *e1, struct expr *e2)
1176 return expr_get_leftmost_symbol(ret); 1176 return expr_get_leftmost_symbol(ret);
1177} 1177}
1178 1178
1179void expr_print(struct expr *e, void (*fn)(void *, struct symbol *, const char *), void *data, int prevtoken) 1179static void __expr_print(struct expr *e, void (*fn)(void *, struct symbol *, const char *), void *data, int prevtoken, bool revdep)
1180{ 1180{
1181 if (!e) { 1181 if (!e) {
1182 fn(data, NULL, "y"); 1182 fn(data, NULL, "y");
@@ -1231,9 +1231,14 @@ void expr_print(struct expr *e, void (*fn)(void *, struct symbol *, const char *
1231 fn(data, e->right.sym, e->right.sym->name); 1231 fn(data, e->right.sym, e->right.sym->name);
1232 break; 1232 break;
1233 case E_OR: 1233 case E_OR:
1234 expr_print(e->left.expr, fn, data, E_OR); 1234 if (revdep && e->left.expr->type != E_OR)
1235 fn(data, NULL, " || "); 1235 fn(data, NULL, "\n - ");
1236 expr_print(e->right.expr, fn, data, E_OR); 1236 __expr_print(e->left.expr, fn, data, E_OR, revdep);
1237 if (revdep)
1238 fn(data, NULL, "\n - ");
1239 else
1240 fn(data, NULL, " || ");
1241 __expr_print(e->right.expr, fn, data, E_OR, revdep);
1237 break; 1242 break;
1238 case E_AND: 1243 case E_AND:
1239 expr_print(e->left.expr, fn, data, E_AND); 1244 expr_print(e->left.expr, fn, data, E_AND);
@@ -1266,6 +1271,11 @@ void expr_print(struct expr *e, void (*fn)(void *, struct symbol *, const char *
1266 fn(data, NULL, ")"); 1271 fn(data, NULL, ")");
1267} 1272}
1268 1273
1274void expr_print(struct expr *e, void (*fn)(void *, struct symbol *, const char *), void *data, int prevtoken)
1275{
1276 __expr_print(e, fn, data, prevtoken, false);
1277}
1278
1269static void expr_print_file_helper(void *data, struct symbol *sym, const char *str) 1279static void expr_print_file_helper(void *data, struct symbol *sym, const char *str)
1270{ 1280{
1271 xfwrite(str, strlen(str), 1, data); 1281 xfwrite(str, strlen(str), 1, data);
@@ -1310,3 +1320,13 @@ void expr_gstr_print(struct expr *e, struct gstr *gs)
1310{ 1320{
1311 expr_print(e, expr_print_gstr_helper, gs, E_NONE); 1321 expr_print(e, expr_print_gstr_helper, gs, E_NONE);
1312} 1322}
1323
1324/*
1325 * Transform the top level "||" tokens into newlines and prepend each
1326 * line with a minus. This makes expressions much easier to read.
1327 * Suitable for reverse dependency expressions.
1328 */
1329void expr_gstr_print_revdep(struct expr *e, struct gstr *gs)
1330{
1331 __expr_print(e, expr_print_gstr_helper, gs, E_NONE, true);
1332}
diff --git a/scripts/kconfig/expr.h b/scripts/kconfig/expr.h
index e7d7a5e3da68..c16e82e302a2 100644
--- a/scripts/kconfig/expr.h
+++ b/scripts/kconfig/expr.h
@@ -310,6 +310,7 @@ struct expr *expr_simplify_unmet_dep(struct expr *e1, struct expr *e2);
310void expr_fprint(struct expr *e, FILE *out); 310void expr_fprint(struct expr *e, FILE *out);
311struct gstr; /* forward */ 311struct gstr; /* forward */
312void expr_gstr_print(struct expr *e, struct gstr *gs); 312void expr_gstr_print(struct expr *e, struct gstr *gs);
313void expr_gstr_print_revdep(struct expr *e, struct gstr *gs);
313 314
314static inline int expr_is_yes(struct expr *e) 315static inline int expr_is_yes(struct expr *e)
315{ 316{
diff --git a/scripts/kconfig/menu.c b/scripts/kconfig/menu.c
index d365fc9513c5..99222855544c 100644
--- a/scripts/kconfig/menu.c
+++ b/scripts/kconfig/menu.c
@@ -828,14 +828,14 @@ static void get_symbol_str(struct gstr *r, struct symbol *sym,
828 get_symbol_props_str(r, sym, P_SELECT, _(" Selects: ")); 828 get_symbol_props_str(r, sym, P_SELECT, _(" Selects: "));
829 if (sym->rev_dep.expr) { 829 if (sym->rev_dep.expr) {
830 str_append(r, _(" Selected by: ")); 830 str_append(r, _(" Selected by: "));
831 expr_gstr_print(sym->rev_dep.expr, r); 831 expr_gstr_print_revdep(sym->rev_dep.expr, r);
832 str_append(r, "\n"); 832 str_append(r, "\n");
833 } 833 }
834 834
835 get_symbol_props_str(r, sym, P_IMPLY, _(" Implies: ")); 835 get_symbol_props_str(r, sym, P_IMPLY, _(" Implies: "));
836 if (sym->implied.expr) { 836 if (sym->implied.expr) {
837 str_append(r, _(" Implied by: ")); 837 str_append(r, _(" Implied by: "));
838 expr_gstr_print(sym->implied.expr, r); 838 expr_gstr_print_revdep(sym->implied.expr, r);
839 str_append(r, "\n"); 839 str_append(r, "\n");
840 } 840 }
841 841