Agda-2.7.0: A dependently typed functional programming language and proof assistant
Safe HaskellSafe-Inferred
LanguageHaskell2010

Agda.TypeChecking.DiscrimTree

Description

Imperfect discrimination trees for indexing data by internal syntax.

Synopsis

Documentation

insertDT Source #

Arguments

:: (Ord a, PrettyTCM a) 
=> Int

Number of variables to consider wildcards, e.g. the number of leading invisible pis in an instance type.

-> Term

The term to use as a key

-> a 
-> DiscrimTree a 
-> TCM (DiscrimTree a) 

Insert a value into the discrimination tree, turning variables into rigid locals or wildcards depending on the given scope.

lookupDT :: forall a. (Ord a, PrettyTCM a) => Term -> DiscrimTree a -> TCM (QueryResult a) Source #

Look up a Term in the given discrimination tree, treating local variables as rigid symbols. The returned set is guaranteed to contain everything that could overlap the given key.

lookupUnifyDT :: forall a. (Ord a, PrettyTCM a) => Term -> DiscrimTree a -> TCM (QueryResult a) Source #

Look up a Term in the given discrimination tree, treating local variables as wildcards.

data QueryResult a Source #

Constructors

QueryResult 

Instances

Instances details
Ord a => Monoid (QueryResult a) Source # 
Instance details

Defined in Agda.TypeChecking.DiscrimTree

Ord a => Semigroup (QueryResult a) Source # 
Instance details

Defined in Agda.TypeChecking.DiscrimTree

deleteFromDT :: Ord a => DiscrimTree a -> Set a -> DiscrimTree a Source #

Remove a set of values from the discrimination tree. The tree is rebuilt so that cases with no leaves are removed.