Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Type errors that mention the part of the rule declaration being offended? #97

Closed
Mallku2 opened this issue Nov 26, 2024 · 3 comments · Fixed by #101
Closed

Type errors that mention the part of the rule declaration being offended? #97

Mallku2 opened this issue Nov 26, 2024 · 3 comments · Fixed by #101

Comments

@Mallku2
Copy link
Contributor

Mallku2 commented Nov 26, 2024

I have trouble trying to understand type error messages that do not mention explicitly which part of the rule declaration is being offended (either its premises, arguments, parameter, assumptions, etc). For example, I cannot quite grasp the meaning of the following error message:

Type checking application failed:
Children: [subproof, (p a), ((forall ((@varlist x1) @varlist.nil)) (p x1))]
Message: Unexpected argument type 0 of subproof
  LHS (Proof G), from (Proof G)
  RHS Bool
  Context []

produced by the step:

(step-pop t1 (@cl (not (forall ( ( x1 U ) ) (p x1))) (p a)) :rule subproof :premises ( (p a) ))

where subproof is defined as:

(declare-rule subproof ((F Bool) (G Bool :list))
  :assumption F
  :premises (G)
  :requires (...) ; Not showing it, for simplicity
  :conclusion-given
)

(the previous definitions belong to https://github.com/cvc5/AletheInEunoia/tree/main/signature; let me know if it would be useful to provide more info about the error!)

@ajreynol
Copy link
Member

ajreynol commented Dec 3, 2024

In this case, a Boolean (p a) was given as a premise, which is illegal. I will look into giving some more information when catching this error.

@ajreynol
Copy link
Member

ajreynol commented Dec 3, 2024

I've opened a PR to improve the error message, the message will now look like this:

Error: ../tests/err-msg-97.eo:12.53: Type checking application failed when applying subproof
Children: [(p a), ((forall ((@varlist x1) @varlist.nil)) (p x1))]
Message: Unexpected type of child #0
  Term: (p a)
  Has type: Bool
  Expected type: (Proof G)
  Context []

Does this seem intuitive enough?

@Mallku2
Copy link
Contributor Author

Mallku2 commented Dec 3, 2024

Excellent, many thanks!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants