1
1
mirror of https://github.com/github/semantic.git synced 2025-01-04 05:27:08 +03:00

Define equivalence in terms of lifted equality.

This commit is contained in:
Rob Rix 2017-10-03 13:33:04 -04:00
parent 82244515f8
commit 695ceb7d62

View File

@ -20,7 +20,6 @@ import Data.Syntax.Algebra
import qualified Data.Syntax.Declaration as Declaration import qualified Data.Syntax.Declaration as Declaration
import Data.Term import Data.Term
import Data.Text (Text) import Data.Text (Text)
import Data.These
import Data.Union import Data.Union
import Info hiding (Empty, Return) import Info hiding (Empty, Return)
import RWS import RWS
@ -35,7 +34,7 @@ diffSyntaxTerms :: (HasField fields1 Category, HasField fields2 Category)
diffSyntaxTerms = decoratingWith comparableByCategory (equalTerms comparableByCategory) getLabel getLabel diffSyntaxTerms = decoratingWith comparableByCategory (equalTerms comparableByCategory) getLabel getLabel
-- | Diff two à la carte terms recursively. -- | Diff two à la carte terms recursively.
diffTerms :: (Declaration.Method :< fs, Declaration.Function :< fs, Syntax.Context :< fs, Apply Diffable fs, Apply Foldable fs, Apply Functor fs, Apply GAlign fs, Apply Show1 fs, Apply Traversable fs) diffTerms :: (Declaration.Method :< fs, Declaration.Function :< fs, Syntax.Context :< fs, Apply Diffable fs, Apply Eq1 fs, Apply Foldable fs, Apply Functor fs, Apply GAlign fs, Apply Show1 fs, Apply Traversable fs)
=> Term (Union fs) (Record fields1) => Term (Union fs) (Record fields1)
-> Term (Union fs) (Record fields2) -> Term (Union fs) (Record fields2)
-> Diff (Union fs) (Record fields1) (Record fields2) -> Diff (Union fs) (Record fields1) (Record fields2)
@ -112,7 +111,7 @@ comparableByConstructor (In _ u1) (In _ u2)
-- | Equivalency relation for terms. Equivalence is determined by functions and -- | Equivalency relation for terms. Equivalence is determined by functions and
-- methods with equal identifiers/names and recursively by equivalent terms with -- methods with equal identifiers/names and recursively by equivalent terms with
-- identical shapes. -- identical shapes.
equivalentTerms :: (Declaration.Method :< fs, Declaration.Function :< fs, Syntax.Context :< fs, Apply Foldable fs, Apply GAlign fs) equivalentTerms :: (Declaration.Method :< fs, Declaration.Function :< fs, Syntax.Context :< fs, Apply Eq1 fs, Apply Foldable fs)
=> Term (Union fs) ann1 => Term (Union fs) ann1
-> Term (Union fs) ann2 -> Term (Union fs) ann2
-> Bool -> Bool
@ -130,6 +129,4 @@ equivalentTerms t1@(Term (In _ u1)) t2@(Term (In _ u2))
= equivalentTerms s1 t2 = equivalentTerms s1 t2
| Just (Syntax.Context _ s2) <- prj u2 | Just (Syntax.Context _ s2) <- prj u2
= equivalentTerms t1 s2 = equivalentTerms t1 s2
| Just aligned <- galignWith (Just . these (const False) (const False) equivalentTerms) u1 u2 | otherwise = liftEq equivalentTerms u1 u2
= and aligned
| otherwise = False