aboutsummaryrefslogtreecommitdiffstats
path: root/subprojects/store-query/src/main/java/tools/refinery/store/query/rewriter/AbstractRecursiveRewriter.java
blob: fb4c14a7af74d85ca8f29fd1030b12983831a47e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
/*
 * SPDX-FileCopyrightText: 2023 The Refinery Authors <https://refinery.tools/>
 *
 * SPDX-License-Identifier: EPL-2.0
 */
package tools.refinery.store.query.rewriter;

import tools.refinery.store.query.dnf.Dnf;
import tools.refinery.store.query.equality.DnfEqualityChecker;
import tools.refinery.store.util.CycleDetectingMapper;

public abstract class AbstractRecursiveRewriter implements DnfRewriter {
	private final CycleDetectingMapper<Dnf, Dnf> mapper = new CycleDetectingMapper<>(Dnf::name, this::map);

	@Override
	public Dnf rewrite(Dnf dnf) {
		return mapper.map(dnf);
	}

	protected Dnf map(Dnf dnf) {
		var result = doRewrite(dnf);
		return dnf.equalsWithSubstitution(DnfEqualityChecker.DEFAULT, result) ? dnf : result;
	}

	protected abstract Dnf doRewrite(Dnf dnf);
}