mirror of
https://github.com/NixOS/nix.git
synced 2025-11-22 18:29:36 +01:00
Also do a better JSON and testing for deep and shallow NAR listings. As documented, this for file system objects themselves, since `MemorySourceAccessor` is an implementation detail.
68 lines
1.8 KiB
Markdown
68 lines
1.8 KiB
Markdown
# File System Object
|
|
|
|
Nix uses a simplified model of the file system, which consists of file system objects.
|
|
Every file system object is one of the following:
|
|
|
|
- [**Regular File**]{#regular}
|
|
|
|
- A possibly empty sequence of bytes for contents
|
|
- A single boolean representing the [executable](https://en.m.wikipedia.org/wiki/File-system_permissions#Permissions) permission
|
|
|
|
- [**Directory**]{#directory}
|
|
|
|
Mapping of names to child file system objects
|
|
|
|
- [**Symbolic link**]{#symlink}
|
|
|
|
An arbitrary string, known as the *target* of the symlink.
|
|
|
|
In general, Nix does not assign any semantics to symbolic links.
|
|
Certain operations however, may make additional assumptions and attempt to use the target to find another file system object.
|
|
|
|
> See [the Wikpedia article on symbolic links](https://en.m.wikipedia.org/wiki/Symbolic_link) for background information if you are unfamiliar with this Unix concept.
|
|
|
|
File system objects and their children form a tree.
|
|
A bare file or symlink can be a root file system object.
|
|
|
|
Nix does not encode any other file system notions such as [hard links](https://en.m.wikipedia.org/wiki/Hard_link), [permissions](https://en.m.wikipedia.org/wiki/File-system_permissions), timestamps, or other metadata.
|
|
|
|
## Examples of file system objects
|
|
|
|
A plain file:
|
|
|
|
```
|
|
50 B, executable: false
|
|
```
|
|
|
|
An executable file:
|
|
|
|
```
|
|
122 KB, executable: true
|
|
```
|
|
|
|
A symlink:
|
|
|
|
```
|
|
-> /usr/bin/sh
|
|
```
|
|
|
|
A directory with contents:
|
|
|
|
```
|
|
├── bin
|
|
│ └── hello: 35 KB, executable: true
|
|
└── share
|
|
├── info
|
|
│ └── hello.info: 36 KB, executable: false
|
|
└── man
|
|
└── man1
|
|
└── hello.1.gz: 790 B, executable: false
|
|
```
|
|
|
|
A directory that contains a symlink and other directories:
|
|
|
|
```
|
|
├── bin -> share/go/bin
|
|
├── nix-support/
|
|
└── share/
|
|
```
|