-
-
Notifications
You must be signed in to change notification settings - Fork 1.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge remote-tracking branch 'obsidian/meson-functional-tests' into m…
…eson-misc
- Loading branch information
Showing
46 changed files
with
1,092 additions
and
426 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
2.24.0 | ||
2.25.0 |
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,14 +1,28 @@ | ||
# Scoping rules | ||
|
||
Nix is [statically scoped](https://en.wikipedia.org/wiki/Scope_(computer_science)#Lexical_scope), but with multiple scopes and shadowing rules. | ||
A *scope* in the Nix language is a dictionary keyed by [name](./identifiers.md#names), mapping each name to an expression and a *definition type*. | ||
The definition type is either *explicit* or *implicit*. | ||
Each entry in this dictionary is a *definition*. | ||
|
||
* primary scope: explicitly-bound variables | ||
* [`let`](./syntax.md#let-expressions) | ||
* [`inherit`](./syntax.md#inheriting-attributes) | ||
* [function](./syntax.md#functions) arguments | ||
Explicit definitions are created by the following expressions: | ||
- [let-expressions](syntax.md#let-expressions) | ||
- [recursive attribute set literals](syntax.md#recursive-sets) (`rec`) | ||
- [function literals](syntax.md#functions) | ||
|
||
* secondary scope: implicitly-bound variables | ||
* [`with`](./syntax.md#with-expressions) | ||
Implicit definitions are only created by [with-expressions](./syntax.md#with-expressions). | ||
|
||
Primary scope takes precedence over secondary scope. | ||
See [`with`](./syntax.md#with-expressions) for a detailed example. | ||
Every expression is *enclosed* by a scope. | ||
The outermost expression is enclosed by the [built-in, global scope](./builtins.md), which contains only explicit definitions. | ||
The expressions listed above *extend* their enclosing scope by adding new definitions, or replacing existing ones with the same name. | ||
An explicit definition can replace a definition of any type; an implicit definition can only replace another implicit definition. | ||
|
||
Each of the above expressions defines which of its subexpressions are enclosed by the extended scope. | ||
In all other cases, the same scope that encloses an expression is the enclosing scope for its subexpressions. | ||
|
||
The Nix language is [statically scoped](https://en.wikipedia.org/wiki/Scope_(computer_science)#Lexical_scope); | ||
the value of a variable is determined only by the variable's enclosing scope, and not by the dynamic context in which the variable is evaluated. | ||
|
||
> **Note** | ||
> | ||
> Expressions entered into the [Nix REPL](@docroot@/command-ref/new-cli/nix3-repl.md) are enclosed by a scope that can be extended by command line arguments or previous REPL commands. | ||
> These ways of extending scope are not, strictly speaking, part of the Nix language. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
# Variables | ||
|
||
A *variable* is an [identifier](identifiers.md) used as an expression. | ||
|
||
> **Syntax** | ||
> | ||
> *expression* → *identifier* | ||
A variable must have the same name as a definition in the [scope](./scope.md) that encloses it. | ||
The value of a variable is the value of the corresponding expression in the enclosing scope. |
Oops, something went wrong.