summaryrefslogtreecommitdiffstats
path: root/scripts/kconfig/expr.c
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/kconfig/expr.c')
-rw-r--r--scripts/kconfig/expr.c28
1 files changed, 24 insertions, 4 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}