package rocq-runtime
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
md5=8d522602d23e7a665631826dab9aa92b
    
    
  sha512=f4f76a6a178e421c99ee7a331a2fd97a06e9c5d0168d7e60c44e3820d8e1a124370ea104ad90c7f87a9a1e9d87b2d0d7d2d387c998feeaed4a75ed04e176a4be
    
    
  doc/rocq-runtime.tactics/Hipattern/index.html
Module HipatternSource
High-order patterns
Given a term with second-order variables in it, represented by Meta's, and possibly applied using SoApp terms, this function will perform second-order, binding-preserving, matching, in the case where the pattern is a pattern in the sense of Dale Miller.
ALGORITHM:
Given a pattern, we decompose it, flattening casts and apply's, recursing on all operators, and pushing the name of the binder each time we descend a binder.
When we reach a first-order variable, we ask that the corresponding term's free-rels all be higher than the depth of the current stack.
When we reach a second-order application, we ask that the intersection of the free-rels of the term and the current stack be contained in the arguments of the application
I implemented the following functions which test whether a term t is an inductive but non-recursive type, a general conjunction, a general disjunction, or a type with no constructors.
They are more general than matching with or_term, and_term, etc, since they do not depend on the name of the type. Hence, they also work on ad-hoc disjunctions introduced by the user. (Eduardo, 6/8/97).
val match_with_disjunction : 
  ?strict:bool ->
  ?onlybinary:bool ->
  (EConstr.constr * EConstr.constr list) matching_functionNon recursive type with no indices and exactly one argument for each constructor; canonical definition of n-ary disjunction if strict
val match_with_conjunction : 
  ?strict:bool ->
  ?onlybinary:bool ->
  (EConstr.constr * EConstr.constr list) matching_functionNon recursive tuple (one constructor and no indices) with no inner dependencies; canonical definition of n-ary conjunction if strict
Non recursive tuple, possibly with inner dependencies
Like record but supports and tells if recursive (e.g. Acc)
No constructor, possibly with indices
type with only one constructor and no arguments, possibly with indices
type with only one constructor and no arguments, no indices
type with only one constructor, no arguments and at least one dependency
val match_with_forall_term : 
  (Names.Name.t EConstr.binder_annot * EConstr.constr * EConstr.constr)
    matching_functionI added these functions to test whether a type contains dependent products or not, and if an inductive has constructors with dependent types (excluding parameters). this is useful to check whether a conjunction is a real conjunction and not a dependent tuple. (Pierre Corbineau, 13/5/2002)
Recongnize inductive relation defined by reflexivity
type equation_kind = - | MonomorphicLeibnizEq of EConstr.constr * EConstr.constr
- | PolymorphicLeibnizEq of EConstr.constr * EConstr.constr * EConstr.constr
- | HeterogenousEq of EConstr.constr * EConstr.constr * EConstr.constr * EConstr.constr
val match_with_equation : 
  Environ.env ->
  Evd.evar_map ->
  EConstr.constr ->
  Rocqlib.rocq_eq_data option * EConstr.constr * equation_kindval find_eq_data_decompose : 
  Environ.env ->
  Evd.evar_map ->
  EConstr.constr ->
  Rocqlib.rocq_eq_data
  * EConstr.EInstance.t
  * (EConstr.types * EConstr.constr * EConstr.constr)Match terms eq A t u, identity A t u or JMeq A t A u Returns associated lemmas and A,t,u or fails PatternMatchingFailure
val find_this_eq_data_decompose : 
  Environ.env ->
  Evd.evar_map ->
  EConstr.constr ->
  Rocqlib.rocq_eq_data
  * EConstr.EInstance.t
  * (EConstr.types * EConstr.constr * EConstr.constr)Idem but fails with an error message instead of PatternMatchingFailure
val find_eq_data : 
  Environ.env ->
  Evd.evar_map ->
  EConstr.constr ->
  Rocqlib.rocq_eq_data * EConstr.EInstance.t * equation_kindA variant that returns more informative structure on the equality found
val find_sigma_data_decompose : 
  Environ.env ->
  Evd.evar_map ->
  EConstr.constr ->
  Rocqlib.rocq_sigma_data
  * (EConstr.EInstance.t
     * EConstr.constr
     * EConstr.constr
     * EConstr.constr
     * EConstr.constr)Match a term of the form (existT A P t p) Returns associated lemmas and A,P,t,p
val match_sigma : 
  Environ.env ->
  Evd.evar_map ->
  EConstr.constr ->
  EConstr.constr * EConstr.constrMatch a term of the form {x:A|P}, returns A and P
val match_eqdec : 
  Environ.env ->
  Evd.evar_map ->
  EConstr.constr ->
  bool * Names.GlobRef.t * EConstr.constr * EConstr.constr * EConstr.constrMatch a decidable equality judgement (e.g {t=u:>T}+{~t=u}), returns t,u,T and a boolean telling if equality is on the left side
Match a negation
val is_homogeneous_relation : 
  ?loc:Loc.t ->
  Environ.env ->
  Evd.evar_map ->
  EConstr.constr ->
  EConstr.typesTest if a homogeneous relation (in Prop) and, if so, returns the domain