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

Update flake inputs #2058

Merged
merged 1 commit into from
Oct 2, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
17 changes: 13 additions & 4 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 2 additions & 2 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -101,13 +101,13 @@ metrics = "0.21"
metrics-util = "0.15"

topiary-core = "0.4.0"
topiary-queries = { version = "0.4.2", default-features = false, features = ["nickel"] }
topiary-queries = { version = "=0.4.2", default-features = false, features = ["nickel"] }
# This version should agree with the topiary-query version: Nickel queries
# target a specific version of the Nickel grammar (though that dependency
# doesn't appear explicitly in `topiary-queries`'s Cargo.toml file). For now you
# might have to look at Topiary's commit messages, but in a near future, we'll
# try to make this data more accessible, e.g. in the query file
tree-sitter-nickel = "0.2.0"
tree-sitter-nickel = "=0.2.0"
tempfile = "3.5.0"

[profile.dev.package.lalrpop]
Expand Down
6 changes: 3 additions & 3 deletions core/src/cache.rs
Original file line number Diff line number Diff line change
Expand Up @@ -101,9 +101,9 @@ impl InputFormat {
/// the corresponding parsed terms. The storage comprises three elements:
///
/// - The file database, holding the string content of sources indexed by unique `FileId`
/// identifiers.
/// identifiers.
/// - The name-id table, associating source names for standalone inputs, or paths and timestamps
/// for files, to `FileId`s.
/// for files, to `FileId`s.
/// - The term cache, holding parsed terms indexed by `FileId`s.
///
/// Terms possibly undergo typechecking and program transformation. The state of each entry (that
Expand Down Expand Up @@ -759,7 +759,7 @@ impl Cache {
/// # Preconditions
///
/// - the entry must syntactically be a record (`Record` or `RecRecord`). Otherwise, this
/// function panics
/// function panics
pub fn transform_inner(
&mut self,
file_id: FileId,
Expand Down
2 changes: 1 addition & 1 deletion core/src/error/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -979,7 +979,7 @@ fn secondary(span: &RawSpan) -> Label<FileId> {
/// additional text placed at the end of diagnostic. What you lose:
/// - pretty formatting of annotations for such snippets
/// - style consistency: the style of the error now depends on the term being from the source or
/// a byproduct of evaluation
/// a byproduct of evaluation
/// 3. Add the term to files, take 1: pass a reference to files so that the code building the
/// diagnostic can itself add arbitrary snippets if necessary, and get back their `FileId`. This
/// is what is done here.
Expand Down
4 changes: 2 additions & 2 deletions core/src/error/report.rs
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ impl Default for ColorOpt {
/// # Arguments
///
/// - `cache` is the file cache used during the evaluation, which is required by the reporting
/// infrastructure to point at specific locations and print snippets when needed.
/// infrastructure to point at specific locations and print snippets when needed.
pub fn report<E: IntoDiagnostics<FileId>>(
cache: &mut Cache,
error: E,
Expand All @@ -83,7 +83,7 @@ pub fn report<E: IntoDiagnostics<FileId>>(
/// # Arguments
///
/// - `cache` is the file cache used during the evaluation, which is required by the reporting
/// infrastructure to point at specific locations and print snippets when needed.
/// infrastructure to point at specific locations and print snippets when needed.
pub fn report_to_stdout<E: IntoDiagnostics<FileId>>(
cache: &mut Cache,
error: E,
Expand Down
4 changes: 2 additions & 2 deletions core/src/eval/merge.rs
Original file line number Diff line number Diff line change
Expand Up @@ -11,13 +11,13 @@
//! - All the fields of `r1` that are not in `r2`
//! - All the fields of `r2` that are not in `r1`
//! - Fields that are both in `r1` and `r2` are recursively merged: for a field `f`, the result
//! contains the binding `f = r1.f & r2.f`
//! contains the binding `f = r1.f & r2.f`
//!
//! As fields are recursively merged, merge needs to operate on any value, not only on records:
//!
//! - *function*: merging a function with anything else fails
//! - *values*: merging any other values succeeds if and only if these two values are equals, in
//! which case it evaluates to this common value.
//! which case it evaluates to this common value.
//!
//! ## Metadata
//!
Expand Down
6 changes: 3 additions & 3 deletions core/src/eval/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -44,15 +44,15 @@
//! be performed:
//!
//! - `exp1` needs to be evaluated. The result must be saved somewhere, together with the resulting
//! environment
//! environment
//! - same thing for `exp2`
//! - Finally, the implementation of `+` can proceed with the computation
//!
//! We detail the case of binary operators, as the case of unary ones is similar and simpler.
//!
//! - **Op(op, first, second)**: pushes an `OpFirst` element on the stack, which saves the operator
//! `op`, the second argument `second` and the current environment, and proceed with the evaluation
//! of `first`
//! `op`, the second argument `second` and the current environment, and proceed with the evaluation
//! of `first`
//! - **OpFirst on stack**: if the evaluation of the current term is done and there is an `OpFirst`
//! marker on the stack, then:
//! 1. Extract the saved operator, the second argument and the environment `env2` from the
Expand Down
6 changes: 3 additions & 3 deletions core/src/label.rs
Original file line number Diff line number Diff line change
Expand Up @@ -260,10 +260,10 @@ pub mod ty_path {
/// but we want to report the failures of the two introduced subcontracts in a different way:
///
/// - The inner one (on the argument) says that `f` has been misused: it has been applied to
/// something that is not a `Number`.
/// something that is not a `Number`.
/// - The outer one says that `f` failed to satisfy its contract, as it has been provided with a
/// `Number` (otherwise the inner contracts would have failed before) but failed to deliver a
/// `Number`.
/// `Number` (otherwise the inner contracts would have failed before) but failed to deliver a
/// `Number`.
///
/// This duality caller/callee or function/context is indicated by the polarity: the outer
/// corresponds to a *positive* polarity (the contract is on the term), while the inner corresponds
Expand Down
4 changes: 4 additions & 0 deletions core/src/nix_ffi/cpp/nix.cc
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,10 @@ using namespace nix;
#include <nix/value-to-json.hh>
#include <nix/command.hh>
#include <nix/value.hh>
// We will need this include when we update to latest Nix, but for now it's
// pinned to a previous version where `initGC()` is still exported by already
// imported headers, so we don't need it yet.
// #include <nix/eval-gc.hh>

#include "nickel-lang-core/src/nix_ffi/mod.rs.h"

Expand Down
2 changes: 1 addition & 1 deletion core/src/position.rs
Original file line number Diff line number Diff line change
Expand Up @@ -157,7 +157,7 @@ impl TermPos {
/// Fuse two positions if they are from the same source file.
///
/// - If both positions are defined and from the same file, the resulting position is the
/// smallest span that contain both.
/// smallest span that contain both.
/// - If both positions are defined but aren't from the same file, this returns `TermPos::None`
/// - If at most one position is defined, the other is returned (whether defined or not).
pub fn fuse(self, other: Self) -> Self {
Expand Down
2 changes: 1 addition & 1 deletion core/src/program.rs
Original file line number Diff line number Diff line change
Expand Up @@ -640,7 +640,7 @@ impl<EC: EvalCache> Program<EC> {
/// - If the result is a record, we recursively evaluate subfields to record spines
/// - If the result isn't a record, it is returned as it is
/// - If the evaluation fails with [crate::error::EvalError::MissingFieldDef], the original
/// term is returned unevaluated[^missing-field-def]
/// term is returned unevaluated[^missing-field-def]
/// - If any other error occurs, the evaluation fails and returns the error.
///
/// [^missing-field-def]: Because we want to handle partial configurations as well,
Expand Down
14 changes: 7 additions & 7 deletions core/src/term/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -192,12 +192,12 @@ pub enum Term {
///
/// - Assign a unique identifier to each type variable: say `a => 1`, `b => 2`
/// - For each cast on a negative occurrence of a type variable `a` or `b` (corresponding to an
/// argument position), tag the argument with the associated identifier. In our example, `f
/// true "a"` will push `Sealed(1, true)` then `Sealed(2, "a")` on the stack.
/// argument position), tag the argument with the associated identifier. In our example, `f
/// true "a"` will push `Sealed(1, true)` then `Sealed(2, "a")` on the stack.
/// - For each cast on a positive occurrence of a type variable, this contract check that the
/// term is of the form `Sealed(id, term)` where `id` corresponds to the identifier of the
/// type variable. In our example, the last cast to `a` finds `Sealed(2, "a")`, while it
/// expected `Sealed(1, _)`, hence it raises a positive blame.
/// term is of the form `Sealed(id, term)` where `id` corresponds to the identifier of the
/// type variable. In our example, the last cast to `a` finds `Sealed(2, "a")`, while it
/// expected `Sealed(1, _)`, hence it raises a positive blame.
#[serde(skip)]
Sealed(SealingKey, RichTerm, Label),

Expand Down Expand Up @@ -1831,9 +1831,9 @@ pub enum BinaryOp {
///
/// - `left_only`: fields of the left argument but not in the right
/// - `left_center`: fields of the left argument that happens to also be in the right (but the
/// value and the metadata are taken from the left)
/// value and the metadata are taken from the left)
/// - `right_center`: fields of the right argument that happens to also be in the left (but the
/// value and the metadata are taken from the right)
/// value and the metadata are taken from the right)
/// - `right_only`: fields of the right argument but not in the left
///
/// As opposed to an equivalent user-defined implementation, this primop has better performance
Expand Down
8 changes: 5 additions & 3 deletions core/src/typ.rs
Original file line number Diff line number Diff line change
Expand Up @@ -958,10 +958,12 @@ impl EnumRows {
/// The following simplification are applied:
///
/// - the type of the argument of each enum variant is simplified as well
/// - if the polarity is positive and the rows are composed entirely of enum tags and enum variants whose argument's simplified type is `Dyn`, the entire rows are elided by returning `None`
/// - if the polarity is positive and the rows are composed entirely of enum tags and enum
/// variants whose argument's simplified type is `Dyn`, the entire rows are elided by returning
/// `None`
/// - a tail variable in tail position is currently left unchanged, because it doesn't give
/// rise to any sealing at runtime currently (see documentation of `$forall_enum_tail` in the
/// internals module of the stdlib)
/// rise to any sealing at runtime currently (see documentation of `$forall_enum_tail` in the
/// internals module of the stdlib)
fn simplify(
self,
contract_env: &mut Environment<Ident, RichTerm>,
Expand Down
2 changes: 1 addition & 1 deletion core/src/typecheck/error.rs
Original file line number Diff line number Diff line change
Expand Up @@ -271,7 +271,7 @@ impl UnifError {
/// # Parameters
///
/// - `state`: the state of unification. Used to access the unification table, and the original
/// names of of unification variable or type constant.
/// names of of unification variable or type constant.
/// - `pos_opt`: the position span of the expression that failed to typecheck.
pub fn into_typecheck_err(self, state: &State, pos_opt: TermPos) -> TypecheckError {
let mut names = reporting::NameReg::new(state.names.clone());
Expand Down
52 changes: 25 additions & 27 deletions core/src/typecheck/unif.rs
Original file line number Diff line number Diff line change
Expand Up @@ -86,15 +86,14 @@ impl UnifTable {
/// # Preconditions
///
/// - This method doesn't check for the variable level conditions. This is the responsibility
/// of the caller.
/// of the caller.
/// - If the target type is a unification variable as well, it must not be assigned to another
/// unification type. That is, `assign` should always be passed a root type. Otherwise, the
/// handling of variable levels will be messed up.
/// unification type. That is, `assign` should always be passed a root type. Otherwise, the
/// handling of variable levels will be messed up.
/// - This method doesn't force pending level updates when needed (calling to
/// `force_type_updates`), i.e.
/// when `uty` is a rigid type variable. Having pending variable level updates and using
/// `assign_type` might make typechecking incorrect in some situation by unduely allowing
/// unsound generalization. This is the responsibility of the caller.
/// `force_type_updates`), i.e. when `uty` is a rigid type variable. Having pending variable
/// level updates and using `assign_type` might make typechecking incorrect in some situation
/// by unduely allowing unsound generalization. This is the responsibility of the caller.
pub fn assign_type(&mut self, var: VarId, uty: UnifType) {
// Unifying a free variable with itself is a no-op.
if matches!(uty, UnifType::UnifVar { id, ..} if id == var) {
Expand Down Expand Up @@ -157,15 +156,14 @@ impl UnifTable {
/// # Preconditions
///
/// - This method doesn't check for the variable level conditions. This is the responsibility
/// of the caller.
/// of the caller.
/// - If the target type is a unification variable as well, it must not be assigned to another
/// unification type. That is, `assign` should always be passed a root type. Otherwise, the
/// handling of variable levels will be messed up.
/// unification type. That is, `assign` should always be passed a root type. Otherwise, the
/// handling of variable levels will be messed up.
/// - This method doesn't force pending level updates when needed (calling to
/// `force_rrows_updates`), i.e.
/// when `uty` is a rigid type variable. Having pending variable level updates and using
/// `assign_type` might make typechecking incorrect in some situation by unduly allowing
/// unsound generalization. This is the responsibility of the caller.
/// `force_rrows_updates`), i.e. when `uty` is a rigid type variable. Having pending variable
/// level updates and using `assign_type` might make typechecking incorrect in some situation
/// by unduly allowing unsound generalization. This is the responsibility of the caller.
pub fn assign_rrows(&mut self, var: VarId, rrows: UnifRecordRows) {
// Unifying a free variable with itself is a no-op.
if matches!(rrows, UnifRecordRows::UnifVar { id, ..} if id == var) {
Expand Down Expand Up @@ -207,15 +205,14 @@ impl UnifTable {
/// # Preconditions
///
/// - This method doesn't check for the variable level conditions. This is the responsibility
/// of the caller.
/// of the caller.
/// - If the target type is a unification variable as well, it must not be assigned to another
/// unification type. That is, `assign` should always be passed a root type. Otherwise, the
/// handling of variable levels will be messed up.
/// unification type. That is, `assign` should always be passed a root type. Otherwise, the
/// handling of variable levels will be messed up.
/// - This method doesn't force pending level updates when needed (calling to
/// `force_erows_updates`), i.e.
/// when `uty` is a rigid type variable. Having pending variable level updates and using
/// `assign_type` might make typechecking incorrect in some situation by unduly allowing
/// unsound generalization. This is the responsibility of the caller.
/// `force_erows_updates`), i.e. when `uty` is a rigid type variable. Having pending variable
/// level updates and using `assign_type` might make typechecking incorrect in some situation
/// by unduly allowing unsound generalization. This is the responsibility of the caller.
pub fn assign_erows(&mut self, var: VarId, erows: UnifEnumRows) {
// Unifying a free variable with itself is a no-op.
if matches!(erows, UnifEnumRows::UnifVar { id, .. } if id == var) {
Expand Down Expand Up @@ -1621,6 +1618,7 @@ pub(super) trait RemoveRow: Sized {
/// the original row type without the found row.
///
/// If the searched row isn't found:
///
/// - If the row type is extensible, i.e. it ends with a free unification variable in tail
/// position, this function adds the missing row (with `row.types` as a type for record rows,
/// if allowed by row constraints) and then acts as if `remove_row` was called again on
Expand All @@ -1636,12 +1634,12 @@ pub(super) trait RemoveRow: Sized {
///
/// For those to unify, we must have either:
///
/// - `r1` is somewhere in `tail2`, and `tail1` unifies with `{..tail2'}` where `tail2'` is
/// `tail2` without `r1`.
/// - `tail2` is extensible, in which case we can extend `tail2` with `r1`, assuming that
/// `tail1` unifies with `{..tail2'}`, where `tail2'` is `tail2` after extending with `r1` and
/// then removing it. Modulo fresh unification variable shuffling, `tail2'` is in fact
/// isomorphic to `tail2` before it was extended.
/// - `r1` is somewhere in `tail2`, and `tail1` unifies with `{..tail2'}` where `tail2'` is
/// `tail2` without `r1`.
/// - `tail2` is extensible, in which case we can extend `tail2` with `r1`, assuming that
/// `tail1` unifies with `{..tail2'}`, where `tail2'` is `tail2` after extending with `r1`
/// and then removing it. Modulo fresh unification variable shuffling, `tail2'` is in fact
/// isomorphic to `tail2` before it was extended.
///
/// When we unify two row types, we destructure the left hand side to extract the head `r1` and
/// the tail `tail1`. Then, we try to find and extract `r1` from `tail2`. If `r1` was found, we
Expand Down
Loading