All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.aya.tyck.error.UnifyError Maven / Gradle / Ivy

There is a newer version: 0.36.0
Show newest version
// Copyright (c) 2020-2024 Tesla (Yinsen) Zhang.
// Use of this source code is governed by the MIT license that can be found in the LICENSE.md file.
package org.aya.tyck.error;

import org.aya.pretty.doc.Doc;
import org.aya.syntax.concrete.Expr;
import org.aya.syntax.concrete.stmt.decl.DataCon;
import org.aya.syntax.core.term.SortTerm;
import org.aya.syntax.core.term.Term;
import org.aya.util.error.SourcePos;
import org.aya.util.prettier.PrettierOptions;
import org.jetbrains.annotations.NotNull;

public sealed interface UnifyError extends TyckError {
  record Type(
    @Override @NotNull Expr expr,
    @Override @NotNull SourcePos sourcePos,
    @NotNull UnifyInfo.Comparison comparison,
    @NotNull UnifyInfo info
  ) implements UnifyError {
    @Override public @NotNull Doc describe(@NotNull PrettierOptions options) {
      var prologue = Doc.vcat(
        Doc.english("Cannot check the expression"),
        Doc.par(1, expr.toDoc(options)),
        Doc.english("of type"));
      return info.describeUnify(options, comparison, prologue, Doc.english("against the type"));
    }
  }


  record ConReturn(
    @NotNull DataCon con,
    @NotNull UnifyInfo.Comparison comparison,
    @NotNull UnifyInfo info
  ) implements UnifyError {
    @Override public @NotNull SourcePos sourcePos() {
      return con.sourcePos();
    }

    @Override public @NotNull Doc describe(@NotNull PrettierOptions options) {
      var prologue = Doc.vcat(
        Doc.english("Cannot make sense of the return type of the constructor"),
        Doc.par(1, con.toDoc(options)),
        Doc.english("which eventually returns"));
      return info.describeUnify(options, comparison, prologue, Doc.english("while it should return"));
    }
  }

  record PiDom(
    @Override @NotNull Expr expr,
    @Override @NotNull SourcePos sourcePos,
    Term result, SortTerm sort
  ) implements UnifyError {
    @Override public @NotNull Doc describe(@NotNull PrettierOptions options) {
      return Doc.vcat(
        Doc.english("The type"),
        Doc.par(1, result.toDoc(options)),
        Doc.english("is in the domain of a function whose type is"),
        Doc.par(1, sort.toDoc(options)));
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy