Lines Matching refs:e2

14 static int expr_eq(struct expr *e1, struct expr *e2);
36 struct expr *expr_alloc_two(enum expr_type type, struct expr *e1, struct expr *e2) in expr_alloc_two() argument
41 e->right.expr = e2; in expr_alloc_two()
54 struct expr *expr_alloc_and(struct expr *e1, struct expr *e2) in expr_alloc_and() argument
57 return e2; in expr_alloc_and()
58 return e2 ? expr_alloc_two(E_AND, e1, e2) : e1; in expr_alloc_and()
61 struct expr *expr_alloc_or(struct expr *e1, struct expr *e2) in expr_alloc_or() argument
64 return e2; in expr_alloc_or()
65 return e2 ? expr_alloc_two(E_OR, e1, e2) : e1; in expr_alloc_or()
134 #define e2 (*ep2) macro
139 __expr_eliminate_eq(type, &e1->left.expr, &e2); in __expr_eliminate_eq()
140 __expr_eliminate_eq(type, &e1->right.expr, &e2); in __expr_eliminate_eq()
143 if (e2->type == type) { in __expr_eliminate_eq()
144 __expr_eliminate_eq(type, &e1, &e2->left.expr); in __expr_eliminate_eq()
145 __expr_eliminate_eq(type, &e1, &e2->right.expr); in __expr_eliminate_eq()
148 if (e1->type == E_SYMBOL && e2->type == E_SYMBOL && in __expr_eliminate_eq()
149 e1->left.sym == e2->left.sym && in __expr_eliminate_eq()
152 if (!expr_eq(e1, e2)) in __expr_eliminate_eq()
155 expr_free(e1); expr_free(e2); in __expr_eliminate_eq()
159 e2 = expr_alloc_symbol(&symbol_no); in __expr_eliminate_eq()
163 e2 = expr_alloc_symbol(&symbol_yes); in __expr_eliminate_eq()
172 if (!e1 || !e2) in expr_eliminate_eq()
181 if (e1->type != e2->type) switch (e2->type) { in expr_eliminate_eq()
184 __expr_eliminate_eq(e2->type, ep1, ep2); in expr_eliminate_eq()
189 e2 = expr_eliminate_yn(e2); in expr_eliminate_eq()
193 #undef e2
195 static int expr_eq(struct expr *e1, struct expr *e2) in expr_eq() argument
199 if (e1->type != e2->type) in expr_eq()
204 return e1->left.sym == e2->left.sym && e1->right.sym == e2->right.sym; in expr_eq()
206 return e1->left.sym == e2->left.sym; in expr_eq()
208 return expr_eq(e1->left.expr, e2->left.expr); in expr_eq()
212 e2 = expr_copy(e2); in expr_eq()
214 expr_eliminate_eq(&e1, &e2); in expr_eq()
215 res = (e1->type == E_SYMBOL && e2->type == E_SYMBOL && in expr_eq()
216 e1->left.sym == e2->left.sym); in expr_eq()
218 expr_free(e2); in expr_eq()
230 expr_fprint(e2, stdout); in expr_eq()
352 static struct expr *expr_join_or(struct expr *e1, struct expr *e2) in expr_join_or() argument
357 if (expr_eq(e1, e2)) in expr_join_or()
361 if (e2->type != E_EQUAL && e2->type != E_UNEQUAL && e2->type != E_SYMBOL && e2->type != E_NOT) in expr_join_or()
370 if (e2->type == E_NOT) { in expr_join_or()
371 if (e2->left.expr->type != E_SYMBOL) in expr_join_or()
373 sym2 = e2->left.expr->left.sym; in expr_join_or()
375 sym2 = e2->left.sym; in expr_join_or()
381 if (e1->type == E_EQUAL && e2->type == E_EQUAL && in expr_join_or()
382 ((e1->right.sym == &symbol_yes && e2->right.sym == &symbol_mod) || in expr_join_or()
383 (e1->right.sym == &symbol_mod && e2->right.sym == &symbol_yes))) { in expr_join_or()
387 if (e1->type == E_EQUAL && e2->type == E_EQUAL && in expr_join_or()
388 ((e1->right.sym == &symbol_yes && e2->right.sym == &symbol_no) || in expr_join_or()
389 (e1->right.sym == &symbol_no && e2->right.sym == &symbol_yes))) { in expr_join_or()
393 if (e1->type == E_EQUAL && e2->type == E_EQUAL && in expr_join_or()
394 ((e1->right.sym == &symbol_mod && e2->right.sym == &symbol_no) || in expr_join_or()
395 (e1->right.sym == &symbol_no && e2->right.sym == &symbol_mod))) { in expr_join_or()
401 if ((e1->type == E_NOT && e1->left.expr->type == E_SYMBOL && e2->type == E_SYMBOL) || in expr_join_or()
402 (e2->type == E_NOT && e2->left.expr->type == E_SYMBOL && e1->type == E_SYMBOL)) in expr_join_or()
410 expr_fprint(e2, stdout); in expr_join_or()
416 static struct expr *expr_join_and(struct expr *e1, struct expr *e2) in expr_join_and() argument
421 if (expr_eq(e1, e2)) in expr_join_and()
425 if (e2->type != E_EQUAL && e2->type != E_UNEQUAL && e2->type != E_SYMBOL && e2->type != E_NOT) in expr_join_and()
434 if (e2->type == E_NOT) { in expr_join_and()
435 if (e2->left.expr->type != E_SYMBOL) in expr_join_and()
437 sym2 = e2->left.expr->left.sym; in expr_join_and()
439 sym2 = e2->left.sym; in expr_join_and()
445 if ((e1->type == E_SYMBOL && e2->type == E_EQUAL && e2->right.sym == &symbol_yes) || in expr_join_and()
446 (e2->type == E_SYMBOL && e1->type == E_EQUAL && e1->right.sym == &symbol_yes)) in expr_join_and()
450 if ((e1->type == E_SYMBOL && e2->type == E_UNEQUAL && e2->right.sym == &symbol_no) || in expr_join_and()
451 (e2->type == E_SYMBOL && e1->type == E_UNEQUAL && e1->right.sym == &symbol_no)) in expr_join_and()
455 if ((e1->type == E_SYMBOL && e2->type == E_UNEQUAL && e2->right.sym == &symbol_mod) || in expr_join_and()
456 (e2->type == E_SYMBOL && e1->type == E_UNEQUAL && e1->right.sym == &symbol_mod)) in expr_join_and()
461 if (e1->type == E_EQUAL && e2->type == E_UNEQUAL) { in expr_join_and()
464 if ((e2->right.sym->flags & SYMBOL_CONST) && (sym2->flags & SYMBOL_CONST)) in expr_join_and()
465 return sym2 != e2->right.sym ? expr_alloc_comp(E_EQUAL, sym1, sym2) in expr_join_and()
468 if (e1->type == E_UNEQUAL && e2->type == E_EQUAL) { in expr_join_and()
470 sym2 = e2->right.sym; in expr_join_and()
475 if (e1->type == E_UNEQUAL && e2->type == E_UNEQUAL && in expr_join_and()
476 ((e1->right.sym == &symbol_yes && e2->right.sym == &symbol_no) || in expr_join_and()
477 (e1->right.sym == &symbol_no && e2->right.sym == &symbol_yes))) in expr_join_and()
481 if (e1->type == E_UNEQUAL && e2->type == E_UNEQUAL && in expr_join_and()
482 ((e1->right.sym == &symbol_yes && e2->right.sym == &symbol_mod) || in expr_join_and()
483 (e1->right.sym == &symbol_mod && e2->right.sym == &symbol_yes))) in expr_join_and()
487 if (e1->type == E_UNEQUAL && e2->type == E_UNEQUAL && in expr_join_and()
488 ((e1->right.sym == &symbol_mod && e2->right.sym == &symbol_no) || in expr_join_and()
489 (e1->right.sym == &symbol_no && e2->right.sym == &symbol_mod))) in expr_join_and()
493 if ((e1->type == E_SYMBOL && e2->type == E_EQUAL && e2->right.sym == &symbol_mod) || in expr_join_and()
494 (e2->type == E_SYMBOL && e1->type == E_EQUAL && e1->right.sym == &symbol_mod) || in expr_join_and()
495 (e1->type == E_SYMBOL && e2->type == E_UNEQUAL && e2->right.sym == &symbol_yes) || in expr_join_and()
496 (e2->type == E_SYMBOL && e1->type == E_UNEQUAL && e1->right.sym == &symbol_yes)) in expr_join_and()
504 expr_fprint(e2, stdout); in expr_join_and()
513 #define e2 (*ep2) in expr_eliminate_dups1() macro
517 expr_eliminate_dups1(type, &e1->left.expr, &e2); in expr_eliminate_dups1()
518 expr_eliminate_dups1(type, &e1->right.expr, &e2); in expr_eliminate_dups1()
521 if (e2->type == type) { in expr_eliminate_dups1()
522 expr_eliminate_dups1(type, &e1, &e2->left.expr); in expr_eliminate_dups1()
523 expr_eliminate_dups1(type, &e1, &e2->right.expr); in expr_eliminate_dups1()
526 if (e1 == e2) in expr_eliminate_dups1()
538 tmp = expr_join_or(e1, e2); in expr_eliminate_dups1()
540 expr_free(e1); expr_free(e2); in expr_eliminate_dups1()
542 e2 = tmp; in expr_eliminate_dups1()
547 tmp = expr_join_and(e1, e2); in expr_eliminate_dups1()
549 expr_free(e1); expr_free(e2); in expr_eliminate_dups1()
551 e2 = tmp; in expr_eliminate_dups1()
559 #undef e2 in expr_eliminate_dups1()
565 #define e2 (*ep2) in expr_eliminate_dups2() macro
569 expr_eliminate_dups2(type, &e1->left.expr, &e2); in expr_eliminate_dups2()
570 expr_eliminate_dups2(type, &e1->right.expr, &e2); in expr_eliminate_dups2()
573 if (e2->type == type) { in expr_eliminate_dups2()
574 expr_eliminate_dups2(type, &e1, &e2->left.expr); in expr_eliminate_dups2()
575 expr_eliminate_dups2(type, &e1, &e2->right.expr); in expr_eliminate_dups2()
577 if (e1 == e2) in expr_eliminate_dups2()
585 tmp2 = expr_copy(e2); in expr_eliminate_dups2()
600 tmp2 = expr_copy(e2); in expr_eliminate_dups2()
615 #undef e2 in expr_eliminate_dups2()
857 #define e2 (*ep2) in expr_extract_eq() macro
859 expr_extract_eq(type, ep, &e1->left.expr, &e2); in expr_extract_eq()
860 expr_extract_eq(type, ep, &e1->right.expr, &e2); in expr_extract_eq()
863 if (e2->type == type) { in expr_extract_eq()
864 expr_extract_eq(type, ep, ep1, &e2->left.expr); in expr_extract_eq()
865 expr_extract_eq(type, ep, ep1, &e2->right.expr); in expr_extract_eq()
868 if (expr_eq(e1, e2)) { in expr_extract_eq()
870 expr_free(e2); in expr_extract_eq()
873 e2 = expr_alloc_symbol(&symbol_yes); in expr_extract_eq()
876 e2 = expr_alloc_symbol(&symbol_no); in expr_extract_eq()
880 #undef e2 in expr_extract_eq()
885 struct expr *e1, *e2; in expr_trans_compare() local
896 e2 = expr_trans_compare(e->right.expr, E_EQUAL, sym); in expr_trans_compare()
898 e = expr_alloc_two(E_AND, e1, e2); in expr_trans_compare()
900 e = expr_alloc_two(E_OR, e1, e2); in expr_trans_compare()
906 e2 = expr_trans_compare(e->right.expr, E_EQUAL, sym); in expr_trans_compare()
908 e = expr_alloc_two(E_OR, e1, e2); in expr_trans_compare()
910 e = expr_alloc_two(E_AND, e1, e2); in expr_trans_compare()
1030 struct expr *expr_simplify_unmet_dep(struct expr *e1, struct expr *e2) in expr_simplify_unmet_dep() argument
1037 expr_simplify_unmet_dep(e1->left.expr, e2), in expr_simplify_unmet_dep()
1038 expr_simplify_unmet_dep(e1->right.expr, e2)); in expr_simplify_unmet_dep()
1041 e = expr_alloc_and(expr_copy(e1), expr_copy(e2)); in expr_simplify_unmet_dep()