forked from lix-project/lix
formalize file system objects
convention: describe every data type in prose, and illustrate with a class diagram, and a textual representation of an abstract data type. right now we save ourselves the trouble of doing class diagrams, we can add them later. but they are important.
This commit is contained in:
parent
fb2ec7e4ec
commit
5fda995491
1 changed files with 18 additions and 7 deletions
|
@ -6,31 +6,42 @@ A store object is the pair of
|
||||||
- a [file system object](#file-system-object)
|
- a [file system object](#file-system-object)
|
||||||
- a set of [references](#reference) to store objects.
|
- a set of [references](#reference) to store objects.
|
||||||
|
|
||||||
|
We call a store object's outermost file system object the *root*.
|
||||||
|
|
||||||
|
```haskell
|
||||||
|
data StoreOject = StoreObject {
|
||||||
|
root :: FileSystemObject
|
||||||
|
, references :: Set StoreObject
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
## File system object {#file-system-object}
|
## File system object {#file-system-object}
|
||||||
|
|
||||||
The Nix store uses a simple file system model.
|
The Nix store uses a simple file system model.
|
||||||
|
|
||||||
data FileSystemObject
|
|
||||||
= File Executable Contents
|
|
||||||
| Directory (Map FileName FileSystemObject)
|
|
||||||
| SymLink Path
|
|
||||||
|
|
||||||
Every file system object is one of the following:
|
Every file system object is one of the following:
|
||||||
- File: an executable flag, and arbitrary data for contents
|
- File: an executable flag, and arbitrary data for contents
|
||||||
- Directory: mapping of names to child file system objects
|
- Directory: mapping of names to child file system objects
|
||||||
- [Symbolic link](https://en.m.wikipedia.org/wiki/Symbolic_link): may point anywhere.
|
- [Symbolic link](https://en.m.wikipedia.org/wiki/Symbolic_link): may point anywhere.
|
||||||
|
|
||||||
In particular, symlinks pointing outside of their own root file system object, or to a store object without a matching reference, are allowed, but might not function as intended.
|
```haskell
|
||||||
|
data FileSystemObject
|
||||||
|
= File { isExecutable :: Bool, contents :: Bytes }
|
||||||
|
| Directory { entries :: Map FileName FileSystemObject }
|
||||||
|
| SymLink { target :: Path }
|
||||||
|
```
|
||||||
|
|
||||||
A bare file or symlink can be a root file system object.
|
A bare file or symlink can be a root file system object.
|
||||||
|
|
||||||
|
Symlinks pointing outside of their own root, or to a store object without a matching reference, are allowed, but might not function as intended.
|
||||||
|
|
||||||
## Reference {#reference}
|
## Reference {#reference}
|
||||||
|
|
||||||
A store object can refer to other store objects or itself.
|
A store object can refer to other store objects or itself.
|
||||||
|
|
||||||
Nix collects these references by scanning file contents for [store paths](./paths.md) when a new store object is created.
|
Nix collects these references by scanning file contents for [store paths](./paths.md) when a new store object is created.
|
||||||
|
|
||||||
While references could be arbitrary paths, Nix requires them to be store paths to ensure correctness:
|
While references could be arbitrary paths, Nix requires them to be store paths to ensure correctness.
|
||||||
Anything outside a given store is not under control of Nix, and therefore cannot be guaranteed to be present when needed.
|
Anything outside a given store is not under control of Nix, and therefore cannot be guaranteed to be present when needed.
|
||||||
|
|
||||||
However, having references match store paths in files is not enforced by the data model:
|
However, having references match store paths in files is not enforced by the data model:
|
||||||
|
|
Loading…
Reference in a new issue