remove non ascii whitespaces
This commit is contained in:
parent
598a10bc28
commit
5a6d6c4d13
117 changed files with 1928 additions and 1928 deletions
|
@ -10,14 +10,14 @@ Negative numbers are commonly represented in binary using two's complement.
|
||||||
Two's complement of an integer number is achieved by:
|
Two's complement of an integer number is achieved by:
|
||||||
- Step 1: Start with the absolute value of the number.
|
- Step 1: Start with the absolute value of the number.
|
||||||
- Step 2: inverting (or flipping) all bits – changing every 0 to 1, and every 1 to 0;
|
- Step 2: inverting (or flipping) all bits – changing every 0 to 1, and every 1 to 0;
|
||||||
- Step 3: adding 1 to the entire inverted number, ignoring any overflow. Accounting for overflow will produce the wrong value for the result.
|
- Step 3: adding 1 to the entire inverted number, ignoring any overflow. Accounting for overflow will produce the wrong value for the result.
|
||||||
|
|
||||||
For example, to calculate the decimal number **−6** in binary:
|
For example, to calculate the decimal number **−6** in binary:
|
||||||
- Step 1: _+6_ in decimal is _0110_ in binary; the leftmost significant bit (the first 0) is the sign (just _110_ in binary would be -2 in decimal).
|
- Step 1: _+6_ in decimal is _0110_ in binary; the leftmost significant bit (the first 0) is the sign (just _110_ in binary would be -2 in decimal).
|
||||||
- Step 2: flip all bits in _0110_, giving _1001_.
|
- Step 2: flip all bits in _0110_, giving _1001_.
|
||||||
- Step 3: add the place value 1 to the flipped number _1001_, giving _1010_.
|
- Step 3: add the place value 1 to the flipped number _1001_, giving _1010_.
|
||||||
|
|
||||||
To verify that _1010_ indeed has a value of _−6_, add the place values together, but _subtract_ the sign value from the final calculation. Because the most significant value is the sign value, it must be subtracted to produce the correct result: **1010** = **−**(**1**×23) + (**0**×22) + (**1**×21) + (**0**×20) = **1**×−8 + **0** + **1**×2 + **0** = −6.
|
To verify that _1010_ indeed has a value of _−6_, add the place values together, but _subtract_ the sign value from the final calculation. Because the most significant value is the sign value, it must be subtracted to produce the correct result: **1010** = **−**(**1**×23) + (**0**×22) + (**1**×21) + (**0**×20) = **1**×−8 + **0** + **1**×2 + **0** = −6.
|
||||||
|
|
||||||
| Bits: | 1 | 0 | 1 | 0 |
|
| Bits: | 1 | 0 | 1 | 0 |
|
||||||
| -------------------- | --------------- | ---------- | ---------- | ---------- |
|
| -------------------- | --------------- | ---------- | ---------- | ---------- |
|
||||||
|
|
|
@ -60,8 +60,8 @@ gpg --import
|
||||||
|
|
||||||
**Key selection:**
|
**Key selection:**
|
||||||
```shell
|
```shell
|
||||||
-r, --recipient KEY # Encrypt for key
|
-r, --recipient KEY # Encrypt for key
|
||||||
-u, --local-user KEY # Use this key
|
-u, --local-user KEY # Use this key
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -16,12 +16,12 @@ All Borg commands share these options:
|
||||||
|
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| ----------------------- | ------------------------------------------------------------------------------------- |
|
| ----------------------- | ------------------------------------------------------------------------------------- |
|
||||||
| `--info, -v, --verbose` | work on log level INFO |
|
| `--info, -v, --verbose` | work on log level INFO |
|
||||||
| `-p, --progress` | show progress information |
|
| `-p, --progress` | show progress information |
|
||||||
| `--log-json` | Output one [JSON](../../files/JSON.md) object per log line instead of formatted text. |
|
| `--log-json` | Output one [JSON](../../files/JSON.md) object per log line instead of formatted text. |
|
||||||
| `--bypass-lock` | Bypass locking mechanism |
|
| `--bypass-lock` | Bypass locking mechanism |
|
||||||
| `--remote-path PATH` | use PATH as borg executable on the remote (default: “borg”) |
|
| `--remote-path PATH` | use PATH as borg executable on the remote (default: “borg”) |
|
||||||
| `--rsh RSH` | Use this command to connect to the ‘borg serve’ process (default: ‘ssh’) |
|
| `--rsh RSH` | Use this command to connect to the ‘borg serve’ process (default: ‘ssh’) |
|
||||||
|
|
||||||
### `borg init`
|
### `borg init`
|
||||||
This command initializes an empty repository. A repository is a filesystem directory containing the deduplicated data from zero or more archives.
|
This command initializes an empty repository. A repository is a filesystem directory containing the deduplicated data from zero or more archives.
|
||||||
|
@ -31,7 +31,7 @@ Usage: `borg [common options] init [options] [REPOSITORY]`
|
||||||
|
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| ------------------------------ | ----------------------------------------- |
|
| ------------------------------ | ----------------------------------------- |
|
||||||
| `-e MODE`, `--encryption MODE` | select encryption key mode **(required)** |
|
| `-e MODE`, `--encryption MODE` | select encryption key mode **(required)** |
|
||||||
|
|
||||||
#### Examples
|
#### Examples
|
||||||
```shell
|
```shell
|
||||||
|
@ -57,31 +57,31 @@ Usage: `borg [common options] create [options] ARCHIVE [PATH...]`
|
||||||
#### Options
|
#### Options
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| --------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------- |
|
| --------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| ` -n`, `--dry-run` | do not create a backup archive |
|
| ` -n`, `--dry-run` | do not create a backup archive |
|
||||||
| `-s`, `--stats` | print statistics for the created archive |
|
| `-s`, `--stats` | print statistics for the created archive |
|
||||||
| `--list` | output verbose list of items (files, dirs, …) |
|
| `--list` | output verbose list of items (files, dirs, …) |
|
||||||
| `--json` | output stats as JSON. Implies `--stats`. |
|
| `--json` | output stats as JSON. Implies `--stats`. |
|
||||||
| `--stdin-name NAME` | use NAME in archive for stdin data (default: `stdin`) |
|
| `--stdin-name NAME` | use NAME in archive for stdin data (default: `stdin`) |
|
||||||
| `--stdin-user USER` | set user USER in archive for stdin data (default: `root`) |
|
| `--stdin-user USER` | set user USER in archive for stdin data (default: `root`) |
|
||||||
| `--stdin-group GROUP` | set group GROUP in archive for stdin data (default: `wheel`) |
|
| `--stdin-group GROUP` | set group GROUP in archive for stdin data (default: `wheel`) |
|
||||||
| `--stdin-mode M` | set mode to M in archive for stdin data (default: 0660) |
|
| `--stdin-mode M` | set mode to M in archive for stdin data (default: 0660) |
|
||||||
| `--content-from-command` | interpret PATH as command and store its stdout. |
|
| `--content-from-command` | interpret PATH as command and store its stdout. |
|
||||||
| `--paths-from-stdin` | read DELIM-separated list of paths to backup from stdin. All control is external: it will back up all files given - no more, no less. |
|
| `--paths-from-stdin` | read DELIM-separated list of paths to backup from stdin. All control is external: it will back up all files given - no more, no less. |
|
||||||
| `--paths-from-command` | interpret PATH as command and treat its output as `--paths-from-stdin` |
|
| `--paths-from-command` | interpret PATH as command and treat its output as `--paths-from-stdin` |
|
||||||
| `--paths-delimiter DELIM` | set path delimiter for `--paths-from-stdin` and `--paths-from-command` (default: `\n`) |
|
| `--paths-delimiter DELIM` | set path delimiter for `--paths-from-stdin` and `--paths-from-command` (default: `\n`) |
|
||||||
| `-e PATTERN`, `--exclude PATTERN` | exclude paths matching PATTERN |
|
| `-e PATTERN`, `--exclude PATTERN` | exclude paths matching PATTERN |
|
||||||
| `--exclude-from EXCLUDEFILE` | read exclude patterns from EXCLUDEFILE, one per line |
|
| `--exclude-from EXCLUDEFILE` | read exclude patterns from EXCLUDEFILE, one per line |
|
||||||
| `--pattern PATTERN` | include/exclude paths matching PATTERN |
|
| `--pattern PATTERN` | include/exclude paths matching PATTERN |
|
||||||
| `--patterns-from PATTERNFILE` | read include/exclude patterns from PATTERNFILE, one per line |
|
| `--patterns-from PATTERNFILE` | read include/exclude patterns from PATTERNFILE, one per line |
|
||||||
| `--exclude-caches` | exclude directories that contain a CACHEDIR.TAG file |
|
| `--exclude-caches` | exclude directories that contain a CACHEDIR.TAG file |
|
||||||
| `--exclude-if-present NAME` | exclude directories that are tagged by containing a filesystem object with the given NAME |
|
| `--exclude-if-present NAME` | exclude directories that are tagged by containing a filesystem object with the given NAME |
|
||||||
| `--keep-exclude-tags` | if tag objects are specified with `--exclude-if-present`, don’t omit the tag objects themselves from the backup archive |
|
| `--keep-exclude-tags` | if tag objects are specified with `--exclude-if-present`, don’t omit the tag objects themselves from the backup archive |
|
||||||
| `--exclude-nodump` | exclude files flagged NODUMP |
|
| `--exclude-nodump` | exclude files flagged NODUMP |
|
||||||
| `-x`, `--one-file-system` | stay in the same file system and do not store mount points of other file systems |
|
| `-x`, `--one-file-system` | stay in the same file system and do not store mount points of other file systems |
|
||||||
| `--comment COMMENT` | add a comment text to the archive |
|
| `--comment COMMENT` | add a comment text to the archive |
|
||||||
| `--timestamp TIMESTAMP` | manually specify the archive creation date/time (UTC, yyyy-mm-ddThh:mm:ss format). Alternatively, give a reference file/directory. |
|
| `--timestamp TIMESTAMP` | manually specify the archive creation date/time (UTC, yyyy-mm-ddThh:mm:ss format). Alternatively, give a reference file/directory. |
|
||||||
| `-c SECONDS`, `--checkpoint-interval SECONDS` | write checkpoint every SECONDS seconds (Default: 1800) |
|
| `-c SECONDS`, `--checkpoint-interval SECONDS` | write checkpoint every SECONDS seconds (Default: 1800) |
|
||||||
| `-C COMPRESSION`, `--compression COMPRESSION` | select compression algorithm, see the output of the “borg help compression” command for details. |
|
| `-C COMPRESSION`, `--compression COMPRESSION` | select compression algorithm, see the output of the “borg help compression” command for details. |
|
||||||
|
|
||||||
#### Examples
|
#### Examples
|
||||||
```shell
|
```shell
|
||||||
|
@ -158,19 +158,19 @@ $ borg create /path/to/repo::daily-projectA-{now:%Y-%m-%d} projectA
|
||||||
```
|
```
|
||||||
|
|
||||||
### `borg extract`
|
### `borg extract`
|
||||||
This command extracts the contents of an archive. By default the entire archive is extracted but a subset of files and directories can be selected by passing a list of `PATHs` as arguments. The file selection can further be restricted by using the `--exclude` option.
|
This command extracts the contents of an archive. By default the entire archive is extracted but a subset of files and directories can be selected by passing a list of `PATHs` as arguments. The file selection can further be restricted by using the `--exclude` option.
|
||||||
Usage: `borg [common options] extract [options] ARCHIVE [PATH...]`
|
Usage: `borg [common options] extract [options] ARCHIVE [PATH...]`
|
||||||
|
|
||||||
#### Options
|
#### Options
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| --------------------------------- | --------------------------------------------------------------------------------------------------------- |
|
| --------------------------------- | --------------------------------------------------------------------------------------------------------- |
|
||||||
| `--list` | output verbose list of items (files, dirs, …) |
|
| `--list` | output verbose list of items (files, dirs, …) |
|
||||||
| `-n`, `--dry-run` | do not actually change any files |
|
| `-n`, `--dry-run` | do not actually change any files |
|
||||||
| `-e PATTERN`, `--exclude PATTERN` | exclude paths matching PATTERN |
|
| `-e PATTERN`, `--exclude PATTERN` | exclude paths matching PATTERN |
|
||||||
| `--exclude-from EXCLUDEFILE` | read exclude patterns from EXCLUDEFILE, one per line |
|
| `--exclude-from EXCLUDEFILE` | read exclude patterns from EXCLUDEFILE, one per line |
|
||||||
| `--pattern PATTERN` | include/exclude paths matching PATTERN |
|
| `--pattern PATTERN` | include/exclude paths matching PATTERN |
|
||||||
| `--patterns-from PATTERNFILE` | read include/exclude patterns from PATTERNFILE, one per line |
|
| `--patterns-from PATTERNFILE` | read include/exclude patterns from PATTERNFILE, one per line |
|
||||||
| `--strip-components NUMBER` | Remove the specified number of leading path elements. Paths with fewer elements will be silently skipped. |
|
| `--strip-components NUMBER` | Remove the specified number of leading path elements. Paths with fewer elements will be silently skipped. |
|
||||||
|
|
||||||
#### Examples
|
#### Examples
|
||||||
```shell
|
```shell
|
||||||
|
@ -203,10 +203,10 @@ Usage: `borg [common options] check [options] [REPOSITORY_OR_ARCHIVE]`
|
||||||
| ------------------------ | ---------------------------------------------------------------------------------------------- |
|
| ------------------------ | ---------------------------------------------------------------------------------------------- |
|
||||||
| `--repository-only` | only perform repository checks |
|
| `--repository-only` | only perform repository checks |
|
||||||
| `--archives-only` | only perform archives checks |
|
| `--archives-only` | only perform archives checks |
|
||||||
| `--verify-data` | perform cryptographic archive data integrity verification (conflicts with `--repository-only`) |
|
| `--verify-data` | perform cryptographic archive data integrity verification (conflicts with `--repository-only`) |
|
||||||
| `--repair` | attempt to repair any inconsistencies found |
|
| `--repair` | attempt to repair any inconsistencies found |
|
||||||
| `--save-space` | work slower, but using less space |
|
| `--save-space` | work slower, but using less space |
|
||||||
| `--max-duration SECONDS` | do only a partial repo check for max. SECONDS seconds (Default: unlimited) |
|
| `--max-duration SECONDS` | do only a partial repo check for max. SECONDS seconds (Default: unlimited) |
|
||||||
|
|
||||||
### `borg rename`
|
### `borg rename`
|
||||||
This command renames an archive in the repository.
|
This command renames an archive in the repository.
|
||||||
|
@ -232,18 +232,18 @@ Usage: `borg [common options] list [options] [REPOSITORY_OR_ARCHIVE] [PATH...]`
|
||||||
| --------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| --------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `--consider-checkpoints` | Show checkpoint archives in the repository contents list (default: hidden). |
|
| `--consider-checkpoints` | Show checkpoint archives in the repository contents list (default: hidden). |
|
||||||
| `--short` | only print file/directory names, nothing else |
|
| `--short` | only print file/directory names, nothing else |
|
||||||
| `--format FORMAT` | specify format for file or archive listing (default for files: `{mode} {user:6} {group:6} {size:8} {mtime} {path}{extra}{NL}`; for archives: `{archive:<36} {time} [{id}]{NL}`) |
|
| `--format FORMAT` | specify format for file or archive listing (default for files: `{mode} {user:6} {group:6} {size:8} {mtime} {path}{extra}{NL}`; for archives: `{archive:<36} {time} [{id}]{NL}`) |
|
||||||
| `--json` | Only valid for listing repository contents. Format output as [JSON](../../files/JSON.md). The form of `--format` is ignored, but keys used in it are added to the [JSON](../../files/JSON.md) output. Some keys are always present. Note: [JSON](../../files/JSON.md) can only represent text. A “barchive” key is therefore not available. |
|
| `--json` | Only valid for listing repository contents. Format output as [JSON](../../files/JSON.md). The form of `--format` is ignored, but keys used in it are added to the [JSON](../../files/JSON.md) output. Some keys are always present. Note: [JSON](../../files/JSON.md) can only represent text. A “barchive” key is therefore not available. |
|
||||||
| `--json-lines` | Only valid for listing archive contents. Format output as [JSON](../../files/JSON.md) Lines. The form of `--format` is ignored, but keys used in it are added to the [JSON](../../files/JSON.md) output. Some keys are always present. Note: [JSON](../../files/JSON.md) can only represent text. A “bpath” key is therefore not available. |
|
| `--json-lines` | Only valid for listing archive contents. Format output as [JSON](../../files/JSON.md) Lines. The form of `--format` is ignored, but keys used in it are added to the [JSON](../../files/JSON.md) output. Some keys are always present. Note: [JSON](../../files/JSON.md) can only represent text. A “bpath” key is therefore not available. |
|
||||||
| `-P PREFIX`, `--prefix PREFIX` | only consider archive names starting with this prefix. (deprecated) |
|
| `-P PREFIX`, `--prefix PREFIX` | only consider archive names starting with this prefix. (deprecated) |
|
||||||
| `-a GLOB`, `--glob-archives GLOB` | only consider archive names matching the glob. sh: rules apply (without actually using the sh: prefix), see “borg help patterns”. |
|
| `-a GLOB`, `--glob-archives GLOB` | only consider archive names matching the glob. sh: rules apply (without actually using the sh: prefix), see “borg help patterns”. |
|
||||||
| `--sort-by KEYS` | Comma-separated list of sorting keys; valid keys are: timestamp, archive, name, id; default is: timestamp |
|
| `--sort-by KEYS` | Comma-separated list of sorting keys; valid keys are: timestamp, archive, name, id; default is: timestamp |
|
||||||
| `--first N` | consider first N archives after other filters were applied |
|
| `--first N` | consider first N archives after other filters were applied |
|
||||||
| `--last N` | consider last N archives after other filters were applied |
|
| `--last N` | consider last N archives after other filters were applied |
|
||||||
| `-e PATTERN`, `--exclude PATTERN` | exclude paths matching PATTERN |
|
| `-e PATTERN`, `--exclude PATTERN` | exclude paths matching PATTERN |
|
||||||
| `--exclude-from EXCLUDEFILE` | read exclude patterns from EXCLUDEFILE, one per line |
|
| `--exclude-from EXCLUDEFILE` | read exclude patterns from EXCLUDEFILE, one per line |
|
||||||
| `--pattern PATTERN` | include/exclude paths matching PATTERN |
|
| `--pattern PATTERN` | include/exclude paths matching PATTERN |
|
||||||
| `--patterns-from PATTERNFILE` | read include/exclude patterns from PATTERNFILE, one per line |
|
| `--patterns-from PATTERNFILE` | read include/exclude patterns from PATTERNFILE, one per line |
|
||||||
|
|
||||||
#### Examples
|
#### Examples
|
||||||
```shell
|
```shell
|
||||||
|
@ -313,9 +313,9 @@ Usage: `borg [common options] delete [options] [REPOSITORY_OR_ARCHIVE] [ARCHIVE.
|
||||||
#### Options
|
#### Options
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| ----------------- | ---------------------------------------- |
|
| ----------------- | ---------------------------------------- |
|
||||||
| `-n`, `--dry-run` | do not change repository |
|
| `-n`, `--dry-run` | do not change repository |
|
||||||
| `--list` | output verbose list of archives |
|
| `--list` | output verbose list of archives |
|
||||||
| `-s`, `--stats` | print statistics for the deleted archive |
|
| `-s`, `--stats` | print statistics for the deleted archive |
|
||||||
|
|
||||||
#### Examples
|
#### Examples
|
||||||
```shell
|
```shell
|
||||||
|
@ -341,18 +341,18 @@ Usage: `borg [common options] prune [options] [REPOSITORY]`
|
||||||
#### Options
|
#### Options
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| -------------------------------- | ------------------------------------------------------------------------------------------- |
|
| -------------------------------- | ------------------------------------------------------------------------------------------- |
|
||||||
| `-n`, `--dry-run` | do not change repository |
|
| `-n`, `--dry-run` | do not change repository |
|
||||||
| `--force` | force pruning of corrupted archives, use `--force --force` in case `--force` does not work. |
|
| `--force` | force pruning of corrupted archives, use `--force --force` in case `--force` does not work. |
|
||||||
| `-s`, `--stats` | print statistics for the deleted archive |
|
| `-s`, `--stats` | print statistics for the deleted archive |
|
||||||
| `--list` | output verbose list of archives it keeps/prunes |
|
| `--list` | output verbose list of archives it keeps/prunes |
|
||||||
| `--keep-within INTERVAL` | keep all archives within this time interval |
|
| `--keep-within INTERVAL` | keep all archives within this time interval |
|
||||||
| `--keep-last`, `--keep-secondly` | number of secondly archives to keep |
|
| `--keep-last`, `--keep-secondly` | number of secondly archives to keep |
|
||||||
| `--keep-minutely` | number of minutely archives to keep |
|
| `--keep-minutely` | number of minutely archives to keep |
|
||||||
| `-H`, `--keep-hourly` | number of hourly archives to keep |
|
| `-H`, `--keep-hourly` | number of hourly archives to keep |
|
||||||
| `-d`, `--keep-daily` | number of daily archives to keep |
|
| `-d`, `--keep-daily` | number of daily archives to keep |
|
||||||
| `-w`, `--keep-weekly` | number of weekly archives to keep |
|
| `-w`, `--keep-weekly` | number of weekly archives to keep |
|
||||||
| `-m`, `--keep-monthly` | number of monthly archives to keep |
|
| `-m`, `--keep-monthly` | number of monthly archives to keep |
|
||||||
| `-y`, `--keep-yearly` | number of yearly archives to keep |
|
| `-y`, `--keep-yearly` | number of yearly archives to keep |
|
||||||
|
|
||||||
#### Examples
|
#### Examples
|
||||||
```shell
|
```shell
|
||||||
|
@ -398,13 +398,13 @@ Usage: `borg [common options] info [options] [REPOSITORY_OR_ARCHIVE]`
|
||||||
| `--json` | format output as JSON |
|
| `--json` | format output as JSON |
|
||||||
|
|
||||||
### `borg mount`
|
### `borg mount`
|
||||||
This command mounts an archive as a FUSE filesystem. This can be useful for browsing an archive or restoring individual files. Unless the `--foreground` option is given the command will run in the background until the filesystem is `umounted`.
|
This command mounts an archive as a FUSE filesystem. This can be useful for browsing an archive or restoring individual files. Unless the `--foreground` option is given the command will run in the background until the filesystem is `umounted`.
|
||||||
Usage: `borg [common options] mount [options] REPOSITORY_OR_ARCHIVE MOUNTPOINT [PATH...]`
|
Usage: `borg [common options] mount [options] REPOSITORY_OR_ARCHIVE MOUNTPOINT [PATH...]`
|
||||||
|
|
||||||
#### Options
|
#### Options
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| -------------------- | ------------------------------------------------------ |
|
| -------------------- | ------------------------------------------------------ |
|
||||||
| `-f`, `--foreground` | stay in foreground, do not daemonize |
|
| `-f`, `--foreground` | stay in foreground, do not daemonize |
|
||||||
| `-o` | Extra mount options |
|
| `-o` | Extra mount options |
|
||||||
| `--numeric-ids` | use numeric user and group identifiers from archive(s) |
|
| `--numeric-ids` | use numeric user and group identifiers from archive(s) |
|
||||||
|
|
||||||
|
@ -427,7 +427,7 @@ $ borg umount /tmp/mymountpoint
|
||||||
```
|
```
|
||||||
|
|
||||||
### `borg unmount`
|
### `borg unmount`
|
||||||
This command un-mounts a FUSE filesystem that was mounted with `borg mount`.
|
This command un-mounts a FUSE filesystem that was mounted with `borg mount`.
|
||||||
Usage: `borg [common options] umount [options] MOUNTPOINT`
|
Usage: `borg [common options] umount [options] MOUNTPOINT`
|
||||||
|
|
||||||
### `borg key change-passphrase`
|
### `borg key change-passphrase`
|
||||||
|
@ -441,5 +441,5 @@ Usage: `borg [common options] serve [options]`
|
||||||
#### Options
|
#### Options
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| ------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `--restrict-to-path PATH` | restrict repository access to PATH. Can be specified multiple times to allow the client access to several directories. Access to all sub-directories is granted implicitly; PATH doesn’t need to directly point to a repository. |
|
| `--restrict-to-path PATH` | restrict repository access to PATH. Can be specified multiple times to allow the client access to several directories. Access to all sub-directories is granted implicitly; PATH doesn’t need to directly point to a repository. |
|
||||||
| `--restrict-to-repository PATH` | restrict repository access. Only the repository located at PATH (no sub-directories are considered) is accessible. Can be specified multiple times to allow the client access to several repositories. Unlike `--restrict-to-path` sub-directories are not accessible; PATH needs to directly point at a repository location. PATH may be an empty directory or the last element of PATH may not exist, in which case the client may initialize a repository there. |
|
| `--restrict-to-repository PATH` | restrict repository access. Only the repository located at PATH (no sub-directories are considered) is accessible. Can be specified multiple times to allow the client access to several repositories. Unlike `--restrict-to-path` sub-directories are not accessible; PATH needs to directly point at a repository location. PATH may be an empty directory or the last element of PATH may not exist, in which case the client may initialize a repository there. |
|
||||||
|
|
|
@ -22,7 +22,7 @@ The database files are saved in:
|
||||||
/var/lib/clamav/bytecode.cvd
|
/var/lib/clamav/bytecode.cvd
|
||||||
```
|
```
|
||||||
|
|
||||||
Start/Enable`clamav-freshclam.service` so that the virus definitions are kept recent.
|
Start/Enable`clamav-freshclam.service` so that the virus definitions are kept recent.
|
||||||
|
|
||||||
### Starting the daemon
|
### Starting the daemon
|
||||||
|
|
||||||
|
|
|
@ -133,7 +133,7 @@ command2 < mypipe # Reading from the pipe
|
||||||
### **tee Command**
|
### **tee Command**
|
||||||
The `tee` command reads from standard input and writes to standard output and files simultaneously.
|
The `tee` command reads from standard input and writes to standard output and files simultaneously.
|
||||||
```shell
|
```shell
|
||||||
echo "Hello, World!" | tee output.txt | wc -l
|
echo "Hello, World!" | tee output.txt | wc -l
|
||||||
```
|
```
|
||||||
|
|
||||||
### **/dev/null**
|
### **/dev/null**
|
||||||
|
@ -210,7 +210,7 @@ esac
|
||||||
|
|
||||||
#### Operators
|
#### Operators
|
||||||
##### Arithmetic Operators
|
##### Arithmetic Operators
|
||||||
Assume variable **a** holds 10 and variable **b** holds 20 then −
|
Assume variable **a** holds 10 and variable **b** holds 20 then −
|
||||||
|
|
||||||
| Operator | Description | Example |
|
| Operator | Description | Example |
|
||||||
| ------------------ | --------------------------------------------------------------------- | --------------------------------------- |
|
| ------------------ | --------------------------------------------------------------------- | --------------------------------------- |
|
||||||
|
@ -226,7 +226,7 @@ Assume variable **a** holds 10 and variable **b** holds 20 then −
|
||||||
##### Relational Operators
|
##### Relational Operators
|
||||||
For example, following operators will work to check a relation between 10 and 20 as well as in between "10" and "20" but not in between "ten" and "twenty".
|
For example, following operators will work to check a relation between 10 and 20 as well as in between "10" and "20" but not in between "ten" and "twenty".
|
||||||
|
|
||||||
Assume variable **a** holds 10 and variable **b** holds 20 then −
|
Assume variable **a** holds 10 and variable **b** holds 20 then −
|
||||||
|
|
||||||
| Operator | Description | Example |
|
| Operator | Description | Example |
|
||||||
| -------- | ------------------------------------------------------------------------------------------------------------------------------------ | ---------------------------- |
|
| -------- | ------------------------------------------------------------------------------------------------------------------------------------ | ---------------------------- |
|
||||||
|
@ -238,18 +238,18 @@ Assume variable **a** holds 10 and variable **b** holds 20 then −
|
||||||
| **-le** | Checks if the value of left operand is less than or equal to the value of right operand; if yes, then the condition becomes true. | `[ $a -le $b ]` is true. |
|
| **-le** | Checks if the value of left operand is less than or equal to the value of right operand; if yes, then the condition becomes true. | `[ $a -le $b ]` is true. |
|
||||||
|
|
||||||
##### Boolean Operators
|
##### Boolean Operators
|
||||||
Assume variable **a** holds 10 and variable **b** holds 20 then −
|
Assume variable **a** holds 10 and variable **b** holds 20 then −
|
||||||
|
|
||||||
| Operator | Description | Example |
|
| Operator | Description | Example |
|
||||||
| -------- | -------------------------------------------------------------------------------------------------------- | ------------------------------------- |
|
| -------- | -------------------------------------------------------------------------------------------------------- | ------------------------------------- |
|
||||||
| **!** | This is logical negation. This inverts a true condition into false and vice versa. | `[ ! false ]` is true. |
|
| **!** | This is logical negation. This inverts a true condition into false and vice versa. | `[ ! false ]` is true. |
|
||||||
| **-o** | This is logical **OR**. If one of the operands is true, then the condition becomes true. | `[ $a -lt 20 -o $b -gt 100 ]` is true. |
|
| **-o** | This is logical **OR**. If one of the operands is true, then the condition becomes true. | `[ $a -lt 20 -o $b -gt 100 ]` is true. |
|
||||||
| **-a** | This is logical **AND**. If both the operands are true, then the condition becomes true otherwise false. | `[ $a -lt 20 -a $b -gt 100 ]` is false. |
|
| **-a** | This is logical **AND**. If both the operands are true, then the condition becomes true otherwise false. | `[ $a -lt 20 -a $b -gt 100 ]` is false. |
|
||||||
|
|
||||||
##### File Test Operators
|
##### File Test Operators
|
||||||
We have a few operators that can be used to test various properties associated with a Unix file.
|
We have a few operators that can be used to test various properties associated with a Unix file.
|
||||||
|
|
||||||
Assume a variable **file** holds an existing file name "test" the size of which is 100 bytes and has **read**, **write** and **execute** permission.
|
Assume a variable **file** holds an existing file name "test" the size of which is 100 bytes and has **read**, **write** and **execute** permission.
|
||||||
|
|
||||||
| Operator | Description | Example |
|
| Operator | Description | Example |
|
||||||
| ----------- | ---------------------------------------------------------------------------------------------------------------------- | --------------------------- |
|
| ----------- | ---------------------------------------------------------------------------------------------------------------------- | --------------------------- |
|
||||||
|
|
|
@ -7,7 +7,7 @@ os:
|
||||||
repo: https://github.com/theryangeary/choose
|
repo: https://github.com/theryangeary/choose
|
||||||
---
|
---
|
||||||
# choose
|
# choose
|
||||||
`choose`, a human-friendly and fast alternative to `cut` and (sometimes) `awk`
|
`choose`, a human-friendly and fast alternative to `cut` and (sometimes) `awk`
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
```shell
|
```shell
|
||||||
|
|
|
@ -5,7 +5,7 @@ website: https://savannah.gnu.org/projects/tar
|
||||||
repo: https://git.savannah.gnu.org/cgit/tar.git
|
repo: https://git.savannah.gnu.org/cgit/tar.git
|
||||||
---
|
---
|
||||||
# Tar
|
# Tar
|
||||||
Tar is the most widely used command in Unix and Linux like operating system for creating archive of multiple files and folders into a single archive file and that archive file can be further compressed using other compression techniques
|
Tar is the most widely used command in Unix and Linux like operating system for creating archive of multiple files and folders into a single archive file and that archive file can be further compressed using other compression techniques
|
||||||
|
|
||||||
Creating Archives:
|
Creating Archives:
|
||||||
```shell
|
```shell
|
||||||
|
|
|
@ -19,5 +19,5 @@ Usage: `crunch <min-len> <max-len> [<charset string>] [options]`
|
||||||
| `-i` | Inverts the output so instead of aaa,aab,aac,aad, etc you get aaa,baa,caa,daa,aba,bba |
|
| `-i` | Inverts the output so instead of aaa,aab,aac,aad, etc you get aaa,baa,caa,daa,aba,bba |
|
||||||
| `-o wordlist.txt` | Specifies the file to write the output to, eg: wordlist.txt |
|
| `-o wordlist.txt` | Specifies the file to write the output to, eg: wordlist.txt |
|
||||||
| `-s startblock` | Specifies a starting string, eg: 03god22fs |
|
| `-s startblock` | Specifies a starting string, eg: 03god22fs |
|
||||||
| `-t @,%^` | Specifies a pattern, eg: @@god@@@@ where the only the @'s, ,'s, %'s, and ^'s will change. <br>`@` will insert lower case characters<br>`,` will insert upper case characters<br>`%` will insert numbers<br>`^` will insert symbols |
|
| `-t @,%^` | Specifies a pattern, eg: @@god@@@@ where the only the @'s, ,'s, %'s, and ^'s will change. <br>`@` will insert lower case characters<br>`,` will insert upper case characters<br>`%` will insert numbers<br>`^` will insert symbols |
|
||||||
| `-z gzip, bzip2, lzma, and 7z` | Compresses the output from the -o option. Valid parameters are gzip, bzip2, lzma, and [7z](compression/p7zip.md). |
|
| `-z gzip, bzip2, lzma, and 7z` | Compresses the output from the -o option. Valid parameters are gzip, bzip2, lzma, and [7z](compression/p7zip.md). |
|
||||||
|
|
|
@ -4,17 +4,17 @@ os: linux
|
||||||
repo: https://github.com/eza-community/eza
|
repo: https://github.com/eza-community/eza
|
||||||
---
|
---
|
||||||
# exa
|
# exa
|
||||||
[**eza**](https://eza.rocks/) is a modern replacement for the venerable file-listing command-line program `ls` that ships with Unix and Linux operating systems, giving it more features and better defaults. It uses colours to distinguish file types and metadata. It knows about symlinks, extended attributes, and Git. And it’s **small**, **fast**, and just **one single binary**.
|
[**eza**](https://eza.rocks/) is a modern replacement for the venerable file-listing command-line program `ls` that ships with Unix and Linux operating systems, giving it more features and better defaults. It uses colours to distinguish file types and metadata. It knows about symlinks, extended attributes, and Git. And it’s **small**, **fast**, and just **one single binary**.
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
Flags:
|
Flags:
|
||||||
```shell
|
```shell
|
||||||
-l, --long display extended file metadata as a table
|
-l, --long display extended file metadata as a table
|
||||||
-R, --recurse recurse into directories
|
-R, --recurse recurse into directories
|
||||||
-L, --level DEPTH limit the depth of recursion
|
-L, --level DEPTH limit the depth of recursion
|
||||||
-T, --tree recurse into directories as a tree
|
-T, --tree recurse into directories as a tree
|
||||||
-a, --all show hidden and 'dot' files
|
-a, --all show hidden and 'dot' files
|
||||||
-r, --reverse reverse the sort order
|
-r, --reverse reverse the sort order
|
||||||
-D, --only-dirs list only directories
|
-D, --only-dirs list only directories
|
||||||
--git-ignore ignore files mentioned in '.gitignore'
|
--git-ignore ignore files mentioned in '.gitignore'
|
||||||
```
|
```
|
|
@ -4,7 +4,7 @@ os: linux
|
||||||
repo: https://github.com/sharkdp/fd
|
repo: https://github.com/sharkdp/fd
|
||||||
---
|
---
|
||||||
# fd
|
# fd
|
||||||
`fd` is a program to find entries in your filesystem. It is a simple, fast and user-friendly alternative to [`find`](https://www.gnu.org/software/findutils/). While it does not aim to support all of `find`'s powerful functionality, it provides sensible (opinionated) defaults for a majority of use cases.
|
`fd` is a program to find entries in your filesystem. It is a simple, fast and user-friendly alternative to [`find`](https://www.gnu.org/software/findutils/). While it does not aim to support all of `find`'s powerful functionality, it provides sensible (opinionated) defaults for a majority of use cases.
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
Usage: `fd [OPTIONS] [pattern] [path]...`
|
Usage: `fd [OPTIONS] [pattern] [path]...`
|
||||||
|
|
|
@ -4,7 +4,7 @@ os: linux
|
||||||
repo: https://github.com/chmln/handlr
|
repo: https://github.com/chmln/handlr
|
||||||
---
|
---
|
||||||
# Handlr
|
# Handlr
|
||||||
Manage your default applications with ease using `handlr`!
|
Manage your default applications with ease using `handlr`!
|
||||||
|
|
||||||
Open files in default application:
|
Open files in default application:
|
||||||
```shell
|
```shell
|
||||||
|
|
|
@ -4,11 +4,11 @@ os: linux
|
||||||
repo: https://github.com/sstadick/hck
|
repo: https://github.com/sstadick/hck
|
||||||
---
|
---
|
||||||
# hck
|
# hck
|
||||||
_`hck` is a shortening of `hack`, a rougher form of `cut`._
|
_`hck` is a shortening of `hack`, a rougher form of `cut`._
|
||||||
|
|
||||||
A close to drop in replacement for cut that can use a regex delimiter instead of a fixed string. Additionally this tool allows for specification of the order of the output columns using the same column selection syntax as cut (see below for examples).
|
A close to drop in replacement for cut that can use a regex delimiter instead of a fixed string. Additionally this tool allows for specification of the order of the output columns using the same column selection syntax as cut (see below for examples).
|
||||||
|
|
||||||
No single feature of `hck` on its own makes it stand out over `awk`, `cut`, `xsv` or other such tools. Where `hck` excels is making common things easy, such as reordering output fields, or splitting records on a weird delimiter. It is meant to be simple and easy to use while exploring datasets. Think of this as filling a gap between `cut` and `awk`.
|
No single feature of `hck` on its own makes it stand out over `awk`, `cut`, `xsv` or other such tools. Where `hck` excels is making common things easy, such as reordering output fields, or splitting records on a weird delimiter. It is meant to be simple and easy to use while exploring datasets. Think of this as filling a gap between `cut` and `awk`.
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
Usage: `hck [options]`
|
Usage: `hck [options]`
|
||||||
|
|
|
@ -5,7 +5,7 @@ os:
|
||||||
repo: https://github.com/sharkdp/hexyl
|
repo: https://github.com/sharkdp/hexyl
|
||||||
---
|
---
|
||||||
# Hexyl
|
# Hexyl
|
||||||
`hexyl` is a simple hex viewer for the terminal. It uses a colored output to distinguish different categories of bytes (NULL bytes, printable [ASCII](../../files/ASCII.md) characters, [ASCII](../../files/ASCII.md) whitespace characters, other [ASCII](../../files/ASCII.md) characters and non-[ASCII](../../files/ASCII.md)).
|
`hexyl` is a simple hex viewer for the terminal. It uses a colored output to distinguish different categories of bytes (NULL bytes, printable [ASCII](../../files/ASCII.md) characters, [ASCII](../../files/ASCII.md) whitespace characters, other [ASCII](../../files/ASCII.md) characters and non-[ASCII](../../files/ASCII.md)).
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
Usage: `hexyl [OPTIONS] [FILE]`
|
Usage: `hexyl [OPTIONS] [FILE]`
|
||||||
|
|
|
@ -10,11 +10,11 @@ Command line utility to remove duplicates from the given input. Note that huniq
|
||||||
## Usage
|
## Usage
|
||||||
Flags:
|
Flags:
|
||||||
```shell
|
```shell
|
||||||
-c, --count Output the amount of times a line was encountered
|
-c, --count Output the amount of times a line was encountered
|
||||||
|
|
||||||
-d, --delim <delim> Which delimiter between elements to use. [default: "\n"]
|
-d, --delim <delim> Which delimiter between elements to use. [default: "\n"]
|
||||||
|
|
||||||
-s, --sort Sort output by the number of occurences, in ascending order
|
-s, --sort Sort output by the number of occurences, in ascending order
|
||||||
|
|
||||||
-S, --sort-descending Order output by the number of occurences, in descending order
|
-S, --sort-descending Order output by the number of occurences, in descending order
|
||||||
```
|
```
|
|
@ -5,7 +5,7 @@ repo: https://github.com/casey/intermodal
|
||||||
---
|
---
|
||||||
# Intermodal
|
# Intermodal
|
||||||
[Repo](https://github.com/casey/intermodal)
|
[Repo](https://github.com/casey/intermodal)
|
||||||
Intermodal is a user-friendly and featureful command-line [BitTorrent](../../internet/BitTorrent.md) metainfo utility. The binary is called `imdl` and runs on [Linux](../../linux/Linux.md), [Windows](../../windows/Windows.md), and [macOS](../../macos/macOS.md).
|
Intermodal is a user-friendly and featureful command-line [BitTorrent](../../internet/BitTorrent.md) metainfo utility. The binary is called `imdl` and runs on [Linux](../../linux/Linux.md), [Windows](../../windows/Windows.md), and [macOS](../../macos/macOS.md).
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
### Create torrent file:
|
### Create torrent file:
|
||||||
|
|
|
@ -3,4 +3,4 @@ obj: application
|
||||||
os: linux
|
os: linux
|
||||||
---
|
---
|
||||||
# Jless
|
# Jless
|
||||||
[`jless`](https://jless.io/) is a command-line [JSON](../../files/JSON.md) viewer. Use it as a replacement for whatever combination of `less`, `jq`, `cat` and your editor you currently use for viewing [JSON](../../files/JSON.md) files. It is written in [Rust](../../dev/programming/languages/Rust.md) and can be installed as a single standalone binary.
|
[`jless`](https://jless.io/) is a command-line [JSON](../../files/JSON.md) viewer. Use it as a replacement for whatever combination of `less`, `jq`, `cat` and your editor you currently use for viewing [JSON](../../files/JSON.md) files. It is written in [Rust](../../dev/programming/languages/Rust.md) and can be installed as a single standalone binary.
|
|
@ -8,7 +8,7 @@ jq is a lightweight and flexible command-line [JSON](../../files/JSON.md) proces
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
```shell
|
```shell
|
||||||
cat data.json | jq [FILTER]
|
cat data.json | jq [FILTER]
|
||||||
|
|
||||||
# Raw Data
|
# Raw Data
|
||||||
cat data.json | jq -r [FILTER]
|
cat data.json | jq -r [FILTER]
|
||||||
|
@ -16,67 +16,67 @@ cat data.json | jq -r [FILTER]
|
||||||
|
|
||||||
## Filters
|
## Filters
|
||||||
### Identity
|
### Identity
|
||||||
The absolute simplest filter is `.` . This filter takes its input and produces the same value as output. That is, this is the identity operator.
|
The absolute simplest filter is `.` . This filter takes its input and produces the same value as output. That is, this is the identity operator.
|
||||||
|
|
||||||
### Object Identifier
|
### Object Identifier
|
||||||
The simplest _useful_ filter has the form `.foo`. When given a [JSON](../../files/JSON.md) object (aka dictionary or hash) as input, `.foo` produces the value at the key "foo" if the key is present, or null otherwise.
|
The simplest _useful_ filter has the form `.foo`. When given a [JSON](../../files/JSON.md) object (aka dictionary or hash) as input, `.foo` produces the value at the key "foo" if the key is present, or null otherwise.
|
||||||
|
|
||||||
The `.foo` syntax only works for simple, identifier-like keys, that is, keys that are all made of alphanumeric characters and underscore, and which do not start with a digit.
|
The `.foo` syntax only works for simple, identifier-like keys, that is, keys that are all made of alphanumeric characters and underscore, and which do not start with a digit.
|
||||||
|
|
||||||
If the key contains special characters or starts with a digit, you need to surround it with double quotes like this: `."foo$"`, or else `.["foo$"]`.
|
If the key contains special characters or starts with a digit, you need to surround it with double quotes like this: `."foo$"`, or else `.["foo$"]`.
|
||||||
|
|
||||||
### Array Index
|
### Array Index
|
||||||
When the index value is an integer, `.[<number>]` can index arrays. Arrays are zero-based, so `.[2]` returns the third element.
|
When the index value is an integer, `.[<number>]` can index arrays. Arrays are zero-based, so `.[2]` returns the third element.
|
||||||
|
|
||||||
Negative indices are allowed, with -1 referring to the last element, -2 referring to the next to last element, and so on.
|
Negative indices are allowed, with -1 referring to the last element, -2 referring to the next to last element, and so on.
|
||||||
|
|
||||||
### Array/String Slice
|
### Array/String Slice
|
||||||
The `.[<number>:<number>]` syntax can be used to return a subarray of an array or substring of a string. The array returned by `.[10:15]` will be of length 5, containing the elements from index 10 (inclusive) to index 15 (exclusive). Either index may be negative (in which case it counts backwards from the end of the array), or omitted (in which case it refers to the start or end of the array). Indices are zero-based.
|
The `.[<number>:<number>]` syntax can be used to return a subarray of an array or substring of a string. The array returned by `.[10:15]` will be of length 5, containing the elements from index 10 (inclusive) to index 15 (exclusive). Either index may be negative (in which case it counts backwards from the end of the array), or omitted (in which case it refers to the start or end of the array). Indices are zero-based.
|
||||||
|
|
||||||
### Array/Object Value Iterator
|
### Array/Object Value Iterator
|
||||||
If you use the `.[index]` syntax, but omit the index entirely, it will return _all_ of the elements of an array. Running `.[]` with the input `[1,2,3]` will produce the numbers as three separate results, rather than as a single array. A filter of the form `.foo[]` is equivalent to `.foo | .[]`.
|
If you use the `.[index]` syntax, but omit the index entirely, it will return _all_ of the elements of an array. Running `.[]` with the input `[1,2,3]` will produce the numbers as three separate results, rather than as a single array. A filter of the form `.foo[]` is equivalent to `.foo | .[]`.
|
||||||
|
|
||||||
You can also use this on an object, and it will return all the values of the object.
|
You can also use this on an object, and it will return all the values of the object.
|
||||||
|
|
||||||
Note that the iterator operator is a generator of values.
|
Note that the iterator operator is a generator of values.
|
||||||
|
|
||||||
### Comma
|
### Comma
|
||||||
If two filters are separated by a comma, then the same input will be fed into both and the two filters' output value streams will be concatenated in order: first, all of the outputs produced by the left expression, and then all of the outputs produced by the right. For instance, filter `.foo, .bar`, produces both the "foo" fields and "bar" fields as separate outputs.
|
If two filters are separated by a comma, then the same input will be fed into both and the two filters' output value streams will be concatenated in order: first, all of the outputs produced by the left expression, and then all of the outputs produced by the right. For instance, filter `.foo, .bar`, produces both the "foo" fields and "bar" fields as separate outputs.
|
||||||
|
|
||||||
The `,` operator is one way to contruct generators.
|
The `,` operator is one way to contruct generators.
|
||||||
|
|
||||||
### Pipe
|
### Pipe
|
||||||
The `|` operator combines two filters by feeding the output(s) of the one on the left into the input of the one on the right. It's similar to the Unix [shell](Shell.md)'s pipe, if you're used to that.
|
The `|` operator combines two filters by feeding the output(s) of the one on the left into the input of the one on the right. It's similar to the Unix [shell](Shell.md)'s pipe, if you're used to that.
|
||||||
|
|
||||||
If the one on the left produces multiple results, the one on the right will be run for each of those results. So, the expression `.[] | .foo` retrieves the "foo" field of each element of the input array. This is a cartesian product, which can be surprising.
|
If the one on the left produces multiple results, the one on the right will be run for each of those results. So, the expression `.[] | .foo` retrieves the "foo" field of each element of the input array. This is a cartesian product, which can be surprising.
|
||||||
|
|
||||||
Note that `.a.b.c` is the same as `.a | .b | .c`.
|
Note that `.a.b.c` is the same as `.a | .b | .c`.
|
||||||
|
|
||||||
Note too that `.` is the input value at the particular stage in a "pipeline", specifically: where the `.` expression appears. Thus `.a | . | .b` is the same as `.a.b`, as the `.` in the middle refers to whatever value `.a` produced.
|
Note too that `.` is the input value at the particular stage in a "pipeline", specifically: where the `.` expression appears. Thus `.a | . | .b` is the same as `.a.b`, as the `.` in the middle refers to whatever value `.a` produced.
|
||||||
|
|
||||||
### Array Construction: `[]`
|
### Array Construction: `[]`
|
||||||
As in [JSON](../../files/JSON.md), `[]` is used to construct arrays, as in `[1,2,3]`. The elements of the arrays can be any jq expression, including a pipeline. All of the results produced by all of the expressions are collected into one big array. You can use it to construct an array out of a known quantity of values (as in `[.foo, .bar, .baz]`) or to "collect" all the results of a filter into an array (as in `[.items[].name]`)
|
As in [JSON](../../files/JSON.md), `[]` is used to construct arrays, as in `[1,2,3]`. The elements of the arrays can be any jq expression, including a pipeline. All of the results produced by all of the expressions are collected into one big array. You can use it to construct an array out of a known quantity of values (as in `[.foo, .bar, .baz]`) or to "collect" all the results of a filter into an array (as in `[.items[].name]`)
|
||||||
|
|
||||||
Once you understand the "," operator, you can look at jq's array syntax in a different light: the expression `[1,2,3]` is not using a built-in syntax for comma-separated arrays, but is instead applying the `[]` operator (collect results) to the expression 1,2,3 (which produces three different results).
|
Once you understand the "," operator, you can look at jq's array syntax in a different light: the expression `[1,2,3]` is not using a built-in syntax for comma-separated arrays, but is instead applying the `[]` operator (collect results) to the expression 1,2,3 (which produces three different results).
|
||||||
|
|
||||||
If you have a filter `X` that produces four results, then the expression `[X]` will produce a single result, an array of four elements.
|
If you have a filter `X` that produces four results, then the expression `[X]` will produce a single result, an array of four elements.
|
||||||
|
|
||||||
### Object Construction: `{}`
|
### Object Construction: `{}`
|
||||||
Like [JSON](../../files/JSON.md), `{}` is for constructing objects (aka dictionaries or hashes), as in: `{"a": 42, "b": 17}`.
|
Like [JSON](../../files/JSON.md), `{}` is for constructing objects (aka dictionaries or hashes), as in: `{"a": 42, "b": 17}`.
|
||||||
|
|
||||||
If the keys are "identifier-like", then the quotes can be left off, as in `{a:42, b:17}`. Variable references as key expressions use the value of the variable as the key. Key expressions other than constant literals, identifiers, or variable references, need to be parenthesized, e.g., `{("a"+"b"):59}`.
|
If the keys are "identifier-like", then the quotes can be left off, as in `{a:42, b:17}`. Variable references as key expressions use the value of the variable as the key. Key expressions other than constant literals, identifiers, or variable references, need to be parenthesized, e.g., `{("a"+"b"):59}`.
|
||||||
|
|
||||||
The value can be any expression (although you may need to wrap it in parentheses if, for example, it contains colons), which gets applied to the {} expression's input (remember, all filters have an input and an output).
|
The value can be any expression (although you may need to wrap it in parentheses if, for example, it contains colons), which gets applied to the {} expression's input (remember, all filters have an input and an output).
|
||||||
```
|
```
|
||||||
{foo: .bar}
|
{foo: .bar}
|
||||||
```
|
```
|
||||||
|
|
||||||
will produce the [JSON](../../files/JSON.md) object `{"foo": 42}` if given the [JSON](../../files/JSON.md) object `{"bar":42, "baz":43}` as its input. You can use this to select particular fields of an object: if the input is an object with "user", "title", "id", and "content" fields and you just want "user" and "title", you can write
|
will produce the [JSON](../../files/JSON.md) object `{"foo": 42}` if given the [JSON](../../files/JSON.md) object `{"bar":42, "baz":43}` as its input. You can use this to select particular fields of an object: if the input is an object with "user", "title", "id", and "content" fields and you just want "user" and "title", you can write
|
||||||
```
|
```
|
||||||
{user: .user, title: .title}
|
{user: .user, title: .title}
|
||||||
```
|
```
|
||||||
|
|
||||||
Because that is so common, there's a shortcut syntax for it: `{user, title}`.
|
Because that is so common, there's a shortcut syntax for it: `{user, title}`.
|
||||||
|
|
||||||
If one of the expressions produces multiple results, multiple dictionaries will be produced. If the input's
|
If one of the expressions produces multiple results, multiple dictionaries will be produced. If the input's
|
||||||
```
|
```
|
||||||
|
@ -106,55 +106,55 @@ produces
|
||||||
|
|
||||||
## Functions
|
## Functions
|
||||||
### `has(key)`
|
### `has(key)`
|
||||||
The builtin function `has` returns whether the input object has the given key, or the input array has an element at the given index.
|
The builtin function `has` returns whether the input object has the given key, or the input array has an element at the given index.
|
||||||
|
|
||||||
### `map(f)`, `map_values(f)`
|
### `map(f)`, `map_values(f)`
|
||||||
For any filter `f`, `map(f)` and `map_values(f)` apply `f` to each of the values in the input array or object, that is, to the values of `.[]`.
|
For any filter `f`, `map(f)` and `map_values(f)` apply `f` to each of the values in the input array or object, that is, to the values of `.[]`.
|
||||||
|
|
||||||
In the absence of errors, `map(f)` always outputs an array whereas `map_values(f)` outputs an array if given an array, or an object if given an object.
|
In the absence of errors, `map(f)` always outputs an array whereas `map_values(f)` outputs an array if given an array, or an object if given an object.
|
||||||
|
|
||||||
When the input to `map_values(f)` is an object, the output object has the same keys as the input object except for those keys whose values when piped to `f` produce no values at all.
|
When the input to `map_values(f)` is an object, the output object has the same keys as the input object except for those keys whose values when piped to `f` produce no values at all.
|
||||||
|
|
||||||
`map(f)` is equivalent to `[.[] | f]` and `map_values(f)` is equivalent to `.[] |= f`.
|
`map(f)` is equivalent to `[.[] | f]` and `map_values(f)` is equivalent to `.[] |= f`.
|
||||||
|
|
||||||
### `del(path)`
|
### `del(path)`
|
||||||
The builtin function `del` removes a key and its corresponding value from an object.
|
The builtin function `del` removes a key and its corresponding value from an object.
|
||||||
|
|
||||||
### `reverse`
|
### `reverse`
|
||||||
This function reverses an array.
|
This function reverses an array.
|
||||||
|
|
||||||
### `contains(element)`
|
### `contains(element)`
|
||||||
The filter `contains(b)` will produce true if b is completely contained within the input. A string B is contained in a string A if B is a substring of A. An array B is contained in an array A if all elements in B are contained in any element in A. An object B is contained in object A if all of the values in B are contained in the value in A with the same key. All other types are assumed to be contained in each other if they are equal.
|
The filter `contains(b)` will produce true if b is completely contained within the input. A string B is contained in a string A if B is a substring of A. An array B is contained in an array A if all elements in B are contained in any element in A. An object B is contained in object A if all of the values in B are contained in the value in A with the same key. All other types are assumed to be contained in each other if they are equal.
|
||||||
|
|
||||||
### `startswith(str)`
|
### `startswith(str)`
|
||||||
Outputs `true` if . starts with the given string argument.
|
Outputs `true` if . starts with the given string argument.
|
||||||
|
|
||||||
### `endswith(str)`
|
### `endswith(str)`
|
||||||
Outputs `true` if . ends with the given string argument.
|
Outputs `true` if . ends with the given string argument.
|
||||||
|
|
||||||
### `split(str)`
|
### `split(str)`
|
||||||
Splits an input string on the separator argument.
|
Splits an input string on the separator argument.
|
||||||
|
|
||||||
### `join(str)`
|
### `join(str)`
|
||||||
Joins the array of elements given as input, using the argument as separator. It is the inverse of `split`: that is, running `split("foo") | join("foo")` over any input string returns said input string.
|
Joins the array of elements given as input, using the argument as separator. It is the inverse of `split`: that is, running `split("foo") | join("foo")` over any input string returns said input string.
|
||||||
|
|
||||||
## Conditionals
|
## Conditionals
|
||||||
### if-then-else-end
|
### if-then-else-end
|
||||||
`if A then B else C end` will act the same as `B` if `A` produces a value other than false or null, but act the same as `C` otherwise.
|
`if A then B else C end` will act the same as `B` if `A` produces a value other than false or null, but act the same as `C` otherwise.
|
||||||
|
|
||||||
`if A then B end` is the same as `if A then B else . end`. That is, the `else` branch is optional, and if absent is the same as `.`. This also applies to `elif` with absent ending `else` branch.
|
`if A then B end` is the same as `if A then B else . end`. That is, the `else` branch is optional, and if absent is the same as `.`. This also applies to `elif` with absent ending `else` branch.
|
||||||
|
|
||||||
Checking for false or null is a simpler notion of "truthiness" than is found in JavaScript or [Python](../../dev/programming/languages/Python.md), but it means that you'll sometimes have to be more explicit about the condition you want. You can't test whether, e.g. a string is empty using `if .name then A else B end`; you'll need something like `if .name == "" then A else B end` instead.
|
Checking for false or null is a simpler notion of "truthiness" than is found in JavaScript or [Python](../../dev/programming/languages/Python.md), but it means that you'll sometimes have to be more explicit about the condition you want. You can't test whether, e.g. a string is empty using `if .name then A else B end`; you'll need something like `if .name == "" then A else B end` instead.
|
||||||
|
|
||||||
If the condition `A` produces multiple results, then `B` is evaluated once for each result that is not false or null, and `C` is evaluated once for each false or null.
|
If the condition `A` produces multiple results, then `B` is evaluated once for each result that is not false or null, and `C` is evaluated once for each false or null.
|
||||||
|
|
||||||
More cases can be added to an if using `elif A then B` syntax.
|
More cases can be added to an if using `elif A then B` syntax.
|
||||||
|
|
||||||
Example: `jq 'if . == 0 then "zero" elif . == 1 then "one" else "many" end'`
|
Example: `jq 'if . == 0 then "zero" elif . == 1 then "one" else "many" end'`
|
||||||
|
|
||||||
### Alternative Operator `//`
|
### Alternative Operator `//`
|
||||||
The `//` operator produces all the values of its left-hand side that are neither `false` nor `null`, or, if the left-hand side produces no values other than `false` or `null`, then `//` produces all the values of its right-hand side.
|
The `//` operator produces all the values of its left-hand side that are neither `false` nor `null`, or, if the left-hand side produces no values other than `false` or `null`, then `//` produces all the values of its right-hand side.
|
||||||
|
|
||||||
A filter of the form `a // b` produces all the results of `a` that are not `false` or `null`. If `a` produces no results, or no results other than `false` or `null`, then `a // b` produces the results of `b`.
|
A filter of the form `a // b` produces all the results of `a` that are not `false` or `null`. If `a` produces no results, or no results other than `false` or `null`, then `a // b` produces the results of `b`.
|
||||||
|
|
||||||
This is useful for providing defaults: `.foo // 1` will evaluate to `1` if there's no `.foo` element in the input.
|
This is useful for providing defaults: `.foo // 1` will evaluate to `1` if there's no `.foo` element in the input.
|
|
@ -4,12 +4,12 @@ website: https://just.systems/
|
||||||
repo: https://github.com/casey/just
|
repo: https://github.com/casey/just
|
||||||
---
|
---
|
||||||
# just
|
# just
|
||||||
`just` is a handy way to save and run project-specific commands.
|
`just` is a handy way to save and run project-specific commands.
|
||||||
Commands, called recipes, are stored in a file called `justfile` with syntax inspired by `make`:
|
Commands, called recipes, are stored in a file called `justfile` with syntax inspired by `make`:
|
||||||
|
|
||||||
![Screenshot][Screenshot]
|
![Screenshot][Screenshot]
|
||||||
|
|
||||||
You can then run them with `just RECIPE`:
|
You can then run them with `just RECIPE`:
|
||||||
```shell
|
```shell
|
||||||
$ just test-all
|
$ just test-all
|
||||||
cc *.c -o main
|
cc *.c -o main
|
||||||
|
@ -50,7 +50,7 @@ just --variables
|
||||||
| `-d, --working-directory <WORKING-DIRECTORY>` | Use \<WORKING-DIRECTORY> as working directory. `--justfile` must also be set |
|
| `-d, --working-directory <WORKING-DIRECTORY>` | Use \<WORKING-DIRECTORY> as working directory. `--justfile` must also be set |
|
||||||
|
|
||||||
## Quick Start
|
## Quick Start
|
||||||
Create a file named `justfile` in the root of your project with the following contents:
|
Create a file named `justfile` in the root of your project with the following contents:
|
||||||
```
|
```
|
||||||
recipe-name:
|
recipe-name:
|
||||||
echo 'This is a recipe!'
|
echo 'This is a recipe!'
|
||||||
|
@ -60,11 +60,11 @@ another-recipe:
|
||||||
@echo 'This is another recipe.'
|
@echo 'This is another recipe.'
|
||||||
```
|
```
|
||||||
|
|
||||||
When you invoke `just` it looks for file `justfile` in the current directory and upwards, so you can invoke it from any subdirectory of your project.
|
When you invoke `just` it looks for file `justfile` in the current directory and upwards, so you can invoke it from any subdirectory of your project.
|
||||||
|
|
||||||
The search for a `justfile` is case insensitive, so any case, like `Justfile`, `JUSTFILE`, or `JuStFiLe`, will work. `just` will also look for files with the name `.justfile`, in case you’d like to hide a `justfile`.
|
The search for a `justfile` is case insensitive, so any case, like `Justfile`, `JUSTFILE`, or `JuStFiLe`, will work. `just` will also look for files with the name `.justfile`, in case you’d like to hide a `justfile`.
|
||||||
|
|
||||||
Running `just` with no arguments runs the first recipe in the `justfile`:
|
Running `just` with no arguments runs the first recipe in the `justfile`:
|
||||||
```shell
|
```shell
|
||||||
$ just
|
$ just
|
||||||
echo 'This is a recipe!'
|
echo 'This is a recipe!'
|
||||||
|
@ -77,16 +77,16 @@ $ just another-recipe
|
||||||
This is another recipe.
|
This is another recipe.
|
||||||
```
|
```
|
||||||
|
|
||||||
`just` prints each command to standard error before running it, which is why `echo 'This is a recipe!'` was printed. This is suppressed for lines starting with `@`, which is why `echo 'This is another recipe.'` was not printed.
|
`just` prints each command to standard error before running it, which is why `echo 'This is a recipe!'` was printed. This is suppressed for lines starting with `@`, which is why `echo 'This is another recipe.'` was not printed.
|
||||||
|
|
||||||
Recipes stop running if a command fails. Here `cargo publish` will only run if `cargo test` succeeds:
|
Recipes stop running if a command fails. Here `cargo publish` will only run if `cargo test` succeeds:
|
||||||
```
|
```
|
||||||
publish:
|
publish:
|
||||||
cargo test # tests passed, time to publish!
|
cargo test # tests passed, time to publish!
|
||||||
cargo publish
|
cargo publish
|
||||||
```
|
```
|
||||||
|
|
||||||
Recipes can depend on other recipes. Here the `test` recipe depends on the `build` recipe, so `build` will run before `test`:
|
Recipes can depend on other recipes. Here the `test` recipe depends on the `build` recipe, so `build` will run before `test`:
|
||||||
|
|
||||||
```
|
```
|
||||||
build:
|
build:
|
||||||
|
@ -115,7 +115,7 @@ cc main.c foo.c bar.c -o main
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
### Default Recipe
|
### Default Recipe
|
||||||
When `just` is invoked without a recipe, it runs the first recipe in the `justfile`. This recipe might be the most frequently run command in the project, like running the tests:
|
When `just` is invoked without a recipe, it runs the first recipe in the `justfile`. This recipe might be the most frequently run command in the project, like running the tests:
|
||||||
```
|
```
|
||||||
test:
|
test:
|
||||||
cargo test
|
cargo test
|
||||||
|
@ -135,14 +135,14 @@ lint:
|
||||||
echo Linting
|
echo Linting
|
||||||
```
|
```
|
||||||
|
|
||||||
If no recipe makes sense as the default recipe, you can add a recipe to the beginning of your `justfile` that lists the available recipes:
|
If no recipe makes sense as the default recipe, you can add a recipe to the beginning of your `justfile` that lists the available recipes:
|
||||||
```
|
```
|
||||||
default:
|
default:
|
||||||
@just --list
|
@just --list
|
||||||
```
|
```
|
||||||
|
|
||||||
### Listing Available Recipes
|
### Listing Available Recipes
|
||||||
Recipes can be listed in alphabetical order with `just --list`:
|
Recipes can be listed in alphabetical order with `just --list`:
|
||||||
```shell
|
```shell
|
||||||
$ just --list
|
$ just --list
|
||||||
Available recipes:
|
Available recipes:
|
||||||
|
@ -152,21 +152,21 @@ Available recipes:
|
||||||
lint
|
lint
|
||||||
```
|
```
|
||||||
|
|
||||||
`just --summary` is more concise:
|
`just --summary` is more concise:
|
||||||
```shell
|
```shell
|
||||||
$ just --summary
|
$ just --summary
|
||||||
build test deploy lint
|
build test deploy lint
|
||||||
```
|
```
|
||||||
|
|
||||||
If you'd like `just` to default to listing the recipes in the `justfile`, you can use this as your default recipe:
|
If you'd like `just` to default to listing the recipes in the `justfile`, you can use this as your default recipe:
|
||||||
```just
|
```just
|
||||||
default:
|
default:
|
||||||
@just --list
|
@just --list
|
||||||
```
|
```
|
||||||
|
|
||||||
> Note that you may need to add `--justfile {{justfile()}}` to the line above above. Without it, if you executed `just -f /some/distant/justfile -d .` or `just -f ./non-standard-justfile`, the plain `just --list` inside the recipe would not necessarily use the file you provided. It would try to find a justfile in your current path, maybe even resulting in a `No justfile found` error.
|
> Note that you may need to add `--justfile {{justfile()}}` to the line above above. Without it, if you executed `just -f /some/distant/justfile -d .` or `just -f ./non-standard-justfile`, the plain `just --list` inside the recipe would not necessarily use the file you provided. It would try to find a justfile in your current path, maybe even resulting in a `No justfile found` error.
|
||||||
|
|
||||||
The heading text can be customized with `--list-heading`:
|
The heading text can be customized with `--list-heading`:
|
||||||
```shell
|
```shell
|
||||||
$ just --list --list-heading $'Cool stuff…\n'
|
$ just --list --list-heading $'Cool stuff…\n'
|
||||||
Cool stuff…
|
Cool stuff…
|
||||||
|
@ -191,7 +191,7 @@ Building!
|
||||||
```
|
```
|
||||||
|
|
||||||
### Settings
|
### Settings
|
||||||
Settings control interpretation and execution. Each setting may be specified at most once, anywhere in the `justfile`.
|
Settings control interpretation and execution. Each setting may be specified at most once, anywhere in the `justfile`.
|
||||||
|
|
||||||
For example:
|
For example:
|
||||||
```just
|
```just
|
||||||
|
@ -205,36 +205,36 @@ foo:
|
||||||
#### Table of Settings
|
#### Table of Settings
|
||||||
| Name | Value | Default | Description |
|
| Name | Value | Default | Description |
|
||||||
| ------------------------- | ------------------ | ------- | --------------------------------------------------------------------------------------------- |
|
| ------------------------- | ------------------ | ------- | --------------------------------------------------------------------------------------------- |
|
||||||
| `allow-duplicate-recipes` | boolean | `false` | Allow recipes appearing later in a `justfile` to override earlier recipes with the same name. |
|
| `allow-duplicate-recipes` | boolean | `false` | Allow recipes appearing later in a `justfile` to override earlier recipes with the same name. |
|
||||||
| `dotenv-filename` | string | - | Load a `.env` file with a custom name, if present. |
|
| `dotenv-filename` | string | - | Load a `.env` file with a custom name, if present. |
|
||||||
| `dotenv-load` | boolean | `false` | Load a `.env` file, if present. |
|
| `dotenv-load` | boolean | `false` | Load a `.env` file, if present. |
|
||||||
| `dotenv-path` | string | - | Load a `.env` file from a custom path, if present. Overrides `dotenv-filename`. |
|
| `dotenv-path` | string | - | Load a `.env` file from a custom path, if present. Overrides `dotenv-filename`. |
|
||||||
| `export` | boolean | `false` | Export all variables as [environment variables](../../linux/Environment%20Variables.md). |
|
| `export` | boolean | `false` | Export all variables as [environment variables](../../linux/Environment%20Variables.md). |
|
||||||
| `fallback` | boolean | `false` | Search `justfile` in parent directory if the first recipe on the command line is not found. |
|
| `fallback` | boolean | `false` | Search `justfile` in parent directory if the first recipe on the command line is not found. |
|
||||||
| `ignore-comments` | boolean | `false` | Ignore recipe lines beginning with `#`. |
|
| `ignore-comments` | boolean | `false` | Ignore recipe lines beginning with `#`. |
|
||||||
| `positional-arguments` | boolean | `false` | Pass positional arguments. |
|
| `positional-arguments` | boolean | `false` | Pass positional arguments. |
|
||||||
| `shell` | `[COMMAND, ARGS…]` | - | Set the command used to invoke recipes and evaluate backticks. |
|
| `shell` | `[COMMAND, ARGS…]` | - | Set the command used to invoke recipes and evaluate backticks. |
|
||||||
| `tempdir` | string | - | Create temporary directories in `tempdir` instead of the system default temporary directory. |
|
| `tempdir` | string | - | Create temporary directories in `tempdir` instead of the system default temporary directory. |
|
||||||
| `windows-powershell` | boolean | `false` | Use PowerShell on [Windows](../../windows/Windows.md) as default [shell](Shell.md). (Deprecated. Use `windows-shell` instead. |
|
| `windows-powershell` | boolean | `false` | Use PowerShell on [Windows](../../windows/Windows.md) as default [shell](Shell.md). (Deprecated. Use `windows-shell` instead. |
|
||||||
| `windows-shell` | `[COMMAND, ARGS…]` | - | Set the command used to invoke recipes and evaluate backticks. |
|
| `windows-shell` | `[COMMAND, ARGS…]` | - | Set the command used to invoke recipes and evaluate backticks. |
|
||||||
|
|
||||||
#### Dotenv Settings
|
#### Dotenv Settings
|
||||||
If `dotenv-load`, `dotenv-filename` or `dotenv-path` is set, `just` will load [environment variables](../../linux/Environment%20Variables.md) from a file.
|
If `dotenv-load`, `dotenv-filename` or `dotenv-path` is set, `just` will load [environment variables](../../linux/Environment%20Variables.md) from a file.
|
||||||
|
|
||||||
If `dotenv-path` is set, `just` will look for a file at the given path.
|
If `dotenv-path` is set, `just` will look for a file at the given path.
|
||||||
|
|
||||||
Otherwise, `just` looks for a file named `.env` by default, unless `dotenv-filename` set, in which case the value of `dotenv-filename` is used. This file can be located in the same directory as your `justfile` or in a parent directory.
|
Otherwise, `just` looks for a file named `.env` by default, unless `dotenv-filename` set, in which case the value of `dotenv-filename` is used. This file can be located in the same directory as your `justfile` or in a parent directory.
|
||||||
|
|
||||||
The loaded variables are [environment variables](../../linux/Environment%20Variables.md), not `just` variables, and so must be accessed using `$VARIABLE_NAME` in recipes and backticks.
|
The loaded variables are [environment variables](../../linux/Environment%20Variables.md), not `just` variables, and so must be accessed using `$VARIABLE_NAME` in recipes and backticks.
|
||||||
|
|
||||||
For example, if your `.env` file contains:
|
For example, if your `.env` file contains:
|
||||||
```shell
|
```shell
|
||||||
# a comment, will be ignored
|
# a comment, will be ignored
|
||||||
DATABASE_ADDRESS=localhost:6379
|
DATABASE_ADDRESS=localhost:6379
|
||||||
SERVER_PORT=1337
|
SERVER_PORT=1337
|
||||||
```
|
```
|
||||||
|
|
||||||
And your `justfile` contains:
|
And your `justfile` contains:
|
||||||
```just
|
```just
|
||||||
set dotenv-load
|
set dotenv-load
|
||||||
|
|
||||||
|
@ -243,7 +243,7 @@ serve:
|
||||||
./server --database $DATABASE_ADDRESS --port $SERVER_PORT
|
./server --database $DATABASE_ADDRESS --port $SERVER_PORT
|
||||||
```
|
```
|
||||||
|
|
||||||
`just serve` will output:
|
`just serve` will output:
|
||||||
```shell
|
```shell
|
||||||
$ just serve
|
$ just serve
|
||||||
Starting server with database localhost:6379 on port 1337…
|
Starting server with database localhost:6379 on port 1337…
|
||||||
|
@ -251,7 +251,7 @@ Starting server with database localhost:6379 on port 1337…
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Positional Arguments
|
#### Positional Arguments
|
||||||
If `positional-arguments` is `true`, recipe arguments will be passed as positional arguments to commands. For linewise recipes, argument `$0` will be the name of the recipe.
|
If `positional-arguments` is `true`, recipe arguments will be passed as positional arguments to commands. For linewise recipes, argument `$0` will be the name of the recipe.
|
||||||
|
|
||||||
For example, running this recipe:
|
For example, running this recipe:
|
||||||
```just
|
```just
|
||||||
|
@ -269,7 +269,7 @@ foo
|
||||||
hello
|
hello
|
||||||
```
|
```
|
||||||
|
|
||||||
When using an `sh`-compatible [shell](Shell.md), such as [`bash`](bash.md) or [`zsh`](zsh.md), `$@` expands to the positional arguments given to the recipe, starting from one. When used within double quotes as `"$@"`, arguments including whitespace will be passed on as if they were double-quoted. That is, `"$@"` is equivalent to `"$1" "$2"`… When there are no positional parameters, `"$@"` and `$@` expand to nothing (i.e., they are removed).
|
When using an `sh`-compatible [shell](Shell.md), such as [`bash`](bash.md) or [`zsh`](zsh.md), `$@` expands to the positional arguments given to the recipe, starting from one. When used within double quotes as `"$@"`, arguments including whitespace will be passed on as if they were double-quoted. That is, `"$@"` is equivalent to `"$1" "$2"`… When there are no positional parameters, `"$@"` and `$@` expand to nothing (i.e., they are removed).
|
||||||
|
|
||||||
This example recipe will print arguments one by one on separate lines:
|
This example recipe will print arguments one by one on separate lines:
|
||||||
```just
|
```just
|
||||||
|
@ -279,7 +279,7 @@ set positional-arguments
|
||||||
bash -c 'while (( "$#" )); do echo - $1; shift; done' -- "$@"
|
bash -c 'while (( "$#" )); do echo - $1; shift; done' -- "$@"
|
||||||
```
|
```
|
||||||
|
|
||||||
Running it with _two_ arguments:
|
Running it with _two_ arguments:
|
||||||
```shell
|
```shell
|
||||||
$ just test foo "bar baz"
|
$ just test foo "bar baz"
|
||||||
- foo
|
- foo
|
||||||
|
@ -287,7 +287,7 @@ $ just test foo "bar baz"
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Shell
|
#### Shell
|
||||||
The `shell` setting controls the command used to invoke recipe lines and backticks. Shebang recipes are unaffected.
|
The `shell` setting controls the command used to invoke recipe lines and backticks. Shebang recipes are unaffected.
|
||||||
```just
|
```just
|
||||||
# use python3 to execute recipe lines and backticks
|
# use python3 to execute recipe lines and backticks
|
||||||
set shell := ["python3", "-c"]
|
set shell := ["python3", "-c"]
|
||||||
|
@ -300,10 +300,10 @@ foo:
|
||||||
print("{{foos}}")
|
print("{{foos}}")
|
||||||
```
|
```
|
||||||
|
|
||||||
`just` passes the command to be executed as an argument. Many shells will need an additional flag, often `-c`, to make them evaluate the first argument.
|
`just` passes the command to be executed as an argument. Many shells will need an additional flag, often `-c`, to make them evaluate the first argument.
|
||||||
|
|
||||||
### Documentation Comments
|
### Documentation Comments
|
||||||
Comments immediately preceding a recipe will appear in `just --list`:
|
Comments immediately preceding a recipe will appear in `just --list`:
|
||||||
```just
|
```just
|
||||||
# build stuff
|
# build stuff
|
||||||
build:
|
build:
|
||||||
|
@ -322,7 +322,7 @@ Available recipes:
|
||||||
```
|
```
|
||||||
|
|
||||||
### Variables and Substitution
|
### Variables and Substitution
|
||||||
Variables, strings, concatenation, path joining, and substitution using `{{…}}` are supported:
|
Variables, strings, concatenation, path joining, and substitution using `{{…}}` are supported:
|
||||||
```just
|
```just
|
||||||
tmpdir := `mktemp -d`
|
tmpdir := `mktemp -d`
|
||||||
version := "0.2.7"
|
version := "0.2.7"
|
||||||
|
@ -339,7 +339,7 @@ publish:
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Joining Paths
|
#### Joining Paths
|
||||||
The `/` operator can be used to join two strings with a slash:
|
The `/` operator can be used to join two strings with a slash:
|
||||||
```just
|
```just
|
||||||
foo := "a" / "b"
|
foo := "a" / "b"
|
||||||
```
|
```
|
||||||
|
@ -349,7 +349,7 @@ $ just --evaluate foo
|
||||||
a/b
|
a/b
|
||||||
```
|
```
|
||||||
|
|
||||||
Note that a `/` is added even if one is already present:
|
Note that a `/` is added even if one is already present:
|
||||||
```just
|
```just
|
||||||
foo := "a/"
|
foo := "a/"
|
||||||
bar := foo / "b"
|
bar := foo / "b"
|
||||||
|
@ -370,14 +370,14 @@ $ just --evaluate foo
|
||||||
/b
|
/b
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Escaping `{{`
|
#### Escaping `{{`
|
||||||
To write a recipe containing `{{`, use `{{{{`:
|
To write a recipe containing `{{`, use `{{{{`:
|
||||||
```just
|
```just
|
||||||
braces:
|
braces:
|
||||||
echo 'I {{{{LOVE}} curly braces!'
|
echo 'I {{{{LOVE}} curly braces!'
|
||||||
```
|
```
|
||||||
|
|
||||||
(An unmatched `}}` is ignored, so it doesn't need to be escaped.)
|
(An unmatched `}}` is ignored, so it doesn't need to be escaped.)
|
||||||
|
|
||||||
Another option is to put all the text you'd like to escape inside of an interpolation:
|
Another option is to put all the text you'd like to escape inside of an interpolation:
|
||||||
```just
|
```just
|
||||||
|
@ -385,14 +385,14 @@ braces:
|
||||||
echo '{{'I {{LOVE}} curly braces!'}}'
|
echo '{{'I {{LOVE}} curly braces!'}}'
|
||||||
```
|
```
|
||||||
|
|
||||||
Yet another option is to use `{{ "{{" }}`:
|
Yet another option is to use `{{ "{{" }}`:
|
||||||
```just
|
```just
|
||||||
braces:
|
braces:
|
||||||
echo 'I {{ "{{" }}LOVE}} curly braces!'
|
echo 'I {{ "{{" }}LOVE}} curly braces!'
|
||||||
```
|
```
|
||||||
|
|
||||||
### Ignoring Errors
|
### Ignoring Errors
|
||||||
Normally, if a command returns a non-zero exit status, execution will stop. To continue execution after a command, even if it fails, prefix the command with `-`:
|
Normally, if a command returns a non-zero exit status, execution will stop. To continue execution after a command, even if it fails, prefix the command with `-`:
|
||||||
```just
|
```just
|
||||||
foo:
|
foo:
|
||||||
-cat foo
|
-cat foo
|
||||||
|
@ -408,13 +408,13 @@ Done!
|
||||||
```
|
```
|
||||||
|
|
||||||
### Functions
|
### Functions
|
||||||
`just` provides a few built-in functions that might be useful when writing recipes.
|
`just` provides a few built-in functions that might be useful when writing recipes.
|
||||||
|
|
||||||
#### System Information
|
#### System Information
|
||||||
- `arch()` — Instruction set architecture. Possible values are: `"aarch64"`, `"arm"`, `"asmjs"`, `"hexagon"`, `"mips"`, `"msp430"`, `"powerpc"`, `"powerpc64"`, `"s390x"`, `"sparc"`, `"wasm32"`, `"x86"`, `"x86_64"`, and `"xcore"`.
|
- `arch()` — Instruction set architecture. Possible values are: `"aarch64"`, `"arm"`, `"asmjs"`, `"hexagon"`, `"mips"`, `"msp430"`, `"powerpc"`, `"powerpc64"`, `"s390x"`, `"sparc"`, `"wasm32"`, `"x86"`, `"x86_64"`, and `"xcore"`.
|
||||||
- `num_cpus()` - Number of logical CPUs.
|
- `num_cpus()` - Number of logical CPUs.
|
||||||
- `os()` — Operating system. Possible values are: `"android"`, `"bitrig"`, `"dragonfly"`, `"emscripten"`, `"freebsd"`, `"haiku"`, `"ios"`, `"linux"`, `"macos"`, `"netbsd"`, `"openbsd"`, `"solaris"`, and `"windows"`.
|
- `os()` — Operating system. Possible values are: `"android"`, `"bitrig"`, `"dragonfly"`, `"emscripten"`, `"freebsd"`, `"haiku"`, `"ios"`, `"linux"`, `"macos"`, `"netbsd"`, `"openbsd"`, `"solaris"`, and `"windows"`.
|
||||||
- `os_family()` — Operating system family; possible values are: `"unix"` and `"windows"`.
|
- `os_family()` — Operating system family; possible values are: `"unix"` and `"windows"`.
|
||||||
|
|
||||||
For example:
|
For example:
|
||||||
```just
|
```just
|
||||||
|
@ -428,7 +428,7 @@ This is an x86_64 machine
|
||||||
```
|
```
|
||||||
|
|
||||||
#### [Environment Variables](../../linux/Environment%20Variables.md)
|
#### [Environment Variables](../../linux/Environment%20Variables.md)
|
||||||
- `env_var(key)` — Retrieves the environment variable with name `key`, aborting if it is not present.
|
- `env_var(key)` — Retrieves the environment variable with name `key`, aborting if it is not present.
|
||||||
|
|
||||||
```just
|
```just
|
||||||
home_dir := env_var('HOME')
|
home_dir := env_var('HOME')
|
||||||
|
@ -442,14 +442,14 @@ $ just
|
||||||
/home/user1
|
/home/user1
|
||||||
```
|
```
|
||||||
|
|
||||||
- `env_var_or_default(key, default)` — Retrieves the environment variable with name `key`, returning `default` if it is not present.
|
- `env_var_or_default(key, default)` — Retrieves the environment variable with name `key`, returning `default` if it is not present.
|
||||||
- `env(key)` — Alias for `env_var(key)`.
|
- `env(key)` — Alias for `env_var(key)`.
|
||||||
- `env(key, default)` — Alias for `env_var_or_default(key, default)`.
|
- `env(key, default)` — Alias for `env_var_or_default(key, default)`.
|
||||||
|
|
||||||
#### Invocation Directory
|
#### Invocation Directory
|
||||||
- `invocation_directory()` - Retrieves the absolute path to the current directory when `just` was invoked.
|
- `invocation_directory()` - Retrieves the absolute path to the current directory when `just` was invoked.
|
||||||
|
|
||||||
For example, to call `rustfmt` on files just under the "current directory" (from the user/invoker's perspective), use the following rule:
|
For example, to call `rustfmt` on files just under the "current directory" (from the user/invoker's perspective), use the following rule:
|
||||||
```just
|
```just
|
||||||
rustfmt:
|
rustfmt:
|
||||||
find {{invocation_directory()}} -name \*.rs -exec rustfmt {} \;
|
find {{invocation_directory()}} -name \*.rs -exec rustfmt {} \;
|
||||||
|
@ -462,17 +462,17 @@ build:
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Justfile and Justfile Directory
|
#### Justfile and Justfile Directory
|
||||||
- `justfile()` - Retrieves the path of the current `justfile`.
|
- `justfile()` - Retrieves the path of the current `justfile`.
|
||||||
- `justfile_directory()` - Retrieves the path of the parent directory of the current `justfile`.
|
- `justfile_directory()` - Retrieves the path of the parent directory of the current `justfile`.
|
||||||
|
|
||||||
For example, to run a command relative to the location of the current `justfile`:
|
For example, to run a command relative to the location of the current `justfile`:
|
||||||
```just
|
```just
|
||||||
script:
|
script:
|
||||||
./{{justfile_directory()}}/scripts/some_script
|
./{{justfile_directory()}}/scripts/some_script
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Just Executable
|
#### Just Executable
|
||||||
- `just_executable()` - Absolute path to the `just` executable.
|
- `just_executable()` - Absolute path to the `just` executable.
|
||||||
|
|
||||||
For example:
|
For example:
|
||||||
```just
|
```just
|
||||||
|
@ -486,54 +486,54 @@ The executable is at: /bin/just
|
||||||
```
|
```
|
||||||
|
|
||||||
#### String Manipulation
|
#### String Manipulation
|
||||||
- `quote(s)` - Replace all single quotes with `'\''` and prepend and append single quotes to `s`. This is sufficient to escape special characters for many shells, including most Bourne [shell](Shell.md) descendants.
|
- `quote(s)` - Replace all single quotes with `'\''` and prepend and append single quotes to `s`. This is sufficient to escape special characters for many shells, including most Bourne [shell](Shell.md) descendants.
|
||||||
- `replace(s, from, to)` - Replace all occurrences of `from` in `s` to `to`.
|
- `replace(s, from, to)` - Replace all occurrences of `from` in `s` to `to`.
|
||||||
- `replace_regex(s, regex, replacement)` - Replace all occurrences of `regex` in `s` to `replacement`. Regular expressions are provided by the [Rust `regex` crate](https://docs.rs/regex/latest/regex/). See the [syntax documentation](https://docs.rs/regex/latest/regex/#syntax) for usage examples. Capture groups are supported. The `replacement` string uses [Replacement string syntax](https://docs.rs/regex/latest/regex/struct.Regex.html#replacement-string-syntax).
|
- `replace_regex(s, regex, replacement)` - Replace all occurrences of `regex` in `s` to `replacement`. Regular expressions are provided by the [Rust `regex` crate](https://docs.rs/regex/latest/regex/). See the [syntax documentation](https://docs.rs/regex/latest/regex/#syntax) for usage examples. Capture groups are supported. The `replacement` string uses [Replacement string syntax](https://docs.rs/regex/latest/regex/struct.Regex.html#replacement-string-syntax).
|
||||||
- `trim(s)` - Remove leading and trailing whitespace from `s`.
|
- `trim(s)` - Remove leading and trailing whitespace from `s`.
|
||||||
- `trim_end(s)` - Remove trailing whitespace from `s`.
|
- `trim_end(s)` - Remove trailing whitespace from `s`.
|
||||||
- `trim_end_match(s, pat)` - Remove suffix of `s` matching `pat`.
|
- `trim_end_match(s, pat)` - Remove suffix of `s` matching `pat`.
|
||||||
- `trim_end_matches(s, pat)` - Repeatedly remove suffixes of `s` matching `pat`.
|
- `trim_end_matches(s, pat)` - Repeatedly remove suffixes of `s` matching `pat`.
|
||||||
- `trim_start(s)` - Remove leading whitespace from `s`.
|
- `trim_start(s)` - Remove leading whitespace from `s`.
|
||||||
- `trim_start_match(s, pat)` - Remove prefix of `s` matching `pat`.
|
- `trim_start_match(s, pat)` - Remove prefix of `s` matching `pat`.
|
||||||
- `trim_start_matches(s, pat)` - Repeatedly remove prefixes of `s` matching `pat`.
|
- `trim_start_matches(s, pat)` - Repeatedly remove prefixes of `s` matching `pat`.
|
||||||
|
|
||||||
#### Case Conversion
|
#### Case Conversion
|
||||||
- `capitalize(s)` - Convert first character of `s` to uppercase and the rest to lowercase.
|
- `capitalize(s)` - Convert first character of `s` to uppercase and the rest to lowercase.
|
||||||
- `kebabcase(s)` - Convert `s` to `kebab-case`.
|
- `kebabcase(s)` - Convert `s` to `kebab-case`.
|
||||||
- `lowercamelcase(s)` - Convert `s` to `lowerCamelCase`.
|
- `lowercamelcase(s)` - Convert `s` to `lowerCamelCase`.
|
||||||
- `lowercase(s)` - Convert `s` to lowercase.
|
- `lowercase(s)` - Convert `s` to lowercase.
|
||||||
- `shoutykebabcase(s)` - Convert `s` to `SHOUTY-KEBAB-CASE`.
|
- `shoutykebabcase(s)` - Convert `s` to `SHOUTY-KEBAB-CASE`.
|
||||||
- `shoutysnakecase(s)` - Convert `s` to `SHOUTY_SNAKE_CASE`.
|
- `shoutysnakecase(s)` - Convert `s` to `SHOUTY_SNAKE_CASE`.
|
||||||
- `snakecase(s)` - Convert `s` to `snake_case`.
|
- `snakecase(s)` - Convert `s` to `snake_case`.
|
||||||
- `titlecase(s)` - Convert `s` to `Title Case`.
|
- `titlecase(s)` - Convert `s` to `Title Case`.
|
||||||
- `uppercamelcase(s)` - Convert `s` to `UpperCamelCase`.
|
- `uppercamelcase(s)` - Convert `s` to `UpperCamelCase`.
|
||||||
- `uppercase(s)` - Convert `s` to uppercase.
|
- `uppercase(s)` - Convert `s` to uppercase.
|
||||||
|
|
||||||
#### Path Manipulation
|
#### Path Manipulation
|
||||||
##### Fallible
|
##### Fallible
|
||||||
- `absolute_path(path)` - Absolute path to relative `path` in the working directory. `absolute_path("./bar.txt")` in directory `/foo` is `/foo/bar.txt`.
|
- `absolute_path(path)` - Absolute path to relative `path` in the working directory. `absolute_path("./bar.txt")` in directory `/foo` is `/foo/bar.txt`.
|
||||||
- `extension(path)` - Extension of `path`. `extension("/foo/bar.txt")` is `txt`.
|
- `extension(path)` - Extension of `path`. `extension("/foo/bar.txt")` is `txt`.
|
||||||
- `file_name(path)` - File name of `path` with any leading directory components removed. `file_name("/foo/bar.txt")` is `bar.txt`.
|
- `file_name(path)` - File name of `path` with any leading directory components removed. `file_name("/foo/bar.txt")` is `bar.txt`.
|
||||||
- `file_stem(path)` - File name of `path` without extension. `file_stem("/foo/bar.txt")` is `bar`.
|
- `file_stem(path)` - File name of `path` without extension. `file_stem("/foo/bar.txt")` is `bar`.
|
||||||
- `parent_directory(path)` - Parent directory of `path`. `parent_directory("/foo/bar.txt")` is `/foo`.
|
- `parent_directory(path)` - Parent directory of `path`. `parent_directory("/foo/bar.txt")` is `/foo`.
|
||||||
- `without_extension(path)` - `path` without extension. `without_extension("/foo/bar.txt")` is `/foo/bar`.
|
- `without_extension(path)` - `path` without extension. `without_extension("/foo/bar.txt")` is `/foo/bar`.
|
||||||
|
|
||||||
These functions can fail, for example if a path does not have an extension, which will halt execution.
|
These functions can fail, for example if a path does not have an extension, which will halt execution.
|
||||||
|
|
||||||
##### Infallible
|
##### Infallible
|
||||||
- `clean(path)` - Simplify `path` by removing extra path separators, intermediate `.` components, and `..` where possible. `clean("foo//bar")` is `foo/bar`, `clean("foo/..")` is `.`, `clean("foo/./bar")` is `foo/bar`.
|
- `clean(path)` - Simplify `path` by removing extra path separators, intermediate `.` components, and `..` where possible. `clean("foo//bar")` is `foo/bar`, `clean("foo/..")` is `.`, `clean("foo/./bar")` is `foo/bar`.
|
||||||
- `join(a, b…)` - _This function uses `/` on Unix and `\` on [Windows](../../windows/Windows.md), which can be lead to unwanted behavior. The `/` operator, e.g., `a / b`, which always uses `/`, should be considered as a replacement unless `\`s are specifically desired on [Windows](../../windows/Windows.md)._ Join path `a` with path `b`. `join("foo/bar", "baz")` is `foo/bar/baz`. Accepts two or more arguments.
|
- `join(a, b…)` - _This function uses `/` on Unix and `\` on [Windows](../../windows/Windows.md), which can be lead to unwanted behavior. The `/` operator, e.g., `a / b`, which always uses `/`, should be considered as a replacement unless `\`s are specifically desired on [Windows](../../windows/Windows.md)._ Join path `a` with path `b`. `join("foo/bar", "baz")` is `foo/bar/baz`. Accepts two or more arguments.
|
||||||
|
|
||||||
#### Filesystem Access
|
#### Filesystem Access
|
||||||
- `path_exists(path)` - Returns `true` if the path points at an existing entity and `false` otherwise. Traverses symbolic links, and returns `false` if the path is inaccessible or points to a broken symlink.
|
- `path_exists(path)` - Returns `true` if the path points at an existing entity and `false` otherwise. Traverses symbolic links, and returns `false` if the path is inaccessible or points to a broken symlink.
|
||||||
|
|
||||||
#### Error Reporting
|
#### Error Reporting
|
||||||
- `error(message)` - Abort execution and report error `message` to user.
|
- `error(message)` - Abort execution and report error `message` to user.
|
||||||
|
|
||||||
#### UUID and Hash Generation
|
#### UUID and Hash Generation
|
||||||
- `sha256(string)` - Return the [SHA](../../cryptography/SHA.md)-256 hash of `string` as a hexadecimal string.
|
- `sha256(string)` - Return the [SHA](../../cryptography/SHA.md)-256 hash of `string` as a hexadecimal string.
|
||||||
- `sha256_file(path)` - Return the [SHA](../../cryptography/SHA.md)-256 hash of the file at `path` as a hexadecimal string.
|
- `sha256_file(path)` - Return the [SHA](../../cryptography/SHA.md)-256 hash of the file at `path` as a hexadecimal string.
|
||||||
- `uuid()` - Return a randomly generated UUID.
|
- `uuid()` - Return a randomly generated UUID.
|
||||||
|
|
||||||
### Recipe Attributes
|
### Recipe Attributes
|
||||||
Recipes may be annotated with attributes that change their behavior.
|
Recipes may be annotated with attributes that change their behavior.
|
||||||
|
@ -546,7 +546,7 @@ Recipes may be annotated with attributes that change their behavior.
|
||||||
| `[macos]` | Enable recipe on [MacOS](../../macos/macOS.md). |
|
| `[macos]` | Enable recipe on [MacOS](../../macos/macOS.md). |
|
||||||
| `[unix]` | Enable recipe on Unixes. (Includes [MacOS](../../macos/macOS.md)). |
|
| `[unix]` | Enable recipe on Unixes. (Includes [MacOS](../../macos/macOS.md)). |
|
||||||
| `[windows]` | Enable recipe on [Windows](../../windows/Windows.md). |
|
| `[windows]` | Enable recipe on [Windows](../../windows/Windows.md). |
|
||||||
| `[private]`1 | See Private Recipes. |
|
| `[private]`1 | See Private Recipes. |
|
||||||
|
|
||||||
A recipe can have multiple attributes, either on multiple lines:
|
A recipe can have multiple attributes, either on multiple lines:
|
||||||
```just
|
```just
|
||||||
|
@ -564,9 +564,9 @@ foo:
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Enabling and Disabling Recipes
|
#### Enabling and Disabling Recipes
|
||||||
The `[linux]`, `[macos]`, `[unix]`, and `[windows]` attributes are configuration attributes. By default, recipes are always enabled. A recipe with one or more configuration attributes will only be enabled when one or more of those configurations is active.
|
The `[linux]`, `[macos]`, `[unix]`, and `[windows]` attributes are configuration attributes. By default, recipes are always enabled. A recipe with one or more configuration attributes will only be enabled when one or more of those configurations is active.
|
||||||
|
|
||||||
This can be used to write `justfile`s that behave differently depending on which operating system they run on. The `run` recipe in this `justfile` will compile and run `main.c`, using a different C compiler and using the correct output binary name for that compiler depending on the operating system:
|
This can be used to write `justfile`s that behave differently depending on which operating system they run on. The `run` recipe in this `justfile` will compile and run `main.c`, using a different C compiler and using the correct output binary name for that compiler depending on the operating system:
|
||||||
|
|
||||||
```just
|
```just
|
||||||
[unix]
|
[unix]
|
||||||
|
@ -581,9 +581,9 @@ run:
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Disabling Changing Directory
|
#### Disabling Changing Directory
|
||||||
`just` normally executes recipes with the current directory set to the directory that contains the `justfile`. This can be disabled using the `[no-cd]` attribute. This can be used to create recipes which use paths relative to the invocation directory, or which operate on the current directory.
|
`just` normally executes recipes with the current directory set to the directory that contains the `justfile`. This can be disabled using the `[no-cd]` attribute. This can be used to create recipes which use paths relative to the invocation directory, or which operate on the current directory.
|
||||||
|
|
||||||
For example, this `commit` recipe:
|
For example, this `commit` recipe:
|
||||||
```just
|
```just
|
||||||
[no-cd]
|
[no-cd]
|
||||||
commit file:
|
commit file:
|
||||||
|
@ -591,7 +591,7 @@ commit file:
|
||||||
git commit
|
git commit
|
||||||
```
|
```
|
||||||
|
|
||||||
Can be used with paths that are relative to the current directory, because `[no-cd]` prevents `just` from changing the current directory when executing `commit`.
|
Can be used with paths that are relative to the current directory, because `[no-cd]` prevents `just` from changing the current directory when executing `commit`.
|
||||||
|
|
||||||
### Command Evaluation Using Backticks
|
### Command Evaluation Using Backticks
|
||||||
Backticks can be used to store the result of commands:
|
Backticks can be used to store the result of commands:
|
||||||
|
@ -612,7 +612,7 @@ stuff := ```
|
||||||
</code></pre>
|
</code></pre>
|
||||||
|
|
||||||
### Conditional Expressions
|
### Conditional Expressions
|
||||||
`if`/`else` expressions evaluate different branches depending on if two expressions evaluate to the same value:
|
`if`/`else` expressions evaluate different branches depending on if two expressions evaluate to the same value:
|
||||||
```just
|
```just
|
||||||
foo := if "2" == "2" { "Good!" } else { "1984" }
|
foo := if "2" == "2" { "Good!" } else { "1984" }
|
||||||
|
|
||||||
|
@ -651,7 +651,7 @@ $ just bar
|
||||||
match
|
match
|
||||||
```
|
```
|
||||||
|
|
||||||
Regular expressions are provided by the [regex crate](https://github.com/rust-lang/regex), whose syntax is documented on [docs.rs](https://docs.rs/regex/1.5.4/regex/#syntax). Since regular expressions commonly use backslash escape sequences, consider using single-quoted string literals, which will pass slashes to the regex parser unmolested.
|
Regular expressions are provided by the [regex crate](https://github.com/rust-lang/regex), whose syntax is documented on [docs.rs](https://docs.rs/regex/1.5.4/regex/#syntax). Since regular expressions commonly use backslash escape sequences, consider using single-quoted string literals, which will pass slashes to the regex parser unmolested.
|
||||||
|
|
||||||
Conditional expressions short-circuit, which means they only evaluate one of their branches. This can be used to make sure that backtick expressions don't run when they shouldn't.
|
Conditional expressions short-circuit, which means they only evaluate one of their branches. This can be used to make sure that backtick expressions don't run when they shouldn't.
|
||||||
```just
|
```just
|
||||||
|
@ -664,7 +664,7 @@ bar foo:
|
||||||
echo {{ if foo == "bar" { "hello" } else { "goodbye" } }}
|
echo {{ if foo == "bar" { "hello" } else { "goodbye" } }}
|
||||||
```
|
```
|
||||||
|
|
||||||
> Note the space after the final `}`! Without the space, the interpolation will be prematurely closed.
|
> Note the space after the final `}`! Without the space, the interpolation will be prematurely closed.
|
||||||
|
|
||||||
Multiple conditionals can be chained:
|
Multiple conditionals can be chained:
|
||||||
```just
|
```just
|
||||||
|
@ -686,7 +686,7 @@ abc
|
||||||
```
|
```
|
||||||
|
|
||||||
### Stopping execution with error
|
### Stopping execution with error
|
||||||
Execution can be halted with the `error` function. For example:
|
Execution can be halted with the `error` function. For example:
|
||||||
```just
|
```just
|
||||||
foo := if "hello" == "goodbye" {
|
foo := if "hello" == "goodbye" {
|
||||||
"xyz"
|
"xyz"
|
||||||
|
@ -722,14 +722,14 @@ $ just
|
||||||
./test --test linux
|
./test --test linux
|
||||||
```
|
```
|
||||||
|
|
||||||
Any number of arguments of the form `NAME=VALUE` can be passed before recipes:
|
Any number of arguments of the form `NAME=VALUE` can be passed before recipes:
|
||||||
```shell
|
```shell
|
||||||
$ just os=plan9
|
$ just os=plan9
|
||||||
./build plan9
|
./build plan9
|
||||||
./test --test plan9
|
./test --test plan9
|
||||||
```
|
```
|
||||||
|
|
||||||
Or you can use the `--set` flag:
|
Or you can use the `--set` flag:
|
||||||
```shell
|
```shell
|
||||||
$ just --set os bsd
|
$ just --set os bsd
|
||||||
./build bsd
|
./build bsd
|
||||||
|
@ -737,8 +737,8 @@ $ just --set os bsd
|
||||||
```
|
```
|
||||||
|
|
||||||
### Getting and Setting [Environment Variables](../../linux/Environment%20Variables.md)
|
### Getting and Setting [Environment Variables](../../linux/Environment%20Variables.md)
|
||||||
#### Exporting `just` Variables
|
#### Exporting `just` Variables
|
||||||
Assignments prefixed with the `export` keyword will be exported to recipes as [environment variables](../../linux/Environment%20Variables.md):
|
Assignments prefixed with the `export` keyword will be exported to recipes as [environment variables](../../linux/Environment%20Variables.md):
|
||||||
```just
|
```just
|
||||||
export RUST_BACKTRACE := "1"
|
export RUST_BACKTRACE := "1"
|
||||||
|
|
||||||
|
@ -747,7 +747,7 @@ test:
|
||||||
cargo test
|
cargo test
|
||||||
```
|
```
|
||||||
|
|
||||||
Parameters prefixed with a `$` will be exported as [environment variables](../../linux/Environment%20Variables.md):
|
Parameters prefixed with a `$` will be exported as [environment variables](../../linux/Environment%20Variables.md):
|
||||||
```just
|
```just
|
||||||
test $RUST_BACKTRACE="1":
|
test $RUST_BACKTRACE="1":
|
||||||
# will print a stack trace if it crashes
|
# will print a stack trace if it crashes
|
||||||
|
@ -767,7 +767,7 @@ a $A $B=`echo $A`:
|
||||||
echo $A $B
|
echo $A $B
|
||||||
```
|
```
|
||||||
|
|
||||||
When `export` is set, all `just` variables are exported as [environment variables](../../linux/Environment%20Variables.md).
|
When `export` is set, all `just` variables are exported as [environment variables](../../linux/Environment%20Variables.md).
|
||||||
|
|
||||||
#### Getting [Environment Variables](../../linux/Environment%20Variables.md) from the environment
|
#### Getting [Environment Variables](../../linux/Environment%20Variables.md) from the environment
|
||||||
[Environment variables](../../linux/Environment%20Variables.md) from the environment are passed automatically to the recipes.
|
[Environment variables](../../linux/Environment%20Variables.md) from the environment are passed automatically to the recipes.
|
||||||
|
@ -782,11 +782,11 @@ $ just
|
||||||
HOME is '/home/myuser'
|
HOME is '/home/myuser'
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Setting `just` Variables from [Environment Variables](../../linux/Environment%20Variables.md)
|
#### Setting `just` Variables from [Environment Variables](../../linux/Environment%20Variables.md)
|
||||||
[Environment variables](../../linux/Environment%20Variables.md) can be propagated to `just` variables using the functions `env_var()` and `env_var_or_default()`.
|
[Environment variables](../../linux/Environment%20Variables.md) can be propagated to `just` variables using the functions `env_var()` and `env_var_or_default()`.
|
||||||
|
|
||||||
### Recipe Parameters
|
### Recipe Parameters
|
||||||
Recipes may have parameters. Here recipe `build` has a parameter called `target`:
|
Recipes may have parameters. Here recipe `build` has a parameter called `target`:
|
||||||
```just
|
```just
|
||||||
build target:
|
build target:
|
||||||
@echo 'Building {{target}}…'
|
@echo 'Building {{target}}…'
|
||||||
|
@ -860,13 +860,13 @@ test triple=(arch + "-unknown-unknown") input=(arch / "input.dat"):
|
||||||
./test {{triple}}
|
./test {{triple}}
|
||||||
```
|
```
|
||||||
|
|
||||||
The last parameter of a recipe may be variadic, indicated with either a `+` or a `*` before the argument name:
|
The last parameter of a recipe may be variadic, indicated with either a `+` or a `*` before the argument name:
|
||||||
```just
|
```just
|
||||||
backup +FILES:
|
backup +FILES:
|
||||||
scp {{FILES}} me@server.com:
|
scp {{FILES}} me@server.com:
|
||||||
```
|
```
|
||||||
|
|
||||||
Variadic parameters prefixed with `+` accept _one or more_ arguments and expand to a string containing those arguments separated by spaces:
|
Variadic parameters prefixed with `+` accept _one or more_ arguments and expand to a string containing those arguments separated by spaces:
|
||||||
```shell
|
```shell
|
||||||
$ just backup FAQ.md GRAMMAR.md
|
$ just backup FAQ.md GRAMMAR.md
|
||||||
scp FAQ.md GRAMMAR.md me@server.com:
|
scp FAQ.md GRAMMAR.md me@server.com:
|
||||||
|
@ -874,7 +874,7 @@ FAQ.md 100% 1831 1.8KB/s 00:00
|
||||||
GRAMMAR.md 100% 1666 1.6KB/s 00:00
|
GRAMMAR.md 100% 1666 1.6KB/s 00:00
|
||||||
```
|
```
|
||||||
|
|
||||||
Variadic parameters prefixed with `*` accept _zero or more_ arguments and expand to a string containing those arguments separated by spaces, or an empty string if no arguments are present:
|
Variadic parameters prefixed with `*` accept _zero or more_ arguments and expand to a string containing those arguments separated by spaces, or an empty string if no arguments are present:
|
||||||
```just
|
```just
|
||||||
commit MESSAGE *FLAGS:
|
commit MESSAGE *FLAGS:
|
||||||
git commit {{FLAGS}} -m "{{MESSAGE}}"
|
git commit {{FLAGS}} -m "{{MESSAGE}}"
|
||||||
|
@ -886,7 +886,7 @@ test +FLAGS='-q':
|
||||||
cargo test {{FLAGS}}
|
cargo test {{FLAGS}}
|
||||||
```
|
```
|
||||||
|
|
||||||
`{{…}}` substitutions may need to be quoted if they contain spaces. For example, if you have the following recipe:
|
`{{…}}` substitutions may need to be quoted if they contain spaces. For example, if you have the following recipe:
|
||||||
```just
|
```just
|
||||||
search QUERY:
|
search QUERY:
|
||||||
lynx https://www.google.com/?q={{QUERY}}
|
lynx https://www.google.com/?q={{QUERY}}
|
||||||
|
@ -897,7 +897,7 @@ And you type:
|
||||||
$ just search "cat toupee"
|
$ just search "cat toupee"
|
||||||
```
|
```
|
||||||
|
|
||||||
`just` will run the command `lynx https://www.google.com/?q=cat toupee`, which will get parsed by `sh` as `lynx`, `https://www.google.com/?q=cat`, and `toupee`, and not the intended `lynx` and `https://www.google.com/?q=cat toupee`.
|
`just` will run the command `lynx https://www.google.com/?q=cat toupee`, which will get parsed by `sh` as `lynx`, `https://www.google.com/?q=cat`, and `toupee`, and not the intended `lynx` and `https://www.google.com/?q=cat toupee`.
|
||||||
|
|
||||||
You can fix this by adding quotes:
|
You can fix this by adding quotes:
|
||||||
```just
|
```just
|
||||||
|
@ -905,7 +905,7 @@ search QUERY:
|
||||||
lynx 'https://www.google.com/?q={{QUERY}}'
|
lynx 'https://www.google.com/?q={{QUERY}}'
|
||||||
```
|
```
|
||||||
|
|
||||||
Parameters prefixed with a `$` will be exported as [environment variables](../../linux/Environment%20Variables.md):
|
Parameters prefixed with a `$` will be exported as [environment variables](../../linux/Environment%20Variables.md):
|
||||||
```just
|
```just
|
||||||
foo $bar:
|
foo $bar:
|
||||||
echo $bar
|
echo $bar
|
||||||
|
@ -914,7 +914,7 @@ foo $bar:
|
||||||
### Running Recipes at the End of a Recipe
|
### Running Recipes at the End of a Recipe
|
||||||
Normal dependencies of a recipes always run before a recipe starts. That is to say, the dependee always runs before the depender. These dependencies are called "prior dependencies".
|
Normal dependencies of a recipes always run before a recipe starts. That is to say, the dependee always runs before the depender. These dependencies are called "prior dependencies".
|
||||||
|
|
||||||
A recipe can also have subsequent dependencies, which run after the recipe and are introduced with an `&&`:
|
A recipe can also have subsequent dependencies, which run after the recipe and are introduced with an `&&`:
|
||||||
```just
|
```just
|
||||||
a:
|
a:
|
||||||
echo 'A!'
|
echo 'A!'
|
||||||
|
@ -929,7 +929,7 @@ d:
|
||||||
echo 'D!'
|
echo 'D!'
|
||||||
```
|
```
|
||||||
|
|
||||||
…running _b_ prints:
|
…running _b_ prints:
|
||||||
```shell
|
```shell
|
||||||
$ just b
|
$ just b
|
||||||
echo 'A!'
|
echo 'A!'
|
||||||
|
@ -943,7 +943,7 @@ D!
|
||||||
```
|
```
|
||||||
|
|
||||||
### Running Recipes in the Middle of a Recipe
|
### Running Recipes in the Middle of a Recipe
|
||||||
`just` doesn't support running recipes in the middle of another recipe, but you can call `just` recursively in the middle of a recipe. Given the following `justfile`:
|
`just` doesn't support running recipes in the middle of another recipe, but you can call `just` recursively in the middle of a recipe. Given the following `justfile`:
|
||||||
```just
|
```just
|
||||||
a:
|
a:
|
||||||
echo 'A!'
|
echo 'A!'
|
||||||
|
@ -957,7 +957,7 @@ c:
|
||||||
echo 'C!'
|
echo 'C!'
|
||||||
```
|
```
|
||||||
|
|
||||||
…running _b_ prints:
|
…running _b_ prints:
|
||||||
```shell
|
```shell
|
||||||
$ just b
|
$ just b
|
||||||
echo 'A!'
|
echo 'A!'
|
||||||
|
@ -970,10 +970,10 @@ echo 'B end!'
|
||||||
B end!
|
B end!
|
||||||
```
|
```
|
||||||
|
|
||||||
This has limitations, since recipe `c` is run with an entirely new invocation of `just`: Assignments will be recalculated, dependencies might run twice, and command line arguments will not be propagated to the child `just` process.
|
This has limitations, since recipe `c` is run with an entirely new invocation of `just`: Assignments will be recalculated, dependencies might run twice, and command line arguments will not be propagated to the child `just` process.
|
||||||
|
|
||||||
### Writing Recipes in Other Languages
|
### Writing Recipes in Other Languages
|
||||||
Recipes that start with `#!` are called shebang recipes, and are executed by saving the recipe body to a file and running it. This lets you write recipes in different languages:
|
Recipes that start with `#!` are called shebang recipes, and are executed by saving the recipe body to a file and running it. This lets you write recipes in different languages:
|
||||||
```just
|
```just
|
||||||
polyglot: python js perl sh ruby nu
|
polyglot: python js perl sh ruby nu
|
||||||
|
|
||||||
|
@ -1014,14 +1014,14 @@ Hola from a nushell script!
|
||||||
Hello from ruby!
|
Hello from ruby!
|
||||||
```
|
```
|
||||||
|
|
||||||
On Unix-like operating systems, including [Linux](../../linux/Linux.md) and [MacOS](../../macos/macOS.md), shebang recipes are executed by saving the recipe body to a file in a temporary directory, marking the file as executable, and executing it. The OS then parses the shebang line into a command line and invokes it, including the path to the file. For example, if a recipe starts with `#!/usr/bin/env bash`, the final command that the OS runs will be something like `/usr/bin/env bash /tmp/PATH_TO_SAVED_RECIPE_BODY`. Keep in mind that different operating systems split shebang lines differently.
|
On Unix-like operating systems, including [Linux](../../linux/Linux.md) and [MacOS](../../macos/macOS.md), shebang recipes are executed by saving the recipe body to a file in a temporary directory, marking the file as executable, and executing it. The OS then parses the shebang line into a command line and invokes it, including the path to the file. For example, if a recipe starts with `#!/usr/bin/env bash`, the final command that the OS runs will be something like `/usr/bin/env bash /tmp/PATH_TO_SAVED_RECIPE_BODY`. Keep in mind that different operating systems split shebang lines differently.
|
||||||
|
|
||||||
[Windows](../../windows/Windows.md) does not support shebang lines. On [Windows](../../windows/Windows.md), `just` splits the shebang line into a command and arguments, saves the recipe body to a file, and invokes the split command and arguments, adding the path to the saved recipe body as the final argument.
|
[Windows](../../windows/Windows.md) does not support shebang lines. On [Windows](../../windows/Windows.md), `just` splits the shebang line into a command and arguments, saves the recipe body to a file, and invokes the split command and arguments, adding the path to the saved recipe body as the final argument.
|
||||||
|
|
||||||
### Multi-Line Constructs
|
### Multi-Line Constructs
|
||||||
Recipes without an initial shebang are evaluated and run line-by-line, which means that multi-line constructs probably won't do what you want.
|
Recipes without an initial shebang are evaluated and run line-by-line, which means that multi-line constructs probably won't do what you want.
|
||||||
|
|
||||||
For example, with the following `justfile`:
|
For example, with the following `justfile`:
|
||||||
```makefile
|
```makefile
|
||||||
conditional:
|
conditional:
|
||||||
if true; then
|
if true; then
|
||||||
|
@ -1029,7 +1029,7 @@ conditional:
|
||||||
fi
|
fi
|
||||||
```
|
```
|
||||||
|
|
||||||
The extra leading whitespace before the second line of the `conditional` recipe will produce a parse error:
|
The extra leading whitespace before the second line of the `conditional` recipe will produce a parse error:
|
||||||
```shell
|
```shell
|
||||||
$ just conditional
|
$ just conditional
|
||||||
error: Recipe line has extra leading whitespace
|
error: Recipe line has extra leading whitespace
|
||||||
|
@ -1040,7 +1040,7 @@ error: Recipe line has extra leading whitespace
|
||||||
|
|
||||||
To work around this, you can write conditionals on one line, escape newlines with slashes, or add a shebang to your recipe. Some examples of multi-line constructs are provided for reference.
|
To work around this, you can write conditionals on one line, escape newlines with slashes, or add a shebang to your recipe. Some examples of multi-line constructs are provided for reference.
|
||||||
|
|
||||||
#### `if` statements
|
#### `if` statements
|
||||||
```just
|
```just
|
||||||
conditional:
|
conditional:
|
||||||
if true; then echo 'True!'; fi
|
if true; then echo 'True!'; fi
|
||||||
|
@ -1061,7 +1061,7 @@ conditional:
|
||||||
fi
|
fi
|
||||||
```
|
```
|
||||||
|
|
||||||
#### `for` loops
|
#### `for` loops
|
||||||
```just
|
```just
|
||||||
for:
|
for:
|
||||||
for file in `ls .`; do echo $file; done
|
for file in `ls .`; do echo $file; done
|
||||||
|
@ -1082,7 +1082,7 @@ for:
|
||||||
done
|
done
|
||||||
```
|
```
|
||||||
|
|
||||||
#### `while` loops
|
#### `while` loops
|
||||||
```just
|
```just
|
||||||
while:
|
while:
|
||||||
while `server-is-dead`; do ping -c 1 server; done
|
while `server-is-dead`; do ping -c 1 server; done
|
||||||
|
@ -1104,7 +1104,7 @@ while:
|
||||||
```
|
```
|
||||||
|
|
||||||
### Private Recipes
|
### Private Recipes
|
||||||
Recipes and aliases whose name starts with a `_` are omitted from `just --list`:
|
Recipes and aliases whose name starts with a `_` are omitted from `just --list`:
|
||||||
```just
|
```just
|
||||||
test: _test-helper
|
test: _test-helper
|
||||||
./bin/test
|
./bin/test
|
||||||
|
@ -1119,7 +1119,7 @@ Available recipes:
|
||||||
test
|
test
|
||||||
```
|
```
|
||||||
|
|
||||||
The `[private]` attribute may also be used to hide recipes or aliases without needing to change the name:
|
The `[private]` attribute may also be used to hide recipes or aliases without needing to change the name:
|
||||||
```just
|
```just
|
||||||
[private]
|
[private]
|
||||||
foo:
|
foo:
|
||||||
|
|
|
@ -5,7 +5,7 @@ repo: https://github.com/zyedidia/micro
|
||||||
website: https://micro-editor.github.io/
|
website: https://micro-editor.github.io/
|
||||||
---
|
---
|
||||||
# micro
|
# micro
|
||||||
**micro** is a terminal-based text editor that aims to be easy to use and intuitive, while also taking advantage of the capabilities of modern terminals. It comes as a single, batteries-included, static binary with no dependencies; you can download and use it right now!
|
**micro** is a terminal-based text editor that aims to be easy to use and intuitive, while also taking advantage of the capabilities of modern terminals. It comes as a single, batteries-included, static binary with no dependencies; you can download and use it right now!
|
||||||
|
|
||||||
As its name indicates, micro aims to be somewhat of a successor to the nano editor by being easy to install and use. It strives to be enjoyable as a full-time editor for people who prefer to work in a terminal, or those who regularly edit files over [SSH](../network/SSH.md).
|
As its name indicates, micro aims to be somewhat of a successor to the nano editor by being easy to install and use. It strives to be enjoyable as a full-time editor for people who prefer to work in a terminal, or those who regularly edit files over [SSH](../network/SSH.md).
|
||||||
|
|
||||||
|
@ -283,30 +283,30 @@ MouseWheelRight
|
||||||
```
|
```
|
||||||
|
|
||||||
# Commands
|
# Commands
|
||||||
Micro provides the following commands that can be executed at the command-bar by pressing `Ctrl-e` and entering the command. Arguments are placed in single quotes here but these are not necessary when entering the command in micro.
|
Micro provides the following commands that can be executed at the command-bar by pressing `Ctrl-e` and entering the command. Arguments are placed in single quotes here but these are not necessary when entering the command in micro.
|
||||||
|
|
||||||
- `bind 'key' 'action'`: creates a keybinding from key to action. See the `keybindings` documentation for more information about binding keys. This command will modify `bindings.json` and overwrite any bindings to `key` that already exist.
|
- `bind 'key' 'action'`: creates a keybinding from key to action. See the `keybindings` documentation for more information about binding keys. This command will modify `bindings.json` and overwrite any bindings to `key` that already exist.
|
||||||
- `help 'topic'?`: opens the corresponding help topic. If no topic is provided opens the default help screen. Help topics are stored as `.md` files in the `runtime/help` directory of the source tree, which is embedded in the final binary.
|
- `help 'topic'?`: opens the corresponding help topic. If no topic is provided opens the default help screen. Help topics are stored as `.md` files in the `runtime/help` directory of the source tree, which is embedded in the final binary.
|
||||||
- `save 'filename'?`: saves the current buffer. If the file is provided it will 'save as' the filename.
|
- `save 'filename'?`: saves the current buffer. If the file is provided it will 'save as' the filename.
|
||||||
- `quit`: quits micro.
|
- `quit`: quits micro.
|
||||||
- `goto 'line'`: jumps to the given line number. A negative number can be passed to jump inward from the end of the file; for example, -5 jumps to the 5th-last line in the file.
|
- `goto 'line'`: jumps to the given line number. A negative number can be passed to jump inward from the end of the file; for example, -5 jumps to the 5th-last line in the file.
|
||||||
- `replace 'search' 'value' 'flags'?`: This will replace `search` with `value`. The `flags` are optional. Possible flags are:
|
- `replace 'search' 'value' 'flags'?`: This will replace `search` with `value`. The `flags` are optional. Possible flags are:
|
||||||
- `-a`: Replace all occurrences at once
|
- `-a`: Replace all occurrences at once
|
||||||
- `-l`: Do a literal search instead of a [regex](../../tools/Regex.md) search
|
- `-l`: Do a literal search instead of a [regex](../../tools/Regex.md) search
|
||||||
|
|
||||||
Note that `search` must be a valid [regex](../../tools/Regex.md) (unless `-l` is passed). If one of the arguments does not have any spaces in it, you may omit the quotes.
|
Note that `search` must be a valid [regex](../../tools/Regex.md) (unless `-l` is passed). If one of the arguments does not have any spaces in it, you may omit the quotes.
|
||||||
- `replaceall 'search' 'value'`: this will replace all occurrences of `search` with `value` without user confirmation.
|
- `replaceall 'search' 'value'`: this will replace all occurrences of `search` with `value` without user confirmation.
|
||||||
See `replace` command for more information.
|
See `replace` command for more information.
|
||||||
- `set 'option' 'value'`: sets the option to value. See the `options` help topic for a list of options you can set. This will modify your `settings.json` with the new value.
|
- `set 'option' 'value'`: sets the option to value. See the `options` help topic for a list of options you can set. This will modify your `settings.json` with the new value.
|
||||||
- `setlocal 'option' 'value'`: sets the option to value locally (only in the current buffer). This will _not_ modify `settings.json`.
|
- `setlocal 'option' 'value'`: sets the option to value locally (only in the current buffer). This will _not_ modify `settings.json`.
|
||||||
- `show 'option'`: shows the current value of the given option.
|
- `show 'option'`: shows the current value of the given option.
|
||||||
- `run 'sh-command'`: runs the given [shell](Shell.md) command in the background. The command's output will be displayed in one line when it finishes running.
|
- `run 'sh-command'`: runs the given [shell](Shell.md) command in the background. The command's output will be displayed in one line when it finishes running.
|
||||||
- `vsplit 'filename'`: opens a vertical split with `filename`. If no filename is provided, a vertical split is opened with an empty buffer.
|
- `vsplit 'filename'`: opens a vertical split with `filename`. If no filename is provided, a vertical split is opened with an empty buffer.
|
||||||
- `hsplit 'filename'`: same as `vsplit` but opens a horizontal split instead of a vertical split.
|
- `hsplit 'filename'`: same as `vsplit` but opens a horizontal split instead of a vertical split.
|
||||||
- `tab 'filename'`: opens the given file in a new tab.
|
- `tab 'filename'`: opens the given file in a new tab.
|
||||||
- `tabmove '[-+]?n'`: Moves the active tab to another slot. `n` is an integer. If `n` is prefixed with `-` or `+`, then it represents a relative position (e.g. `tabmove +2` moves the tab to the right by `2`). If `n` has no prefix, it represents an absolute position (e.g. `tabmove 2` moves the tab to slot `2`).
|
- `tabmove '[-+]?n'`: Moves the active tab to another slot. `n` is an integer. If `n` is prefixed with `-` or `+`, then it represents a relative position (e.g. `tabmove +2` moves the tab to the right by `2`). If `n` has no prefix, it represents an absolute position (e.g. `tabmove 2` moves the tab to slot `2`).
|
||||||
- `tabswitch 'tab'`: This command will switch to the specified tab. The `tab` can either be a tab number, or a name of a tab.
|
- `tabswitch 'tab'`: This command will switch to the specified tab. The `tab` can either be a tab number, or a name of a tab.
|
||||||
- `textfilter 'sh-command'`: filters the current selection through a [shell](Shell.md) command as standard input and replaces the selection with the stdout of the [shell](Shell.md) command. For example, to sort a list of numbers, first select them, and then execute `> textfilter sort -n`.
|
- `textfilter 'sh-command'`: filters the current selection through a [shell](Shell.md) command as standard input and replaces the selection with the stdout of the [shell](Shell.md) command. For example, to sort a list of numbers, first select them, and then execute `> textfilter sort -n`.
|
||||||
- `log`: opens a log of all messages and debug statements.
|
- `log`: opens a log of all messages and debug statements.
|
||||||
- `plugin list`: lists all installed plugins.
|
- `plugin list`: lists all installed plugins.
|
||||||
- `plugin install 'pl'`: install a plugin.
|
- `plugin install 'pl'`: install a plugin.
|
||||||
|
@ -315,13 +315,13 @@ Micro provides the following commands that can be executed at the command-bar by
|
||||||
- `plugin search 'pl'`: search available plugins for a keyword.
|
- `plugin search 'pl'`: search available plugins for a keyword.
|
||||||
- `plugin available`: show available plugins that can be installed.
|
- `plugin available`: show available plugins that can be installed.
|
||||||
- `reload`: reloads all runtime files.
|
- `reload`: reloads all runtime files.
|
||||||
- `cd 'path'`: Change the working directory to the given `path`.
|
- `cd 'path'`: Change the working directory to the given `path`.
|
||||||
- `pwd`: Print the current working directory.
|
- `pwd`: Print the current working directory.
|
||||||
- `open 'filename'`: Open a file in the current buffer.
|
- `open 'filename'`: Open a file in the current buffer.
|
||||||
- `reset 'option'`: resets the given option to its default value
|
- `reset 'option'`: resets the given option to its default value
|
||||||
- `retab`: Replaces all leading tabs with spaces or leading spaces with tabs depending on the value of `tabstospaces`.
|
- `retab`: Replaces all leading tabs with spaces or leading spaces with tabs depending on the value of `tabstospaces`.
|
||||||
- `raw`: micro will open a new tab and show the escape sequence for every event it receives from the terminal. This shows you what micro actually sees from the terminal and helps you see which bindings aren't possible and why. This is most useful for debugging keybindings.
|
- `raw`: micro will open a new tab and show the escape sequence for every event it receives from the terminal. This shows you what micro actually sees from the terminal and helps you see which bindings aren't possible and why. This is most useful for debugging keybindings.
|
||||||
- `showkey`: Show the action(s) bound to a given key. For example running `> showkey Ctrl-c` will display `Copy`.
|
- `showkey`: Show the action(s) bound to a given key. For example running `> showkey Ctrl-c` will display `Copy`.
|
||||||
- `term exec?`: Open a terminal emulator running the given executable. If no executable is given, this will open the default [shell](Shell.md) in the terminal emulator.
|
- `term exec?`: Open a terminal emulator running the given executable. If no executable is given, this will open the default [shell](Shell.md) in the terminal emulator.
|
||||||
|
|
||||||
## Settings
|
## Settings
|
||||||
|
|
|
@ -24,7 +24,7 @@ aria2c [<OPTIONS>] [<URI>|<MAGNET>|<TORRENT_FILE>|<METALINK_FILE>]
|
||||||
| `-V, --check-integrity [true/false]` | Check file integrity by validating piece hashes or a hash of entire file. This option has effect only in [BitTorrent](../../../internet/BitTorrent.md), Metalink downloads with checksums or [HTTP](../../../internet/HTTP.md)(S)/[FTP](../../../internet/FTP.md) downloads with --checksum option. If piece hashes are provided, this option can detect damaged portions of a file and re-download them. If a hash of entire file is provided, hash check is only done when file has been already download. This is determined by file length. If hash check fails, file is re-downloaded from scratch. If both piece hashes and a hash of entire file are provided, only piece hashes are used. Default: false |
|
| `-V, --check-integrity [true/false]` | Check file integrity by validating piece hashes or a hash of entire file. This option has effect only in [BitTorrent](../../../internet/BitTorrent.md), Metalink downloads with checksums or [HTTP](../../../internet/HTTP.md)(S)/[FTP](../../../internet/FTP.md) downloads with --checksum option. If piece hashes are provided, this option can detect damaged portions of a file and re-download them. If a hash of entire file is provided, hash check is only done when file has been already download. This is determined by file length. If hash check fails, file is re-downloaded from scratch. If both piece hashes and a hash of entire file are provided, only piece hashes are used. Default: false |
|
||||||
| `-c, --continue [true/false]` | Continue downloading a partially downloaded file. Use this option to resume a download started by a web browser or another program which downloads files sequentially from the beginning. Currently this option is only applicable to [HTTP](../../../internet/HTTP.md)(S)/[FTP](../../../internet/FTP.md) downloads. |
|
| `-c, --continue [true/false]` | Continue downloading a partially downloaded file. Use this option to resume a download started by a web browser or another program which downloads files sequentially from the beginning. Currently this option is only applicable to [HTTP](../../../internet/HTTP.md)(S)/[FTP](../../../internet/FTP.md) downloads. |
|
||||||
| `--checksum=<TYPE>=<DIGEST>` | Set checksum. TYPE is hash type. The supported hash type is listed in Hash Algorithms in aria2c -v. DIGEST is hex digest. For example, setting sha-1 digest looks like this: `sha-1=0192ba11326fe2298c8cb4de616f4d4140213838` This option applies only to [HTTP](../../../internet/HTTP.md)(S)/[FTP](../../../internet/FTP.md) downloads. |
|
| `--checksum=<TYPE>=<DIGEST>` | Set checksum. TYPE is hash type. The supported hash type is listed in Hash Algorithms in aria2c -v. DIGEST is hex digest. For example, setting sha-1 digest looks like this: `sha-1=0192ba11326fe2298c8cb4de616f4d4140213838` This option applies only to [HTTP](../../../internet/HTTP.md)(S)/[FTP](../../../internet/FTP.md) downloads. |
|
||||||
| `-x, --max-connection-per-server=<NUM>` | The maximum number of connections to one server for each download. Default: **1** |
|
| `-x, --max-connection-per-server=<NUM>` | The maximum number of connections to one server for each download. Default: **1** |
|
||||||
| `-k, --min-split-size=<SIZE>` | aria2 does not split less than 2\*SIZE byte range. For example, let's consider downloading 20MiB file. If SIZE is 10M, aria2 can split file into 2 range (0-10MiB) and (10MiB-20MiB) and download it using 2 sources(if --split >= 2, of course). If SIZE is 15M, since 2\*15M > 20MiB, aria2 does not split file and download it using 1 source. You can append K or M (1K = 1024, 1M = 1024K). Possible Values: 1M -1024M Default: 20M |
|
| `-k, --min-split-size=<SIZE>` | aria2 does not split less than 2\*SIZE byte range. For example, let's consider downloading 20MiB file. If SIZE is 10M, aria2 can split file into 2 range (0-10MiB) and (10MiB-20MiB) and download it using 2 sources(if --split >= 2, of course). If SIZE is 15M, since 2\*15M > 20MiB, aria2 does not split file and download it using 1 source. You can append K or M (1K = 1024, 1M = 1024K). Possible Values: 1M -1024M Default: 20M |
|
||||||
| `-o, --out=<FILE>` | The file name of the downloaded file. It is always relative to the directory given in `--dir` option. |
|
| `-o, --out=<FILE>` | The file name of the downloaded file. It is always relative to the directory given in `--dir` option. |
|
||||||
| `-s, --split=<N>` | Download a file using N connections. If more than N URIs are given, first N URIs are used and remaining URIs are used for backup. If less than N URIs are given, those URIs are used more than once so that N connections total are made simultaneously. The number of connections to the same host is restricted by the `--max-connection-per-server` option. See also the `--min-split-size` option. Default: 5 |
|
| `-s, --split=<N>` | Download a file using N connections. If more than N URIs are given, first N URIs are used and remaining URIs are used for backup. If less than N URIs are given, those URIs are used more than once so that N connections total are made simultaneously. The number of connections to the same host is restricted by the `--max-connection-per-server` option. See also the `--min-split-size` option. Default: 5 |
|
||||||
|
|
|
@ -4,7 +4,7 @@ wiki: https://en.wikipedia.org/wiki/Netcat
|
||||||
---
|
---
|
||||||
|
|
||||||
# netcat
|
# netcat
|
||||||
The `nc` (or `netcat`) utility is used for just about anything under the sun involving [TCP](../../../internet/TCP.md), [UDP](../../../internet/UDP.md), or UNIX-domain sockets. It can open [TCP](../../../internet/TCP.md) connections, send [UDP](../../../internet/UDP.md) packets, listen on arbitrary [TCP](../../../internet/TCP.md) and [UDP](../../../internet/UDP.md) ports, do port scanning, and deal with both IPv4 and IPv6.
|
The `nc` (or `netcat`) utility is used for just about anything under the sun involving [TCP](../../../internet/TCP.md), [UDP](../../../internet/UDP.md), or UNIX-domain sockets. It can open [TCP](../../../internet/TCP.md) connections, send [UDP](../../../internet/UDP.md) packets, listen on arbitrary [TCP](../../../internet/TCP.md) and [UDP](../../../internet/UDP.md) ports, do port scanning, and deal with both IPv4 and IPv6.
|
||||||
|
|
||||||
Common uses include:
|
Common uses include:
|
||||||
- simple [TCP](../../../internet/TCP.md) proxies
|
- simple [TCP](../../../internet/TCP.md) proxies
|
||||||
|
@ -19,32 +19,32 @@ Common uses include:
|
||||||
| `-6` | Use IPv6 addresses only |
|
| `-6` | Use IPv6 addresses only |
|
||||||
| `-b` | Allow broadcast |
|
| `-b` | Allow broadcast |
|
||||||
| `-l` | Listen for an incoming connection rather than initiating a connection to a remote host |
|
| `-l` | Listen for an incoming connection rather than initiating a connection to a remote host |
|
||||||
| `-N` | shutdown the network socket after EOF on the input. Some servers require this to finish their work |
|
| `-N` | shutdown the network socket after EOF on the input. Some servers require this to finish their work |
|
||||||
| `-p <source_port>` | Specify the source port `nc` should use, subject to privilege restrictions and availability |
|
| `-p <source_port>` | Specify the source port `nc` should use, subject to privilege restrictions and availability |
|
||||||
|
|
||||||
## Examples
|
## Examples
|
||||||
### Client/Server Model
|
### Client/Server Model
|
||||||
On one console, start `nc` listening on a specific port for a connection. For example:
|
On one console, start `nc` listening on a specific port for a connection. For example:
|
||||||
```shell
|
```shell
|
||||||
nc -l 1234
|
nc -l 1234
|
||||||
```
|
```
|
||||||
|
|
||||||
`nc` is now listening on port 1234 for a connection. On a second console (or a second machine), connect to the machine and port being listened on:
|
`nc` is now listening on port 1234 for a connection. On a second console (or a second machine), connect to the machine and port being listened on:
|
||||||
```shell
|
```shell
|
||||||
nc -N 127.0.0.1 1234
|
nc -N 127.0.0.1 1234
|
||||||
```
|
```
|
||||||
|
|
||||||
There should now be a connection between the ports. Anything typed at the second console will be concatenated to the first, and vice-versa. After the connection has been set up, `nc` does not really care which side is being used as a ‘server’ and which side is being used as a ‘client’. The connection may be terminated using an `EOF` (`^D`), as the `-N` flag was given.
|
There should now be a connection between the ports. Anything typed at the second console will be concatenated to the first, and vice-versa. After the connection has been set up, `nc` does not really care which side is being used as a ‘server’ and which side is being used as a ‘client’. The connection may be terminated using an `EOF` (`^D`), as the `-N` flag was given.
|
||||||
|
|
||||||
### Data Transfer
|
### Data Transfer
|
||||||
The example in the previous section can be expanded to build a basic data transfer model. Any information input into one end of the connection will be output to the other end, and input and output can be easily captured in order to emulate file transfer.
|
The example in the previous section can be expanded to build a basic data transfer model. Any information input into one end of the connection will be output to the other end, and input and output can be easily captured in order to emulate file transfer.
|
||||||
|
|
||||||
Start by using `nc` to listen on a specific port, with output captured into a file:
|
Start by using `nc` to listen on a specific port, with output captured into a file:
|
||||||
```shell
|
```shell
|
||||||
nc -l 1234 > filename.out
|
nc -l 1234 > filename.out
|
||||||
```
|
```
|
||||||
|
|
||||||
Using a second machine, connect to the listening `nc` process, feeding it the file which is to be transferred:
|
Using a second machine, connect to the listening `nc` process, feeding it the file which is to be transferred:
|
||||||
```shell
|
```shell
|
||||||
nc -N host.example.com 1234 < filename.in
|
nc -N host.example.com 1234 < filename.in
|
||||||
```
|
```
|
||||||
|
|
|
@ -17,7 +17,7 @@ Wget has been designed for robustness over slow or unstable network connections;
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| ----------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ----------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `-b, --background` | Go to background immediately after startup. If no output file is specified via the -o, output is redirected to wget-log. |
|
| `-b, --background` | Go to background immediately after startup. If no output file is specified via the -o, output is redirected to wget-log. |
|
||||||
| `-e, --execute command` | Execute command as if it were a part of .wgetrc. A command thus invoked will be executed after the commands in .wgetrc, thus taking precedence over them. If you need to specify more than one wgetrc command, use multiple instances of -e. |
|
| `-e, --execute command` | Execute command as if it were a part of .wgetrc. A command thus invoked will be executed after the commands in .wgetrc, thus taking precedence over them. If you need to specify more than one wgetrc command, use multiple instances of -e. |
|
||||||
|
|
||||||
### Logging Options
|
### Logging Options
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
|
@ -25,48 +25,48 @@ Wget has been designed for robustness over slow or unstable network connections;
|
||||||
| `-o, --output-file=logfile` | Log all messages to logfile. The messages are normally reported to standard error. |
|
| `-o, --output-file=logfile` | Log all messages to logfile. The messages are normally reported to standard error. |
|
||||||
| `-a, --append-output=logfile` | Append to logfile. This is the same as -o, only it appends to logfile instead of overwriting the old log file. |
|
| `-a, --append-output=logfile` | Append to logfile. This is the same as -o, only it appends to logfile instead of overwriting the old log file. |
|
||||||
| `-q, --quiet` | Turn off Wget's output. |
|
| `-q, --quiet` | Turn off Wget's output. |
|
||||||
| `-i, --input-file=file` | Read URLs from a local or external file. If - is specified as file, URLs are read from the standard input. (Use ./- to read from a file literally named -.). If this function is used, no URLs need be present on the command line. If there are URLs both on the command line and in an input file, those on the command lines will be the first ones to be retrieved. If --force-html is not specified, then file should consist of a series of URLs, one per line. However, if you specify --force-html, the document will be regarded as [html](../../../internet/HTML.md). In that case you may have problems with relative links, which you can solve either by adding "\<base href="url">" to the documents or by specifying --base=url on the command line. If the file is an external one, the document will be automatically treated as [html](../../../internet/HTML.md) if the Content-Type matches text/html. Furthermore, the file's location will be implicitly used as base href if none was specified. |
|
| `-i, --input-file=file` | Read URLs from a local or external file. If - is specified as file, URLs are read from the standard input. (Use ./- to read from a file literally named -.). If this function is used, no URLs need be present on the command line. If there are URLs both on the command line and in an input file, those on the command lines will be the first ones to be retrieved. If --force-html is not specified, then file should consist of a series of URLs, one per line. However, if you specify --force-html, the document will be regarded as [html](../../../internet/HTML.md). In that case you may have problems with relative links, which you can solve either by adding "\<base href="url">" to the documents or by specifying --base=url on the command line. If the file is an external one, the document will be automatically treated as [html](../../../internet/HTML.md) if the Content-Type matches text/html. Furthermore, the file's location will be implicitly used as base href if none was specified. |
|
||||||
| `-B, --base=URL` | Resolves relative links using URL as the point of reference, when reading links from an [HTML](../../../internet/HTML.md) file specified via the -i/--input-file option (together with --force-html, or when the input file was fetched remotely from a server describing it as [HTML](../../../internet/HTML.md)). This is equivalent to the presence of a "BASE" tag in the [HTML](../../../internet/HTML.md) input file, with URL as the value for the "href" attribute. |
|
| `-B, --base=URL` | Resolves relative links using URL as the point of reference, when reading links from an [HTML](../../../internet/HTML.md) file specified via the -i/--input-file option (together with --force-html, or when the input file was fetched remotely from a server describing it as [HTML](../../../internet/HTML.md)). This is equivalent to the presence of a "BASE" tag in the [HTML](../../../internet/HTML.md) input file, with URL as the value for the "href" attribute. |
|
||||||
|
|
||||||
### Download Options
|
### Download Options
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| ---------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ---------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `-t, --tries=number` | Set number of tries to number. Specify 0 or inf for infinite retrying. The default is to retry 20 times, with the exception of fatal errors like "connection refused" or "not found" (404), which are not retried. |
|
| `-t, --tries=number` | Set number of tries to number. Specify 0 or inf for infinite retrying. The default is to retry 20 times, with the exception of fatal errors like "connection refused" or "not found" (404), which are not retried. |
|
||||||
| `-O, --output-document=file` | The documents will not be written to the appropriate files, but all will be concatenated together and written to file. If - is used as file, documents will be printed to standard output, disabling link conversion. (Use ./- to print to a file literally named -.) |
|
| `-O, --output-document=file` | The documents will not be written to the appropriate files, but all will be concatenated together and written to file. If - is used as file, documents will be printed to standard output, disabling link conversion. (Use ./- to print to a file literally named -.) |
|
||||||
| `--backups=backups` | Before (over)writing a file, back up an existing file by adding a .1 suffix (\_1 on VMS) to the file name. Such backup files are rotated to .2, .3, and so on, up to `backups` (and lost beyond that) |
|
| `--backups=backups` | Before (over)writing a file, back up an existing file by adding a .1 suffix (\_1 on VMS) to the file name. Such backup files are rotated to .2, .3, and so on, up to `backups` (and lost beyond that) |
|
||||||
| `-c, --continue` | Continue getting a partially-downloaded file. This is useful when you want to finish up a download started by a previous instance of Wget, or by another program. |
|
| `-c, --continue` | Continue getting a partially-downloaded file. This is useful when you want to finish up a download started by a previous instance of Wget, or by another program. |
|
||||||
| `--show-progress` | Force wget to display the progress bar in any verbosity. |
|
| `--show-progress` | Force wget to display the progress bar in any verbosity. |
|
||||||
| `-T, --timeout=seconds` | Set the network timeout to `seconds` seconds. |
|
| `-T, --timeout=seconds` | Set the network timeout to `seconds` seconds. |
|
||||||
| `--limit-rate=amount` | Limit the download speed to amount bytes per second. Amount may be expressed in bytes, kilobytes with the k suffix, or megabytes with the m suffix. For example, --limit-rate=20k will limit the retrieval rate to 20KB/s. This is useful when, for whatever reason, you don't want Wget to consume the entire available bandwidth. |
|
| `--limit-rate=amount` | Limit the download speed to amount bytes per second. Amount may be expressed in bytes, kilobytes with the k suffix, or megabytes with the m suffix. For example, --limit-rate=20k will limit the retrieval rate to 20KB/s. This is useful when, for whatever reason, you don't want Wget to consume the entire available bandwidth. |
|
||||||
| `-w, --wait=seconds` | Wait the specified number of seconds between the retrievals. Use of this option is recommended, as it lightens the server load by making the requests less frequent. Instead of in seconds, the time can be specified in minutes using the "m" suffix, in hours using "h" suffix, or in days using "d" suffix. |
|
| `-w, --wait=seconds` | Wait the specified number of seconds between the retrievals. Use of this option is recommended, as it lightens the server load by making the requests less frequent. Instead of in seconds, the time can be specified in minutes using the "m" suffix, in hours using "h" suffix, or in days using "d" suffix. |
|
||||||
| `--waitretry=seconds` | If you don't want Wget to wait between every retrieval, but only between retries of failed downloads, you can use this option. Wget will use linear backoff, waiting 1 second after the first failure on a given file, then waiting 2 seconds after the second failure on that file, up to the maximum number of seconds you specify. |
|
| `--waitretry=seconds` | If you don't want Wget to wait between every retrieval, but only between retries of failed downloads, you can use this option. Wget will use linear backoff, waiting 1 second after the first failure on a given file, then waiting 2 seconds after the second failure on that file, up to the maximum number of seconds you specify. |
|
||||||
| `--random-wait` | Some web sites may perform log analysis to identify retrieval programs such as Wget by looking for statistically significant similarities in the time between requests. This option causes the time between requests to vary between 0.5 and 1.5 * wait seconds, where wait was specified using the --wait option, in order to mask Wget's presence from such analysis. |
|
| `--random-wait` | Some web sites may perform log analysis to identify retrieval programs such as Wget by looking for statistically significant similarities in the time between requests. This option causes the time between requests to vary between 0.5 and 1.5 * wait seconds, where wait was specified using the --wait option, in order to mask Wget's presence from such analysis. |
|
||||||
| `--user=user, --password=password` | Specify the username and password for both [FTP](../../../internet/FTP.md) and [HTTP](../../../internet/HTTP.md) file retrieval. |
|
| `--user=user, --password=password` | Specify the username and password for both [FTP](../../../internet/FTP.md) and [HTTP](../../../internet/HTTP.md) file retrieval. |
|
||||||
| `--ask-password` | Prompt for a password for each connection established. |
|
| `--ask-password` | Prompt for a password for each connection established. |
|
||||||
|
|
||||||
### Directory Options
|
### Directory Options
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| ------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `-nH, --no-host-directories` | Disable generation of host-prefixed directories. By default, invoking Wget with -r http://fly.srk.fer.hr/ will create a structure of directories beginning with fly.srk.fer.hr/. This option disables such behavior. |
|
| `-nH, --no-host-directories` | Disable generation of host-prefixed directories. By default, invoking Wget with -r http://fly.srk.fer.hr/ will create a structure of directories beginning with fly.srk.fer.hr/. This option disables such behavior. |
|
||||||
| `--cut-dirs=number` | Ignore number directory components. This is useful for getting a fine-grained control over the directory where recursive retrieval will be saved. |
|
| `--cut-dirs=number` | Ignore number directory components. This is useful for getting a fine-grained control over the directory where recursive retrieval will be saved. |
|
||||||
| `-P, --directory-prefix=prefix` | Set directory prefix to prefix. The directory prefix is the directory where all other files and subdirectories will be saved to, i.e. the top of the retrieval tree. The default is . (the current directory). |
|
| `-P, --directory-prefix=prefix` | Set directory prefix to prefix. The directory prefix is the directory where all other files and subdirectories will be saved to, i.e. the top of the retrieval tree. The default is . (the current directory). |
|
||||||
|
|
||||||
### HTTP Options
|
### HTTP Options
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| ---------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ---------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `--no-cookies` | Disable the use of cookies. |
|
| `--no-cookies` | Disable the use of cookies. |
|
||||||
| `--load-cookies file` | Load cookies from file before the first [HTTP](../../../internet/HTTP.md) retrieval. file is a textual file in the format originally used by Netscape's cookies.txt file. |
|
| `--load-cookies file` | Load cookies from file before the first [HTTP](../../../internet/HTTP.md) retrieval. file is a textual file in the format originally used by Netscape's cookies.txt file. |
|
||||||
| `--save-cookies file` | Save cookies to file before exiting. This will not save cookies that have expired or that have no expiry time (so-called "session cookies"), but also see --keep-session-cookies. |
|
| `--save-cookies file` | Save cookies to file before exiting. This will not save cookies that have expired or that have no expiry time (so-called "session cookies"), but also see --keep-session-cookies. |
|
||||||
| `--keep-session-cookies` | When specified, causes --save-cookies to also save session cookies. Session cookies are normally not saved because they are meant to be kept in memory and forgotten when you exit the browser. Saving them is useful on sites that require you to log in or to visit the home page before you can access some pages. With this option, multiple Wget runs are considered a single browser session as far as the site is concerned. |
|
| `--keep-session-cookies` | When specified, causes --save-cookies to also save session cookies. Session cookies are normally not saved because they are meant to be kept in memory and forgotten when you exit the browser. Saving them is useful on sites that require you to log in or to visit the home page before you can access some pages. With this option, multiple Wget runs are considered a single browser session as far as the site is concerned. |
|
||||||
| `--header=header-line` | Send header-line along with the rest of the headers in each [HTTP](../../../internet/HTTP.md) request. The supplied header is sent as-is, which means it must contain name and value separated by colon, and must not contain newlines. |
|
| `--header=header-line` | Send header-line along with the rest of the headers in each [HTTP](../../../internet/HTTP.md) request. The supplied header is sent as-is, which means it must contain name and value separated by colon, and must not contain newlines. |
|
||||||
| `--proxy-user=user, --proxy-password=password` | Specify the username user and password password for authentication on a proxy server. Wget will encode them using the "basic" authentication scheme. |
|
| `--proxy-user=user, --proxy-password=password` | Specify the username user and password password for authentication on a proxy server. Wget will encode them using the "basic" authentication scheme. |
|
||||||
| `--referer=url` | Include 'Referer: url' header in [HTTP](../../../internet/HTTP.md) request. Useful for retrieving documents with server-side processing that assume they are always being retrieved by interactive web browsers and only come out properly when Referer is set to one of the pages that point to them. |
|
| `--referer=url` | Include 'Referer: url' header in [HTTP](../../../internet/HTTP.md) request. Useful for retrieving documents with server-side processing that assume they are always being retrieved by interactive web browsers and only come out properly when Referer is set to one of the pages that point to them. |
|
||||||
| `-U, --user-agent=agent-string` | Identify as `agent-string` to the [HTTP](../../../internet/HTTP.md) server. |
|
| `-U, --user-agent=agent-string` | Identify as `agent-string` to the [HTTP](../../../internet/HTTP.md) server. |
|
||||||
|
|
||||||
### HTTPS Options
|
### HTTPS Options
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| -------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
| -------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
||||||
| `--no-check-certificate` | Don't check the server certificate against the available certificate authorities. Also don't require the URL host name to match the common name presented by the certificate. |
|
| `--no-check-certificate` | Don't check the server certificate against the available certificate authorities. Also don't require the URL host name to match the common name presented by the certificate. |
|
||||||
| `--ca-certificate=file` | Use file as the file with the bundle of certificate authorities ("CA") to verify the peers. The certificates must be in PEM format. |
|
| `--ca-certificate=file` | Use file as the file with the bundle of certificate authorities ("CA") to verify the peers. The certificates must be in PEM format. |
|
||||||
| `--ca-directory=directory` | Specifies directory containing CA certificates in PEM format. |
|
| `--ca-directory=directory` | Specifies directory containing CA certificates in PEM format. |
|
||||||
|
|
||||||
|
@ -75,5 +75,5 @@ Wget has been designed for robustness over slow or unstable network connections;
|
||||||
| ----------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
| ----------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
||||||
| `-r, --recursive` | Turn on recursive retrieving. The default maximum depth is 5. |
|
| `-r, --recursive` | Turn on recursive retrieving. The default maximum depth is 5. |
|
||||||
| `-l, --level=depth` | Set the maximum number of subdirectories that Wget will recurse into to depth. |
|
| `-l, --level=depth` | Set the maximum number of subdirectories that Wget will recurse into to depth. |
|
||||||
| `-k, --convert-links` | After the download is complete, convert the links in the document to make them suitable for local viewing. This affects not only the visible hyperlinks, but any part of the document that links to external content, such as embedded images, links to style sheets, hyperlinks to non-[HTML](../../../internet/HTML.md) content, etc. |
|
| `-k, --convert-links` | After the download is complete, convert the links in the document to make them suitable for local viewing. This affects not only the visible hyperlinks, but any part of the document that links to external content, such as embedded images, links to style sheets, hyperlinks to non-[HTML](../../../internet/HTML.md) content, etc. |
|
||||||
| `-p, --page-requisites` | This option causes Wget to download all the files that are necessary to properly display a given [HTML](../../../internet/HTML.md) page. This includes such things as inlined images, sounds, and referenced stylesheets. |
|
| `-p, --page-requisites` | This option causes Wget to download all the files that are necessary to properly display a given [HTML](../../../internet/HTML.md) page. This includes such things as inlined images, sounds, and referenced stylesheets. |
|
||||||
|
|
|
@ -21,7 +21,7 @@ patch -i <dir> <patch-file>
|
||||||
## Options
|
## Options
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| ------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `-b, --backup` | Make backup files. That is, when patching a file, rename or copy the original instead of removing it. When backing up a file that does not exist, an empty, unreadable backup file is created as a placeholder to represent the nonexistent file |
|
| `-b, --backup` | Make backup files. That is, when patching a file, rename or copy the original instead of removing it. When backing up a file that does not exist, an empty, unreadable backup file is created as a placeholder to represent the nonexistent file |
|
||||||
| `-d, --directory <dir>` | Change to the directory dir immediately, before doing anything else. |
|
| `-d, --directory <dir>` | Change to the directory dir immediately, before doing anything else. |
|
||||||
| `--dry-run` | Print the results of applying the patches without actually changing any files |
|
| `--dry-run` | Print the results of applying the patches without actually changing any files |
|
||||||
| `-i, --input <patchfile>` | Read the patch from patchfile. If patchfile is -, read from standard input, the default |
|
| `-i, --input <patchfile>` | Read the patch from patchfile. If patchfile is -, read from standard input, the default |
|
||||||
|
|
|
@ -5,30 +5,30 @@ repo: https://github.com/nukesor/pueue
|
||||||
# pueue
|
# pueue
|
||||||
Pueue is a command-line task management tool for sequential and parallel execution of long-running tasks.
|
Pueue is a command-line task management tool for sequential and parallel execution of long-running tasks.
|
||||||
|
|
||||||
Simply put, it's a tool that **p**rocesses a q**ueue** of [shell](Shell.md) commands. On top of that, there are a lot of convenient features and abstractions.
|
Simply put, it's a tool that **p**rocesses a q**ueue** of [shell](Shell.md) commands. On top of that, there are a lot of convenient features and abstractions.
|
||||||
|
|
||||||
Since Pueue is not bound to any terminal, you can control your tasks from any terminal on the same machine. The queue will be continuously processed, even if you no longer have any active [ssh](../network/SSH.md) sessions.
|
Since Pueue is not bound to any terminal, you can control your tasks from any terminal on the same machine. The queue will be continuously processed, even if you no longer have any active [ssh](../network/SSH.md) sessions.
|
||||||
|
|
||||||
## Start the Daemon
|
## Start the Daemon
|
||||||
Before you can use the `pueue` client, you have to start the daemon.
|
Before you can use the `pueue` client, you have to start the daemon.
|
||||||
|
|
||||||
**Local:** The daemon can be run in the current [shell](Shell.md). Just run `pueued` anywhere on your command line. It'll exit if you close the terminal, though.
|
**Local:** The daemon can be run in the current [shell](Shell.md). Just run `pueued` anywhere on your command line. It'll exit if you close the terminal, though.
|
||||||
|
|
||||||
**Background:** To fork and run `pueued` into the background, add the `-d` or `--daemonize` flag. E.g. `pueued -d`.
|
**Background:** To fork and run `pueued` into the background, add the `-d` or `--daemonize` flag. E.g. `pueued -d`.
|
||||||
The daemon can always be shut down using the client command `pueue shutdown`.
|
The daemon can always be shut down using the client command `pueue shutdown`.
|
||||||
|
|
||||||
### Systemd
|
### Systemd
|
||||||
[Systemd](../../linux/systemd/Systemd.md) user services allow every user to start/enable their own session on [Linux](../../linux/Linux.md) operating system distributions.
|
[Systemd](../../linux/systemd/Systemd.md) user services allow every user to start/enable their own session on [Linux](../../linux/Linux.md) operating system distributions.
|
||||||
|
|
||||||
If you didn't install Pueue with a package manager, follow these instructions first:
|
If you didn't install Pueue with a package manager, follow these instructions first:
|
||||||
1. download `pueued.service` from the GitHub Releases page;
|
1. download `pueued.service` from the GitHub Releases page;
|
||||||
2. place `pueued.service` in `/etc/systemd/user/` or `~/.config/systemd/user/`;
|
2. place `pueued.service` in `/etc/systemd/user/` or `~/.config/systemd/user/`;
|
||||||
3. make sure the `pueued` binary is placed at `/usr/bin`, which is where `pueued.service` expects is to be.
|
3. make sure the `pueued` binary is placed at `/usr/bin`, which is where `pueued.service` expects is to be.
|
||||||
|
|
||||||
Then, regardless of how you installed Pueue, run:
|
Then, regardless of how you installed Pueue, run:
|
||||||
1. `systemctl --user start pueued`, to start the `pueued` service;
|
1. `systemctl --user start pueued`, to start the `pueued` service;
|
||||||
2. `systemctl --user enable pueued`, to run the `pueued` service at system startup;
|
2. `systemctl --user enable pueued`, to run the `pueued` service at system startup;
|
||||||
3. `systemctl --user status pueued`, to ensure it is **active (running)**.
|
3. `systemctl --user status pueued`, to ensure it is **active (running)**.
|
||||||
|
|
||||||
## Using pueue
|
## Using pueue
|
||||||
Usage: `pueue <action> <options>`
|
Usage: `pueue <action> <options>`
|
||||||
|
|
|
@ -6,7 +6,7 @@ repo: https://github.com/BurntSushi/ripgrep
|
||||||
---
|
---
|
||||||
|
|
||||||
# ripgrep
|
# ripgrep
|
||||||
ripgrep is a line-oriented search tool that recursively searches the current directory for a [regex](../../tools/Regex.md) pattern. By default, ripgrep will respect gitignore rules and automatically skip hidden files/directories and binary files. ripgrep has first class support on Windows, [macOS](../../macos/macOS.md) and [Linux](../../linux/Linux.md) with binary downloads available for [every release](https://github.com/BurntSushi/ripgrep/releases). ripgrep is similar to other popular search tools like The Silver Searcher, ack and grep.
|
ripgrep is a line-oriented search tool that recursively searches the current directory for a [regex](../../tools/Regex.md) pattern. By default, ripgrep will respect gitignore rules and automatically skip hidden files/directories and binary files. ripgrep has first class support on Windows, [macOS](../../macos/macOS.md) and [Linux](../../linux/Linux.md) with binary downloads available for [every release](https://github.com/BurntSushi/ripgrep/releases). ripgrep is similar to other popular search tools like The Silver Searcher, ack and grep.
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
```shell
|
```shell
|
||||||
|
|
|
@ -5,16 +5,16 @@ repo: https://github.com/ismaelgv/rnr
|
||||||
---
|
---
|
||||||
# rnr
|
# rnr
|
||||||
[Repo](https://github.com/ismaelgv/rnr)
|
[Repo](https://github.com/ismaelgv/rnr)
|
||||||
**RnR** is a command-line tool to **securely rename** multiple files and directories that supports regular expressions.
|
**RnR** is a command-line tool to **securely rename** multiple files and directories that supports regular expressions.
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
Flags
|
Flags
|
||||||
```shell
|
```shell
|
||||||
-n, --dry-run Only show what would be done (default mode)
|
-n, --dry-run Only show what would be done (default mode)
|
||||||
-f, --force Make actual changes to files
|
-f, --force Make actual changes to files
|
||||||
-x, --hidden Include hidden files and directories
|
-x, --hidden Include hidden files and directories
|
||||||
-D, --include-dirs Rename matching directories
|
-D, --include-dirs Rename matching directories
|
||||||
-r, --recursive Recursive mode
|
-r, --recursive Recursive mode
|
||||||
-s, --silent Do not print any information
|
-s, --silent Do not print any information
|
||||||
--no-dump Do not dump operations into a file
|
--no-dump Do not dump operations into a file
|
||||||
```
|
```
|
|
@ -5,7 +5,7 @@ repo: https://github.com/chmln/sd
|
||||||
---
|
---
|
||||||
# sd
|
# sd
|
||||||
[Repo](https://github.com/chmln/sd)
|
[Repo](https://github.com/chmln/sd)
|
||||||
`sd` is an intuitive find & replace CLI.
|
`sd` is an intuitive find & replace CLI.
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
```shell
|
```shell
|
||||||
|
|
|
@ -8,7 +8,7 @@ source: https://www.kali.org/tools/smbmap
|
||||||
SMBMap allows users to enumerate [samba](../web/Samba.md) share drives across an entire domain. List share drives, drive permissions, share contents, upload/download functionality, file name auto-download pattern matching, and even execute remote commands. This tool was designed with pen testing in mind, and is intended to simplify searching for potentially sensitive data across large networks.
|
SMBMap allows users to enumerate [samba](../web/Samba.md) share drives across an entire domain. List share drives, drive permissions, share contents, upload/download functionality, file name auto-download pattern matching, and even execute remote commands. This tool was designed with pen testing in mind, and is intended to simplify searching for potentially sensitive data across large networks.
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
Usage: `smbmap [options]...`
|
Usage: `smbmap [options]...`
|
||||||
|
|
||||||
### Options
|
### Options
|
||||||
#### Main arguments
|
#### Main arguments
|
||||||
|
|
|
@ -238,7 +238,7 @@ Usage: `install [OPTION]... SOURCE... DIRECTORY`
|
||||||
| ---------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ---------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `-b` | make a backup of each existing destination file |
|
| `-b` | make a backup of each existing destination file |
|
||||||
| `-S, --suffix=SUFFIX` | override the usual backup suffix |
|
| `-S, --suffix=SUFFIX` | override the usual backup suffix |
|
||||||
| `-C, --compare` | compare content of source and destination files, and if no change to content, ownership, and permissions, do not modify the destination at all |
|
| `-C, --compare` | compare content of source and destination files, and if no change to content, ownership, and permissions, do not modify the destination at all |
|
||||||
| `-d, --directory` | treat all arguments as directory names; create all components of the specified directories |
|
| `-d, --directory` | treat all arguments as directory names; create all components of the specified directories |
|
||||||
| `-g, --group=GROUP` | set group ownership, instead of process' current group |
|
| `-g, --group=GROUP` | set group ownership, instead of process' current group |
|
||||||
| `-m, --mode=MODE` | set permission mode (as in chmod), instead of rwxr-xr-x |
|
| `-m, --mode=MODE` | set permission mode (as in chmod), instead of rwxr-xr-x |
|
||||||
|
|
|
@ -29,7 +29,7 @@ $ doas -s
|
||||||
The configuration for doas is stored at `/etc/doas.conf`.
|
The configuration for doas is stored at `/etc/doas.conf`.
|
||||||
|
|
||||||
The config file consist of rules with the following format:
|
The config file consist of rules with the following format:
|
||||||
`permit|deny [options] identity [as target] [cmd command [args ...]]`
|
`permit|deny [options] identity [as target] [cmd command [args ...]]`
|
||||||
|
|
||||||
Rules consist of the following parts:
|
Rules consist of the following parts:
|
||||||
- `permit|deny`: The action to be taken if this rule matches.
|
- `permit|deny`: The action to be taken if this rule matches.
|
||||||
|
@ -39,19 +39,19 @@ Options:
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| -------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| -------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `nopass` | The user is not required to enter a password. |
|
| `nopass` | The user is not required to enter a password. |
|
||||||
| `nolog` | Do not log successful command execution to syslogd |
|
| `nolog` | Do not log successful command execution to syslogd |
|
||||||
| `persist` | After the user successfully authenticates, do not ask for a password again for some time. |
|
| `persist` | After the user successfully authenticates, do not ask for a password again for some time. |
|
||||||
| `keepenv` | Environment variables other than those listed in doas are retained when creating the environment for the new process. |
|
| `keepenv` | Environment variables other than those listed in doas are retained when creating the environment for the new process. |
|
||||||
| `setenv {var=value}` | Keep or set the space-separated specified variables. Variables may also be removed with a leading ‘-’ or set using the latter syntax. If the first character of value is a ‘`$`’ then the value to be set is taken from the existing environment variable of the indicated name. This option is processed after the default environment has been created. |
|
| `setenv {var=value}` | Keep or set the space-separated specified variables. Variables may also be removed with a leading ‘-’ or set using the latter syntax. If the first character of value is a ‘`$`’ then the value to be set is taken from the existing environment variable of the indicated name. This option is processed after the default environment has been created. |
|
||||||
|
|
||||||
|
|
||||||
- `identity`: The username to match. Groups may be specified by prepending a colon (‘:’). Numeric IDs are also accepted.
|
- `identity`: The username to match. Groups may be specified by prepending a colon (‘:’). Numeric IDs are also accepted.
|
||||||
|
|
||||||
- `as`: The target user the running user is allowed to run the command as. The default is all users.
|
- `as`: The target user the running user is allowed to run the command as. The default is all users.
|
||||||
|
|
||||||
- `cmd`: The command the user is allowed or denied to run. The default is all commands. Be advised that it is best to specify absolute paths. If a relative path is specified, only a restricted `PATH` will be searched.
|
- `cmd`: The command the user is allowed or denied to run. The default is all commands. Be advised that it is best to specify absolute paths. If a relative path is specified, only a restricted `PATH` will be searched.
|
||||||
|
|
||||||
- `args`: Arguments to command. The command arguments provided by the user need to match those specified. The keyword `args` alone means that command must be run without any arguments.
|
- `args`: Arguments to command. The command arguments provided by the user need to match those specified. The keyword `args` alone means that command must be run without any arguments.
|
||||||
|
|
||||||
The last matching rule determines the action taken. If no rule matches, the action is denied.
|
The last matching rule determines the action taken. If no rule matches, the action is denied.
|
||||||
|
|
||||||
|
|
|
@ -10,4 +10,4 @@ repo: https://github.com/zsh-users/zsh
|
||||||
Zsh is a powerful [shell](Shell.md) that operates as both an interactive [shell](Shell.md) and as a scripting language interpreter.
|
Zsh is a powerful [shell](Shell.md) that operates as both an interactive [shell](Shell.md) and as a scripting language interpreter.
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
`~/.zshrc`: Used for setting user's interactive [shell](Shell.md) configuration and executing commands, will be read when starting as an _**interactive shell**_.
|
`~/.zshrc`: Used for setting user's interactive [shell](Shell.md) configuration and executing commands, will be read when starting as an _**interactive shell**_.
|
|
@ -8,14 +8,14 @@ Highly customizable Wayland bar for Sway, [hyprland](../desktops/hyprland.md) an
|
||||||
![Screenshot][Screenshot]
|
![Screenshot][Screenshot]
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
The configuration uses the [JSON](../../files/JSON.md) file format and is named `config`.
|
The configuration uses the [JSON](../../files/JSON.md) file format and is named `config`.
|
||||||
|
|
||||||
Valid directories for this file are:
|
Valid directories for this file are:
|
||||||
- `~/.config/waybar/`
|
- `~/.config/waybar/`
|
||||||
- `~/waybar/`
|
- `~/waybar/`
|
||||||
- `/etc/xdg/waybar/`
|
- `/etc/xdg/waybar/`
|
||||||
|
|
||||||
A good starting point is the [default config](https://github.com/Alexays/Waybar/blob/master/resources/config).
|
A good starting point is the [default config](https://github.com/Alexays/Waybar/blob/master/resources/config).
|
||||||
|
|
||||||
### Bar Config
|
### Bar Config
|
||||||
|
|
||||||
|
@ -23,7 +23,7 @@ A good starting point is the [default config](https://github.com/Alexays/Waybar
|
||||||
| ----------------------------------- | ------- | -------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ----------------------------------- | ------- | -------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `layer` | string | `bottom` | Decide if the bar is displayed in front (`top`) of the windows or behind (`bottom`) them. |
|
| `layer` | string | `bottom` | Decide if the bar is displayed in front (`top`) of the windows or behind (`bottom`) them. |
|
||||||
| `output` | string | array | |
|
| `output` | string | array | |
|
||||||
| `position` | string | `top` | Bar position, can be `top`,`bottom`,`left`,`right`. |
|
| `position` | string | `top` | Bar position, can be `top`,`bottom`,`left`,`right`. |
|
||||||
| `height` | integer | | Height to be used by the bar if possible, leave blank for a dynamic value. |
|
| `height` | integer | | Height to be used by the bar if possible, leave blank for a dynamic value. |
|
||||||
| `width` | integer | | Width to be used by the bar if possible, leave blank for a dynamic value. |
|
| `width` | integer | | Width to be used by the bar if possible, leave blank for a dynamic value. |
|
||||||
| `modules-left` | array | | Modules that will be displayed on the left. |
|
| `modules-left` | array | | Modules that will be displayed on the left. |
|
||||||
|
@ -33,25 +33,25 @@ A good starting point is the [default config](https://github.com/Alexays/Waybar
|
||||||
| `margin-<top\|left\|bottom\|right>` | integer | | Margins value without units. |
|
| `margin-<top\|left\|bottom\|right>` | integer | | Margins value without units. |
|
||||||
| `spacing` | integer | `4` | Size of gaps in between of the different modules. |
|
| `spacing` | integer | `4` | Size of gaps in between of the different modules. |
|
||||||
| `name` | string | | Optional name added as a CSS class, for styling multiple waybars. |
|
| `name` | string | | Optional name added as a CSS class, for styling multiple waybars. |
|
||||||
| `mode` | string | | Selects one of the preconfigured display modes. This is an equivalent of the [`sway-bar(5)`](https://github.com/swaywm/sway/blob/master/sway/sway-bar.5.scd) `mode` command and supports the same values: `dock`, `hide`, `invisible`, `overlay`. <br>Note: `hide` and `invisible` modes may be not as useful without Sway IPC. |
|
| `mode` | string | | Selects one of the preconfigured display modes. This is an equivalent of the [`sway-bar(5)`](https://github.com/swaywm/sway/blob/master/sway/sway-bar.5.scd) `mode` command and supports the same values: `dock`, `hide`, `invisible`, `overlay`. <br>Note: `hide` and `invisible` modes may be not as useful without Sway IPC. |
|
||||||
| `start_hidden` | bool | `false` | Option to start the bar hidden. |
|
| `start_hidden` | bool | `false` | Option to start the bar hidden. |
|
||||||
| `modifier-reset` | string | `press` | Defines the timing of modifier key to reset the bar visibility. To reset the visibility of the bar with the press of the modifier key use `press`. Use `release` to reset the visibility upon the release of the modifier key and only if no other action happened while the key was pressed. This prevents hiding the bar when the modifier is used to switch a workspace, change binding mode or start a keybinding. |
|
| `modifier-reset` | string | `press` | Defines the timing of modifier key to reset the bar visibility. To reset the visibility of the bar with the press of the modifier key use `press`. Use `release` to reset the visibility upon the release of the modifier key and only if no other action happened while the key was pressed. This prevents hiding the bar when the modifier is used to switch a workspace, change binding mode or start a keybinding. |
|
||||||
| `exclusive` | bool | `true` | Option to request an exclusive zone from the compositor. Disable this to allow drawing application windows underneath or on top of the bar. <br>Disabled by default for `overlay` layer. |
|
| `exclusive` | bool | `true` | Option to request an exclusive zone from the compositor. Disable this to allow drawing application windows underneath or on top of the bar. <br>Disabled by default for `overlay` layer. |
|
||||||
| `fixed-center` | bool | `true` | Prefer fixed center position for the `modules-center` block. The center block will stay in the middle of the bar whenever possible. It can still be pushed around if other blocks need more space. <br>When false, the center block is centered in the space between the left and right block. |
|
| `fixed-center` | bool | `true` | Prefer fixed center position for the `modules-center` block. The center block will stay in the middle of the bar whenever possible. It can still be pushed around if other blocks need more space. <br>When false, the center block is centered in the space between the left and right block. |
|
||||||
| `passthrough` | bool | `false` | Option to pass any pointer events to the window under the bar. <br>Intended to be used with either `top` or `overlay` layers and without exclusive zone. <br>Enabled by default for `overlay` layer. |
|
| `passthrough` | bool | `false` | Option to pass any pointer events to the window under the bar. <br>Intended to be used with either `top` or `overlay` layers and without exclusive zone. <br>Enabled by default for `overlay` layer. |
|
||||||
| `gtk-layer-shell` | bool | `true` | Option to disable the use of gtk-layer-shell for popups. Only functional if compiled with gtk-layer-shell support. |
|
| `gtk-layer-shell` | bool | `true` | Option to disable the use of gtk-layer-shell for popups. Only functional if compiled with gtk-layer-shell support. |
|
||||||
| `ipc` | bool | `false` | Option to subscribe to the Sway IPC bar configuration and visibility events and control waybar with `swaymsg bar` commands. <br>Requires `bar_id` value from sway configuration to be either passed with the `-b` commandline argument or specified with the `id` option. <br>See [#1244](https://github.com/Alexays/Waybar/pull/1244) for the documentation and configuration examples. |
|
| `ipc` | bool | `false` | Option to subscribe to the Sway IPC bar configuration and visibility events and control waybar with `swaymsg bar` commands. <br>Requires `bar_id` value from sway configuration to be either passed with the `-b` commandline argument or specified with the `id` option. <br>See [#1244](https://github.com/Alexays/Waybar/pull/1244) for the documentation and configuration examples. |
|
||||||
| `id` | string | | `bar_id` for the Sway IPC. Use this if you need to override the value passed with the `-b bar_id` commandline argument for the specific bar instance. |
|
| `id` | string | | `bar_id` for the Sway IPC. Use this if you need to override the value passed with the `-b bar_id` commandline argument for the specific bar instance. |
|
||||||
| `include` | array | | Paths to additional configuration files. <br>Each file can contain a single object with any of the bar configuration options. In case of duplicate options, the first defined value takes precedence, i.e. including file -> first included file -> etc. Nested includes are permitted, but make sure to avoid circular imports. <br>For a multi-bar config, the `include` directive affects only current bar configuration object. |
|
| `include` | array | | Paths to additional configuration files. <br>Each file can contain a single object with any of the bar configuration options. In case of duplicate options, the first defined value takes precedence, i.e. including file -> first included file -> etc. Nested includes are permitted, but make sure to avoid circular imports. <br>For a multi-bar config, the `include` directive affects only current bar configuration object. |
|
||||||
|
|
||||||
### Multiple instances of a module
|
### Multiple instances of a module
|
||||||
If you want to have a second instance of a module, you can suffix it by a '#' and a custom name.
|
If you want to have a second instance of a module, you can suffix it by a '#' and a custom name.
|
||||||
|
|
||||||
For example if you want a second battery module, you can add `"battery#bat2"` to your modules.
|
For example if you want a second battery module, you can add `"battery#bat2"` to your modules.
|
||||||
|
|
||||||
To configure the newly added module, you then also add a module configuration with the same name.
|
To configure the newly added module, you then also add a module configuration with the same name.
|
||||||
|
|
||||||
This could then look something like this _(this is an incomplete example)_:
|
This could then look something like this _(this is an incomplete example)_:
|
||||||
```js
|
```js
|
||||||
"modules-right": ["battery", "battery#bat2"],
|
"modules-right": ["battery", "battery#bat2"],
|
||||||
"battery": {
|
"battery": {
|
||||||
|
@ -62,7 +62,7 @@ This could then look something like this _(this is an incomplete example)_:
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
To style in `styles.css` use :
|
To style in `styles.css` use :
|
||||||
```css
|
```css
|
||||||
battery.bat2 {
|
battery.bat2 {
|
||||||
border-bottom: 2px solid #FFFFFF;
|
border-bottom: 2px solid #FFFFFF;
|
||||||
|
@ -70,14 +70,14 @@ battery.bat2 {
|
||||||
```
|
```
|
||||||
|
|
||||||
## Styling
|
## Styling
|
||||||
Styling is done using the CSS file format and with a file named `style.css`.
|
Styling is done using the CSS file format and with a file named `style.css`.
|
||||||
|
|
||||||
Valid directories for this file are:
|
Valid directories for this file are:
|
||||||
- `~/.config/waybar/`
|
- `~/.config/waybar/`
|
||||||
- `~/waybar/`
|
- `~/waybar/`
|
||||||
- `/etc/xdg/waybar/`
|
- `/etc/xdg/waybar/`
|
||||||
|
|
||||||
A good starting point is the [default style](https://github.com/Alexays/Waybar/blob/master/resources/style.css).
|
A good starting point is the [default style](https://github.com/Alexays/Waybar/blob/master/resources/style.css).
|
||||||
|
|
||||||
## Modules
|
## Modules
|
||||||
- [Battery](https://github.com/Alexays/Waybar/wiki/Module:-Battery)
|
- [Battery](https://github.com/Alexays/Waybar/wiki/Module:-Battery)
|
||||||
|
|
|
@ -11,6 +11,6 @@ repo: https://git.suckless.org/dwm/
|
||||||
dwm is a dynamic window manager for Xorg. It manages windows in tiled, stacked, and full-screen layouts, as well as many others with the help of optional patches. Layouts can be applied dynamically, optimizing the environment for the application in use and the task being performed. dwm is extremely lightweight and fast, written in C and with a stated design goal of remaining under 2000 source lines of code. dwm can be used with compositor ([picom](picom.md))
|
dwm is a dynamic window manager for Xorg. It manages windows in tiled, stacked, and full-screen layouts, as well as many others with the help of optional patches. Layouts can be applied dynamically, optimizing the environment for the application in use and the task being performed. dwm is extremely lightweight and fast, written in C and with a stated design goal of remaining under 2000 source lines of code. dwm can be used with compositor ([picom](picom.md))
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
dwm is configured at compile-time by editing some of its source files, specifically `config.h`. For detailed information on these settings see the included, well-commented `config.def.h` as well as the [customisation section](https://dwm.suckless.org/customisation/) on the dwm website.
|
dwm is configured at compile-time by editing some of its source files, specifically `config.h`. For detailed information on these settings see the included, well-commented `config.def.h` as well as the [customisation section](https://dwm.suckless.org/customisation/) on the dwm website.
|
||||||
|
|
||||||
The official website has a number of [patches](https://dwm.suckless.org/patches/) that can add extra functionality to dwm. These patches primarily make changes to the `dwm.c` file but also make changes to the `config.h` file where appropriate.
|
The official website has a number of [patches](https://dwm.suckless.org/patches/) that can add extra functionality to dwm. These patches primarily make changes to the `dwm.c` file but also make changes to the `config.h` file where appropriate.
|
File diff suppressed because one or more lines are too long
|
@ -6,11 +6,11 @@ os: linux
|
||||||
picom is a standalone compositor for Xorg, suitable for use with window managers that do not provide compositing. picom is a fork of compton, which is a fork of xcompmgr-dana, which in turn is a fork of xcompmgr.
|
picom is a standalone compositor for Xorg, suitable for use with window managers that do not provide compositing. picom is a fork of compton, which is a fork of xcompmgr-dana, which in turn is a fork of xcompmgr.
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
The default configuration is available in `/etc/xdg/picom.conf`. For modifications, it can be copied to `~/.config/picom/picom.conf` or `~/.config/picom.conf`.
|
The default configuration is available in `/etc/xdg/picom.conf`. For modifications, it can be copied to `~/.config/picom/picom.conf` or `~/.config/picom.conf`.
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
To manually enable default compositing effects during a session, use the following command:
|
To manually enable default compositing effects during a session, use the following command:
|
||||||
`picom &`
|
`picom &`
|
||||||
|
|
||||||
To autostart picom as a background process for a session, the `-b` argument can be used (may cause a display freeze):
|
To autostart picom as a background process for a session, the `-b` argument can be used (may cause a display freeze):
|
||||||
`picom -b`
|
`picom -b`
|
|
@ -5,7 +5,7 @@ website: https://sqlitebrowser.org
|
||||||
repo: https://github.com/sqlitebrowser/sqlitebrowser
|
repo: https://github.com/sqlitebrowser/sqlitebrowser
|
||||||
---
|
---
|
||||||
# DB Browser for SQLite
|
# DB Browser for SQLite
|
||||||
_DB Browser for SQLite_ (DB4S) is a high quality, visual, open source tool to create, design, and edit database files compatible with [SQLite](../../dev/programming/SQLite.md).
|
_DB Browser for SQLite_ (DB4S) is a high quality, visual, open source tool to create, design, and edit database files compatible with [SQLite](../../dev/programming/SQLite.md).
|
||||||
|
|
||||||
DB4S is for users and developers who want to create, search, and edit databases. DB4S uses a familiar spreadsheet-like interface, and complicated [SQL](../../dev/programming/languages/SQL.md) commands do not have to be learned.
|
DB4S is for users and developers who want to create, search, and edit databases. DB4S uses a familiar spreadsheet-like interface, and complicated [SQL](../../dev/programming/languages/SQL.md) commands do not have to be learned.
|
||||||
|
|
||||||
|
|
|
@ -19,9 +19,9 @@ http [flags] [METHOD] URL [ITEM [ITEM]]
|
||||||
```
|
```
|
||||||
|
|
||||||
### Querystring parameters
|
### Querystring parameters
|
||||||
If you find yourself manually constructing URLs with querystring parameters on the terminal, you may appreciate the `param==value` syntax for appending [URL](../../internet/URL.md) parameters.
|
If you find yourself manually constructing URLs with querystring parameters on the terminal, you may appreciate the `param==value` syntax for appending [URL](../../internet/URL.md) parameters.
|
||||||
|
|
||||||
With that, you don’t have to worry about escaping the `&` separators for your [shell](../cli/Shell.md). Additionally, any special characters in the parameter name or value get automatically [URL](../../internet/URL.md)-escaped (as opposed to the parameters specified in the full [URL](../../internet/URL.md), which HTTPie doesn’t modify).
|
With that, you don’t have to worry about escaping the `&` separators for your [shell](../cli/Shell.md). Additionally, any special characters in the parameter name or value get automatically [URL](../../internet/URL.md)-escaped (as opposed to the parameters specified in the full [URL](../../internet/URL.md), which HTTPie doesn’t modify).
|
||||||
```shell
|
```shell
|
||||||
$ http https://api.github.com/search/repositories q==httpie per_page==1
|
$ http https://api.github.com/search/repositories q==httpie per_page==1
|
||||||
```
|
```
|
||||||
|
@ -33,16 +33,16 @@ GET /search/repositories?q=httpie&per_page=1 HTTP/1.1
|
||||||
### Request Items
|
### Request Items
|
||||||
| Item Type | Description |
|
| Item Type | Description |
|
||||||
| ------------------------------------------------------------:| ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ------------------------------------------------------------:| ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| HTTP Headers `Name:Value` | Arbitrary [HTTP](../../internet/HTTP.md) header, e.g. `X-API-Token:123` |
|
| HTTP Headers `Name:Value` | Arbitrary [HTTP](../../internet/HTTP.md) header, e.g. `X-API-Token:123` |
|
||||||
| [URL](../../internet/URL.md) parameters `name==value` | Appends the given name/value pair as a querystring parameter to the [URL](../../internet/URL.md). The `==` separator is used. |
|
| [URL](../../internet/URL.md) parameters `name==value` | Appends the given name/value pair as a querystring parameter to the [URL](../../internet/URL.md). The `==` separator is used. |
|
||||||
| Data Fields `field=value` | Request data fields to be serialized as a [JSON](../../files/JSON.md) object (default), to be form-encoded (with `--form, -f`), or to be serialized as `multipart/form-data` (with `--multipart`) |
|
| Data Fields `field=value` | Request data fields to be serialized as a [JSON](../../files/JSON.md) object (default), to be form-encoded (with `--form, -f`), or to be serialized as `multipart/form-data` (with `--multipart`) |
|
||||||
| Raw JSON fields `field:=json` | Useful when sending [JSON](../../files/JSON.md) and one or more fields need to be a `Boolean`, `Number`, nested `Object`, or an `Array`, e.g., `meals:='["ham","spam"]'` or `pies:=[1,2,3]` (note the quotes) |
|
| Raw JSON fields `field:=json` | Useful when sending [JSON](../../files/JSON.md) and one or more fields need to be a `Boolean`, `Number`, nested `Object`, or an `Array`, e.g., `meals:='["ham","spam"]'` or `pies:=[1,2,3]` (note the quotes) |
|
||||||
| File upload fields `field@/dir/file`, `field@file;type=mime` | Only available with `--form`, `-f` and `--multipart`. For example `screenshot@~/Pictures/img.png`, or `'cv@cv.txt;type=text/markdown'`. With `--form`, the presence of a file field results in a `--multipart` request |
|
| File upload fields `field@/dir/file`, `field@file;type=mime` | Only available with `--form`, `-f` and `--multipart`. For example `screenshot@~/Pictures/img.png`, or `'cv@cv.txt;type=text/markdown'`. With `--form`, the presence of a file field results in a `--multipart` request |
|
||||||
|
|
||||||
### JSON Requests
|
### JSON Requests
|
||||||
Data is send as [JSON](../../files/JSON.md) by default.
|
Data is send as [JSON](../../files/JSON.md) by default.
|
||||||
|
|
||||||
Non-string [JSON](../../files/JSON.md) fields use the `:=` separator, which allows you to embed arbitrary [JSON](../../files/JSON.md) data into the resulting [JSON](../../files/JSON.md) object. Additionally, text and raw [JSON](../../files/JSON.md) files can also be embedded into fields using `=@` and `:=@`:
|
Non-string [JSON](../../files/JSON.md) fields use the `:=` separator, which allows you to embed arbitrary [JSON](../../files/JSON.md) data into the resulting [JSON](../../files/JSON.md) object. Additionally, text and raw [JSON](../../files/JSON.md) files can also be embedded into fields using `=@` and `:=@`:
|
||||||
```shell
|
```shell
|
||||||
$ http PUT pie.dev/put \
|
$ http PUT pie.dev/put \
|
||||||
name=John \ # String (default)
|
name=John \ # String (default)
|
||||||
|
@ -79,7 +79,7 @@ Host: pie.dev
|
||||||
```
|
```
|
||||||
|
|
||||||
### Forms
|
### Forms
|
||||||
Submitting forms is very similar to sending [JSON](../../files/JSON.md) requests. Often the only difference is in adding the `--form, -f` option, which ensures that data fields are serialized as, and `Content-Type` is set to `application/x-www-form-urlencoded; charset=utf-8`.
|
Submitting forms is very similar to sending [JSON](../../files/JSON.md) requests. Often the only difference is in adding the `--form, -f` option, which ensures that data fields are serialized as, and `Content-Type` is set to `application/x-www-form-urlencoded; charset=utf-8`.
|
||||||
|
|
||||||
#### Regular forms
|
#### Regular forms
|
||||||
```shell
|
```shell
|
||||||
|
@ -94,7 +94,7 @@ name=John+Smith
|
||||||
```
|
```
|
||||||
|
|
||||||
#### File upload forms
|
#### File upload forms
|
||||||
If one or more file fields is present, the serialization and content type is `multipart/form-data`:
|
If one or more file fields is present, the serialization and content type is `multipart/form-data`:
|
||||||
```shell
|
```shell
|
||||||
$ http -f POST pie.dev/post name='John Smith' cv@~/files/data.xml
|
$ http -f POST pie.dev/post name='John Smith' cv@~/files/data.xml
|
||||||
```
|
```
|
||||||
|
@ -107,7 +107,7 @@ The request above is the same as if the following [HTML](../../internet/HTML.md)
|
||||||
</form>
|
</form>
|
||||||
```
|
```
|
||||||
|
|
||||||
Please note that `@` is used to simulate a file upload form field, whereas `=@` just embeds the file content as a regular text field value.
|
Please note that `@` is used to simulate a file upload form field, whereas `=@` just embeds the file content as a regular text field value.
|
||||||
|
|
||||||
When uploading files, their content type is inferred from the file name. You can manually override the inferred content type:
|
When uploading files, their content type is inferred from the file name. You can manually override the inferred content type:
|
||||||
```shell
|
```shell
|
||||||
|
@ -115,7 +115,7 @@ $ http -f POST pie.dev/post name='John Smith' cv@'~/files/data.bin;type=applicat
|
||||||
```
|
```
|
||||||
|
|
||||||
### HTTP headers
|
### HTTP headers
|
||||||
To set custom headers you can use the `Header:Value` notation:
|
To set custom headers you can use the `Header:Value` notation:
|
||||||
```shell
|
```shell
|
||||||
$ http pie.dev/headers User-Agent:Bacon/1.0 'Cookie:valued-visitor=yes;foo=bar' \
|
$ http pie.dev/headers User-Agent:Bacon/1.0 'Cookie:valued-visitor=yes;foo=bar' \
|
||||||
X-Foo:Bar Referer:https://httpie.org/
|
X-Foo:Bar Referer:https://httpie.org/
|
||||||
|
@ -146,24 +146,24 @@ Host: <taken-from-URL>
|
||||||
All of these can be overwritten or unset.
|
All of these can be overwritten or unset.
|
||||||
|
|
||||||
#### Reading headers from a file
|
#### Reading headers from a file
|
||||||
You can read headers from a file by using the `:@` operator. This would also effectively strip the newlines from the end.
|
You can read headers from a file by using the `:@` operator. This would also effectively strip the newlines from the end.
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
$ http pie.dev/headers X-Data:@files/text.txt
|
$ http pie.dev/headers X-Data:@files/text.txt
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Empty headers and header un-setting
|
#### Empty headers and header un-setting
|
||||||
To unset a previously specified header (such a one of the default headers), use `Header:`:
|
To unset a previously specified header (such a one of the default headers), use `Header:`:
|
||||||
```shell
|
```shell
|
||||||
$ http pie.dev/headers Accept: User-Agent:
|
$ http pie.dev/headers Accept: User-Agent:
|
||||||
```
|
```
|
||||||
|
|
||||||
To send a header with an empty value, use `Header;`, with a semicolon:
|
To send a header with an empty value, use `Header;`, with a semicolon:
|
||||||
```shell
|
```shell
|
||||||
$ http pie.dev/headers 'Header;'
|
$ http pie.dev/headers 'Header;'
|
||||||
```
|
```
|
||||||
|
|
||||||
Please note that some internal headers, such as `Content-Length`, can’t be unset if they are automatically added by the client itself.
|
Please note that some internal headers, such as `Content-Length`, can’t be unset if they are automatically added by the client itself.
|
||||||
|
|
||||||
#### Multiple header values with the same name
|
#### Multiple header values with the same name
|
||||||
If the request is sent with multiple headers that are sharing the same name, then the HTTPie will send them individually.
|
If the request is sent with multiple headers that are sharing the same name, then the HTTPie will send them individually.
|
||||||
|
@ -190,7 +190,7 @@ Numbers: one,two
|
||||||
Also be aware that if the current session contains any headers they will get overwritten by individual commands when sending a request instead of being joined together.
|
Also be aware that if the current session contains any headers they will get overwritten by individual commands when sending a request instead of being joined together.
|
||||||
|
|
||||||
### Offline mode
|
### Offline mode
|
||||||
Use `--offline` to construct [HTTP](../../internet/HTTP.md) requests without sending them anywhere. With `--offline`, HTTPie builds a request based on the specified options and arguments, prints it to `stdout`, and then exits. It works completely offline; no network connection is ever made. This has a number of use cases, including:
|
Use `--offline` to construct [HTTP](../../internet/HTTP.md) requests without sending them anywhere. With `--offline`, HTTPie builds a request based on the specified options and arguments, prints it to `stdout`, and then exits. It works completely offline; no network connection is ever made. This has a number of use cases, including:
|
||||||
|
|
||||||
Generating API documentation examples that you can copy & paste without sending a request:
|
Generating API documentation examples that you can copy & paste without sending a request:
|
||||||
```shell
|
```shell
|
||||||
|
@ -210,10 +210,10 @@ $ http --offline POST pie.dev/post hello=world > request.http
|
||||||
$ nc pie.dev 80 < request.http
|
$ nc pie.dev 80 < request.http
|
||||||
```
|
```
|
||||||
|
|
||||||
You can also use the `--offline` mode for debugging and exploring [HTTP](../../internet/HTTP.md) and HTTPie, and for “dry runs”.
|
You can also use the `--offline` mode for debugging and exploring [HTTP](../../internet/HTTP.md) and HTTPie, and for “dry runs”.
|
||||||
|
|
||||||
### Cookies
|
### Cookies
|
||||||
[HTTP](../../internet/HTTP.md) clients send [cookies](../../internet/Cookie.md) to the server as regular [HTTP](../../internet/HTTP.md) headers. That means, HTTPie does not offer any special syntax for specifying cookies — the usual `Header:Value` notation is used:
|
[HTTP](../../internet/HTTP.md) clients send [cookies](../../internet/Cookie.md) to the server as regular [HTTP](../../internet/HTTP.md) headers. That means, HTTPie does not offer any special syntax for specifying cookies — the usual `Header:Value` notation is used:
|
||||||
|
|
||||||
Send a single [cookie](../../internet/Cookie.md):
|
Send a single [cookie](../../internet/Cookie.md):
|
||||||
```shell
|
```shell
|
||||||
|
@ -230,7 +230,7 @@ Host: pie.dev
|
||||||
User-Agent: HTTPie/0.9.9
|
User-Agent: HTTPie/0.9.9
|
||||||
```
|
```
|
||||||
|
|
||||||
Send multiple cookies (note: the header is quoted to prevent the [shell](../cli/Shell.md) from interpreting the `;`):
|
Send multiple cookies (note: the header is quoted to prevent the [shell](../cli/Shell.md) from interpreting the `;`):
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
$ http pie.dev/cookies 'Cookie:sessionid=foo;another-cookie=bar'
|
$ http pie.dev/cookies 'Cookie:sessionid=foo;another-cookie=bar'
|
||||||
|
@ -263,7 +263,7 @@ https -A bearer -a token pie.dev/bearer
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Password prompt
|
#### Password prompt
|
||||||
If you omit the password part of `--auth, -a`, HTTPie securely prompts you for it:
|
If you omit the password part of `--auth, -a`, HTTPie securely prompts you for it:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
$ http -a username pie.dev/basic-auth/username/password
|
$ http -a username pie.dev/basic-auth/username/password
|
||||||
|
@ -275,30 +275,30 @@ By default, [HTTP](../../internet/HTTP.md) redirects are not followed and only t
|
||||||
$ http pie.dev/redirect/3
|
$ http pie.dev/redirect/3
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Follow `Location`
|
#### Follow `Location`
|
||||||
To instruct HTTPie to follow the `Location` header of `30x` responses and show the final response instead, use the `--follow, -F` option:
|
To instruct HTTPie to follow the `Location` header of `30x` responses and show the final response instead, use the `--follow, -F` option:
|
||||||
```shell
|
```shell
|
||||||
$ http --follow pie.dev/redirect/3
|
$ http --follow pie.dev/redirect/3
|
||||||
```
|
```
|
||||||
|
|
||||||
With `307 Temporary Redirect` and `308 Permanent Redirect`, the method and the body of the original request are reused to perform the redirected request. Otherwise, a body-less `GET` request is performed.
|
With `307 Temporary Redirect` and `308 Permanent Redirect`, the method and the body of the original request are reused to perform the redirected request. Otherwise, a body-less `GET` request is performed.
|
||||||
|
|
||||||
#### Showing intermediary redirect responses
|
#### Showing intermediary redirect responses
|
||||||
If you wish to see the intermediary requests/responses, then use the `--all` option:
|
If you wish to see the intermediary requests/responses, then use the `--all` option:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
$ http --follow --all pie.dev/redirect/3
|
$ http --follow --all pie.dev/redirect/3
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Limiting maximum redirects followed
|
#### Limiting maximum redirects followed
|
||||||
To change the default limit of maximum `30` redirects, use the `--max-redirects=<limit>` option:
|
To change the default limit of maximum `30` redirects, use the `--max-redirects=<limit>` option:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
$ http --follow --all --max-redirects=2 pie.dev/redirect/3
|
$ http --follow --all --max-redirects=2 pie.dev/redirect/3
|
||||||
```
|
```
|
||||||
|
|
||||||
### Proxies
|
### Proxies
|
||||||
You can specify proxies to be used through the `--proxy` argument for each protocol (which is included in the value in case of redirects across protocols):
|
You can specify proxies to be used through the `--proxy` argument for each protocol (which is included in the value in case of redirects across protocols):
|
||||||
```shell
|
```shell
|
||||||
$ http --proxy=http:http://10.10.1.10:3128 --proxy=https:https://10.10.1.10:1080 example.org
|
$ http --proxy=http:http://10.10.1.10:3128 --proxy=https:https://10.10.1.10:1080 example.org
|
||||||
```
|
```
|
||||||
|
@ -309,9 +309,9 @@ $ http --proxy=http:http://user:pass@10.10.1.10:3128 example.org
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Environment variables
|
#### Environment variables
|
||||||
You can also configure proxies by [environment variables](../../linux/Environment%20Variables.md) `ALL_PROXY`, `HTTP_PROXY` and `HTTPS_PROXY`, and the underlying [Requests library](https://requests.readthedocs.io/en/latest/) will pick them up. If you want to disable proxies configured through the [environment variables](../../linux/Environment%20Variables.md) for certain hosts, you can specify them in `NO_PROXY`.
|
You can also configure proxies by [environment variables](../../linux/Environment%20Variables.md) `ALL_PROXY`, `HTTP_PROXY` and `HTTPS_PROXY`, and the underlying [Requests library](https://requests.readthedocs.io/en/latest/) will pick them up. If you want to disable proxies configured through the [environment variables](../../linux/Environment%20Variables.md) for certain hosts, you can specify them in `NO_PROXY`.
|
||||||
|
|
||||||
In your `~/.bash_profile`:
|
In your `~/.bash_profile`:
|
||||||
```shell
|
```shell
|
||||||
export HTTP_PROXY=http://10.10.1.10:3128
|
export HTTP_PROXY=http://10.10.1.10:3128
|
||||||
export HTTPS_PROXY=https://10.10.1.10:1080
|
export HTTPS_PROXY=https://10.10.1.10:1080
|
||||||
|
@ -319,13 +319,13 @@ export NO_PROXY=localhost,example.com
|
||||||
```
|
```
|
||||||
|
|
||||||
#### SOCK
|
#### SOCK
|
||||||
Usage for SOCKS is the same as for other types of proxies:
|
Usage for SOCKS is the same as for other types of proxies:
|
||||||
```shell
|
```shell
|
||||||
$ http --proxy=http:socks5://user:pass@host:port --proxy=https:socks5://user:pass@host:port example.org
|
$ http --proxy=http:socks5://user:pass@host:port --proxy=https:socks5://user:pass@host:port example.org
|
||||||
```
|
```
|
||||||
|
|
||||||
### HTTPS
|
### HTTPS
|
||||||
To skip the host’s SSL certificate verification, you can pass `--verify=no` (default is `yes`):
|
To skip the host’s SSL certificate verification, you can pass `--verify=no` (default is `yes`):
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
$ http --verify=no https://pie.dev/get
|
$ http --verify=no https://pie.dev/get
|
||||||
|
@ -338,16 +338,16 @@ By default, HTTPie only outputs the final response and the whole response messag
|
||||||
| --------------------------:| -------------------------------------------------------------------------------------------------- |
|
| --------------------------:| -------------------------------------------------------------------------------------------------- |
|
||||||
| `--headers, -h` | Only the response headers are printed |
|
| `--headers, -h` | Only the response headers are printed |
|
||||||
| `--body, -b` | Only the response body is printed |
|
| `--body, -b` | Only the response body is printed |
|
||||||
| `--meta, -m` | Only the response metadata is printed |
|
| `--meta, -m` | Only the response metadata is printed |
|
||||||
| `--verbose, -v` | Print the whole [HTTP](../../internet/HTTP.md) exchange (request and response). This option also enables `--all` (see below) |
|
| `--verbose, -v` | Print the whole [HTTP](../../internet/HTTP.md) exchange (request and response). This option also enables `--all` (see below) |
|
||||||
| `--verbose --verbose, -vv` | Just like `-v`, but also include the response metadata. |
|
| `--verbose --verbose, -vv` | Just like `-v`, but also include the response metadata. |
|
||||||
| `--print, -p` | Selects parts of the [HTTP](../../internet/HTTP.md) exchange |
|
| `--print, -p` | Selects parts of the [HTTP](../../internet/HTTP.md) exchange |
|
||||||
| `--quiet, -q` | Don’t print anything to `stdout` and `stderr` |
|
| `--quiet, -q` | Don’t print anything to `stdout` and `stderr` |
|
||||||
|
|
||||||
### Download mode
|
### Download mode
|
||||||
HTTPie features a download mode in which it acts similarly to [wget](../cli/network/wget.md).
|
HTTPie features a download mode in which it acts similarly to [wget](../cli/network/wget.md).
|
||||||
|
|
||||||
When enabled using the `--download, -d` flag, response headers are printed to the terminal (`stderr`), and a progress bar is shown while the response body is being saved to a file.
|
When enabled using the `--download, -d` flag, response headers are printed to the terminal (`stderr`), and a progress bar is shown while the response body is being saved to a file.
|
||||||
```shell
|
```shell
|
||||||
$ http --download https://github.com/httpie/cli/archive/master.tar.gz
|
$ http --download https://github.com/httpie/cli/archive/master.tar.gz
|
||||||
```
|
```
|
||||||
|
@ -365,11 +365,11 @@ Done. 251.30 kB in 2.73862s (91.76 kB/s)
|
||||||
#### Downloaded filename
|
#### Downloaded filename
|
||||||
There are three mutually exclusive ways through which HTTPie determines the output filename (with decreasing priority):
|
There are three mutually exclusive ways through which HTTPie determines the output filename (with decreasing priority):
|
||||||
|
|
||||||
1. You can explicitly provide it via `--output, -o`. The file gets overwritten if it already exists (or appended to with `--continue, -c`).
|
1. You can explicitly provide it via `--output, -o`. The file gets overwritten if it already exists (or appended to with `--continue, -c`).
|
||||||
2. The server may specify the filename in the optional `Content-Disposition` response header. Any leading dots are stripped from a server-provided filename.
|
2. The server may specify the filename in the optional `Content-Disposition` response header. Any leading dots are stripped from a server-provided filename.
|
||||||
3. The last resort HTTPie uses is to generate the filename from a combination of the request [URL](../../internet/URL.md) and the response `Content-Type`. The initial [URL](../../internet/URL.md) is always used as the basis for the generated filename — even if there has been one or more redirects.
|
3. The last resort HTTPie uses is to generate the filename from a combination of the request [URL](../../internet/URL.md) and the response `Content-Type`. The initial [URL](../../internet/URL.md) is always used as the basis for the generated filename — even if there has been one or more redirects.
|
||||||
|
|
||||||
To prevent data loss by overwriting, HTTPie adds a unique numerical suffix to the filename when necessary (unless specified with `--output, -o`).
|
To prevent data loss by overwriting, HTTPie adds a unique numerical suffix to the filename when necessary (unless specified with `--output, -o`).
|
||||||
|
|
||||||
#### Piping while downloading
|
#### Piping while downloading
|
||||||
You can also redirect the response body to another program while the response headers and progress are still shown in the terminal:
|
You can also redirect the response body to another program while the response headers and progress are still shown in the terminal:
|
||||||
|
@ -379,17 +379,17 @@ $ http -d https://github.com/httpie/cli/archive/master.tar.gz | tar zxf -
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Resuming downloads
|
#### Resuming downloads
|
||||||
If `--output, -o` is specified, you can resume a partial download using the `--continue, -c` option. This only works with servers that support `Range` requests and `206 Partial Content` responses. If the server doesn’t support that, the whole file will simply be downloaded:
|
If `--output, -o` is specified, you can resume a partial download using the `--continue, -c` option. This only works with servers that support `Range` requests and `206 Partial Content` responses. If the server doesn’t support that, the whole file will simply be downloaded:
|
||||||
```shell
|
```shell
|
||||||
$ http -dco file.zip example.org/file
|
$ http -dco file.zip example.org/file
|
||||||
```
|
```
|
||||||
|
|
||||||
`-dco` is shorthand for `--download` `--continue` `--output`.
|
`-dco` is shorthand for `--download` `--continue` `--output`.
|
||||||
|
|
||||||
### Sessions
|
### Sessions
|
||||||
By default, every request HTTPie makes is completely independent of any previous ones to the same host.
|
By default, every request HTTPie makes is completely independent of any previous ones to the same host.
|
||||||
|
|
||||||
However, HTTPie also supports persistent sessions via the `--session=SESSION_NAME_OR_PATH` option. In a session, custom [HTTP](../../internet/HTTP.md) headers (except for the ones starting with `Content-` or `If-`), authentication, and cookies (manually specified or sent by the server) persist between requests to the same host.
|
However, HTTPie also supports persistent sessions via the `--session=SESSION_NAME_OR_PATH` option. In a session, custom [HTTP](../../internet/HTTP.md) headers (except for the ones starting with `Content-` or `If-`), authentication, and cookies (manually specified or sent by the server) persist between requests to the same host.
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
# Create a new session:
|
# Create a new session:
|
||||||
|
@ -405,7 +405,7 @@ $ http --session=./session.json pie.dev/headers
|
||||||
All session data, including credentials, prompted passwords, [cookie](../../internet/Cookie.md) data, and custom headers are stored in plain text. That means session files can also be created and edited manually in a text editor—they are regular [JSON](../../files/JSON.md). It also means that they can be read by anyone who has access to the session file.
|
All session data, including credentials, prompted passwords, [cookie](../../internet/Cookie.md) data, and custom headers are stored in plain text. That means session files can also be created and edited manually in a text editor—they are regular [JSON](../../files/JSON.md). It also means that they can be read by anyone who has access to the session file.
|
||||||
|
|
||||||
#### Readonly session
|
#### Readonly session
|
||||||
To use the original session file without updating it from the request/response exchange after it has been created, specify the session name via `--session-read-only=SESSION_NAME_OR_PATH` instead.
|
To use the original session file without updating it from the request/response exchange after it has been created, specify the session name via `--session-read-only=SESSION_NAME_OR_PATH` instead.
|
||||||
```shell
|
```shell
|
||||||
# If the session file doesn’t exist, then it is created:
|
# If the session file doesn’t exist, then it is created:
|
||||||
$ http --session-read-only=./ro-session.json pie.dev/headers Custom-Header:orig-value
|
$ http --session-read-only=./ro-session.json pie.dev/headers Custom-Header:orig-value
|
||||||
|
|
|
@ -227,57 +227,57 @@ Usage: `cargo update [--dry-run]`
|
||||||
The `Cargo.toml` file for each package is called its manifest. It is written in the [TOML](../../files/TOML.md) format. It contains metadata that is needed to compile the package.
|
The `Cargo.toml` file for each package is called its manifest. It is written in the [TOML](../../files/TOML.md) format. It contains metadata that is needed to compile the package.
|
||||||
|
|
||||||
Every manifest file consists of the following sections:
|
Every manifest file consists of the following sections:
|
||||||
- [`cargo-features`](https://doc.rust-lang.org/cargo/reference/unstable.html) — Unstable, nightly-only features.
|
- [`cargo-features`](https://doc.rust-lang.org/cargo/reference/unstable.html) — Unstable, nightly-only features.
|
||||||
- [`[package]`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-package-section) — Defines a package.
|
- [`[package]`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-package-section) — Defines a package.
|
||||||
- [`name`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-name-field) — The name of the package.
|
- [`name`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-name-field) — The name of the package.
|
||||||
- [`version`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-version-field) — The version of the package.
|
- [`version`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-version-field) — The version of the package.
|
||||||
- [`authors`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-authors-field) — The authors of the package.
|
- [`authors`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-authors-field) — The authors of the package.
|
||||||
- [`edition`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-edition-field) — The [Rust](../../dev/programming/languages/Rust.md) edition.
|
- [`edition`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-edition-field) — The [Rust](../../dev/programming/languages/Rust.md) edition.
|
||||||
- [`rust-version`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-rust-version-field) — The minimal supported [Rust](../../dev/programming/languages/Rust.md) version.
|
- [`rust-version`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-rust-version-field) — The minimal supported [Rust](../../dev/programming/languages/Rust.md) version.
|
||||||
- [`description`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-description-field) — A description of the package.
|
- [`description`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-description-field) — A description of the package.
|
||||||
- [`documentation`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-documentation-field) — [URL](../../internet/URL.md) of the package documentation.
|
- [`documentation`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-documentation-field) — [URL](../../internet/URL.md) of the package documentation.
|
||||||
- [`readme`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-readme-field) — Path to the package’s README file.
|
- [`readme`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-readme-field) — Path to the package’s README file.
|
||||||
- [`homepage`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-homepage-field) — [URL](../../internet/URL.md) of the package homepage.
|
- [`homepage`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-homepage-field) — [URL](../../internet/URL.md) of the package homepage.
|
||||||
- [`repository`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-repository-field) — [URL](../../internet/URL.md) of the package source repository.
|
- [`repository`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-repository-field) — [URL](../../internet/URL.md) of the package source repository.
|
||||||
- [`license`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-license-and-license-file-fields) — The package license.
|
- [`license`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-license-and-license-file-fields) — The package license.
|
||||||
- [`license-file`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-license-and-license-file-fields) — Path to the text of the license.
|
- [`license-file`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-license-and-license-file-fields) — Path to the text of the license.
|
||||||
- [`keywords`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-keywords-field) — Keywords for the package.
|
- [`keywords`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-keywords-field) — Keywords for the package.
|
||||||
- [`categories`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-categories-field) — Categories of the package.
|
- [`categories`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-categories-field) — Categories of the package.
|
||||||
- [`workspace`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-workspace-field) — Path to the workspace for the package.
|
- [`workspace`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-workspace-field) — Path to the workspace for the package.
|
||||||
- [`build`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-build-field) — Path to the package build script.
|
- [`build`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-build-field) — Path to the package build script.
|
||||||
- [`links`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-links-field) — Name of the native library the package links with.
|
- [`links`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-links-field) — Name of the native library the package links with.
|
||||||
- [`exclude`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-exclude-and-include-fields) — Files to exclude when publishing.
|
- [`exclude`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-exclude-and-include-fields) — Files to exclude when publishing.
|
||||||
- [`include`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-exclude-and-include-fields) — Files to include when publishing.
|
- [`include`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-exclude-and-include-fields) — Files to include when publishing.
|
||||||
- [`publish`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-publish-field) — Can be used to prevent publishing the package.
|
- [`publish`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-publish-field) — Can be used to prevent publishing the package.
|
||||||
- [`metadata`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-metadata-table) — Extra settings for external tools.
|
- [`metadata`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-metadata-table) — Extra settings for external tools.
|
||||||
- [`default-run`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-default-run-field) — The default binary to run by [`cargo run`](https://doc.rust-lang.org/cargo/commands/cargo-run.html).
|
- [`default-run`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-default-run-field) — The default binary to run by [`cargo run`](https://doc.rust-lang.org/cargo/commands/cargo-run.html).
|
||||||
- [`autobins`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#target-auto-discovery) — Disables binary auto discovery.
|
- [`autobins`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#target-auto-discovery) — Disables binary auto discovery.
|
||||||
- [`autoexamples`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#target-auto-discovery) — Disables example auto discovery.
|
- [`autoexamples`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#target-auto-discovery) — Disables example auto discovery.
|
||||||
- [`autotests`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#target-auto-discovery) — Disables test auto discovery.
|
- [`autotests`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#target-auto-discovery) — Disables test auto discovery.
|
||||||
- [`autobenches`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#target-auto-discovery) — Disables bench auto discovery.
|
- [`autobenches`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#target-auto-discovery) — Disables bench auto discovery.
|
||||||
- [`resolver`](https://doc.rust-lang.org/cargo/reference/resolver.html#resolver-versions) — Sets the dependency resolver to use.
|
- [`resolver`](https://doc.rust-lang.org/cargo/reference/resolver.html#resolver-versions) — Sets the dependency resolver to use.
|
||||||
- Target tables: (see [configuration](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#configuring-a-target) for settings)
|
- Target tables: (see [configuration](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#configuring-a-target) for settings)
|
||||||
- [`[lib]`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#library) — Library target settings.
|
- [`[lib]`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#library) — Library target settings.
|
||||||
- [`[[bin]]`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#binaries) — Binary target settings.
|
- [`[[bin]]`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#binaries) — Binary target settings.
|
||||||
- [`[[example]]`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#examples) — Example target settings.
|
- [`[[example]]`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#examples) — Example target settings.
|
||||||
- [`[[test]]`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#tests) — Test target settings.
|
- [`[[test]]`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#tests) — Test target settings.
|
||||||
- [`[[bench]]`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#benchmarks) — Benchmark target settings.
|
- [`[[bench]]`](https://doc.rust-lang.org/cargo/reference/cargo-targets.html#benchmarks) — Benchmark target settings.
|
||||||
- Dependency tables:
|
- Dependency tables:
|
||||||
- [`[dependencies]`](https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html) — Package library dependencies.
|
- [`[dependencies]`](https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html) — Package library dependencies.
|
||||||
- [`[dev-dependencies]`](https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html#development-dependencies) — Dependencies for examples, tests, and benchmarks.
|
- [`[dev-dependencies]`](https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html#development-dependencies) — Dependencies for examples, tests, and benchmarks.
|
||||||
- [`[build-dependencies]`](https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html#build-dependencies) — Dependencies for build scripts.
|
- [`[build-dependencies]`](https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html#build-dependencies) — Dependencies for build scripts.
|
||||||
- [`[target]`](https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html#platform-specific-dependencies) — Platform-specific dependencies.
|
- [`[target]`](https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html#platform-specific-dependencies) — Platform-specific dependencies.
|
||||||
- [`[badges]`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-badges-section) — Badges to display on a registry.
|
- [`[badges]`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-badges-section) — Badges to display on a registry.
|
||||||
- [`[features]`](https://doc.rust-lang.org/cargo/reference/features.html) — Conditional compilation features.
|
- [`[features]`](https://doc.rust-lang.org/cargo/reference/features.html) — Conditional compilation features.
|
||||||
- [`[lints]`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-lints-section) — Configure linters for this package.
|
- [`[lints]`](https://doc.rust-lang.org/cargo/reference/manifest.html#the-lints-section) — Configure linters for this package.
|
||||||
- [`[patch]`](https://doc.rust-lang.org/cargo/reference/overriding-dependencies.html#the-patch-section) — Override dependencies.
|
- [`[patch]`](https://doc.rust-lang.org/cargo/reference/overriding-dependencies.html#the-patch-section) — Override dependencies.
|
||||||
- [`[profile]`](https://doc.rust-lang.org/cargo/reference/profiles.html) — Compiler settings and optimizations.
|
- [`[profile]`](https://doc.rust-lang.org/cargo/reference/profiles.html) — Compiler settings and optimizations.
|
||||||
- [`[workspace]`](https://doc.rust-lang.org/cargo/reference/workspaces.html) — The workspace definition.
|
- [`[workspace]`](https://doc.rust-lang.org/cargo/reference/workspaces.html) — The workspace definition.
|
||||||
|
|
||||||
## Build Scripts
|
## Build Scripts
|
||||||
Some packages need to compile third-party non-[Rust](../../dev/programming/languages/Rust.md) code, for example C libraries. Other packages need to link to C libraries which can either be located on the system or possibly need to be built from source. Others still need facilities for functionality such as code generation before building (think parser generators).
|
Some packages need to compile third-party non-[Rust](../../dev/programming/languages/Rust.md) code, for example C libraries. Other packages need to link to C libraries which can either be located on the system or possibly need to be built from source. Others still need facilities for functionality such as code generation before building (think parser generators).
|
||||||
|
|
||||||
Cargo does not aim to replace other tools that are well-optimized for these tasks, but it does integrate with them with custom build scripts. Placing a file named `build.rs` in the root of a package will cause Cargo to compile that script and execute it just before building the package.
|
Cargo does not aim to replace other tools that are well-optimized for these tasks, but it does integrate with them with custom build scripts. Placing a file named `build.rs` in the root of a package will cause Cargo to compile that script and execute it just before building the package.
|
||||||
|
|
||||||
```rust
|
```rust
|
||||||
// Example custom build script.
|
// Example custom build script.
|
||||||
|
@ -292,35 +292,35 @@ fn main() {
|
||||||
```
|
```
|
||||||
|
|
||||||
## Environment Variables
|
## Environment Variables
|
||||||
When the build script is run, there are a number of inputs to the build script, all passed in the form of [environment variables](../../linux/Environment%20Variables.md).
|
When the build script is run, there are a number of inputs to the build script, all passed in the form of [environment variables](../../linux/Environment%20Variables.md).
|
||||||
|
|
||||||
Cargo exposes these [environment variables](../../linux/Environment%20Variables.md) to your crate when it is compiled. Note that this applies for running binaries with `cargo run` and `cargo test` as well. To get the value of any of these variables in a [Rust](../../dev/programming/languages/Rust.md) program, do this:
|
Cargo exposes these [environment variables](../../linux/Environment%20Variables.md) to your crate when it is compiled. Note that this applies for running binaries with `cargo run` and `cargo test` as well. To get the value of any of these variables in a [Rust](../../dev/programming/languages/Rust.md) program, do this:
|
||||||
|
|
||||||
```rust
|
```rust
|
||||||
let version = env!("CARGO_PKG_VERSION");
|
let version = env!("CARGO_PKG_VERSION");
|
||||||
```
|
```
|
||||||
|
|
||||||
Exposed environment variables:
|
Exposed environment variables:
|
||||||
- `CARGO` — Path to the `cargo` binary performing the build.
|
- `CARGO` — Path to the `cargo` binary performing the build.
|
||||||
- `CARGO_MANIFEST_DIR` — The directory containing the manifest of your package.
|
- `CARGO_MANIFEST_DIR` — The directory containing the manifest of your package.
|
||||||
- `CARGO_PKG_VERSION` — The full version of your package.
|
- `CARGO_PKG_VERSION` — The full version of your package.
|
||||||
- `CARGO_PKG_VERSION_MAJOR` — The major version of your package.
|
- `CARGO_PKG_VERSION_MAJOR` — The major version of your package.
|
||||||
- `CARGO_PKG_VERSION_MINOR` — The minor version of your package.
|
- `CARGO_PKG_VERSION_MINOR` — The minor version of your package.
|
||||||
- `CARGO_PKG_VERSION_PATCH` — The patch version of your package.
|
- `CARGO_PKG_VERSION_PATCH` — The patch version of your package.
|
||||||
- `CARGO_PKG_VERSION_PRE` — The pre-release version of your package.
|
- `CARGO_PKG_VERSION_PRE` — The pre-release version of your package.
|
||||||
- `CARGO_PKG_AUTHORS` — Colon separated list of authors from the manifest of your package.
|
- `CARGO_PKG_AUTHORS` — Colon separated list of authors from the manifest of your package.
|
||||||
- `CARGO_PKG_NAME` — The name of your package.
|
- `CARGO_PKG_NAME` — The name of your package.
|
||||||
- `CARGO_PKG_DESCRIPTION` — The description from the manifest of your package.
|
- `CARGO_PKG_DESCRIPTION` — The description from the manifest of your package.
|
||||||
- `CARGO_PKG_HOMEPAGE` — The home page from the manifest of your package.
|
- `CARGO_PKG_HOMEPAGE` — The home page from the manifest of your package.
|
||||||
- `CARGO_PKG_REPOSITORY` — The repository from the manifest of your package.
|
- `CARGO_PKG_REPOSITORY` — The repository from the manifest of your package.
|
||||||
- `CARGO_PKG_LICENSE` — The license from the manifest of your package.
|
- `CARGO_PKG_LICENSE` — The license from the manifest of your package.
|
||||||
- `CARGO_PKG_LICENSE_FILE` — The license file from the manifest of your package.
|
- `CARGO_PKG_LICENSE_FILE` — The license file from the manifest of your package.
|
||||||
- `CARGO_PKG_RUST_VERSION` — The [Rust](../../dev/programming/languages/Rust.md) version from the manifest of your package. Note that this is the minimum [Rust](../../dev/programming/languages/Rust.md) version supported by the package, not the current [Rust](../../dev/programming/languages/Rust.md) version.
|
- `CARGO_PKG_RUST_VERSION` — The [Rust](../../dev/programming/languages/Rust.md) version from the manifest of your package. Note that this is the minimum [Rust](../../dev/programming/languages/Rust.md) version supported by the package, not the current [Rust](../../dev/programming/languages/Rust.md) version.
|
||||||
- `CARGO_PKG_README` — Path to the README file of your package.
|
- `CARGO_PKG_README` — Path to the README file of your package.
|
||||||
- `CARGO_CRATE_NAME` — The name of the crate that is currently being compiled. It is the name of the Cargo target with `-` converted to `_`, such as the name of the library, binary, example, integration test, or benchmark.
|
- `CARGO_CRATE_NAME` — The name of the crate that is currently being compiled. It is the name of the Cargo target with `-` converted to `_`, such as the name of the library, binary, example, integration test, or benchmark.
|
||||||
- `CARGO_BIN_NAME` — The name of the binary that is currently being compiled. Only set for binaries or binary examples. This name does not include any file extension, such as `.exe`.
|
- `CARGO_BIN_NAME` — The name of the binary that is currently being compiled. Only set for binaries or binary examples. This name does not include any file extension, such as `.exe`.
|
||||||
- `OUT_DIR` — If the package has a build script, this is set to the folder where the build script should place its output.
|
- `OUT_DIR` — If the package has a build script, this is set to the folder where the build script should place its output.
|
||||||
- `CARGO_BIN_EXE_<name>` — The absolute path to a binary target’s executable. This is only set when building an integration test or benchmark. This may be used with the `env` macro to find the executable to run for testing purposes. The `<name>` is the name of the binary target, exactly as-is. For example, `CARGO_BIN_EXE_my-program` for a binary named `my-program`. Binaries are automatically built when the test is built, unless the binary has required features that are not enabled.
|
- `CARGO_BIN_EXE_<name>` — The absolute path to a binary target’s executable. This is only set when building an integration test or benchmark. This may be used with the `env` macro to find the executable to run for testing purposes. The `<name>` is the name of the binary target, exactly as-is. For example, `CARGO_BIN_EXE_my-program` for a binary named `my-program`. Binaries are automatically built when the test is built, unless the binary has required features that are not enabled.
|
||||||
- `CARGO_PRIMARY_PACKAGE` — This environment variable will be set if the package being built is primary. Primary packages are the ones the user selected on the command-line, either with `-p` flags or the defaults based on the current directory and the default workspace members. This environment variable will not be set when building dependencies. This is only set when compiling the package (not when running binaries or tests).
|
- `CARGO_PRIMARY_PACKAGE` — This environment variable will be set if the package being built is primary. Primary packages are the ones the user selected on the command-line, either with `-p` flags or the defaults based on the current directory and the default workspace members. This environment variable will not be set when building dependencies. This is only set when compiling the package (not when running binaries or tests).
|
||||||
- `CARGO_TARGET_TMPDIR` — Only set when building integration test or benchmark code. This is a path to a directory inside the target directory where integration tests or benchmarks are free to put any data needed by the tests/benches. Cargo initially creates this directory but doesn’t manage its content in any way, this is the responsibility of the test code.
|
- `CARGO_TARGET_TMPDIR` — Only set when building integration test or benchmark code. This is a path to a directory inside the target directory where integration tests or benchmarks are free to put any data needed by the tests/benches. Cargo initially creates this directory but doesn’t manage its content in any way, this is the responsibility of the test code.
|
||||||
|
|
||||||
|
|
|
@ -28,7 +28,7 @@ The threshold value can be given as a percentage or as an absolute integer value
|
||||||
#### `-blend geometry`
|
#### `-blend geometry`
|
||||||
Blend an image into another by the given absolute value or percent.
|
Blend an image into another by the given absolute value or percent.
|
||||||
|
|
||||||
Blend will average the images together ('plus') according to the percentages given and each pixels transparency. If only a single percentage value is given it sets the weight of the composite or 'source' image, while the background image is weighted by the exact opposite amount. That is a `-blend 30%` merges 30% of the 'source' image with 70% of the 'destination' image. Thus it is equivalent to `-blend 30x70%`.
|
Blend will average the images together ('plus') according to the percentages given and each pixels transparency. If only a single percentage value is given it sets the weight of the composite or 'source' image, while the background image is weighted by the exact opposite amount. That is a `-blend 30%` merges 30% of the 'source' image with 70% of the 'destination' image. Thus it is equivalent to `-blend 30x70%`.
|
||||||
|
|
||||||
#### `-blur radius`
|
#### `-blur radius`
|
||||||
Convolve the image with a Gaussian or normal distribution using the given Sigma value.
|
Convolve the image with a Gaussian or normal distribution using the given Sigma value.
|
||||||
|
|
|
@ -479,10 +479,10 @@ Each line maps a key to an input command. Keys are specified with their literal
|
||||||
Syntax: `[Shift+][Ctrl+][Alt+][Meta+]<key> [{<section>}] <command> ( ; <command> )*`
|
Syntax: `[Shift+][Ctrl+][Alt+][Meta+]<key> [{<section>}] <command> ( ; <command> )*`
|
||||||
|
|
||||||
### List of Input Commands
|
### List of Input Commands
|
||||||
Commands with parameters have the parameter name enclosed in `< / >`. Don't add those to the actual command. Optional arguments are enclosed in `[ / ]`. If you don't pass them, they will be set to a default value.
|
Commands with parameters have the parameter name enclosed in `< / >`. Don't add those to the actual command. Optional arguments are enclosed in `[ / ]`. If you don't pass them, they will be set to a default value.
|
||||||
|
|
||||||
- `ignore`
|
- `ignore`
|
||||||
Use this to "block" keys that should be unbound, and do nothing. Useful for disabling default bindings, without disabling all bindings with `--no-input-default-bindings`.
|
Use this to "block" keys that should be unbound, and do nothing. Useful for disabling default bindings, without disabling all bindings with `--no-input-default-bindings`.
|
||||||
- `seek <target> [<flags>]`
|
- `seek <target> [<flags>]`
|
||||||
Change the playback position. By default, seeks by a relative amount of seconds.
|
Change the playback position. By default, seeks by a relative amount of seconds.
|
||||||
|
|
||||||
|
@ -502,62 +502,62 @@ Set the given property or option to the given value.
|
||||||
- `del <name>`
|
- `del <name>`
|
||||||
Delete the given property. Most properties cannot be deleted.
|
Delete the given property. Most properties cannot be deleted.
|
||||||
- `add <name> [<value>]`
|
- `add <name> [<value>]`
|
||||||
Add the given value to the property or option. On overflow or underflow, clamp the property to the maximum. If `<value>` is omitted, assume 1.
|
Add the given value to the property or option. On overflow or underflow, clamp the property to the maximum. If `<value>` is omitted, assume 1.
|
||||||
- `screenshot <flags>`
|
- `screenshot <flags>`
|
||||||
Take a screenshot.
|
Take a screenshot.
|
||||||
|
|
||||||
Multiple flags are available (some can be combined with +):
|
Multiple flags are available (some can be combined with +):
|
||||||
|
|
||||||
| Flag | Description |
|
| Flag | Description |
|
||||||
| ----------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ----------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `<subtitles> (default)` | Save the video image, in its original resolution, and with subtitles. Some video outputs may still include the OSD in the output under certain circumstances. |
|
| `<subtitles> (default)` | Save the video image, in its original resolution, and with subtitles. Some video outputs may still include the OSD in the output under certain circumstances. |
|
||||||
| `<video>` | Like subtitles, but typically without OSD or subtitles. The exact behavior depends on the selected video output. |
|
| `<video>` | Like subtitles, but typically without OSD or subtitles. The exact behavior depends on the selected video output. |
|
||||||
| `<window>` | Save the contents of the mpv window. Typically scaled, with OSD and subtitles. The exact behavior depends on the selected video output. |
|
| `<window>` | Save the contents of the mpv window. Typically scaled, with OSD and subtitles. The exact behavior depends on the selected video output. |
|
||||||
| `<each-frame>` | Take a screenshot each frame. Issue this command again to stop taking screenshots. Note that you should disable frame-dropping when using this mode - or you might receive duplicate images in cases when a frame was dropped. This flag can be combined with the other flags, e.g. video+each-frame. |
|
| `<each-frame>` | Take a screenshot each frame. Issue this command again to stop taking screenshots. Note that you should disable frame-dropping when using this mode - or you might receive duplicate images in cases when a frame was dropped. This flag can be combined with the other flags, e.g. video+each-frame. |
|
||||||
|
|
||||||
- `playlist-next`
|
- `playlist-next`
|
||||||
Go to the next entry on the playlist.
|
Go to the next entry on the playlist.
|
||||||
- `playlist-prev`
|
- `playlist-prev`
|
||||||
Go to the previous entry on the playlist.
|
Go to the previous entry on the playlist.
|
||||||
- `playlist-play-index <integer|current|none>`
|
- `playlist-play-index <integer|current|none>`
|
||||||
Start (or restart) playback of the given playlist index.
|
Start (or restart) playback of the given playlist index.
|
||||||
- `loadfile <url> [<flags> [<options>]]`
|
- `loadfile <url> [<flags> [<options>]]`
|
||||||
Load the given file or [URL](../../internet/URL.md) and play it. Technically, this is just a playlist manipulation command (which either replaces the playlist or appends an entry to it). Actual file loading happens independently. For example, a loadfile command that replaces the current file with a new one returns before the current file is stopped, and the new file even begins loading.
|
Load the given file or [URL](../../internet/URL.md) and play it. Technically, this is just a playlist manipulation command (which either replaces the playlist or appends an entry to it). Actual file loading happens independently. For example, a loadfile command that replaces the current file with a new one returns before the current file is stopped, and the new file even begins loading.
|
||||||
- `loadlist <url> [<flags>]`
|
- `loadlist <url> [<flags>]`
|
||||||
Load the given playlist file or [URL](../../internet/URL.md) (like `--playlist`).
|
Load the given playlist file or [URL](../../internet/URL.md) (like `--playlist`).
|
||||||
- `playlist-clear`
|
- `playlist-clear`
|
||||||
Clear the playlist, except the currently played file.
|
Clear the playlist, except the currently played file.
|
||||||
- `playlist-remove <index>`
|
- `playlist-remove <index>`
|
||||||
Remove the playlist entry at the given index. Index values start counting with 0. The special value current removes the current entry. Note that removing the current entry also stops playback and starts playing the next entry.
|
Remove the playlist entry at the given index. Index values start counting with 0. The special value current removes the current entry. Note that removing the current entry also stops playback and starts playing the next entry.
|
||||||
- `playlist-move <index1> <index2>`
|
- `playlist-move <index1> <index2>`
|
||||||
Move the playlist entry at index1, so that it takes the place of the entry index2. (Paradoxically, the moved playlist entry will not have the index value index2 after moving if index1 was lower than index2, because index2 refers to the target entry, not the index the entry will have after moving.)
|
Move the playlist entry at index1, so that it takes the place of the entry index2. (Paradoxically, the moved playlist entry will not have the index value index2 after moving if index1 was lower than index2, because index2 refers to the target entry, not the index the entry will have after moving.)
|
||||||
- `playlist-shuffle`
|
- `playlist-shuffle`
|
||||||
Shuffle the playlist. This is similar to what is done on start if the `--shuffle` option is used.
|
Shuffle the playlist. This is similar to what is done on start if the `--shuffle` option is used.
|
||||||
- `run <command> [<arg1> [<arg2> [...]]]`
|
- `run <command> [<arg1> [<arg2> [...]]]`
|
||||||
Run the given command. Unlike in MPlayer/mplayer2 and earlier versions of mpv (0.2.x and older), this doesn't call the [shell](../cli/Shell.md). Instead, the command is run directly, with each argument passed separately. Each argument is expanded like in Property Expansion.
|
Run the given command. Unlike in MPlayer/mplayer2 and earlier versions of mpv (0.2.x and older), this doesn't call the [shell](../cli/Shell.md). Instead, the command is run directly, with each argument passed separately. Each argument is expanded like in Property Expansion.
|
||||||
This command has a variable number of arguments, and cannot be used with named arguments.
|
This command has a variable number of arguments, and cannot be used with named arguments.
|
||||||
The program is run in a detached way. mpv doesn't wait until the command is completed, but continues playback right after spawning it.
|
The program is run in a detached way. mpv doesn't wait until the command is completed, but continues playback right after spawning it.
|
||||||
- `quit [<code>]`
|
- `quit [<code>]`
|
||||||
Exit the player. If an argument is given, it's used as process exit code.
|
Exit the player. If an argument is given, it's used as process exit code.
|
||||||
- `sub-add <url> [<flags> [<title> [<lang>]]]`
|
- `sub-add <url> [<flags> [<title> [<lang>]]]`
|
||||||
Load the given subtitle file or stream. By default, it is selected as current subtitle after loading.
|
Load the given subtitle file or stream. By default, it is selected as current subtitle after loading.
|
||||||
- `sub-remove [<id>]`
|
- `sub-remove [<id>]`
|
||||||
Remove the given subtitle track. If the id argument is missing, remove the current track. (Works on external subtitle files only.)
|
Remove the given subtitle track. If the id argument is missing, remove the current track. (Works on external subtitle files only.)
|
||||||
- `show-text <text> [<duration>|-1 [<level>]]`
|
- `show-text <text> [<duration>|-1 [<level>]]`
|
||||||
Show text on the OSD. The string can contain properties, which are expanded as described in Property Expansion. This can be used to show playback time, filename, and so on. no-osd has no effect on this command.
|
Show text on the OSD. The string can contain properties, which are expanded as described in Property Expansion. This can be used to show playback time, filename, and so on. no-osd has no effect on this command.
|
||||||
- `expand-text <string>`
|
- `expand-text <string>`
|
||||||
Property-expand the argument and return the expanded string. This can be used only through the client API or from a script using mp.command_native.
|
Property-expand the argument and return the expanded string. This can be used only through the client API or from a script using mp.command_native.
|
||||||
- `audio-add <url> [<flags> [<title> [<lang>]]]`
|
- `audio-add <url> [<flags> [<title> [<lang>]]]`
|
||||||
Load the given audio file.
|
Load the given audio file.
|
||||||
- `audio-remove [<id>]`
|
- `audio-remove [<id>]`
|
||||||
Remove the given audio track.
|
Remove the given audio track.
|
||||||
- `audio-reload [<id>]`
|
- `audio-reload [<id>]`
|
||||||
Reload the given audio tracks.
|
Reload the given audio tracks.
|
||||||
- `video-add <url> [<flags> [<title> [<lang> [<albumart>]]]]`
|
- `video-add <url> [<flags> [<title> [<lang> [<albumart>]]]]`
|
||||||
Load the given video file.
|
Load the given video file.
|
||||||
- `video-remove [<id>]`
|
- `video-remove [<id>]`
|
||||||
Remove the given video track.
|
Remove the given video track.
|
||||||
- `video-reload [<id>]`
|
- `video-reload [<id>]`
|
||||||
Reload the given video tracks.
|
Reload the given video tracks.
|
||||||
|
|
||||||
### List of Properties
|
### List of Properties
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -83,31 +83,31 @@ yt-dlp is a website media downloader. It can be used with [MPV](MPV.md).
|
||||||
|
|
||||||
## OUTPUT TEMPLATE
|
## OUTPUT TEMPLATE
|
||||||
|
|
||||||
The `-o` option is used to indicate a template for the output file names while `-P` option is used to specify the path each type of file should be saved to.
|
The `-o` option is used to indicate a template for the output file names while `-P` option is used to specify the path each type of file should be saved to.
|
||||||
|
|
||||||
**tl;dr:** [navigate me to examples](https://github.com/yt-dlp/yt-dlp#output-template-examples).
|
**tl;dr:** [navigate me to examples](https://github.com/yt-dlp/yt-dlp#output-template-examples).
|
||||||
|
|
||||||
The simplest usage of `-o` is not to set any template arguments when downloading a single file, like in `yt-dlp -o funny_video.flv "https://some/video"` (hard-coding file extension like this is _not_ recommended and could break some post-processing).
|
The simplest usage of `-o` is not to set any template arguments when downloading a single file, like in `yt-dlp -o funny_video.flv "https://some/video"` (hard-coding file extension like this is _not_ recommended and could break some post-processing).
|
||||||
|
|
||||||
It may however also contain special sequences that will be replaced when downloading each video. The special sequences may be formatted according to [Python string formatting operations](https://docs.python.org/3/library/stdtypes.html#printf-style-string-formatting), e.g. `%(NAME)s` or `%(NAME)05d`. To clarify, that is a percent symbol followed by a name in parentheses, followed by formatting operations.
|
It may however also contain special sequences that will be replaced when downloading each video. The special sequences may be formatted according to [Python string formatting operations](https://docs.python.org/3/library/stdtypes.html#printf-style-string-formatting), e.g. `%(NAME)s` or `%(NAME)05d`. To clarify, that is a percent symbol followed by a name in parentheses, followed by formatting operations.
|
||||||
|
|
||||||
The field names themselves (the part inside the parenthesis) can also have some special formatting:
|
The field names themselves (the part inside the parenthesis) can also have some special formatting:
|
||||||
|
|
||||||
1. **Object traversal**: The dictionaries and lists available in metadata can be traversed by using a dot `.` separator; e.g. `%(tags.0)s`, `%(subtitles.en.-1.ext)s`. You can do Python slicing with colon `:`; E.g. `%(id.3:7:-1)s`, `%(formats.:.format_id)s`. Curly braces `{}` can be used to build dictionaries with only specific keys; e.g. `%(formats.:.{format_id,height})#j`. An empty field name `%()s` refers to the entire infodict; e.g. `%(.{id,title})s`. Note that all the fields that become available using this method are not listed below. Use `-j` to see such fields
|
1. **Object traversal**: The dictionaries and lists available in metadata can be traversed by using a dot `.` separator; e.g. `%(tags.0)s`, `%(subtitles.en.-1.ext)s`. You can do Python slicing with colon `:`; E.g. `%(id.3:7:-1)s`, `%(formats.:.format_id)s`. Curly braces `{}` can be used to build dictionaries with only specific keys; e.g. `%(formats.:.{format_id,height})#j`. An empty field name `%()s` refers to the entire infodict; e.g. `%(.{id,title})s`. Note that all the fields that become available using this method are not listed below. Use `-j` to see such fields
|
||||||
|
|
||||||
2. **Addition**: Addition and subtraction of numeric fields can be done using `+` and `-` respectively. E.g. `%(playlist_index+10)03d`, `%(n_entries+1-playlist_index)d`
|
2. **Addition**: Addition and subtraction of numeric fields can be done using `+` and `-` respectively. E.g. `%(playlist_index+10)03d`, `%(n_entries+1-playlist_index)d`
|
||||||
|
|
||||||
3. **Date/time Formatting**: Date/time fields can be formatted according to [strftime formatting](https://docs.python.org/3/library/datetime.html#strftime-and-strptime-format-codes) by specifying it separated from the field name using a `>`. E.g. `%(duration>%H-%M-%S)s`, `%(upload_date>%Y-%m-%d)s`, `%(epoch-3600>%H-%M-%S)s`
|
3. **Date/time Formatting**: Date/time fields can be formatted according to [strftime formatting](https://docs.python.org/3/library/datetime.html#strftime-and-strptime-format-codes) by specifying it separated from the field name using a `>`. E.g. `%(duration>%H-%M-%S)s`, `%(upload_date>%Y-%m-%d)s`, `%(epoch-3600>%H-%M-%S)s`
|
||||||
|
|
||||||
4. **Alternatives**: Alternate fields can be specified separated with a `,`. E.g. `%(release_date>%Y,upload_date>%Y|Unknown)s`
|
4. **Alternatives**: Alternate fields can be specified separated with a `,`. E.g. `%(release_date>%Y,upload_date>%Y|Unknown)s`
|
||||||
|
|
||||||
5. **Replacement**: A replacement value can be specified using a `&` separator. If the field is _not_ empty, this replacement value will be used instead of the actual field content. This is done after alternate fields are considered; thus the replacement is used if _any_ of the alternative fields is _not_ empty.
|
5. **Replacement**: A replacement value can be specified using a `&` separator. If the field is _not_ empty, this replacement value will be used instead of the actual field content. This is done after alternate fields are considered; thus the replacement is used if _any_ of the alternative fields is _not_ empty.
|
||||||
|
|
||||||
6. **Default**: A literal default value can be specified for when the field is empty using a `|` separator. This overrides `--output-na-placeholder`. E.g. `%(uploader|Unknown)s`
|
6. **Default**: A literal default value can be specified for when the field is empty using a `|` separator. This overrides `--output-na-placeholder`. E.g. `%(uploader|Unknown)s`
|
||||||
|
|
||||||
7. **More Conversions**: In addition to the normal format types `diouxXeEfFgGcrs`, yt-dlp additionally supports converting to `B` = **B**ytes, `j` = **j**son (flag `#` for pretty-printing, `+` for Unicode), `h` = HTML escaping, `l` = a comma separated **l**ist (flag `#` for `\n` newline-separated), `q` = a string **q**uoted for the terminal (flag `#` to split a list into different arguments), `D` = add **D**ecimal suffixes (e.g. 10M) (flag `#` to use 1024 as factor), and `S` = **S**anitize as filename (flag `#` for restricted)
|
7. **More Conversions**: In addition to the normal format types `diouxXeEfFgGcrs`, yt-dlp additionally supports converting to `B` = **B**ytes, `j` = **j**son (flag `#` for pretty-printing, `+` for Unicode), `h` = HTML escaping, `l` = a comma separated **l**ist (flag `#` for `\n` newline-separated), `q` = a string **q**uoted for the terminal (flag `#` to split a list into different arguments), `D` = add **D**ecimal suffixes (e.g. 10M) (flag `#` to use 1024 as factor), and `S` = **S**anitize as filename (flag `#` for restricted)
|
||||||
|
|
||||||
8. **Unicode normalization**: The format type `U` can be used for NFC [Unicode normalization](https://docs.python.org/3/library/unicodedata.html#unicodedata.normalize). The alternate form flag (`#`) changes the normalization to NFD and the conversion flag `+` can be used for NFKC/NFKD compatibility equivalence normalization. E.g. `%(title)+.100U` is NFKC
|
8. **Unicode normalization**: The format type `U` can be used for NFC [Unicode normalization](https://docs.python.org/3/library/unicodedata.html#unicodedata.normalize). The alternate form flag (`#`) changes the normalization to NFD and the conversion flag `+` can be used for NFKC/NFKD compatibility equivalence normalization. E.g. `%(title)+.100U` is NFKC
|
||||||
|
|
||||||
|
|
||||||
To summarize, the general syntax for a field is:
|
To summarize, the general syntax for a field is:
|
||||||
|
@ -116,141 +116,141 @@ To summarize, the general syntax for a field is:
|
||||||
%(name[.keys][addition][>strf][,alternate][&replacement][|default])[flags][width][.precision][length]type
|
%(name[.keys][addition][>strf][,alternate][&replacement][|default])[flags][width][.precision][length]type
|
||||||
```
|
```
|
||||||
|
|
||||||
Additionally, you can set different output templates for the various metadata files separately from the general output template by specifying the type of file followed by the template separated by a colon `:`. The different file types supported are `subtitle`, `thumbnail`, `description`, `annotation` (deprecated), `infojson`, `link`, `pl_thumbnail`, `pl_description`, `pl_infojson`, `chapter`, `pl_video`. E.g. `-o "%(title)s.%(ext)s" -o "thumbnail:%(title)s\%(title)s.%(ext)s"` will put the thumbnails in a folder with the same name as the video. If any of the templates is empty, that type of file will not be written. E.g. `--write-thumbnail -o "thumbnail:"` will write thumbnails only for playlists and not for video.
|
Additionally, you can set different output templates for the various metadata files separately from the general output template by specifying the type of file followed by the template separated by a colon `:`. The different file types supported are `subtitle`, `thumbnail`, `description`, `annotation` (deprecated), `infojson`, `link`, `pl_thumbnail`, `pl_description`, `pl_infojson`, `chapter`, `pl_video`. E.g. `-o "%(title)s.%(ext)s" -o "thumbnail:%(title)s\%(title)s.%(ext)s"` will put the thumbnails in a folder with the same name as the video. If any of the templates is empty, that type of file will not be written. E.g. `--write-thumbnail -o "thumbnail:"` will write thumbnails only for playlists and not for video.
|
||||||
|
|
||||||
Note: Due to post-processing (i.e. merging etc.), the actual output filename might differ. Use `--print after_move:filepath` to get the name after all post-processing is complete.
|
Note: Due to post-processing (i.e. merging etc.), the actual output filename might differ. Use `--print after_move:filepath` to get the name after all post-processing is complete.
|
||||||
|
|
||||||
The available fields are:
|
The available fields are:
|
||||||
|
|
||||||
- `id` (string): Video identifier
|
- `id` (string): Video identifier
|
||||||
- `title` (string): Video title
|
- `title` (string): Video title
|
||||||
- `fulltitle` (string): Video title ignoring live timestamp and generic title
|
- `fulltitle` (string): Video title ignoring live timestamp and generic title
|
||||||
- `ext` (string): Video filename extension
|
- `ext` (string): Video filename extension
|
||||||
- `alt_title` (string): A secondary title of the video
|
- `alt_title` (string): A secondary title of the video
|
||||||
- `description` (string): The description of the video
|
- `description` (string): The description of the video
|
||||||
- `display_id` (string): An alternative identifier for the video
|
- `display_id` (string): An alternative identifier for the video
|
||||||
- `uploader` (string): Full name of the video uploader
|
- `uploader` (string): Full name of the video uploader
|
||||||
- `license` (string): License name the video is licensed under
|
- `license` (string): License name the video is licensed under
|
||||||
- `creator` (string): The creator of the video
|
- `creator` (string): The creator of the video
|
||||||
- `timestamp` (numeric): UNIX timestamp of the moment the video became available
|
- `timestamp` (numeric): UNIX timestamp of the moment the video became available
|
||||||
- `upload_date` (string): Video upload date in UTC (YYYYMMDD)
|
- `upload_date` (string): Video upload date in UTC (YYYYMMDD)
|
||||||
- `release_timestamp` (numeric): UNIX timestamp of the moment the video was released
|
- `release_timestamp` (numeric): UNIX timestamp of the moment the video was released
|
||||||
- `release_date` (string): The date (YYYYMMDD) when the video was released in UTC
|
- `release_date` (string): The date (YYYYMMDD) when the video was released in UTC
|
||||||
- `modified_timestamp` (numeric): UNIX timestamp of the moment the video was last modified
|
- `modified_timestamp` (numeric): UNIX timestamp of the moment the video was last modified
|
||||||
- `modified_date` (string): The date (YYYYMMDD) when the video was last modified in UTC
|
- `modified_date` (string): The date (YYYYMMDD) when the video was last modified in UTC
|
||||||
- `uploader_id` (string): Nickname or id of the video uploader
|
- `uploader_id` (string): Nickname or id of the video uploader
|
||||||
- `channel` (string): Full name of the channel the video is uploaded on
|
- `channel` (string): Full name of the channel the video is uploaded on
|
||||||
- `channel_id` (string): Id of the channel
|
- `channel_id` (string): Id of the channel
|
||||||
- `channel_follower_count` (numeric): Number of followers of the channel
|
- `channel_follower_count` (numeric): Number of followers of the channel
|
||||||
- `location` (string): Physical location where the video was filmed
|
- `location` (string): Physical location where the video was filmed
|
||||||
- `duration` (numeric): Length of the video in seconds
|
- `duration` (numeric): Length of the video in seconds
|
||||||
- `duration_string` (string): Length of the video (HH:mm:ss)
|
- `duration_string` (string): Length of the video (HH:mm:ss)
|
||||||
- `view_count` (numeric): How many users have watched the video on the platform
|
- `view_count` (numeric): How many users have watched the video on the platform
|
||||||
- `concurrent_view_count` (numeric): How many users are currently watching the video on the platform.
|
- `concurrent_view_count` (numeric): How many users are currently watching the video on the platform.
|
||||||
- `like_count` (numeric): Number of positive ratings of the video
|
- `like_count` (numeric): Number of positive ratings of the video
|
||||||
- `dislike_count` (numeric): Number of negative ratings of the video
|
- `dislike_count` (numeric): Number of negative ratings of the video
|
||||||
- `repost_count` (numeric): Number of reposts of the video
|
- `repost_count` (numeric): Number of reposts of the video
|
||||||
- `average_rating` (numeric): Average rating give by users, the scale used depends on the webpage
|
- `average_rating` (numeric): Average rating give by users, the scale used depends on the webpage
|
||||||
- `comment_count` (numeric): Number of comments on the video (For some extractors, comments are only downloaded at the end, and so this field cannot be used)
|
- `comment_count` (numeric): Number of comments on the video (For some extractors, comments are only downloaded at the end, and so this field cannot be used)
|
||||||
- `age_limit` (numeric): Age restriction for the video (years)
|
- `age_limit` (numeric): Age restriction for the video (years)
|
||||||
- `live_status` (string): One of "not_live", "is_live", "is_upcoming", "was_live", "post_live" (was live, but VOD is not yet processed)
|
- `live_status` (string): One of "not_live", "is_live", "is_upcoming", "was_live", "post_live" (was live, but VOD is not yet processed)
|
||||||
- `is_live` (boolean): Whether this video is a live stream or a fixed-length video
|
- `is_live` (boolean): Whether this video is a live stream or a fixed-length video
|
||||||
- `was_live` (boolean): Whether this video was originally a live stream
|
- `was_live` (boolean): Whether this video was originally a live stream
|
||||||
- `playable_in_embed` (string): Whether this video is allowed to play in embedded players on other sites
|
- `playable_in_embed` (string): Whether this video is allowed to play in embedded players on other sites
|
||||||
- `availability` (string): Whether the video is "private", "premium_only", "subscriber_only", "needs_auth", "unlisted" or "public"
|
- `availability` (string): Whether the video is "private", "premium_only", "subscriber_only", "needs_auth", "unlisted" or "public"
|
||||||
- `start_time` (numeric): Time in seconds where the reproduction should start, as specified in the URL
|
- `start_time` (numeric): Time in seconds where the reproduction should start, as specified in the URL
|
||||||
- `end_time` (numeric): Time in seconds where the reproduction should end, as specified in the URL
|
- `end_time` (numeric): Time in seconds where the reproduction should end, as specified in the URL
|
||||||
- `extractor` (string): Name of the extractor
|
- `extractor` (string): Name of the extractor
|
||||||
- `extractor_key` (string): Key name of the extractor
|
- `extractor_key` (string): Key name of the extractor
|
||||||
- `epoch` (numeric): Unix epoch of when the information extraction was completed
|
- `epoch` (numeric): Unix epoch of when the information extraction was completed
|
||||||
- `autonumber` (numeric): Number that will be increased with each download, starting at `--autonumber-start`
|
- `autonumber` (numeric): Number that will be increased with each download, starting at `--autonumber-start`
|
||||||
- `video_autonumber` (numeric): Number that will be increased with each video
|
- `video_autonumber` (numeric): Number that will be increased with each video
|
||||||
- `n_entries` (numeric): Total number of extracted items in the playlist
|
- `n_entries` (numeric): Total number of extracted items in the playlist
|
||||||
- `playlist_id` (string): Identifier of the playlist that contains the video
|
- `playlist_id` (string): Identifier of the playlist that contains the video
|
||||||
- `playlist_title` (string): Name of the playlist that contains the video
|
- `playlist_title` (string): Name of the playlist that contains the video
|
||||||
- `playlist` (string): `playlist_id` or `playlist_title`
|
- `playlist` (string): `playlist_id` or `playlist_title`
|
||||||
- `playlist_count` (numeric): Total number of items in the playlist. May not be known if entire playlist is not extracted
|
- `playlist_count` (numeric): Total number of items in the playlist. May not be known if entire playlist is not extracted
|
||||||
- `playlist_index` (numeric): Index of the video in the playlist padded with leading zeros according the final index
|
- `playlist_index` (numeric): Index of the video in the playlist padded with leading zeros according the final index
|
||||||
- `playlist_autonumber` (numeric): Position of the video in the playlist download queue padded with leading zeros according to the total length of the playlist
|
- `playlist_autonumber` (numeric): Position of the video in the playlist download queue padded with leading zeros according to the total length of the playlist
|
||||||
- `playlist_uploader` (string): Full name of the playlist uploader
|
- `playlist_uploader` (string): Full name of the playlist uploader
|
||||||
- `playlist_uploader_id` (string): Nickname or id of the playlist uploader
|
- `playlist_uploader_id` (string): Nickname or id of the playlist uploader
|
||||||
- `webpage_url` (string): A URL to the video webpage which if given to yt-dlp should allow to get the same result again
|
- `webpage_url` (string): A URL to the video webpage which if given to yt-dlp should allow to get the same result again
|
||||||
- `webpage_url_basename` (string): The basename of the webpage URL
|
- `webpage_url_basename` (string): The basename of the webpage URL
|
||||||
- `webpage_url_domain` (string): The domain of the webpage URL
|
- `webpage_url_domain` (string): The domain of the webpage URL
|
||||||
- `original_url` (string): The URL given by the user (or same as `webpage_url` for playlist entries)
|
- `original_url` (string): The URL given by the user (or same as `webpage_url` for playlist entries)
|
||||||
|
|
||||||
All the fields in [Filtering Formats](https://github.com/yt-dlp/yt-dlp#filtering-formats) can also be used
|
All the fields in [Filtering Formats](https://github.com/yt-dlp/yt-dlp#filtering-formats) can also be used
|
||||||
|
|
||||||
Available for the video that belongs to some logical chapter or section:
|
Available for the video that belongs to some logical chapter or section:
|
||||||
|
|
||||||
- `chapter` (string): Name or title of the chapter the video belongs to
|
- `chapter` (string): Name or title of the chapter the video belongs to
|
||||||
- `chapter_number` (numeric): Number of the chapter the video belongs to
|
- `chapter_number` (numeric): Number of the chapter the video belongs to
|
||||||
- `chapter_id` (string): Id of the chapter the video belongs to
|
- `chapter_id` (string): Id of the chapter the video belongs to
|
||||||
|
|
||||||
Available for the video that is an episode of some series or programme:
|
Available for the video that is an episode of some series or programme:
|
||||||
|
|
||||||
- `series` (string): Title of the series or programme the video episode belongs to
|
- `series` (string): Title of the series or programme the video episode belongs to
|
||||||
- `season` (string): Title of the season the video episode belongs to
|
- `season` (string): Title of the season the video episode belongs to
|
||||||
- `season_number` (numeric): Number of the season the video episode belongs to
|
- `season_number` (numeric): Number of the season the video episode belongs to
|
||||||
- `season_id` (string): Id of the season the video episode belongs to
|
- `season_id` (string): Id of the season the video episode belongs to
|
||||||
- `episode` (string): Title of the video episode
|
- `episode` (string): Title of the video episode
|
||||||
- `episode_number` (numeric): Number of the video episode within a season
|
- `episode_number` (numeric): Number of the video episode within a season
|
||||||
- `episode_id` (string): Id of the video episode
|
- `episode_id` (string): Id of the video episode
|
||||||
|
|
||||||
Available for the media that is a track or a part of a music album:
|
Available for the media that is a track or a part of a music album:
|
||||||
|
|
||||||
- `track` (string): Title of the track
|
- `track` (string): Title of the track
|
||||||
- `track_number` (numeric): Number of the track within an album or a disc
|
- `track_number` (numeric): Number of the track within an album or a disc
|
||||||
- `track_id` (string): Id of the track
|
- `track_id` (string): Id of the track
|
||||||
- `artist` (string): Artist(s) of the track
|
- `artist` (string): Artist(s) of the track
|
||||||
- `genre` (string): Genre(s) of the track
|
- `genre` (string): Genre(s) of the track
|
||||||
- `album` (string): Title of the album the track belongs to
|
- `album` (string): Title of the album the track belongs to
|
||||||
- `album_type` (string): Type of the album
|
- `album_type` (string): Type of the album
|
||||||
- `album_artist` (string): List of all artists appeared on the album
|
- `album_artist` (string): List of all artists appeared on the album
|
||||||
- `disc_number` (numeric): Number of the disc or other physical medium the track belongs to
|
- `disc_number` (numeric): Number of the disc or other physical medium the track belongs to
|
||||||
- `release_year` (numeric): Year (YYYY) when the album was released
|
- `release_year` (numeric): Year (YYYY) when the album was released
|
||||||
|
|
||||||
Available only when using `--download-sections` and for `chapter:` prefix when using `--split-chapters` for videos with internal chapters:
|
Available only when using `--download-sections` and for `chapter:` prefix when using `--split-chapters` for videos with internal chapters:
|
||||||
|
|
||||||
- `section_title` (string): Title of the chapter
|
- `section_title` (string): Title of the chapter
|
||||||
- `section_number` (numeric): Number of the chapter within the file
|
- `section_number` (numeric): Number of the chapter within the file
|
||||||
- `section_start` (numeric): Start time of the chapter in seconds
|
- `section_start` (numeric): Start time of the chapter in seconds
|
||||||
- `section_end` (numeric): End time of the chapter in seconds
|
- `section_end` (numeric): End time of the chapter in seconds
|
||||||
|
|
||||||
Available only when used in `--print`:
|
Available only when used in `--print`:
|
||||||
|
|
||||||
- `urls` (string): The URLs of all requested formats, one in each line
|
- `urls` (string): The URLs of all requested formats, one in each line
|
||||||
- `filename` (string): Name of the video file. Note that the [actual filename may differ](https://github.com/yt-dlp/yt-dlp#outtmpl-postprocess-note)
|
- `filename` (string): Name of the video file. Note that the [actual filename may differ](https://github.com/yt-dlp/yt-dlp#outtmpl-postprocess-note)
|
||||||
- `formats_table` (table): The video format table as printed by `--list-formats`
|
- `formats_table` (table): The video format table as printed by `--list-formats`
|
||||||
- `thumbnails_table` (table): The thumbnail format table as printed by `--list-thumbnails`
|
- `thumbnails_table` (table): The thumbnail format table as printed by `--list-thumbnails`
|
||||||
- `subtitles_table` (table): The subtitle format table as printed by `--list-subs`
|
- `subtitles_table` (table): The subtitle format table as printed by `--list-subs`
|
||||||
- `automatic_captions_table` (table): The automatic subtitle format table as printed by `--list-subs`
|
- `automatic_captions_table` (table): The automatic subtitle format table as printed by `--list-subs`
|
||||||
|
|
||||||
Available only in `--sponsorblock-chapter-title`:
|
Available only in `--sponsorblock-chapter-title`:
|
||||||
|
|
||||||
- `start_time` (numeric): Start time of the chapter in seconds
|
- `start_time` (numeric): Start time of the chapter in seconds
|
||||||
- `end_time` (numeric): End time of the chapter in seconds
|
- `end_time` (numeric): End time of the chapter in seconds
|
||||||
- `categories` (list): The [SponsorBlock categories](https://wiki.sponsor.ajay.app/w/Types#Category) the chapter belongs to
|
- `categories` (list): The [SponsorBlock categories](https://wiki.sponsor.ajay.app/w/Types#Category) the chapter belongs to
|
||||||
- `category` (string): The smallest SponsorBlock category the chapter belongs to
|
- `category` (string): The smallest SponsorBlock category the chapter belongs to
|
||||||
- `category_names` (list): Friendly names of the categories
|
- `category_names` (list): Friendly names of the categories
|
||||||
- `name` (string): Friendly name of the smallest category
|
- `name` (string): Friendly name of the smallest category
|
||||||
- `type` (string): The [SponsorBlock action type](https://wiki.sponsor.ajay.app/w/Types#Action_Type) of the chapter
|
- `type` (string): The [SponsorBlock action type](https://wiki.sponsor.ajay.app/w/Types#Action_Type) of the chapter
|
||||||
|
|
||||||
Each aforementioned sequence when referenced in an output template will be replaced by the actual value corresponding to the sequence name. E.g. for `-o %(title)s-%(id)s.%(ext)s` and an mp4 video with title `yt-dlp test video` and id `BaW_jenozKc`, this will result in a `yt-dlp test video-BaW_jenozKc.mp4` file created in the current directory.
|
Each aforementioned sequence when referenced in an output template will be replaced by the actual value corresponding to the sequence name. E.g. for `-o %(title)s-%(id)s.%(ext)s` and an mp4 video with title `yt-dlp test video` and id `BaW_jenozKc`, this will result in a `yt-dlp test video-BaW_jenozKc.mp4` file created in the current directory.
|
||||||
|
|
||||||
Note that some of the sequences are not guaranteed to be present since they depend on the metadata obtained by a particular extractor. Such sequences will be replaced with placeholder value provided with `--output-na-placeholder` (`NA` by default).
|
Note that some of the sequences are not guaranteed to be present since they depend on the metadata obtained by a particular extractor. Such sequences will be replaced with placeholder value provided with `--output-na-placeholder` (`NA` by default).
|
||||||
|
|
||||||
**Tip**: Look at the `-j` output to identify which fields are available for the particular URL
|
**Tip**: Look at the `-j` output to identify which fields are available for the particular URL
|
||||||
|
|
||||||
For numeric sequences you can use [numeric related formatting](https://docs.python.org/3/library/stdtypes.html#printf-style-string-formatting); e.g. `%(view_count)05d` will result in a string with view count padded with zeros up to 5 characters, like in `00042`.
|
For numeric sequences you can use [numeric related formatting](https://docs.python.org/3/library/stdtypes.html#printf-style-string-formatting); e.g. `%(view_count)05d` will result in a string with view count padded with zeros up to 5 characters, like in `00042`.
|
||||||
|
|
||||||
Output templates can also contain arbitrary hierarchical path, e.g. `-o "%(playlist)s/%(playlist_index)s - %(title)s.%(ext)s"` which will result in downloading each video in a directory corresponding to this path template. Any missing directory will be automatically created for you.
|
Output templates can also contain arbitrary hierarchical path, e.g. `-o "%(playlist)s/%(playlist_index)s - %(title)s.%(ext)s"` which will result in downloading each video in a directory corresponding to this path template. Any missing directory will be automatically created for you.
|
||||||
|
|
||||||
To use percent literals in an output template use `%%`. To output to stdout use `-o -`.
|
To use percent literals in an output template use `%%`. To output to stdout use `-o -`.
|
||||||
|
|
||||||
The current default template is `%(title)s [%(id)s].%(ext)s`.
|
The current default template is `%(title)s [%(id)s].%(ext)s`.
|
||||||
|
|
||||||
In some cases, you don't want special characters such as 中, spaces, or &, such as when transferring the downloaded filename to a Windows system or the filename through an 8bit-unsafe channel. In these cases, add the `--restrict-filenames` flag to get a shorter title.
|
In some cases, you don't want special characters such as 中, spaces, or &, such as when transferring the downloaded filename to a Windows system or the filename through an 8bit-unsafe channel. In these cases, add the `--restrict-filenames` flag to get a shorter title.
|
||||||
|
|
||||||
#### Output template examples
|
#### Output template examples
|
||||||
```shell
|
```shell
|
||||||
|
|
|
@ -6,7 +6,7 @@ repo: https://github.com/termux/termux-app
|
||||||
---
|
---
|
||||||
|
|
||||||
# Termux
|
# Termux
|
||||||
Termux is an **Android terminal emulator and Linux environment app** that works directly with no rooting or setup required. A minimal base system is installed automatically - additional packages are available using the APT package manager.
|
Termux is an **Android terminal emulator and Linux environment app** that works directly with no rooting or setup required. A minimal base system is installed automatically - additional packages are available using the APT package manager.
|
||||||
|
|
||||||
## Intents and Hooks
|
## Intents and Hooks
|
||||||
Termux is able to catch several intents and execute shell scripts to act upon them:
|
Termux is able to catch several intents and execute shell scripts to act upon them:
|
||||||
|
@ -18,7 +18,7 @@ Termux is able to catch several intents and execute shell scripts to act upon th
|
||||||
1. `nano ~/bin/termux-file-editor`)
|
1. `nano ~/bin/termux-file-editor`)
|
||||||
2. `chmod +x ~/bin/termux-file-editor`)
|
2. `chmod +x ~/bin/termux-file-editor`)
|
||||||
- URL sharing available in common apps (e.g. Youtube).
|
- URL sharing available in common apps (e.g. Youtube).
|
||||||
Following handle will be executed: `~/bin/termux-url-opener`
|
Following handle will be executed: `~/bin/termux-url-opener`
|
||||||
- Sharing a URL to be downloaded.
|
- Sharing a URL to be downloaded.
|
||||||
You can handle incoming URL by editing the content.
|
You can handle incoming URL by editing the content.
|
||||||
`yoursth-dl -f 'bestvideo[ext=mp4][height<=720]+bestaudio' --restrict-filenames -o '~/storage/downloads/%(title)s-%(id)s.%(ext)s' $1`
|
`yoursth-dl -f 'bestvideo[ext=mp4][height<=720]+bestaudio' --restrict-filenames -o '~/storage/downloads/%(title)s-%(id)s.%(ext)s' $1`
|
||||||
|
@ -35,12 +35,12 @@ If you need to stop `sshd`, just kill it's process:
|
||||||
pkill sshd
|
pkill sshd
|
||||||
```
|
```
|
||||||
|
|
||||||
SSH daemon does logging to Android system log, you can view it by running `logcat -s 'sshd:*'`. You can do that either from Termux or ADB.
|
SSH daemon does logging to Android system log, you can view it by running `logcat -s 'sshd:*'`. You can do that either from Termux or ADB.
|
||||||
|
|
||||||
## Sharing Data
|
## Sharing Data
|
||||||
Files stored in the home directory in Termux is not accessible to other applications by default. This is a limitation of Android itself.
|
Files stored in the home directory in Termux is not accessible to other applications by default. This is a limitation of Android itself.
|
||||||
|
|
||||||
As a workaround, you can use `termux-open` available in termux-tools package to share files with read access.
|
As a workaround, you can use `termux-open` available in termux-tools package to share files with read access.
|
||||||
```
|
```
|
||||||
$ termux-open -h
|
$ termux-open -h
|
||||||
Usage: termux-open [options] path-or-url
|
Usage: termux-open [options] path-or-url
|
||||||
|
@ -56,7 +56,7 @@ $ termux-open hello.c
|
||||||
This addon will run scripts immediately after device was booted.
|
This addon will run scripts immediately after device was booted.
|
||||||
|
|
||||||
### Installation
|
### Installation
|
||||||
Download add-on from [F-Droid](https://f-droid.org/packages/com.termux.boot/)
|
Download add-on from [F-Droid](https://f-droid.org/packages/com.termux.boot/)
|
||||||
|
|
||||||
### Usage
|
### Usage
|
||||||
1. Install the Termux:Boot app.
|
1. Install the Termux:Boot app.
|
||||||
|
@ -74,13 +74,13 @@ sshd
|
||||||
```
|
```
|
||||||
|
|
||||||
## Termux:API
|
## Termux:API
|
||||||
This addon exposes device functionality as API to command line programs in [Termux](https://github.com/termux/).
|
This addon exposes device functionality as API to command line programs in [Termux](https://github.com/termux/).
|
||||||
|
|
||||||
### Installation
|
### Installation
|
||||||
Download the Termux:API add-on from [F-Droid](https://f-droid.org/packages/com.termux.api/) or the Google Play Store. It is required for the API implementations to function.
|
Download the Termux:API add-on from [F-Droid](https://f-droid.org/packages/com.termux.api/) or the Google Play Store. It is required for the API implementations to function.
|
||||||
|
|
||||||
### Installing termux-api package
|
### Installing termux-api package
|
||||||
To use Termux:API you also need to install the [termux-api](https://github.com/termux/termux-api-package) package.
|
To use Termux:API you also need to install the [termux-api](https://github.com/termux/termux-api-package) package.
|
||||||
```shell
|
```shell
|
||||||
pkg install termux-api
|
pkg install termux-api
|
||||||
```
|
```
|
||||||
|
|
|
@ -12,7 +12,7 @@ KDE Connect is a multi-platform app that allows your devices to communicate (eg:
|
||||||
## Features
|
## Features
|
||||||
- **Shared clipboard**: copy and paste between your phone and your computer (or any other device).
|
- **Shared clipboard**: copy and paste between your phone and your computer (or any other device).
|
||||||
- **Notification sync**: Read and reply to your [Android](../../systems/Android.md) notifications from the desktop.
|
- **Notification sync**: Read and reply to your [Android](../../systems/Android.md) notifications from the desktop.
|
||||||
- **Share files and URLs** instantly from one device to another including some filesystem integration.
|
- **Share files and URLs** instantly from one device to another including some filesystem integration.
|
||||||
- **Multimedia remote control**: Use your phone as a remote for [Linux](../../linux/Linux.md) media players.
|
- **Multimedia remote control**: Use your phone as a remote for [Linux](../../linux/Linux.md) media players.
|
||||||
- **Virtual touchpad**: Use your phone screen as your computer's touchpad and keyboard.
|
- **Virtual touchpad**: Use your phone screen as your computer's touchpad and keyboard.
|
||||||
- **Presentation remote**: Advance your presentation slides straight from your phone.
|
- **Presentation remote**: Advance your presentation slides straight from your phone.
|
||||||
|
|
|
@ -5,7 +5,7 @@ os: linux
|
||||||
# NetworkManager
|
# NetworkManager
|
||||||
[NetworkManager](https://networkmanager.dev/) is a program for providing detection and configuration for systems to automatically connect to networks. NetworkManager's functionality can be useful for both wireless and wired networks. For wireless networks, NetworkManager prefers known wireless networks and has the ability to switch to the most reliable network. NetworkManager-aware applications can switch from online and offline mode. NetworkManager also prefers wired connections over wireless ones, has support for modem connections and certain types of VPN. NetworkManager was originally developed by Red Hat and now is hosted by the GNOME project.
|
[NetworkManager](https://networkmanager.dev/) is a program for providing detection and configuration for systems to automatically connect to networks. NetworkManager's functionality can be useful for both wireless and wired networks. For wireless networks, NetworkManager prefers known wireless networks and has the ability to switch to the most reliable network. NetworkManager-aware applications can switch from online and offline mode. NetworkManager also prefers wired connections over wireless ones, has support for modem connections and certain types of VPN. NetworkManager was originally developed by Red Hat and now is hosted by the GNOME project.
|
||||||
|
|
||||||
After installation, you should start/enable `NetworkManager.service`. Once the NetworkManager daemon is started, it will automatically connect to any available "system connections" that have already been configured. Any "user connections" or unconfigured connections will need _nmcli_ or an applet to configure and connect.
|
After installation, you should start/enable `NetworkManager.service`. Once the NetworkManager daemon is started, it will automatically connect to any available "system connections" that have already been configured. Any "user connections" or unconfigured connections will need _nmcli_ or an applet to configure and connect.
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
NetworkManager comes with nmcli and nmtui.
|
NetworkManager comes with nmcli and nmtui.
|
||||||
|
@ -20,7 +20,7 @@ Connect to a Wi-Fi network:
|
||||||
Connect to a hidden Wi-Fi network:
|
Connect to a hidden Wi-Fi network:
|
||||||
`nmcli device wifi connect SSID_or_BSSID password password hidden yes`
|
`nmcli device wifi connect SSID_or_BSSID password password hidden yes`
|
||||||
|
|
||||||
Connect to a Wi-Fi on the `wlan1` interface:
|
Connect to a Wi-Fi on the `wlan1` interface:
|
||||||
`nmcli device wifi connect SSID_or_BSSID password password ifname wlan1 profile_name`
|
`nmcli device wifi connect SSID_or_BSSID password password ifname wlan1 profile_name`
|
||||||
|
|
||||||
Disconnect an interface:
|
Disconnect an interface:
|
||||||
|
@ -42,7 +42,7 @@ Turn off Wi-Fi:
|
||||||
`nmcli radio wifi off`
|
`nmcli radio wifi off`
|
||||||
|
|
||||||
### Edit a connection
|
### Edit a connection
|
||||||
For a comprehensive list of settings, see [nm-settings(5)](https://man.archlinux.org/man/nm-settings.5).
|
For a comprehensive list of settings, see [nm-settings(5)](https://man.archlinux.org/man/nm-settings.5).
|
||||||
|
|
||||||
Firstly you need to get list of connections:
|
Firstly you need to get list of connections:
|
||||||
`nmcli connection`
|
`nmcli connection`
|
||||||
|
@ -53,34 +53,34 @@ Wired connection 1 997f2782-f0fc-301d-bfba-15421a2735d8 ethernet enp0s25
|
||||||
MY-HOME-WIFI-5G 92a0f7b3-2eba-49ab-a899-24d83978f308 wifi
|
MY-HOME-WIFI-5G 92a0f7b3-2eba-49ab-a899-24d83978f308 wifi
|
||||||
```
|
```
|
||||||
|
|
||||||
Here you can use the first column as connection-id used later. In this example we pick `Wired connection 2` as a connection-id.
|
Here you can use the first column as connection-id used later. In this example we pick `Wired connection 2` as a connection-id.
|
||||||
|
|
||||||
You have three methods to configure a connection `Wired connection 2` after it has been created:
|
You have three methods to configure a connection `Wired connection 2` after it has been created:
|
||||||
|
|
||||||
nmcli interactive editor
|
nmcli interactive editor
|
||||||
`nmcli connection edit 'Wired connection 2'`.
|
`nmcli connection edit 'Wired connection 2'`.
|
||||||
Usage is well documented from the editor.
|
Usage is well documented from the editor.
|
||||||
|
|
||||||
nmcli command line interface
|
nmcli command line interface
|
||||||
`nmcli connection modify 'Wired connection 2' setting.property value`. See [nmcli(1)](https://man.archlinux.org/man/nmcli.1) for usage. For example you can change its IPv4 route metric to 200 using `nmcli connection modify 'Wired connection 2' ipv4.route-metric 200` command.
|
`nmcli connection modify 'Wired connection 2' setting.property value`. See [nmcli(1)](https://man.archlinux.org/man/nmcli.1) for usage. For example you can change its IPv4 route metric to 200 using `nmcli connection modify 'Wired connection 2' ipv4.route-metric 200` command.
|
||||||
|
|
||||||
To remove a setting pass an empty field ("") to it like this:
|
To remove a setting pass an empty field ("") to it like this:
|
||||||
`nmcli connection modify 'Wired connection 2' setting.property ""`
|
`nmcli connection modify 'Wired connection 2' setting.property ""`
|
||||||
|
|
||||||
Connection file
|
Connection file
|
||||||
In `/etc/NetworkManager/system-connections/`, modify the corresponding `Wired connection 2.nmconnection` file .
|
In `/etc/NetworkManager/system-connections/`, modify the corresponding `Wired connection 2.nmconnection` file .
|
||||||
Do not forget to reload the configuration file with `nmcli connection reload`.
|
Do not forget to reload the configuration file with `nmcli connection reload`.
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
NetworkManager will require some additional steps to be able run properly. Make sure you have configured `/etc/hosts`.
|
NetworkManager will require some additional steps to be able run properly. Make sure you have configured `/etc/hosts`.
|
||||||
|
|
||||||
NetworkManager has a global configuration file at `/etc/NetworkManager/NetworkManager.conf`. Additional configuration files can be placed in `/etc/NetworkManager/conf.d/`. Usually no configuration needs to be done to the global defaults.
|
NetworkManager has a global configuration file at `/etc/NetworkManager/NetworkManager.conf`. Additional configuration files can be placed in `/etc/NetworkManager/conf.d/`. Usually no configuration needs to be done to the global defaults.
|
||||||
|
|
||||||
After editing a configuration file, the changes can be applied by running:
|
After editing a configuration file, the changes can be applied by running:
|
||||||
`nmcli general reload`
|
`nmcli general reload`
|
||||||
|
|
||||||
### DNS
|
### DNS
|
||||||
> **Note:** If `/etc/resolv.conf` is a symlink to `/run/systemd/resolve/stub-resolv.conf`, `/run/systemd/resolve/resolv.conf`,`/lib/systemd/resolv.conf` or `/usr/lib/systemd/resolv.conf`, NetworkManager will choose [systemd](../../linux/systemd/Systemd.md)-resolved automatically. To use dnsmasq, you must first remove that symlink, then restart NetworkManager.
|
> **Note:** If `/etc/resolv.conf` is a symlink to `/run/systemd/resolve/stub-resolv.conf`, `/run/systemd/resolve/resolv.conf`,`/lib/systemd/resolv.conf` or `/usr/lib/systemd/resolv.conf`, NetworkManager will choose [systemd](../../linux/systemd/Systemd.md)-resolved automatically. To use dnsmasq, you must first remove that symlink, then restart NetworkManager.
|
||||||
|
|
||||||
### VPN
|
### VPN
|
||||||
[WireGuard](Wireguard.md) is natively supported. To import a [WireGuard](Wireguard.md) Config File as a connection:
|
[WireGuard](Wireguard.md) is natively supported. To import a [WireGuard](Wireguard.md) Config File as a connection:
|
||||||
|
|
|
@ -99,7 +99,7 @@ Corkscrew is a additional programm to tunnel SSH through [HTTP](../../internet/H
|
||||||
```
|
```
|
||||||
|
|
||||||
## Server
|
## Server
|
||||||
`sshd` is the OpenSSH server daemon, configured with `/etc/ssh/sshd_config` and managed by `sshd.service`. Whenever changing the configuration, use `sshd` in test mode before restarting the service to ensure it will be able to start cleanly. Valid configurations produce no output.
|
`sshd` is the OpenSSH server daemon, configured with `/etc/ssh/sshd_config` and managed by `sshd.service`. Whenever changing the configuration, use `sshd` in test mode before restarting the service to ensure it will be able to start cleanly. Valid configurations produce no output.
|
||||||
```shell
|
```shell
|
||||||
sshd -t
|
sshd -t
|
||||||
```
|
```
|
||||||
|
|
|
@ -20,9 +20,9 @@ mitmproxy is a set of tools that provide an interactive, SSL/TLS-capable interce
|
||||||
|
|
||||||
## 3 Powerful Core Tools
|
## 3 Powerful Core Tools
|
||||||
The mitmproxy project’s tools are a set of front-ends that expose common underlying functionality. When we talk about “mitmproxy” we usually refer to any of the three tools - they are just different front-ends to the same core proxy.
|
The mitmproxy project’s tools are a set of front-ends that expose common underlying functionality. When we talk about “mitmproxy” we usually refer to any of the three tools - they are just different front-ends to the same core proxy.
|
||||||
**mitmproxy** is an interactive, SSL/TLS-capable intercepting proxy with a console interface for [HTTP](../../internet/HTTP.md)/1, [HTTP](../../internet/HTTP.md)/2, and WebSockets.
|
**mitmproxy** is an interactive, SSL/TLS-capable intercepting proxy with a console interface for [HTTP](../../internet/HTTP.md)/1, [HTTP](../../internet/HTTP.md)/2, and WebSockets.
|
||||||
**mitmweb** is a web-based interface for mitmproxy.
|
**mitmweb** is a web-based interface for mitmproxy.
|
||||||
**mitmdump** is the command-line version of mitmproxy. Think tcpdump for [HTTP](../../internet/HTTP.md).
|
**mitmdump** is the command-line version of mitmproxy. Think tcpdump for [HTTP](../../internet/HTTP.md).
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
Mitmproxy starts as a regular [HTTP](../../internet/HTTP.md) proxy by default and listens on http://localhost:8080.
|
Mitmproxy starts as a regular [HTTP](../../internet/HTTP.md) proxy by default and listens on http://localhost:8080.
|
||||||
|
|
|
@ -100,20 +100,20 @@ rclone mount remote:path/to/files /path/to/local/mount
|
||||||
|
|
||||||
## Storage Providers
|
## Storage Providers
|
||||||
### Alias
|
### Alias
|
||||||
The `alias` remote provides a new name for another remote.
|
The `alias` remote provides a new name for another remote.
|
||||||
|
|
||||||
### Amazon S3 Storage
|
### Amazon S3 Storage
|
||||||
The S3 backend can be used with a number of compatible providers (including [Minio](../web/Minio.md)).
|
The S3 backend can be used with a number of compatible providers (including [Minio](../web/Minio.md)).
|
||||||
|
|
||||||
## Chunker
|
## Chunker
|
||||||
The `chunker` overlay transparently splits large files into smaller chunks during upload to wrapped remote and transparently assembles them back when the file is downloaded. This allows to effectively overcome size limits imposed by storage providers.
|
The `chunker` overlay transparently splits large files into smaller chunks during upload to wrapped remote and transparently assembles them back when the file is downloaded. This allows to effectively overcome size limits imposed by storage providers.
|
||||||
|
|
||||||
## Crypt
|
## Crypt
|
||||||
Rclone `crypt` remotes encrypt and decrypt other remotes.
|
Rclone `crypt` remotes encrypt and decrypt other remotes.
|
||||||
|
|
||||||
A remote of type `crypt` does not access a storage system directly, but instead wraps another remote, which in turn accesses the storage system. This is similar to how alias, union, chunker and a few others work. It makes the usage very flexible, as you can add a layer, in this case an encryption layer, on top of any other backend, even in multiple layers. Rclone's functionality can be used as with any other remote, for example you can mount a crypt remote.
|
A remote of type `crypt` does not access a storage system directly, but instead wraps another remote, which in turn accesses the storage system. This is similar to how alias, union, chunker and a few others work. It makes the usage very flexible, as you can add a layer, in this case an encryption layer, on top of any other backend, even in multiple layers. Rclone's functionality can be used as with any other remote, for example you can mount a crypt remote.
|
||||||
|
|
||||||
Accessing a storage system through a crypt remote realizes client-side encryption, which makes it safe to keep your data in a location you do not trust will not get compromised. When working against the `crypt` remote, rclone will automatically encrypt (before uploading) and decrypt (after downloading) on your local system as needed on the fly, leaving the data encrypted at rest in the wrapped remote. If you access the storage system using an application other than rclone, or access the wrapped remote directly using rclone, there will not be any encryption/decryption: Downloading existing content will just give you the encrypted (scrambled) format, and anything you upload will _not_ become encrypted.
|
Accessing a storage system through a crypt remote realizes client-side encryption, which makes it safe to keep your data in a location you do not trust will not get compromised. When working against the `crypt` remote, rclone will automatically encrypt (before uploading) and decrypt (after downloading) on your local system as needed on the fly, leaving the data encrypted at rest in the wrapped remote. If you access the storage system using an application other than rclone, or access the wrapped remote directly using rclone, there will not be any encryption/decryption: Downloading existing content will just give you the encrypted (scrambled) format, and anything you upload will _not_ become encrypted.
|
||||||
|
|
||||||
## FTP
|
## FTP
|
||||||
[FTP](../../internet/FTP.md) is the File Transfer Protocol.
|
[FTP](../../internet/FTP.md) is the File Transfer Protocol.
|
||||||
|
@ -129,22 +129,22 @@ This is an rclone backend for Mega which supports the file transfer features of
|
||||||
## Memory
|
## Memory
|
||||||
The memory backend is an in RAM backend. It does not persist its data.
|
The memory backend is an in RAM backend. It does not persist its data.
|
||||||
|
|
||||||
The memory backend behaves like a bucket-based remote (e.g. like s3). Because it has no parameters you can just use it with the `:memory:` remote name.
|
The memory backend behaves like a bucket-based remote (e.g. like s3). Because it has no parameters you can just use it with the `:memory:` remote name.
|
||||||
|
|
||||||
## SMB
|
## SMB
|
||||||
SMB is a communication protocol to share files over network.
|
SMB is a communication protocol to share files over network.
|
||||||
|
|
||||||
## Union
|
## Union
|
||||||
The `union` backend joins several remotes together to make a single unified view of them.
|
The `union` backend joins several remotes together to make a single unified view of them.
|
||||||
|
|
||||||
During the initial setup with `rclone config` you will specify the upstream remotes as a space separated list. The upstream remotes can either be a local paths or other remotes.
|
During the initial setup with `rclone config` you will specify the upstream remotes as a space separated list. The upstream remotes can either be a local paths or other remotes.
|
||||||
|
|
||||||
The attributes `:ro`, `:nc` and `:nc` can be attached to the end of the remote to tag the remote as **read only**, **no create** or **writeback**, e.g. `remote:directory/subdirectory:ro` or `remote:directory/subdirectory:nc`.
|
The attributes `:ro`, `:nc` and `:nc` can be attached to the end of the remote to tag the remote as **read only**, **no create** or **writeback**, e.g. `remote:directory/subdirectory:ro` or `remote:directory/subdirectory:nc`.
|
||||||
- `:ro` means files will only be read from here and never written
|
- `:ro` means files will only be read from here and never written
|
||||||
- `:nc` means new files or directories won't be created here
|
- `:nc` means new files or directories won't be created here
|
||||||
- `:writeback` means files found in different remotes will be written back here.
|
- `:writeback` means files found in different remotes will be written back here.
|
||||||
|
|
||||||
Subfolders can be used in upstream remotes. Assume a union remote named `backup` with the remotes `mydrive:private/backup`. Invoking `rclone mkdir backup:desktop` is exactly the same as invoking `rclone mkdir mydrive:private/backup/desktop`.
|
Subfolders can be used in upstream remotes. Assume a union remote named `backup` with the remotes `mydrive:private/backup`. Invoking `rclone mkdir backup:desktop` is exactly the same as invoking `rclone mkdir mydrive:private/backup/desktop`.
|
||||||
|
|
||||||
## WebDAV
|
## WebDAV
|
||||||
To configure the [WebDAV](../../internet/WebDAV.md) remote you will need to have a [URL](../../internet/URL.md) for it, and a username and password
|
To configure the [WebDAV](../../internet/WebDAV.md) remote you will need to have a [URL](../../internet/URL.md) for it, and a username and password
|
|
@ -12,7 +12,7 @@ A very simplistic configuration which will deny all by default.
|
||||||
ufw default deny
|
ufw default deny
|
||||||
```
|
```
|
||||||
|
|
||||||
The next line is only needed _once_ the first time you install the package:
|
The next line is only needed _once_ the first time you install the package:
|
||||||
```shell
|
```shell
|
||||||
ufw enable
|
ufw enable
|
||||||
```
|
```
|
||||||
|
|
|
@ -44,12 +44,12 @@ The following variables should be defined by the user:
|
||||||
| Option | Description |
|
| Option | Description |
|
||||||
| ------------------ | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ------------------ | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `!archcheck` | Do not try to verify that the architecture of the binary files is the same architecture as abuild should build for. One example where it makes sense to set this are packages with firmware files, that get executed on another CPU (such as WiFi firmware). |
|
| `!archcheck` | Do not try to verify that the architecture of the binary files is the same architecture as abuild should build for. One example where it makes sense to set this are packages with firmware files, that get executed on another CPU (such as WiFi firmware). |
|
||||||
| `!check` | Do not try to run the `check()` function. Please always add a short comment after the `!check` about why it's disabled. Creating a very simple check function, that calls `program --version` is worse than disabling tests completely because it gives the false impression that the package is thoroughly tested with the testsuite from upstream. |
|
| `!check` | Do not try to run the `check()` function. Please always add a short comment after the `!check` about why it's disabled. Creating a very simple check function, that calls `program --version` is worse than disabling tests completely because it gives the false impression that the package is thoroughly tested with the testsuite from upstream. |
|
||||||
| `checkroot` | Specifies that the package's test suite will be run in _fakeroot_. This is necessary for some test suites which fail when run as non-root. |
|
| `checkroot` | Specifies that the package's test suite will be run in _fakeroot_. This is necessary for some test suites which fail when run as non-root. |
|
||||||
| `net` | Allows network access when run in _rootbld_. |
|
| `net` | Allows network access when run in _rootbld_. |
|
||||||
| `!strip` | Avoid stripping symbols from binaries. |
|
| `!strip` | Avoid stripping symbols from binaries. |
|
||||||
| `suid` | Allow setuid binaries. |
|
| `suid` | Allow setuid binaries. |
|
||||||
| `!tracedeps` | Do not automatically find dependencies (e.g. by using `ldd` to find dynamic libraries, which the resulting binary links against). |
|
| `!tracedeps` | Do not automatically find dependencies (e.g. by using `ldd` to find dynamic libraries, which the resulting binary links against). |
|
||||||
| `chmod-clean` | Make all files writable in the src/ directory. Useful for packages that make files read-only in the process of building packages (go modules). |
|
| `chmod-clean` | Make all files writable in the src/ directory. Useful for packages that make files read-only in the process of building packages (go modules). |
|
||||||
| `toolchain` | Don't warn when g++ is in makedepends |
|
| `toolchain` | Don't warn when g++ is in makedepends |
|
||||||
| `!dbg` | Don't create debugging subpackage |
|
| `!dbg` | Don't create debugging subpackage |
|
||||||
|
|
|
@ -26,39 +26,39 @@ Usage:
|
||||||
- `abuild -r`: builds the package.
|
- `abuild -r`: builds the package.
|
||||||
|
|
||||||
### Building in a chroot
|
### Building in a chroot
|
||||||
Install package `abuild-rootbld`:
|
Install package `abuild-rootbld`:
|
||||||
```shell
|
```shell
|
||||||
apk add abuild-rootbld
|
apk add abuild-rootbld
|
||||||
```
|
```
|
||||||
|
|
||||||
You may now build your packages from source in an unprivileged sandbox based on bubblewrap with the command:
|
You may now build your packages from source in an unprivileged sandbox based on bubblewrap with the command:
|
||||||
```shell
|
```shell
|
||||||
abuild rootbld
|
abuild rootbld
|
||||||
```
|
```
|
||||||
|
|
||||||
If the build process needs network access there has to bet set the **net** option in [APKBUILD](APKBUILD.md).
|
If the build process needs network access there has to bet set the **net** option in [APKBUILD](APKBUILD.md).
|
||||||
|
|
||||||
## Bumping a package version
|
## Bumping a package version
|
||||||
The tool `abump` is a utility to bump pkgver in [APKBUILD](APKBUILD.md) files if the package gets an update to a newer upstream release. `abump` will update the package's `pkgver`, rebuild it and create a new commit with the resulting changes.
|
The tool `abump` is a utility to bump pkgver in [APKBUILD](APKBUILD.md) files if the package gets an update to a newer upstream release. `abump` will update the package's `pkgver`, rebuild it and create a new commit with the resulting changes.
|
||||||
```shell
|
```shell
|
||||||
abump [-hR]
|
abump [-hR]
|
||||||
```
|
```
|
||||||
|
|
||||||
**abump options**
|
**abump options**
|
||||||
- **-h** Show this help
|
- **-h** Show this help
|
||||||
- **-R** Run abuild with -R for recursive building
|
- **-R** Run abuild with -R for recursive building
|
||||||
- **-k** Keep existing packages
|
- **-k** Keep existing packages
|
||||||
|
|
||||||
## Updating a package release
|
## Updating a package release
|
||||||
If you want to bump or reset the pkgrel value of your [APKBUILD](APKBUILD.md) or test your [APKBUILD](APKBUILD.md) files, apkgrel can assist you.
|
If you want to bump or reset the pkgrel value of your [APKBUILD](APKBUILD.md) or test your [APKBUILD](APKBUILD.md) files, apkgrel can assist you.
|
||||||
```shell
|
```shell
|
||||||
apkgrel -a|-h|-s NUM|-t|-z [-f] FILE...
|
apkgrel -a|-h|-s NUM|-t|-z [-f] FILE...
|
||||||
```
|
```
|
||||||
|
|
||||||
**apkgrel options**
|
**apkgrel options**
|
||||||
- **-a** Add 1 to current pkgrel
|
- **-a** Add 1 to current pkgrel
|
||||||
- **-f** Force, even if given files are not in proper format
|
- **-f** Force, even if given files are not in proper format
|
||||||
- **-h** Show this help
|
- **-h** Show this help
|
||||||
- **-s** Set pkgrel to NUM
|
- **-s** Set pkgrel to NUM
|
||||||
- **-t** Only verify that files are in proper format
|
- **-t** Only verify that files are in proper format
|
||||||
- **-z** Set pkgrel to 0
|
- **-z** Set pkgrel to 0
|
||||||
|
|
|
@ -5,7 +5,7 @@ obj: concept
|
||||||
|
|
||||||
# PKGBUILD
|
# PKGBUILD
|
||||||
|
|
||||||
A `PKGBUILD` is a shell script containing the build information required by [Arch Linux](../../../linux/Arch%20Linux.md) packages. [Arch Wiki](https://wiki.archlinux.org/title/PKGBUILD)
|
A `PKGBUILD` is a shell script containing the build information required by [Arch Linux](../../../linux/Arch%20Linux.md) packages. [Arch Wiki](https://wiki.archlinux.org/title/PKGBUILD)
|
||||||
|
|
||||||
Packages in [Arch Linux](../../../linux/Arch%20Linux.md) are built using the [makepkg](makepkg.md) utility. When [makepkg](makepkg.md) is run, it searches for a PKGBUILD file in the current directory and follows the instructions therein to either compile or otherwise acquire the files to build a package archive (pkgname.pkg.tar.zst). The resulting package contains binary files and installation instructions, readily installable with [pacman](Pacman.md).
|
Packages in [Arch Linux](../../../linux/Arch%20Linux.md) are built using the [makepkg](makepkg.md) utility. When [makepkg](makepkg.md) is run, it searches for a PKGBUILD file in the current directory and follows the instructions therein to either compile or otherwise acquire the files to build a package archive (pkgname.pkg.tar.zst). The resulting package contains binary files and installation instructions, readily installable with [pacman](Pacman.md).
|
||||||
|
|
||||||
|
|
|
@ -15,12 +15,12 @@ Configuration is done with `~/.config/dunst/dunstrc`
|
||||||
The configuration is divided into sections in an ini-like format. Every section starts with the section's name in square brackets. After that is a list of key-value pairs that specify the settings. Whitespace is purely cosmetic and doesn't change the result.
|
The configuration is divided into sections in an ini-like format. Every section starts with the section's name in square brackets. After that is a list of key-value pairs that specify the settings. Whitespace is purely cosmetic and doesn't change the result.
|
||||||
|
|
||||||
### Global
|
### Global
|
||||||
- **monitor** (default: 0)
|
- **monitor** (default: 0)
|
||||||
Specifies on which monitor the notifications should be displayed in, count starts at 0. See the **follow** setting.
|
Specifies on which monitor the notifications should be displayed in, count starts at 0. See the **follow** setting.
|
||||||
|
|
||||||
- **follow** (values: \[none/mouse/keyboard] default: none)
|
- **follow** (values: \[none/mouse/keyboard] default: none)
|
||||||
Defines where the notifications should be placed in a multi-monitor setup. All values except _none_ override the **monitor** setting.
|
Defines where the notifications should be placed in a multi-monitor setup. All values except _none_ override the **monitor** setting.
|
||||||
- **none**: The notifications will be placed on the monitor specified by the **monitor** setting.
|
- **none**: The notifications will be placed on the monitor specified by the **monitor** setting.
|
||||||
- **mouse**: The notifications will be placed on the monitor that the mouse is currently in.
|
- **mouse**: The notifications will be placed on the monitor that the mouse is currently in.
|
||||||
- **keyboard**: The notifications will be placed on the monitor that contains the window with keyboard focus.
|
- **keyboard**: The notifications will be placed on the monitor that contains the window with keyboard focus.
|
||||||
|
|
||||||
|
@ -31,70 +31,70 @@ When setting a width bigger than the screen, dunst will clamp the width to the s
|
||||||
- **height**
|
- **height**
|
||||||
The maximum height of a single notification.
|
The maximum height of a single notification.
|
||||||
|
|
||||||
- **notification_limit** (default: 0)
|
- **notification_limit** (default: 0)
|
||||||
The number of notifications that can appear at one time. When this limit is reached any additional notifications will be queued and displayed when the currently displayed ones either time out or are manually dismissed. The value 0 means no limit. If **indicate_hidden** is true, then the specified limit is reduced by 1 and the last notification is a message informing how many hidden notifications are waiting to be displayed. See the **indicate_hidden** entry for more information.
|
The number of notifications that can appear at one time. When this limit is reached any additional notifications will be queued and displayed when the currently displayed ones either time out or are manually dismissed. The value 0 means no limit. If **indicate_hidden** is true, then the specified limit is reduced by 1 and the last notification is a message informing how many hidden notifications are waiting to be displayed. See the **indicate_hidden** entry for more information.
|
||||||
|
|
||||||
- **origin** (default: top-right)
|
- **origin** (default: top-right)
|
||||||
The origin of the notification window on the screen. It can then be moved with offset. Origin can be one of: top-left top-center top-right bottom-left bottom-center bottom-right left-center center right-center
|
The origin of the notification window on the screen. It can then be moved with offset. Origin can be one of: top-left top-center top-right bottom-left bottom-center bottom-right left-center center right-center
|
||||||
|
|
||||||
- **offset** format: (horizontal, vertical)
|
- **offset** format: (horizontal, vertical)
|
||||||
Respectively the horizontal and vertical offset in pixels from the corner of the screen specified by **origin**. A negative offset will lead to the notification being off screen.
|
Respectively the horizontal and vertical offset in pixels from the corner of the screen specified by **origin**. A negative offset will lead to the notification being off screen.
|
||||||
|
|
||||||
- **icon_corner_radius** (default: 0)
|
- **icon_corner_radius** (default: 0)
|
||||||
The corner radius of the icon image in pixels. Gives the icon rounded corners. Set to 0 to disable.
|
The corner radius of the icon image in pixels. Gives the icon rounded corners. Set to 0 to disable.
|
||||||
|
|
||||||
- **indicate_hidden** (values: \[true/false], default: true)
|
- **indicate_hidden** (values: \[true/false], default: true)
|
||||||
If this is set to true, a notification indicating how many notifications are not being displayed due to the notification limit (see **notification_limit**) will be shown **in place of the last notification slot**.
|
If this is set to true, a notification indicating how many notifications are not being displayed due to the notification limit (see **notification_limit**) will be shown **in place of the last notification slot**.
|
||||||
Meaning that if this is enabled the number of visible notifications will be 1 less than what is specified by **notification_limit**, the last slot will be taken by the hidden count.
|
Meaning that if this is enabled the number of visible notifications will be 1 less than what is specified by **notification_limit**, the last slot will be taken by the hidden count.
|
||||||
|
|
||||||
- **separator_height** (default: 2)
|
- **separator_height** (default: 2)
|
||||||
The height in pixels of the separator between notifications, if set to 0 there will be no separating line between notifications. This setting will be ignored if **gap_size** is greater than 0.
|
The height in pixels of the separator between notifications, if set to 0 there will be no separating line between notifications. This setting will be ignored if **gap_size** is greater than 0.
|
||||||
|
|
||||||
- **padding** (default: 8)
|
- **padding** (default: 8)
|
||||||
The distance in pixels from the content to the separator/border of the window in the vertical axis
|
The distance in pixels from the content to the separator/border of the window in the vertical axis
|
||||||
|
|
||||||
- **horizontal_padding** (default: 8)
|
- **horizontal_padding** (default: 8)
|
||||||
The distance in pixels from the content to the border of the window in the horizontal axis
|
The distance in pixels from the content to the border of the window in the horizontal axis
|
||||||
|
|
||||||
- **text_icon_padding** (default: 0)
|
- **text_icon_padding** (default: 0)
|
||||||
The distance in pixels from the text to the icon (or vice versa) in the horizontal axis.
|
The distance in pixels from the text to the icon (or vice versa) in the horizontal axis.
|
||||||
|
|
||||||
- **frame_width** (default: 3)
|
- **frame_width** (default: 3)
|
||||||
Defines width in pixels of frame around the notification window. Set to 0 to disable.
|
Defines width in pixels of frame around the notification window. Set to 0 to disable.
|
||||||
|
|
||||||
- **gap_size** (default: 0)
|
- **gap_size** (default: 0)
|
||||||
Size of gap to display between notifications.
|
Size of gap to display between notifications.
|
||||||
|
|
||||||
- **font** (default: "Monospace 8")
|
- **font** (default: "Monospace 8")
|
||||||
Defines the font or font set used. Optionally set the size as a decimal number after the font name and space. Multiple font options can be separated with commas.
|
Defines the font or font set used. Optionally set the size as a decimal number after the font name and space. Multiple font options can be separated with commas.
|
||||||
|
|
||||||
- **line_height** (default: 0)
|
- **line_height** (default: 0)
|
||||||
The amount of extra spacing between text lines in pixels. Set to 0 to disable.
|
The amount of extra spacing between text lines in pixels. Set to 0 to disable.
|
||||||
|
|
||||||
- **format** (default: `<b>%s</b>\n%b`)
|
- **format** (default: `<b>%s</b>\n%b`)
|
||||||
Specifies how the various attributes of the notification should be formatted on the notification window.
|
Specifies how the various attributes of the notification should be formatted on the notification window.
|
||||||
If `\n` is present anywhere in the format, it will be replaced with a literal newline.
|
If `\n` is present anywhere in the format, it will be replaced with a literal newline.
|
||||||
If any of the following strings are present, they will be replaced with the equivalent notification attribute:
|
If any of the following strings are present, they will be replaced with the equivalent notification attribute:
|
||||||
- **%a** appname
|
- **%a** appname
|
||||||
- **%s** summary
|
- **%s** summary
|
||||||
- **%b** body
|
- **%b** body
|
||||||
- **%i** iconname (including its path)
|
- **%i** iconname (including its path)
|
||||||
- **%I** iconname (without its path)
|
- **%I** iconname (without its path)
|
||||||
- **%p** progress value (\[ 0%] to \[100%])
|
- **%p** progress value (\[ 0%] to \[100%])
|
||||||
- **%n** progress value without any extra characters
|
- **%n** progress value without any extra characters
|
||||||
- **%\%** Literal %
|
- **%\%** Literal %
|
||||||
If any of these exists in the format but hasn't been specified in the notification (e.g. no icon has been set), the placeholders will simply be removed from the format.
|
If any of these exists in the format but hasn't been specified in the notification (e.g. no icon has been set), the placeholders will simply be removed from the format.
|
||||||
|
|
||||||
- **vertical_alignment** (values: [top/center/bottom], default: center)
|
- **vertical_alignment** (values: [top/center/bottom], default: center)
|
||||||
Defines how the text and icon should be aligned vertically within the notification. If icons are disabled, this option has no effect.
|
Defines how the text and icon should be aligned vertically within the notification. If icons are disabled, this option has no effect.
|
||||||
|
|
||||||
- **history_length** (default: 20)
|
- **history_length** (default: 20)
|
||||||
Maximum number of notifications that will be kept in history. After that limit is reached, older notifications will be deleted once a new one arrives.
|
Maximum number of notifications that will be kept in history. After that limit is reached, older notifications will be deleted once a new one arrives.
|
||||||
|
|
||||||
- **browser** (default: "/usr/bin/xdg-open")
|
- **browser** (default: "/usr/bin/xdg-open")
|
||||||
The command that will be run when opening a [URL](../../internet/URL.md). The [URL](../../internet/URL.md) to be opened will be appended to the end of the value of this setting.
|
The command that will be run when opening a [URL](../../internet/URL.md). The [URL](../../internet/URL.md) to be opened will be appended to the end of the value of this setting.
|
||||||
|
|
||||||
- **corner_radius** (default: 0)
|
- **corner_radius** (default: 0)
|
||||||
Define the corner radius in pixels. A corner radius of 0 will result in rectangular shaped notifications.
|
Define the corner radius in pixels. A corner radius of 0 will result in rectangular shaped notifications.
|
||||||
By enabling this setting the outer border and the frame will be shaped. If you have multiple notifications, the whole window is shaped, not every single notification.
|
By enabling this setting the outer border and the frame will be shaped. If you have multiple notifications, the whole window is shaped, not every single notification.
|
||||||
To avoid the corners clipping the icon or text the corner radius will be automatically lowered to half of the notification height if it exceeds it.
|
To avoid the corners clipping the icon or text the corner radius will be automatically lowered to half of the notification height if it exceeds it.
|
||||||
|
|
|
@ -6,7 +6,7 @@ flatpak-id: org.keepassxc.KeePassXC
|
||||||
---
|
---
|
||||||
|
|
||||||
# KeePassXC
|
# KeePassXC
|
||||||
**KeePassXC** is a modern, secure, and open-source password manager that stores and manages your most sensitive information.
|
**KeePassXC** is a modern, secure, and open-source password manager that stores and manages your most sensitive information.
|
||||||
|
|
||||||
You can run KeePassXC on [Windows](../../windows/Windows.md), [macOS](../../macos/macOS.md), and [Linux](../../linux/Linux.md) systems. KeePassXC is for people with extremely high demands of secure personal data management. It saves many types of information, such as usernames, passwords, URLs, attachments, and notes in an offline, encrypted file that can be stored in any location, including private and public cloud solutions.
|
You can run KeePassXC on [Windows](../../windows/Windows.md), [macOS](../../macos/macOS.md), and [Linux](../../linux/Linux.md) systems. KeePassXC is for people with extremely high demands of secure personal data management. It saves many types of information, such as usernames, passwords, URLs, attachments, and notes in an offline, encrypted file that can be stored in any location, including private and public cloud solutions.
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@ Rofi is a window switcher, run dialog, ssh-launcher and dmenu replacement that s
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
There are two methods of setting configuration options:
|
There are two methods of setting configuration options:
|
||||||
- Local configuration. Normally, depending on XDG, in `~/.config/rofi/config.rasi`.
|
- Local configuration. Normally, depending on XDG, in `~/.config/rofi/config.rasi`.
|
||||||
- Command line options:
|
- Command line options:
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
|
@ -26,13 +26,13 @@ configuration {
|
||||||
@theme "solarized"
|
@theme "solarized"
|
||||||
```
|
```
|
||||||
|
|
||||||
To get a full list of options for `config.rasi` file run `rofi -dump-config` or `rofi -h`. You can write the output of the command directly to your configuration file while running `rofi -dump-config > ~/.config/rofi/config.rasi`.
|
To get a full list of options for `config.rasi` file run `rofi -dump-config` or `rofi -h`. You can write the output of the command directly to your configuration file while running `rofi -dump-config > ~/.config/rofi/config.rasi`.
|
||||||
|
|
||||||
## Themes
|
## Themes
|
||||||
The easiest way to get started theming rofi is by modifying your existing theme.
|
The easiest way to get started theming rofi is by modifying your existing theme.
|
||||||
|
|
||||||
Themes can be modified/tweaked by adding theming elements to the end of the
|
Themes can be modified/tweaked by adding theming elements to the end of the
|
||||||
config file. The default location of this file is `~/.config/rofi/config.rasi`, if the file does not exists, you can create it.
|
config file. The default location of this file is `~/.config/rofi/config.rasi`, if the file does not exists, you can create it.
|
||||||
|
|
||||||
A basic config:
|
A basic config:
|
||||||
```
|
```
|
||||||
|
@ -46,11 +46,11 @@ configuration {
|
||||||
/* Insert theme modifications after this */
|
/* Insert theme modifications after this */
|
||||||
```
|
```
|
||||||
|
|
||||||
For example if we want to change the `Type to filter` text in the entry box we append the following:
|
For example if we want to change the `Type to filter` text in the entry box we append the following:
|
||||||
```css
|
```css
|
||||||
entry {
|
entry {
|
||||||
placeholder: "Type here";
|
placeholder: "Type here";
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
In the above section, `entry` indicates the widget, `placeholder` is the property we want to modify and we set it to the string `"Type here"`.
|
In the above section, `entry` indicates the widget, `placeholder` is the property we want to modify and we set it to the string `"Type here"`.
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -151,9 +151,9 @@ curl --user your_username:your_token_or_password -X DELETE \ https://gitea.e
|
||||||
```
|
```
|
||||||
|
|
||||||
## Profile READMEs
|
## Profile READMEs
|
||||||
To display a [Markdown](../../files/Markdown.md) file in your Gitea profile page, simply create a repository named `.profile` and add a new file called `README.md`. Gitea will automatically display the contents of the file on your profile, above your repositories.
|
To display a [Markdown](../../files/Markdown.md) file in your Gitea profile page, simply create a repository named `.profile` and add a new file called `README.md`. Gitea will automatically display the contents of the file on your profile, above your repositories.
|
||||||
|
|
||||||
Making the `.profile` repository private will hide the Profile README.
|
Making the `.profile` repository private will hide the Profile README.
|
||||||
|
|
||||||
## Docker Compose
|
## Docker Compose
|
||||||
```yaml
|
```yaml
|
||||||
|
|
|
@ -10,9 +10,9 @@ Home Assistant is a local smart home hub platform supportig many [integrations](
|
||||||
![Screenshot][Screenshot]
|
![Screenshot][Screenshot]
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
While you can configure most of Home Assistant directly from the user interface, some parts need you to edit `configuration.yaml`.
|
While you can configure most of Home Assistant directly from the user interface, some parts need you to edit `configuration.yaml`.
|
||||||
|
|
||||||
To improve readability, you can source out certain domains from your main configuration file with the `!include`-syntax.
|
To improve readability, you can source out certain domains from your main configuration file with the `!include`-syntax.
|
||||||
```yaml
|
```yaml
|
||||||
light: !include lights.yaml
|
light: !include lights.yaml
|
||||||
```
|
```
|
||||||
|
|
|
@ -9,7 +9,7 @@ Uptime Kuma is an easy-to-use self-hosted monitoring tool.
|
||||||
## Features
|
## Features
|
||||||
- Monitoring uptime for [HTTP](../../internet/HTTP.md)(s) / [TCP](../../internet/TCP.md) / [HTTP](../../internet/HTTP.md)(s) Keyword / [HTTP](../../internet/HTTP.md)(s) [Json](../../files/JSON.md) Query / Ping / [DNS](../../internet/DNS.md) Record / Push / Steam Game Server / [Docker](../../tools/Docker.md) Containers
|
- Monitoring uptime for [HTTP](../../internet/HTTP.md)(s) / [TCP](../../internet/TCP.md) / [HTTP](../../internet/HTTP.md)(s) Keyword / [HTTP](../../internet/HTTP.md)(s) [Json](../../files/JSON.md) Query / Ping / [DNS](../../internet/DNS.md) Record / Push / Steam Game Server / [Docker](../../tools/Docker.md) Containers
|
||||||
- Fancy, Reactive, Fast UI/UX
|
- Fancy, Reactive, Fast UI/UX
|
||||||
- Notifications via Telegram, [Discord](../communication/Discord.md), Gotify, Slack, Pushover, [Email](../../internet/eMail.md) ([SMTP](../../internet/SMTP.md)), and 90+ notification services
|
- Notifications via Telegram, [Discord](../communication/Discord.md), Gotify, Slack, Pushover, [Email](../../internet/eMail.md) ([SMTP](../../internet/SMTP.md)), and 90+ notification services
|
||||||
- 20-second intervals
|
- 20-second intervals
|
||||||
- Multiple status pages
|
- Multiple status pages
|
||||||
- Map status pages to specific domains
|
- Map status pages to specific domains
|
||||||
|
|
|
@ -46,30 +46,30 @@ Usage: `dufs [OPTIONS] [serve-path]`
|
||||||
| `--tls-key <path>` | Path to the SSL/TLS certificate's private key |
|
| `--tls-key <path>` | Path to the SSL/TLS certificate's private key |
|
||||||
|
|
||||||
### Access Control
|
### Access Control
|
||||||
Dufs supports account based access control. You can control who can do what on which path with `--auth`/`-a`.
|
Dufs supports account based access control. You can control who can do what on which path with `--auth`/`-a`.
|
||||||
```
|
```
|
||||||
dufs -a user:pass@/path1:rw,/path2 -a user2:pass2@/path3 -a @/path4
|
dufs -a user:pass@/path1:rw,/path2 -a user2:pass2@/path3 -a @/path4
|
||||||
```
|
```
|
||||||
|
|
||||||
1. Use `@` to separate the account and paths. No account means anonymous user.
|
1. Use `@` to separate the account and paths. No account means anonymous user.
|
||||||
2. Use `:` to separate the username and password of the account.
|
2. Use `:` to separate the username and password of the account.
|
||||||
3. Use `,` to separate paths.
|
3. Use `,` to separate paths.
|
||||||
4. Use `:rw` suffix to indicate that the account has read-write permission on the path.
|
4. Use `:rw` suffix to indicate that the account has read-write permission on the path.
|
||||||
|
|
||||||
Examples:
|
Examples:
|
||||||
- `-a admin:amdin@/:rw`: `admin` has complete permissions for all paths.
|
- `-a admin:amdin@/:rw`: `admin` has complete permissions for all paths.
|
||||||
- `-a guest:guest@/`: `guest` has read-only permissions for all paths.
|
- `-a guest:guest@/`: `guest` has read-only permissions for all paths.
|
||||||
- `-a user:pass@/dir1:rw,/dir2`: `user` has complete permissions for `/dir1/*`, has read-only permissions for `/dir2/`.
|
- `-a user:pass@/dir1:rw,/dir2`: `user` has complete permissions for `/dir1/*`, has read-only permissions for `/dir2/`.
|
||||||
- `-a @/`: All paths is publicly accessible, everyone can view/download it.
|
- `-a @/`: All paths is publicly accessible, everyone can view/download it.
|
||||||
|
|
||||||
### Hide Paths
|
### Hide Paths
|
||||||
Dufs supports hiding paths from directory listings via option `--hidden <glob>,...`.
|
Dufs supports hiding paths from directory listings via option `--hidden <glob>,...`.
|
||||||
|
|
||||||
```
|
```
|
||||||
dufs --hidden .git,.DS_Store,tmp
|
dufs --hidden .git,.DS_Store,tmp
|
||||||
```
|
```
|
||||||
|
|
||||||
> The glob used in --hidden only matches file and directory names, not paths. So `--hidden dir1/file` is invalid.
|
> The glob used in --hidden only matches file and directory names, not paths. So `--hidden dir1/file` is invalid.
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
dufs --hidden '.*' # hidden dotfiles
|
dufs --hidden '.*' # hidden dotfiles
|
||||||
|
@ -79,7 +79,7 @@ dufs --hidden '*.log' --hidden '*.lock'
|
||||||
```
|
```
|
||||||
|
|
||||||
### Log Format
|
### Log Format
|
||||||
Dufs supports customize [http](../../internet/HTTP.md) log format with option `--log-format`.
|
Dufs supports customize [http](../../internet/HTTP.md) log format with option `--log-format`.
|
||||||
|
|
||||||
The log format can use following variables.
|
The log format can use following variables.
|
||||||
|
|
||||||
|
@ -91,13 +91,13 @@ The log format can use following variables.
|
||||||
| `$status` | response status |
|
| `$status` | response status |
|
||||||
| `$http_` | arbitrary request header field. examples: `$http_user_agent`, `$http_referer` |
|
| `$http_` | arbitrary request header field. examples: `$http_user_agent`, `$http_referer` |
|
||||||
|
|
||||||
The default log format is `'$remote_addr "$request" $status'`.
|
The default log format is `'$remote_addr "$request" $status'`.
|
||||||
```
|
```
|
||||||
2022-08-06T06:59:31+08:00 INFO - 127.0.0.1 "GET /" 200
|
2022-08-06T06:59:31+08:00 INFO - 127.0.0.1 "GET /" 200
|
||||||
```
|
```
|
||||||
|
|
||||||
### Environment variables
|
### Environment variables
|
||||||
All options can be set using [environment variables](../../linux/Environment%20Variables.md) prefixed with `DUFS_`.
|
All options can be set using [environment variables](../../linux/Environment%20Variables.md) prefixed with `DUFS_`.
|
||||||
|
|
||||||
| Option | Environment Variable |
|
| Option | Environment Variable |
|
||||||
| ----------------------- | ---------------------------- |
|
| ----------------------- | ---------------------------- |
|
||||||
|
@ -124,7 +124,7 @@ All options can be set using [environment variables](../../linux/Environment%20V
|
||||||
| `--tls-key <path>` | DUFS_TLS_KEY=key.pem |
|
| `--tls-key <path>` | DUFS_TLS_KEY=key.pem |
|
||||||
|
|
||||||
### Configuration File
|
### Configuration File
|
||||||
You can specify and use the configuration file by selecting the option `--config <path-to-config.yaml>`.
|
You can specify and use the configuration file by selecting the option `--config <path-to-config.yaml>`.
|
||||||
|
|
||||||
The following are the configuration items:
|
The following are the configuration items:
|
||||||
```yaml
|
```yaml
|
||||||
|
|
|
@ -20,7 +20,7 @@ git config --global user.email "johndoe@example.com"
|
||||||
```
|
```
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
A Git repository is contained in a `.git` directory, which holds the revision history and other metadata. The directory tracked by the repository, by default the parent directory, is called the working directory. Changes in the working tree need to be staged before they can be recorded (committed) to the repository. Git also lets you restore, previously committed, working tree files.
|
A Git repository is contained in a `.git` directory, which holds the revision history and other metadata. The directory tracked by the repository, by default the parent directory, is called the working directory. Changes in the working tree need to be staged before they can be recorded (committed) to the repository. Git also lets you restore, previously committed, working tree files.
|
||||||
|
|
||||||
### Git repository
|
### Git repository
|
||||||
Initialize a repository
|
Initialize a repository
|
||||||
|
@ -32,7 +32,7 @@ git init -b main
|
||||||
|
|
||||||
Clone an existing repository
|
Clone an existing repository
|
||||||
```shell
|
```shell
|
||||||
git clone repository
|
git clone repository
|
||||||
git clone repository folder
|
git clone repository folder
|
||||||
git clone --recursive repository
|
git clone --recursive repository
|
||||||
git clone --bare repository
|
git clone --bare repository
|
||||||
|
@ -125,7 +125,7 @@ git checkout master
|
||||||
git merge branch
|
git merge branch
|
||||||
```
|
```
|
||||||
|
|
||||||
The changes will be merged if they do not conflict. Otherwise, Git will print an error message, and annotate files in the working tree to record the conflicts. The annotations can be displayed with `git diff`. Conflicts are resolved by editing the files to remove the annotations, and committing the final version.
|
The changes will be merged if they do not conflict. Otherwise, Git will print an error message, and annotate files in the working tree to record the conflicts. The annotations can be displayed with `git diff`. Conflicts are resolved by editing the files to remove the annotations, and committing the final version.
|
||||||
|
|
||||||
Any conflicts will look something like this:
|
Any conflicts will look something like this:
|
||||||
```
|
```
|
||||||
|
|
|
@ -8,7 +8,7 @@ GitHub Actions is a continuous integration and continuous delivery (CI/CD) platf
|
||||||
|
|
||||||
GitHub Actions goes beyond just DevOps and lets you run workflows when other events happen in your repository. For example, you can run a workflow to automatically add the appropriate labels whenever someone creates a new issue in your repository.
|
GitHub Actions goes beyond just DevOps and lets you run workflows when other events happen in your repository. For example, you can run a workflow to automatically add the appropriate labels whenever someone creates a new issue in your repository.
|
||||||
|
|
||||||
You can configure a GitHub Actions _workflow_ to be triggered when an _event_ occurs in your repository, such as a pull request being opened or an issue being created. Your workflow contains one or more _jobs_ which can run in sequential order or in parallel. Each job will run inside its own virtual machine _runner_, or inside a container, and has one or more _steps_ that either run a script that you define or run an _action_, which is a reusable extension that can simplify your workflow.
|
You can configure a GitHub Actions _workflow_ to be triggered when an _event_ occurs in your repository, such as a pull request being opened or an issue being created. Your workflow contains one or more _jobs_ which can run in sequential order or in parallel. Each job will run inside its own virtual machine _runner_, or inside a container, and has one or more _steps_ that either run a script that you define or run an _action_, which is a reusable extension that can simplify your workflow.
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
```yml
|
```yml
|
||||||
|
@ -37,7 +37,7 @@ jobs:
|
||||||
## Expressions
|
## Expressions
|
||||||
You can use expressions to programmatically set [environment variables](../linux/Environment%20Variables.md) in workflow files and access contexts. An expression can be any combination of literal values, references to a context, or functions. You can combine literals, context references, and functions using operators.
|
You can use expressions to programmatically set [environment variables](../linux/Environment%20Variables.md) in workflow files and access contexts. An expression can be any combination of literal values, references to a context, or functions. You can combine literals, context references, and functions using operators.
|
||||||
|
|
||||||
Expressions are commonly used with the conditional `if` keyword in a workflow file to determine whether a step should run. When an `if` conditional is `true`, the step will run.
|
Expressions are commonly used with the conditional `if` keyword in a workflow file to determine whether a step should run. When an `if` conditional is `true`, the step will run.
|
||||||
|
|
||||||
You need to use specific syntax to tell [GitHub](GitHub.md) to evaluate an expression rather than treat it as a string.
|
You need to use specific syntax to tell [GitHub](GitHub.md) to evaluate an expression rather than treat it as a string.
|
||||||
`${{ <expression> }}`
|
`${{ <expression> }}`
|
||||||
|
@ -49,35 +49,35 @@ Secrets passed to GitHub Actions can be used:
|
||||||
#### contains
|
#### contains
|
||||||
`contains( search, item )`
|
`contains( search, item )`
|
||||||
|
|
||||||
Returns `true` if `search` contains `item`. If `search` is an array, this function returns `true` if the `item` is an element in the array. If `search` is a string, this function returns `true` if the `item` is a substring of `search`. This function is not case sensitive. Casts values to a string.
|
Returns `true` if `search` contains `item`. If `search` is an array, this function returns `true` if the `item` is an element in the array. If `search` is a string, this function returns `true` if the `item` is a substring of `search`. This function is not case sensitive. Casts values to a string.
|
||||||
|
|
||||||
#### startsWith
|
#### startsWith
|
||||||
`startsWith( searchString, searchValue )`
|
`startsWith( searchString, searchValue )`
|
||||||
|
|
||||||
Returns `true` when `searchString` starts with `searchValue`. This function is not case sensitive. Casts values to a string.
|
Returns `true` when `searchString` starts with `searchValue`. This function is not case sensitive. Casts values to a string.
|
||||||
|
|
||||||
#### endsWith
|
#### endsWith
|
||||||
`endsWith( searchString, searchValue )`
|
`endsWith( searchString, searchValue )`
|
||||||
|
|
||||||
Returns `true` if `searchString` ends with `searchValue`. This function is not case sensitive. Casts values to a string.
|
Returns `true` if `searchString` ends with `searchValue`. This function is not case sensitive. Casts values to a string.
|
||||||
|
|
||||||
#### format
|
#### format
|
||||||
`format( string, replaceValue0, replaceValue1, ..., replaceValueN)`
|
`format( string, replaceValue0, replaceValue1, ..., replaceValueN)`
|
||||||
|
|
||||||
Replaces values in the `string`, with the variable `replaceValueN`. Variables in the `string` are specified using the `{N}` syntax, where `N` is an integer. You must specify at least one `replaceValue` and `string`. There is no maximum for the number of variables (`replaceValueN`) you can use. Escape curly braces using double braces.
|
Replaces values in the `string`, with the variable `replaceValueN`. Variables in the `string` are specified using the `{N}` syntax, where `N` is an integer. You must specify at least one `replaceValue` and `string`. There is no maximum for the number of variables (`replaceValueN`) you can use. Escape curly braces using double braces.
|
||||||
|
|
||||||
#### always
|
#### always
|
||||||
Causes the step to always execute, and returns `true`, even when canceled. The `always` expression is best used at the step level or on tasks that you expect to run even when a job is canceled. For example, you can use `always` to send logs even when a job is canceled.
|
Causes the step to always execute, and returns `true`, even when canceled. The `always` expression is best used at the step level or on tasks that you expect to run even when a job is canceled. For example, you can use `always` to send logs even when a job is canceled.
|
||||||
|
|
||||||
Example of `always`:
|
Example of `always`:
|
||||||
```yaml
|
```yaml
|
||||||
if: ${{ always() }}
|
if: ${{ always() }}
|
||||||
```
|
```
|
||||||
|
|
||||||
#### failure
|
#### failure
|
||||||
Returns `true` when any previous step of a job fails. If you have a chain of dependent jobs, `failure()` returns `true` if any ancestor job fails.
|
Returns `true` when any previous step of a job fails. If you have a chain of dependent jobs, `failure()` returns `true` if any ancestor job fails.
|
||||||
|
|
||||||
Example of `failure`:
|
Example of `failure`:
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
...
|
...
|
||||||
|
@ -89,25 +89,25 @@ steps:
|
||||||
## Workflows
|
## Workflows
|
||||||
A workflow is a configurable automated process that will run one or more jobs. Workflows are defined by a [YAML](../files/YAML.md) file checked in to your repository and will run when triggered by an event in your repository, or they can be triggered manually, or at a defined schedule.
|
A workflow is a configurable automated process that will run one or more jobs. Workflows are defined by a [YAML](../files/YAML.md) file checked in to your repository and will run when triggered by an event in your repository, or they can be triggered manually, or at a defined schedule.
|
||||||
|
|
||||||
Workflows are defined in the `.github/workflows` directory in a repository, and a repository can have multiple workflows, each of which can perform a different set of tasks. For example, you can have one workflow to build and test pull requests, another workflow to deploy your application every time a release is created, and still another workflow that adds a label every time someone opens a new issue.
|
Workflows are defined in the `.github/workflows` directory in a repository, and a repository can have multiple workflows, each of which can perform a different set of tasks. For example, you can have one workflow to build and test pull requests, another workflow to deploy your application every time a release is created, and still another workflow that adds a label every time someone opens a new issue.
|
||||||
|
|
||||||
### Syntax
|
### Syntax
|
||||||
#### `name`
|
#### `name`
|
||||||
The name of the workflow. [GitHub](GitHub.md) displays the names of your workflows under your repository's "Actions" tab. If you omit `name`, [GitHub](GitHub.md) displays the workflow file path relative to the root of the repository.
|
The name of the workflow. [GitHub](GitHub.md) displays the names of your workflows under your repository's "Actions" tab. If you omit `name`, [GitHub](GitHub.md) displays the workflow file path relative to the root of the repository.
|
||||||
|
|
||||||
#### `on`
|
#### `on`
|
||||||
To automatically trigger a workflow, use `on` to define which events can cause the workflow to run.
|
To automatically trigger a workflow, use `on` to define which events can cause the workflow to run.
|
||||||
|
|
||||||
You can define single or multiple events that can trigger a workflow, or set a time schedule. You can also restrict the execution of a workflow to only occur for specific files, tags, or branch changes. These options are described in the following sections.
|
You can define single or multiple events that can trigger a workflow, or set a time schedule. You can also restrict the execution of a workflow to only occur for specific files, tags, or branch changes. These options are described in the following sections.
|
||||||
|
|
||||||
**Using a single event:**
|
**Using a single event:**
|
||||||
For example, a workflow with the following `on` value will run when a push is made to any branch in the workflow's repository:
|
For example, a workflow with the following `on` value will run when a push is made to any branch in the workflow's repository:
|
||||||
```yaml
|
```yaml
|
||||||
on: push
|
on: push
|
||||||
```
|
```
|
||||||
|
|
||||||
**Using multiple events:**
|
**Using multiple events:**
|
||||||
You can specify a single event or multiple events. For example, a workflow with the following `on` value will run when a push is made to any branch in the repository or when someone forks the repository:
|
You can specify a single event or multiple events. For example, a workflow with the following `on` value will run when a push is made to any branch in the repository or when someone forks the repository:
|
||||||
```yaml
|
```yaml
|
||||||
on: [push, fork]
|
on: [push, fork]
|
||||||
```
|
```
|
||||||
|
@ -115,9 +115,9 @@ on: [push, fork]
|
||||||
If you specify multiple events, only one of those events needs to occur to trigger your workflow. If multiple triggering events for your workflow occur at the same time, multiple workflow runs will be triggered.
|
If you specify multiple events, only one of those events needs to occur to trigger your workflow. If multiple triggering events for your workflow occur at the same time, multiple workflow runs will be triggered.
|
||||||
|
|
||||||
**Using activity types:**
|
**Using activity types:**
|
||||||
Some events have activity types that give you more control over when your workflow should run. Use `on.<event_name>.types` to define the type of event activity that will trigger a workflow run.
|
Some events have activity types that give you more control over when your workflow should run. Use `on.<event_name>.types` to define the type of event activity that will trigger a workflow run.
|
||||||
|
|
||||||
For example, the `issue_comment` event has the `created`, `edited`, and `deleted` activity types. If your workflow triggers on the `label` event, it will run whenever a label is created, edited, or deleted. If you specify the `created` activity type for the `label` event, your workflow will run when a label is created but not when a label is edited or deleted.
|
For example, the `issue_comment` event has the `created`, `edited`, and `deleted` activity types. If your workflow triggers on the `label` event, it will run whenever a label is created, edited, or deleted. If you specify the `created` activity type for the `label` event, your workflow will run when a label is created but not when a label is edited or deleted.
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
label:
|
label:
|
||||||
|
@ -137,7 +137,7 @@ on:
|
||||||
**Using filters:**
|
**Using filters:**
|
||||||
Some events have filters that give you more control over when your workflow should run.
|
Some events have filters that give you more control over when your workflow should run.
|
||||||
|
|
||||||
For example, the `push` event has a `branches` filter that causes your workflow to run only when a push to a branch that matches the `branches` filter occurs, instead of when any push occurs.
|
For example, the `push` event has a `branches` filter that causes your workflow to run only when a push to a branch that matches the `branches` filter occurs, instead of when any push occurs.
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
|
@ -147,7 +147,7 @@ on:
|
||||||
```
|
```
|
||||||
|
|
||||||
#### `on.<event_name>.types`
|
#### `on.<event_name>.types`
|
||||||
Use `on.<event_name>.types` to define the type of activity that will trigger a workflow run. Most [GitHub](GitHub.md) events are triggered by more than one type of activity. For example, the `label` is triggered when a label is `created`, `edited`, or `deleted`. The `types` keyword enables you to narrow down activity that causes the workflow to run. When only one activity type triggers a [webhook](../internet/Webhook.md) event, the `types` keyword is unnecessary.
|
Use `on.<event_name>.types` to define the type of activity that will trigger a workflow run. Most [GitHub](GitHub.md) events are triggered by more than one type of activity. For example, the `label` is triggered when a label is `created`, `edited`, or `deleted`. The `types` keyword enables you to narrow down activity that causes the workflow to run. When only one activity type triggers a [webhook](../internet/Webhook.md) event, the `types` keyword is unnecessary.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
|
@ -156,7 +156,7 @@ on:
|
||||||
```
|
```
|
||||||
|
|
||||||
#### `on.schedule`
|
#### `on.schedule`
|
||||||
You can use `on.schedule` to define a time schedule for your workflows. You can schedule a workflow to run at specific UTC times using POSIX cron syntax. Scheduled workflows run on the latest commit on the default or base branch. The shortest interval you can run scheduled workflows is once every 5 minutes.
|
You can use `on.schedule` to define a time schedule for your workflows. You can schedule a workflow to run at specific UTC times using POSIX cron syntax. Scheduled workflows run on the latest commit on the default or base branch. The shortest interval you can run scheduled workflows is once every 5 minutes.
|
||||||
|
|
||||||
This example triggers the workflow every day at 5:30 and 17:30 UTC:
|
This example triggers the workflow every day at 5:30 and 17:30 UTC:
|
||||||
```yaml
|
```yaml
|
||||||
|
@ -166,7 +166,7 @@ on:
|
||||||
- cron: '30 5,17 * * *'
|
- cron: '30 5,17 * * *'
|
||||||
```
|
```
|
||||||
|
|
||||||
A single workflow can be triggered by multiple `schedule` events. You can access the schedule event that triggered the workflow through the `github.event.schedule` context. This example triggers the workflow to run at 5:30 UTC every Monday-Thursday, but skips the `Not on Monday or Wednesday` step on Monday and Wednesday.
|
A single workflow can be triggered by multiple `schedule` events. You can access the schedule event that triggered the workflow through the `github.event.schedule` context. This example triggers the workflow to run at 5:30 UTC every Monday-Thursday, but skips the `Not on Monday or Wednesday` step on Monday and Wednesday.
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
schedule:
|
schedule:
|
||||||
|
@ -185,31 +185,31 @@ jobs:
|
||||||
```
|
```
|
||||||
|
|
||||||
#### `on.workflow_dispatch`
|
#### `on.workflow_dispatch`
|
||||||
When using the `workflow_dispatch` event, you can manually run this workflow from the UI.
|
When using the `workflow_dispatch` event, you can manually run this workflow from the UI.
|
||||||
|
|
||||||
#### `env`
|
#### `env`
|
||||||
A `map` of variables that are available to the steps of all jobs in the workflow. You can also set variables that are only available to the steps of a single job or to a single step. For more information, see `jobs.<job_id>.env` and `jobs.<job_id>.steps[*].env`.
|
A `map` of variables that are available to the steps of all jobs in the workflow. You can also set variables that are only available to the steps of a single job or to a single step. For more information, see `jobs.<job_id>.env` and `jobs.<job_id>.steps[*].env`.
|
||||||
|
|
||||||
Variables in the `env` map cannot be defined in terms of other variables in the map.
|
Variables in the `env` map cannot be defined in terms of other variables in the map.
|
||||||
|
|
||||||
**Example of `env`:**
|
**Example of `env`:**
|
||||||
```yaml
|
```yaml
|
||||||
env:
|
env:
|
||||||
SERVER: production
|
SERVER: production
|
||||||
```
|
```
|
||||||
|
|
||||||
#### `jobs`
|
#### `jobs`
|
||||||
A workflow run is made up of one or more `jobs`, which run in parallel by default. To run jobs sequentially, you can define dependencies on other jobs using the `jobs.<job_id>.needs` keyword.
|
A workflow run is made up of one or more `jobs`, which run in parallel by default. To run jobs sequentially, you can define dependencies on other jobs using the `jobs.<job_id>.needs` keyword.
|
||||||
|
|
||||||
Each job runs in a runner environment specified by `runs-on`.
|
Each job runs in a runner environment specified by `runs-on`.
|
||||||
|
|
||||||
##### `jobs.<job_id>`
|
##### `jobs.<job_id>`
|
||||||
Use `jobs.<job_id>` to give your job a unique identifier. The key `job_id` is a string and its value is a map of the job's configuration data. You must replace `<job_id>` with a string that is unique to the `jobs` object. The `<job_id>` must start with a letter or `_` and contain only alphanumeric characters, `-`, or `_`.
|
Use `jobs.<job_id>` to give your job a unique identifier. The key `job_id` is a string and its value is a map of the job's configuration data. You must replace `<job_id>` with a string that is unique to the `jobs` object. The `<job_id>` must start with a letter or `_` and contain only alphanumeric characters, `-`, or `_`.
|
||||||
|
|
||||||
Use `jobs.<job_id>.name` to set a name for the job, which is displayed in the [GitHub](GitHub.md) UI.
|
Use `jobs.<job_id>.name` to set a name for the job, which is displayed in the [GitHub](GitHub.md) UI.
|
||||||
|
|
||||||
**Example: Creating jobs:**
|
**Example: Creating jobs:**
|
||||||
In this example, two jobs have been created, and their `job_id` values are `my_first_job` and `my_second_job`.
|
In this example, two jobs have been created, and their `job_id` values are `my_first_job` and `my_second_job`.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
jobs:
|
jobs:
|
||||||
|
@ -220,9 +220,9 @@ jobs:
|
||||||
```
|
```
|
||||||
|
|
||||||
##### `jobs.<job_id>.container`
|
##### `jobs.<job_id>.container`
|
||||||
Use `jobs.<job_id>.container` to create a container to run any steps in a job that don't already specify a container. If you have steps that use both script and container actions, the container actions will run as sibling containers on the same network with the same volume mounts.
|
Use `jobs.<job_id>.container` to create a container to run any steps in a job that don't already specify a container. If you have steps that use both script and container actions, the container actions will run as sibling containers on the same network with the same volume mounts.
|
||||||
|
|
||||||
If you do not set a `container`, all steps will run directly on the host specified by `runs-on` unless a step refers to an action configured to run in a container.
|
If you do not set a `container`, all steps will run directly on the host specified by `runs-on` unless a step refers to an action configured to run in a container.
|
||||||
|
|
||||||
**Example: Running a job within a container:**
|
**Example: Running a job within a container:**
|
||||||
```yaml
|
```yaml
|
||||||
|
@ -247,7 +247,7 @@ jobs:
|
||||||
run: (ls /.dockerenv && echo Found dockerenv) || (echo No dockerenv)
|
run: (ls /.dockerenv && echo Found dockerenv) || (echo No dockerenv)
|
||||||
```
|
```
|
||||||
|
|
||||||
When you only specify a container image, you can omit the `image` keyword.
|
When you only specify a container image, you can omit the `image` keyword.
|
||||||
```yaml
|
```yaml
|
||||||
jobs:
|
jobs:
|
||||||
container-test-job:
|
container-test-job:
|
||||||
|
@ -256,7 +256,7 @@ jobs:
|
||||||
```
|
```
|
||||||
|
|
||||||
##### `jobs.<job_id>.needs`
|
##### `jobs.<job_id>.needs`
|
||||||
Use `jobs.<job_id>.needs` to identify any jobs that must complete successfully before this job will run. It can be a string or array of strings. If a job fails or is skipped, all jobs that need it are skipped unless the jobs use a conditional expression that causes the job to continue. If a run contains a series of jobs that need each other, a failure or skip applies to all jobs in the dependency chain from the point of failure or skip onwards. If you would like a job to run even if a job it is dependent on did not succeed, use the `always()` conditional expression in `jobs.<job_id>.if`.
|
Use `jobs.<job_id>.needs` to identify any jobs that must complete successfully before this job will run. It can be a string or array of strings. If a job fails or is skipped, all jobs that need it are skipped unless the jobs use a conditional expression that causes the job to continue. If a run contains a series of jobs that need each other, a failure or skip applies to all jobs in the dependency chain from the point of failure or skip onwards. If you would like a job to run even if a job it is dependent on did not succeed, use the `always()` conditional expression in `jobs.<job_id>.if`.
|
||||||
|
|
||||||
**Example: Requiring successful dependent jobs:**
|
**Example: Requiring successful dependent jobs:**
|
||||||
```yaml
|
```yaml
|
||||||
|
@ -269,11 +269,11 @@ jobs:
|
||||||
```
|
```
|
||||||
|
|
||||||
##### `jobs.<job_id>.if`
|
##### `jobs.<job_id>.if`
|
||||||
You can use the `jobs.<job_id>.if` conditional to prevent a job from running unless a condition is met. You can use any supported context and expression to create a conditional.
|
You can use the `jobs.<job_id>.if` conditional to prevent a job from running unless a condition is met. You can use any supported context and expression to create a conditional.
|
||||||
|
|
||||||
When you use expressions in an `if` conditional, you can, optionally, omit the `${{ }}` expression syntax because GitHub Actions automatically evaluates the `if` conditional as an expression. However, this exception does not apply everywhere.
|
When you use expressions in an `if` conditional, you can, optionally, omit the `${{ }}` expression syntax because GitHub Actions automatically evaluates the `if` conditional as an expression. However, this exception does not apply everywhere.
|
||||||
|
|
||||||
You must always use the `${{ }}` expression syntax or escape with `''`, `""`, or `()` when the expression starts with `!`, since `!` is reserved notation in [YAML](../files/YAML.md) format. For example:
|
You must always use the `${{ }}` expression syntax or escape with `''`, `""`, or `()` when the expression starts with `!`, since `!` is reserved notation in [YAML](../files/YAML.md) format. For example:
|
||||||
```yaml
|
```yaml
|
||||||
if: ${{ ! startsWith(github.ref, 'refs/tags/') }}
|
if: ${{ ! startsWith(github.ref, 'refs/tags/') }}
|
||||||
```
|
```
|
||||||
|
@ -281,15 +281,15 @@ if: ${{ ! startsWith(github.ref, 'refs/tags/') }}
|
||||||
For more information, see "Expressions."
|
For more information, see "Expressions."
|
||||||
|
|
||||||
##### `jobs.<job_id>.runs-on`
|
##### `jobs.<job_id>.runs-on`
|
||||||
Use `jobs.<job_id>.runs-on` to define the type of machine to run the job on.
|
Use `jobs.<job_id>.runs-on` to define the type of machine to run the job on.
|
||||||
|
|
||||||
##### `jobs.<job_id>.env`
|
##### `jobs.<job_id>.env`
|
||||||
A `map` of variables that are available to all steps in the job. You can set variables for the entire workflow or an individual step.
|
A `map` of variables that are available to all steps in the job. You can set variables for the entire workflow or an individual step.
|
||||||
|
|
||||||
##### `jobs.<job_id>.steps`
|
##### `jobs.<job_id>.steps`
|
||||||
A job contains a sequence of tasks called `steps`. Steps can run commands, run setup tasks, or run an action in your repository, a public repository, or an action published in a [Docker](../tools/Docker.md) registry. Not all steps run actions, but all actions run as a step. Each step runs in its own process in the runner environment and has access to the workspace and filesystem. Because steps run in their own process, changes to [environment variables](../linux/Environment%20Variables.md) are not preserved between steps. [GitHub](GitHub.md) provides built-in steps to set up and complete a job.
|
A job contains a sequence of tasks called `steps`. Steps can run commands, run setup tasks, or run an action in your repository, a public repository, or an action published in a [Docker](../tools/Docker.md) registry. Not all steps run actions, but all actions run as a step. Each step runs in its own process in the runner environment and has access to the workspace and filesystem. Because steps run in their own process, changes to [environment variables](../linux/Environment%20Variables.md) are not preserved between steps. [GitHub](GitHub.md) provides built-in steps to set up and complete a job.
|
||||||
|
|
||||||
**Example of `jobs.<job_id>.steps`:**
|
**Example of `jobs.<job_id>.steps`:**
|
||||||
```yaml
|
```yaml
|
||||||
name: Greeting from Mona
|
name: Greeting from Mona
|
||||||
|
|
||||||
|
@ -311,13 +311,13 @@ jobs:
|
||||||
```
|
```
|
||||||
|
|
||||||
- `jobs.<job_id>.steps[*].if`
|
- `jobs.<job_id>.steps[*].if`
|
||||||
You can use the `if` conditional to prevent a step from running unless a condition is met. You can use any supported context and expression to create a conditional.
|
You can use the `if` conditional to prevent a step from running unless a condition is met. You can use any supported context and expression to create a conditional.
|
||||||
- `jobs.<job_id>.steps[*].name`
|
- `jobs.<job_id>.steps[*].name`
|
||||||
A name for your step to display on [GitHub](GitHub.md).
|
A name for your step to display on [GitHub](GitHub.md).
|
||||||
- `jobs.<job_id>.steps[*].uses`
|
- `jobs.<job_id>.steps[*].uses`
|
||||||
Selects an action to run as part of a step in your job. An action is a reusable unit of code. You can use an action defined in the same repository as the workflow, a public repository, or in a published [Docker](../tools/Docker.md) container image.
|
Selects an action to run as part of a step in your job. An action is a reusable unit of code. You can use an action defined in the same repository as the workflow, a public repository, or in a published [Docker](../tools/Docker.md) container image.
|
||||||
|
|
||||||
Some actions require inputs that you must set using the `with` keyword. Review the action's README file to determine the inputs required.
|
Some actions require inputs that you must set using the `with` keyword. Review the action's README file to determine the inputs required.
|
||||||
|
|
||||||
**Example: Using versioned actions**
|
**Example: Using versioned actions**
|
||||||
```yaml
|
```yaml
|
||||||
|
@ -332,9 +332,9 @@ steps:
|
||||||
- uses: actions/checkout@main
|
- uses: actions/checkout@main
|
||||||
```
|
```
|
||||||
- `jobs.<job_id>.steps[*].run`
|
- `jobs.<job_id>.steps[*].run`
|
||||||
Runs command-line programs using the operating system's [shell](../applications/cli/Shell.md). If you do not provide a `name`, the step name will default to the text specified in the `run` command. Commands run using non-login shells by default.
|
Runs command-line programs using the operating system's [shell](../applications/cli/Shell.md). If you do not provide a `name`, the step name will default to the text specified in the `run` command. Commands run using non-login shells by default.
|
||||||
|
|
||||||
Each `run` keyword represents a new process and [shell](../applications/cli/Shell.md) in the runner environment. When you provide multi-line commands, each line runs in the same [shell](../applications/cli/Shell.md). For example:
|
Each `run` keyword represents a new process and [shell](../applications/cli/Shell.md) in the runner environment. When you provide multi-line commands, each line runs in the same [shell](../applications/cli/Shell.md). For example:
|
||||||
|
|
||||||
A single-line command:
|
A single-line command:
|
||||||
```yaml
|
```yaml
|
||||||
|
@ -350,7 +350,7 @@ A multi-line command:
|
||||||
npm run build
|
npm run build
|
||||||
```
|
```
|
||||||
- `jobs.<job_id>.steps[*].working-directory`
|
- `jobs.<job_id>.steps[*].working-directory`
|
||||||
Using the `working-directory` keyword, you can specify the working directory of where to run the command.
|
Using the `working-directory` keyword, you can specify the working directory of where to run the command.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- name: Clean temp directory
|
- name: Clean temp directory
|
||||||
|
@ -358,13 +358,13 @@ Using the `working-directory` keyword, you can specify the working directory o
|
||||||
working-directory: ./temp
|
working-directory: ./temp
|
||||||
```
|
```
|
||||||
- `jobs.<job_id>.steps[*].with`
|
- `jobs.<job_id>.steps[*].with`
|
||||||
A `map` of the input parameters defined by the action. Each input parameter is a key/value pair. Input parameters are set as [environment variables](../linux/Environment%20Variables.md). The variable is prefixed with `INPUT_` and converted to upper case.
|
A `map` of the input parameters defined by the action. Each input parameter is a key/value pair. Input parameters are set as [environment variables](../linux/Environment%20Variables.md). The variable is prefixed with `INPUT_` and converted to upper case.
|
||||||
|
|
||||||
Input parameters defined for a [Docker](../tools/Docker.md) container must use `args`. For more information, see "`jobs.<job_id>.steps[*].with.args`."
|
Input parameters defined for a [Docker](../tools/Docker.md) container must use `args`. For more information, see "`jobs.<job_id>.steps[*].with.args`."
|
||||||
|
|
||||||
**Example of `jobs.<job_id>.steps[*].with`
|
**Example of `jobs.<job_id>.steps[*].with`
|
||||||
|
|
||||||
Defines the three input parameters (`first_name`, `middle_name`, and `last_name`) defined by the `hello_world` action. These input variables will be accessible to the `hello-world` action as `INPUT_FIRST_NAME`, `INPUT_MIDDLE_NAME`, and `INPUT_LAST_NAME` [environment variables](../linux/Environment%20Variables.md).
|
Defines the three input parameters (`first_name`, `middle_name`, and `last_name`) defined by the `hello_world` action. These input variables will be accessible to the `hello-world` action as `INPUT_FIRST_NAME`, `INPUT_MIDDLE_NAME`, and `INPUT_LAST_NAME` [environment variables](../linux/Environment%20Variables.md).
|
||||||
```yaml
|
```yaml
|
||||||
jobs:
|
jobs:
|
||||||
my_first_job:
|
my_first_job:
|
||||||
|
@ -377,15 +377,15 @@ jobs:
|
||||||
last_name: Octocat
|
last_name: Octocat
|
||||||
```
|
```
|
||||||
- `jobs.<job_id>.steps[*].with.args`
|
- `jobs.<job_id>.steps[*].with.args`
|
||||||
A `string` that defines the inputs for a [Docker](../tools/Docker.md) container. [GitHub](GitHub.md) passes the `args` to the container's `ENTRYPOINT` when the container starts up. An `array of strings` is not supported by this parameter. A single argument that includes spaces should be surrounded by double quotes `""`.
|
A `string` that defines the inputs for a [Docker](../tools/Docker.md) container. [GitHub](GitHub.md) passes the `args` to the container's `ENTRYPOINT` when the container starts up. An `array of strings` is not supported by this parameter. A single argument that includes spaces should be surrounded by double quotes `""`.
|
||||||
- `jobs.<job_id>.steps[*].env`
|
- `jobs.<job_id>.steps[*].env`
|
||||||
Sets variables for steps to use in the runner environment. You can also set variables for the entire workflow or a job. For more information, see `env` and `jobs.<job_id>.env`.
|
Sets variables for steps to use in the runner environment. You can also set variables for the entire workflow or a job. For more information, see `env` and `jobs.<job_id>.env`.
|
||||||
|
|
||||||
When more than one environment variable is defined with the same name, [GitHub](GitHub.md) uses the most specific variable. For example, an environment variable defined in a step will override job and workflow [environment variables](../linux/Environment%20Variables.md) with the same name, while the step executes. An environment variable defined for a job will override a workflow variable with the same name, while the job executes.
|
When more than one environment variable is defined with the same name, [GitHub](GitHub.md) uses the most specific variable. For example, an environment variable defined in a step will override job and workflow [environment variables](../linux/Environment%20Variables.md) with the same name, while the step executes. An environment variable defined for a job will override a workflow variable with the same name, while the job executes.
|
||||||
|
|
||||||
Public actions may specify expected variables in the README file. If you are setting a secret or sensitive value, such as a password or token, you must set secrets using the `secrets` context.
|
Public actions may specify expected variables in the README file. If you are setting a secret or sensitive value, such as a password or token, you must set secrets using the `secrets` context.
|
||||||
|
|
||||||
**Example of `jobs.<job_id>.steps[*].env`**
|
**Example of `jobs.<job_id>.steps[*].env`**
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
- name: My first action
|
- name: My first action
|
||||||
|
@ -396,12 +396,12 @@ steps:
|
||||||
```
|
```
|
||||||
|
|
||||||
## Events
|
## Events
|
||||||
An event is a specific activity in a repository that triggers a workflow run. For example, activity can originate from [GitHub](GitHub.md) when someone creates a pull request, opens an issue, or pushes a commit to a repository. You can also trigger a workflow to run on a schedule, by posting to a REST API, or manually.
|
An event is a specific activity in a repository that triggers a workflow run. For example, activity can originate from [GitHub](GitHub.md) when someone creates a pull request, opens an issue, or pushes a commit to a repository. You can also trigger a workflow to run on a schedule, by posting to a REST API, or manually.
|
||||||
|
|
||||||
### `create`
|
### `create`
|
||||||
Runs your workflow when someone creates a [Git](Git.md) reference ([Git](Git.md) branch or tag) in the workflow's repository.
|
Runs your workflow when someone creates a [Git](Git.md) reference ([Git](Git.md) branch or tag) in the workflow's repository.
|
||||||
|
|
||||||
For example, you can run a workflow when the `create` event occurs.
|
For example, you can run a workflow when the `create` event occurs.
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
create
|
create
|
||||||
|
@ -410,7 +410,7 @@ on:
|
||||||
### `delete`
|
### `delete`
|
||||||
Runs your workflow when someone deletes a [Git](Git.md) reference ([Git](Git.md) branch or tag) in the workflow's repository.
|
Runs your workflow when someone deletes a [Git](Git.md) reference ([Git](Git.md) branch or tag) in the workflow's repository.
|
||||||
|
|
||||||
For example, you can run a workflow when the `delete` event occurs.
|
For example, you can run a workflow when the `delete` event occurs.
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
delete
|
delete
|
||||||
|
@ -420,21 +420,21 @@ on:
|
||||||
Runs your workflow when a discussion in the workflow's repository is created or modified.
|
Runs your workflow when a discussion in the workflow's repository is created or modified.
|
||||||
|
|
||||||
Activity Types:
|
Activity Types:
|
||||||
- `created`
|
- `created`
|
||||||
- `edited`
|
- `edited`
|
||||||
- `deleted`
|
- `deleted`
|
||||||
- `transferred`
|
- `transferred`
|
||||||
- `pinned`
|
- `pinned`
|
||||||
- `unpinned`
|
- `unpinned`
|
||||||
- `labeled`
|
- `labeled`
|
||||||
- `unlabeled`
|
- `unlabeled`
|
||||||
- `locked`
|
- `locked`
|
||||||
- `unlocked`
|
- `unlocked`
|
||||||
- `category_changed`
|
- `category_changed`
|
||||||
- `answered`
|
- `answered`
|
||||||
- `unanswered`
|
- `unanswered`
|
||||||
|
|
||||||
For example, you can run a workflow when a discussion has been `created`, `edited`, or `answered`.
|
For example, you can run a workflow when a discussion has been `created`, `edited`, or `answered`.
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
discussion:
|
discussion:
|
||||||
|
@ -445,11 +445,11 @@ on:
|
||||||
Runs your workflow when a comment on a discussion in the workflow's repository is created or modified.
|
Runs your workflow when a comment on a discussion in the workflow's repository is created or modified.
|
||||||
|
|
||||||
Activity Types:
|
Activity Types:
|
||||||
- `created`
|
- `created`
|
||||||
- `edited`
|
- `edited`
|
||||||
- `deleted`
|
- `deleted`
|
||||||
|
|
||||||
For example, you can run a workflow when a discussion comment has been `created` or `deleted`.
|
For example, you can run a workflow when a discussion comment has been `created` or `deleted`.
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
discussion_comment:
|
discussion_comment:
|
||||||
|
@ -459,7 +459,7 @@ on:
|
||||||
### `fork`
|
### `fork`
|
||||||
Runs your workflow when someone forks a repository.
|
Runs your workflow when someone forks a repository.
|
||||||
|
|
||||||
For example, you can run a workflow when the `fork` event occurs.
|
For example, you can run a workflow when the `fork` event occurs.
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
fork
|
fork
|
||||||
|
@ -469,11 +469,11 @@ on:
|
||||||
Runs your workflow when an issue or pull request comment is created, edited, or deleted.
|
Runs your workflow when an issue or pull request comment is created, edited, or deleted.
|
||||||
|
|
||||||
Activity Types:
|
Activity Types:
|
||||||
- `created`
|
- `created`
|
||||||
- `edited`
|
- `edited`
|
||||||
- `deleted`
|
- `deleted`
|
||||||
|
|
||||||
For example, you can run a workflow when an issue or pull request comment has been `created` or `deleted`.
|
For example, you can run a workflow when an issue or pull request comment has been `created` or `deleted`.
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
issue_comment:
|
issue_comment:
|
||||||
|
@ -484,24 +484,24 @@ on:
|
||||||
Runs your workflow when an issue in the workflow's repository is created or modified.
|
Runs your workflow when an issue in the workflow's repository is created or modified.
|
||||||
|
|
||||||
Activity Types:
|
Activity Types:
|
||||||
- `opened`
|
- `opened`
|
||||||
- `edited`
|
- `edited`
|
||||||
- `deleted`
|
- `deleted`
|
||||||
- `transferred`
|
- `transferred`
|
||||||
- `pinned`
|
- `pinned`
|
||||||
- `unpinned`
|
- `unpinned`
|
||||||
- `closed`
|
- `closed`
|
||||||
- `reopened`
|
- `reopened`
|
||||||
- `assigned`
|
- `assigned`
|
||||||
- `unassigned`
|
- `unassigned`
|
||||||
- `labeled`
|
- `labeled`
|
||||||
- `unlabeled`
|
- `unlabeled`
|
||||||
- `locked`
|
- `locked`
|
||||||
- `unlocked`
|
- `unlocked`
|
||||||
- `milestoned`
|
- `milestoned`
|
||||||
- `demilestoned`
|
- `demilestoned`
|
||||||
|
|
||||||
For example, you can run a workflow when an issue has been `opened`, `edited`, or `milestoned`.
|
For example, you can run a workflow when an issue has been `opened`, `edited`, or `milestoned`.
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
issues:
|
issues:
|
||||||
|
@ -512,13 +512,13 @@ on:
|
||||||
Runs your workflow when a milestone in the workflow's repository is created or modified.
|
Runs your workflow when a milestone in the workflow's repository is created or modified.
|
||||||
|
|
||||||
Activity Types:
|
Activity Types:
|
||||||
- `created`
|
- `created`
|
||||||
- `closed`
|
- `closed`
|
||||||
- `opened`
|
- `opened`
|
||||||
- `edited`
|
- `edited`
|
||||||
- `deleted`
|
- `deleted`
|
||||||
|
|
||||||
For example, you can run a workflow when a milestone has been `opened` or `deleted`.
|
For example, you can run a workflow when a milestone has been `opened` or `deleted`.
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
milestone:
|
milestone:
|
||||||
|
@ -529,25 +529,25 @@ on:
|
||||||
Runs your workflow when activity on a pull request in the workflow's repository occurs. For example, if no activity types are specified, the workflow runs when a pull request is opened or reopened or when the head branch of the pull request is updated.
|
Runs your workflow when activity on a pull request in the workflow's repository occurs. For example, if no activity types are specified, the workflow runs when a pull request is opened or reopened or when the head branch of the pull request is updated.
|
||||||
|
|
||||||
Activity Types:
|
Activity Types:
|
||||||
- `assigned`
|
- `assigned`
|
||||||
- `unassigned`
|
- `unassigned`
|
||||||
- `labeled`
|
- `labeled`
|
||||||
- `unlabeled`
|
- `unlabeled`
|
||||||
- `opened`
|
- `opened`
|
||||||
- `edited`
|
- `edited`
|
||||||
- `closed`
|
- `closed`
|
||||||
- `reopened`
|
- `reopened`
|
||||||
- `synchronize`
|
- `synchronize`
|
||||||
- `converted_to_draft`
|
- `converted_to_draft`
|
||||||
- `ready_for_review`
|
- `ready_for_review`
|
||||||
- `locked`
|
- `locked`
|
||||||
- `unlocked`
|
- `unlocked`
|
||||||
- `milestoned`
|
- `milestoned`
|
||||||
- `demilestoned`
|
- `demilestoned`
|
||||||
- `review_requested`
|
- `review_requested`
|
||||||
- `review_request_removed`
|
- `review_request_removed`
|
||||||
- `auto_merge_enabled`
|
- `auto_merge_enabled`
|
||||||
- `auto_merge_disabled`
|
- `auto_merge_disabled`
|
||||||
|
|
||||||
For example, you can run a workflow when a pull request has been opened or reopened.
|
For example, you can run a workflow when a pull request has been opened or reopened.
|
||||||
```yaml
|
```yaml
|
||||||
|
@ -559,11 +559,11 @@ on:
|
||||||
### `push`
|
### `push`
|
||||||
Runs your workflow when you push a commit or tag, or when you create a repository from a template.
|
Runs your workflow when you push a commit or tag, or when you create a repository from a template.
|
||||||
|
|
||||||
You can use the `branches` or `branches-ignore` filter to configure your workflow to only run when specific branches are pushed.
|
You can use the `branches` or `branches-ignore` filter to configure your workflow to only run when specific branches are pushed.
|
||||||
|
|
||||||
You can use the `tags` or `tags-ignore` filter to configure your workflow to only run when specific tags are pushed.
|
You can use the `tags` or `tags-ignore` filter to configure your workflow to only run when specific tags are pushed.
|
||||||
|
|
||||||
If you use both the `branches` filter and the `paths` filter, the workflow will only run when both filters are satisfied. For example, the following workflow will only run when a push that includes a change to a JavaScript (`.js`) file is made to a branch whose name starts with `releases/`:
|
If you use both the `branches` filter and the `paths` filter, the workflow will only run when both filters are satisfied. For example, the following workflow will only run when a push that includes a change to a JavaScript (`.js`) file is made to a branch whose name starts with `releases/`:
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
|
@ -573,7 +573,7 @@ on:
|
||||||
- '**.js'
|
- '**.js'
|
||||||
```
|
```
|
||||||
|
|
||||||
For example, you can run a workflow when the `push` event occurs.
|
For example, you can run a workflow when the `push` event occurs.
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
push
|
push
|
||||||
|
@ -583,15 +583,15 @@ on:
|
||||||
Runs your workflow when release activity in your repository occurs.
|
Runs your workflow when release activity in your repository occurs.
|
||||||
|
|
||||||
Activity Types:
|
Activity Types:
|
||||||
- `published`
|
- `published`
|
||||||
- `unpublished`
|
- `unpublished`
|
||||||
- `created`
|
- `created`
|
||||||
- `edited`
|
- `edited`
|
||||||
- `deleted`
|
- `deleted`
|
||||||
- `prereleased`
|
- `prereleased`
|
||||||
- `released`
|
- `released`
|
||||||
|
|
||||||
For example, you can run a workflow when a release has been `published`.
|
For example, you can run a workflow when a release has been `published`.
|
||||||
```yaml
|
```yaml
|
||||||
on:
|
on:
|
||||||
release:
|
release:
|
||||||
|
@ -599,9 +599,9 @@ on:
|
||||||
```
|
```
|
||||||
|
|
||||||
### `schedule`
|
### `schedule`
|
||||||
The `schedule` event allows you to trigger a workflow at a scheduled time.
|
The `schedule` event allows you to trigger a workflow at a scheduled time.
|
||||||
|
|
||||||
You can schedule a workflow to run at specific UTC times using POSIX cron syntax. Scheduled workflows run on the latest commit on the default or base branch. The shortest interval you can run scheduled workflows is once every 5 minutes. A single workflow can be triggered by multiple `schedule` events. You can access the schedule event that triggered the workflow through the `github.event.schedule` context.
|
You can schedule a workflow to run at specific UTC times using POSIX cron syntax. Scheduled workflows run on the latest commit on the default or base branch. The shortest interval you can run scheduled workflows is once every 5 minutes. A single workflow can be triggered by multiple `schedule` events. You can access the schedule event that triggered the workflow through the `github.event.schedule` context.
|
||||||
|
|
||||||
This example triggers the workflow every day at 5:30 and 17:30 UTC:
|
This example triggers the workflow every day at 5:30 and 17:30 UTC:
|
||||||
```yaml
|
```yaml
|
||||||
|
@ -612,18 +612,18 @@ on:
|
||||||
```
|
```
|
||||||
|
|
||||||
### `workflow_dispatch`
|
### `workflow_dispatch`
|
||||||
To enable a workflow to be triggered manually, you need to configure the `workflow_dispatch` event. You can manually trigger a workflow run using the [GitHub](GitHub.md) API, [GitHub](GitHub.md) CLI, or [GitHub](GitHub.md) browser interface.
|
To enable a workflow to be triggered manually, you need to configure the `workflow_dispatch` event. You can manually trigger a workflow run using the [GitHub](GitHub.md) API, [GitHub](GitHub.md) CLI, or [GitHub](GitHub.md) browser interface.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
on: workflow_dispatch
|
on: workflow_dispatch
|
||||||
```
|
```
|
||||||
|
|
||||||
## Jobs
|
## Jobs
|
||||||
A job is a set of _steps_ in a workflow that is executed on the same runner. Each step is either a [shell](../applications/cli/Shell.md) script that will be executed, or an _action_ that will be run. Steps are executed in order and are dependent on each other. Since each step is executed on the same runner, you can share data from one step to another. For example, you can have a step that builds your application followed by a step that tests the application that was built.
|
A job is a set of _steps_ in a workflow that is executed on the same runner. Each step is either a [shell](../applications/cli/Shell.md) script that will be executed, or an _action_ that will be run. Steps are executed in order and are dependent on each other. Since each step is executed on the same runner, you can share data from one step to another. For example, you can have a step that builds your application followed by a step that tests the application that was built.
|
||||||
|
|
||||||
You can configure a job's dependencies with other jobs; by default, jobs have no dependencies and run in parallel with each other. When a job takes a dependency on another job, it will wait for the dependent job to complete before it can run. For example, you may have multiple build jobs for different architectures that have no dependencies, and a packaging job that is dependent on those jobs. The build jobs will run in parallel, and when they have all completed successfully, the packaging job will run.
|
You can configure a job's dependencies with other jobs; by default, jobs have no dependencies and run in parallel with each other. When a job takes a dependency on another job, it will wait for the dependent job to complete before it can run. For example, you may have multiple build jobs for different architectures that have no dependencies, and a packaging job that is dependent on those jobs. The build jobs will run in parallel, and when they have all completed successfully, the packaging job will run.
|
||||||
|
|
||||||
## Actions
|
## Actions
|
||||||
An _action_ is a custom application for the GitHub Actions platform that performs a complex but frequently repeated task. Use an action to help reduce the amount of repetitive code that you write in your workflow files. An action can pull your [git](Git.md) repository from [GitHub](GitHub.md), set up the correct toolchain for your build environment, or set up the authentication to your cloud provider.
|
An _action_ is a custom application for the GitHub Actions platform that performs a complex but frequently repeated task. Use an action to help reduce the amount of repetitive code that you write in your workflow files. An action can pull your [git](Git.md) repository from [GitHub](GitHub.md), set up the correct toolchain for your build environment, or set up the authentication to your cloud provider.
|
||||||
|
|
||||||
You can write your own actions, or you can find actions to use in your workflows in the GitHub Marketplace.
|
You can write your own actions, or you can find actions to use in your workflows in the GitHub Marketplace.
|
|
@ -79,7 +79,7 @@ Conditionals like `if` and `match` can be used, while `match` can do more powerf
|
||||||
let age = 20;
|
let age = 20;
|
||||||
if age > 18 {
|
if age > 18 {
|
||||||
println!("Adult");
|
println!("Adult");
|
||||||
} else if age == 18 {
|
} else if age == 18 {
|
||||||
println!("Exactly 18");
|
println!("Exactly 18");
|
||||||
} else {
|
} else {
|
||||||
println!("Minor");
|
println!("Minor");
|
||||||
|
@ -156,7 +156,7 @@ struct Person {
|
||||||
|
|
||||||
impl Person {
|
impl Person {
|
||||||
fn new(first_name: &str) -> Self {
|
fn new(first_name: &str) -> Self {
|
||||||
Self {
|
Self {
|
||||||
first_name: first_name.to_string(),
|
first_name: first_name.to_string(),
|
||||||
age: 0
|
age: 0
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@ A database most often contains one or more tables. Each table is identified by a
|
||||||
Most of the actions you need to perform on a database are done with SQL statements.
|
Most of the actions you need to perform on a database are done with SQL statements.
|
||||||
Example:
|
Example:
|
||||||
```sql
|
```sql
|
||||||
SELECT * FROM Customers;
|
SELECT * FROM Customers;
|
||||||
```
|
```
|
||||||
|
|
||||||
### Comments
|
### Comments
|
||||||
|
@ -31,12 +31,12 @@ SELECT * FROM Customers;
|
||||||
```
|
```
|
||||||
|
|
||||||
## SELECT
|
## SELECT
|
||||||
The `SELECT` statement is used to select data from a database.
|
The `SELECT` statement is used to select data from a database.
|
||||||
|
|
||||||
Select:
|
Select:
|
||||||
```sql
|
```sql
|
||||||
SELECT column1, column2, ...
|
SELECT column1, column2, ...
|
||||||
FROM table_name;
|
FROM table_name;
|
||||||
```
|
```
|
||||||
|
|
||||||
Select all:
|
Select all:
|
||||||
|
@ -45,7 +45,7 @@ SELECT * FROM table
|
||||||
```
|
```
|
||||||
|
|
||||||
### SELECT DISTINC
|
### SELECT DISTINC
|
||||||
The `SELECT DISTINCT` statement is used to return only distinct (different) values.
|
The `SELECT DISTINCT` statement is used to return only distinct (different) values.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT DISTINCT Country FROM Customers;
|
SELECT DISTINCT Country FROM Customers;
|
||||||
|
@ -53,7 +53,7 @@ SELECT COUNT(DISTINCT Country) FROM Customers;
|
||||||
```
|
```
|
||||||
|
|
||||||
## WHERE
|
## WHERE
|
||||||
The `WHERE` clause is used to filter records.
|
The `WHERE` clause is used to filter records.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT column1, column2, ...
|
SELECT column1, column2, ...
|
||||||
|
@ -71,7 +71,7 @@ SELECT * FROM Customers
|
||||||
WHERE CustomerID=1;
|
WHERE CustomerID=1;
|
||||||
```
|
```
|
||||||
|
|
||||||
The following operators can be used in the `WHERE` clause:
|
The following operators can be used in the `WHERE` clause:
|
||||||
|
|
||||||
| Operator | Description |
|
| Operator | Description |
|
||||||
| -------- | ------------------------------------------------------------------------------- |
|
| -------- | ------------------------------------------------------------------------------- |
|
||||||
|
@ -80,17 +80,17 @@ The following operators can be used in the `WHERE` clause:
|
||||||
| < | Less than |
|
| < | Less than |
|
||||||
| >= | Greater than or equal |
|
| >= | Greater than or equal |
|
||||||
| <= | Less than or equal |
|
| <= | Less than or equal |
|
||||||
| <> | Not equal. **Note:** In some versions of SQL this operator may be written as != |
|
| <> | Not equal. **Note:** In some versions of SQL this operator may be written as != |
|
||||||
| BETWEEN | Between a certain range |
|
| BETWEEN | Between a certain range |
|
||||||
| LIKE | Search for a pattern |
|
| LIKE | Search for a pattern |
|
||||||
| IN | To specify multiple possible values for a column |
|
| IN | To specify multiple possible values for a column |
|
||||||
|
|
||||||
### LIKE
|
### LIKE
|
||||||
The `LIKE` operator is used in a `WHERE` clause to search for a specified pattern in a column.
|
The `LIKE` operator is used in a `WHERE` clause to search for a specified pattern in a column.
|
||||||
|
|
||||||
There are two wildcards often used in conjunction with the `LIKE` operator:
|
There are two wildcards often used in conjunction with the `LIKE` operator:
|
||||||
- The percent sign `%` represents zero, one, or multiple characters
|
- The percent sign `%` represents zero, one, or multiple characters
|
||||||
- The underscore sign `_` represents one, single character
|
- The underscore sign `_` represents one, single character
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT column1, column2, ...
|
SELECT column1, column2, ...
|
||||||
|
@ -99,72 +99,72 @@ WHERE columnN LIKE pattern;
|
||||||
```
|
```
|
||||||
|
|
||||||
#### The _ Wildcard
|
#### The _ Wildcard
|
||||||
The `_` wildcard represents a single character.
|
The `_` wildcard represents a single character.
|
||||||
It can be any character or number, but each `_` represents one, and only one, character.
|
It can be any character or number, but each `_` represents one, and only one, character.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT * FROM Customers
|
SELECT * FROM Customers
|
||||||
WHERE city LIKE 'L_nd__';
|
WHERE city LIKE 'L_nd__';
|
||||||
```
|
```
|
||||||
|
|
||||||
#### The % Wildcard
|
#### The % Wildcard
|
||||||
The `%` wildcard represents any number of characters, even zero characters.
|
The `%` wildcard represents any number of characters, even zero characters.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT * FROM Customers
|
SELECT * FROM Customers
|
||||||
WHERE city LIKE '%L%';
|
WHERE city LIKE '%L%';
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Starts With
|
#### Starts With
|
||||||
```sql
|
```sql
|
||||||
SELECT * FROM Customers
|
SELECT * FROM Customers
|
||||||
WHERE CustomerName LIKE 'La%';
|
WHERE CustomerName LIKE 'La%';
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Ends With
|
#### Ends With
|
||||||
```sql
|
```sql
|
||||||
SELECT * FROM Customers
|
SELECT * FROM Customers
|
||||||
WHERE CustomerName LIKE '%a';
|
WHERE CustomerName LIKE '%a';
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Contains
|
#### Contains
|
||||||
```sql
|
```sql
|
||||||
SELECT * FROM Customers
|
SELECT * FROM Customers
|
||||||
WHERE CustomerName LIKE '%or%';
|
WHERE CustomerName LIKE '%or%';
|
||||||
```
|
```
|
||||||
|
|
||||||
### IN
|
### IN
|
||||||
The `IN` operator allows you to specify multiple values in a `WHERE` clause.
|
The `IN` operator allows you to specify multiple values in a `WHERE` clause.
|
||||||
|
|
||||||
The `IN` operator is a shorthand for multiple `OR` conditions.
|
The `IN` operator is a shorthand for multiple `OR` conditions.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT * FROM Customers
|
SELECT * FROM Customers
|
||||||
WHERE Country IN ('Germany', 'France', 'UK');
|
WHERE Country IN ('Germany', 'France', 'UK');
|
||||||
```
|
```
|
||||||
|
|
||||||
Subquery:
|
Subquery:
|
||||||
```sql
|
```sql
|
||||||
SELECT * FROM Customers
|
SELECT * FROM Customers
|
||||||
WHERE CustomerID NOT IN (SELECT CustomerID FROM Orders);
|
WHERE CustomerID NOT IN (SELECT CustomerID FROM Orders);
|
||||||
```
|
```
|
||||||
|
|
||||||
### BETWEEN
|
### BETWEEN
|
||||||
The `BETWEEN` operator selects values within a given range. The values can be numbers, text, or dates.
|
The `BETWEEN` operator selects values within a given range. The values can be numbers, text, or dates.
|
||||||
|
|
||||||
The `BETWEEN` operator is inclusive: begin and end values are included.
|
The `BETWEEN` operator is inclusive: begin and end values are included.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT column_name(s)
|
SELECT column_name(s)
|
||||||
FROM table_name
|
FROM table_name
|
||||||
WHERE column_name BETWEEN value1 AND value2;
|
WHERE column_name BETWEEN value1 AND value2;
|
||||||
|
|
||||||
SELECT * FROM Orders
|
SELECT * FROM Orders
|
||||||
WHERE OrderDate BETWEEN '1996-07-01' AND '1996-07-31';
|
WHERE OrderDate BETWEEN '1996-07-01' AND '1996-07-31';
|
||||||
```
|
```
|
||||||
|
|
||||||
### AND
|
### AND
|
||||||
The `WHERE` clause can contain one or many `AND` operators.
|
The `WHERE` clause can contain one or many `AND` operators.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT *
|
SELECT *
|
||||||
|
@ -173,7 +173,7 @@ WHERE Country = 'Spain' AND CustomerName LIKE 'G%';
|
||||||
```
|
```
|
||||||
|
|
||||||
### OR
|
### OR
|
||||||
The `WHERE` clause can contain one or more `OR` operators.
|
The `WHERE` clause can contain one or more `OR` operators.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT *
|
SELECT *
|
||||||
|
@ -188,20 +188,20 @@ WHERE Country = 'Spain' AND (CustomerName LIKE 'G%' OR CustomerName LIKE 'R%');
|
||||||
```
|
```
|
||||||
|
|
||||||
### NOT
|
### NOT
|
||||||
The `NOT` operator is used in combination with other operators to give the opposite result, also called the negative result.
|
The `NOT` operator is used in combination with other operators to give the opposite result, also called the negative result.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT * FROM Customers
|
SELECT * FROM Customers
|
||||||
WHERE NOT Country = 'Spain';
|
WHERE NOT Country = 'Spain';
|
||||||
|
|
||||||
SELECT * FROM Customers
|
SELECT * FROM Customers
|
||||||
WHERE City NOT IN ('Paris', 'London');
|
WHERE City NOT IN ('Paris', 'London');
|
||||||
```
|
```
|
||||||
|
|
||||||
## ORDER BY
|
## ORDER BY
|
||||||
The `ORDER BY` keyword is used to sort the result-set in ascending or descending order.
|
The `ORDER BY` keyword is used to sort the result-set in ascending or descending order.
|
||||||
|
|
||||||
The `ORDER BY` keyword sorts the records in ascending order by default. To sort the records in descending order, use the `DESC` keyword.
|
The `ORDER BY` keyword sorts the records in ascending order by default. To sort the records in descending order, use the `DESC` keyword.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT column1, column2, ...
|
SELECT column1, column2, ...
|
||||||
|
@ -210,7 +210,7 @@ ORDER BY column1, column2, ... ASC|DESC;
|
||||||
```
|
```
|
||||||
|
|
||||||
## INSERT INTO
|
## INSERT INTO
|
||||||
The `INSERT INTO` statement is used to insert new records in a table.
|
The `INSERT INTO` statement is used to insert new records in a table.
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
```sql
|
```sql
|
||||||
|
@ -228,7 +228,7 @@ VALUES
|
||||||
```
|
```
|
||||||
|
|
||||||
## UPDATE
|
## UPDATE
|
||||||
The `UPDATE` statement is used to modify the existing records in a table.
|
The `UPDATE` statement is used to modify the existing records in a table.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
UPDATE table_name
|
UPDATE table_name
|
||||||
|
@ -237,7 +237,7 @@ WHERE condition;
|
||||||
```
|
```
|
||||||
|
|
||||||
## DELETE
|
## DELETE
|
||||||
The `DELETE` statement is used to delete existing records in a table.
|
The `DELETE` statement is used to delete existing records in a table.
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
```sql
|
```sql
|
||||||
|
@ -251,11 +251,11 @@ DELETE FROM table_name;
|
||||||
|
|
||||||
Delete Table:
|
Delete Table:
|
||||||
```sql
|
```sql
|
||||||
DROP TABLE table_name;
|
DROP TABLE table_name;
|
||||||
```
|
```
|
||||||
|
|
||||||
## LIMIT
|
## LIMIT
|
||||||
The `LIMIT` clause is used to specify the number of records to return.
|
The `LIMIT` clause is used to specify the number of records to return.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT * FROM Customers
|
SELECT * FROM Customers
|
||||||
|
@ -266,7 +266,7 @@ LIMIT 3;
|
||||||
SQL aliases are used to give a table, or a column in a table, a temporary name.
|
SQL aliases are used to give a table, or a column in a table, a temporary name.
|
||||||
Aliases are often used to make column names more readable.
|
Aliases are often used to make column names more readable.
|
||||||
An alias only exists for the duration of that query.
|
An alias only exists for the duration of that query.
|
||||||
An alias is created with the `AS` keyword.
|
An alias is created with the `AS` keyword.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT column_name AS alias_name
|
SELECT column_name AS alias_name
|
||||||
|
@ -274,34 +274,34 @@ FROM table_name;
|
||||||
```
|
```
|
||||||
|
|
||||||
## JOIN
|
## JOIN
|
||||||
A `JOIN` clause is used to combine rows from two or more tables, based on a related column between them.
|
A `JOIN` clause is used to combine rows from two or more tables, based on a related column between them.
|
||||||
|
|
||||||
### INNER JOIN
|
### INNER JOIN
|
||||||
The `INNER JOIN` keyword selects records that have matching values in both tables.
|
The `INNER JOIN` keyword selects records that have matching values in both tables.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT Orders.OrderID, Customers.CustomerName
|
SELECT Orders.OrderID, Customers.CustomerName
|
||||||
FROM Orders
|
FROM Orders
|
||||||
INNER JOIN Customers ON Orders.CustomerID = Customers.CustomerID;
|
INNER JOIN Customers ON Orders.CustomerID = Customers.CustomerID;
|
||||||
```
|
```
|
||||||
|
|
||||||
# Database
|
# Database
|
||||||
## Create Database
|
## Create Database
|
||||||
The `CREATE DATABASE` statement is used to create a new SQL database.
|
The `CREATE DATABASE` statement is used to create a new SQL database.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
CREATE DATABASE databasename;
|
CREATE DATABASE databasename;
|
||||||
```
|
```
|
||||||
|
|
||||||
## Delete Database
|
## Delete Database
|
||||||
The `DROP DATABASE` statement is used to drop an existing SQL database.
|
The `DROP DATABASE` statement is used to drop an existing SQL database.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
DROP DATABASE databasename;
|
DROP DATABASE databasename;
|
||||||
```
|
```
|
||||||
|
|
||||||
## Create Table
|
## Create Table
|
||||||
The `CREATE TABLE` statement is used to create a new table in a database.
|
The `CREATE TABLE` statement is used to create a new table in a database.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
CREATE TABLE table_name (
|
CREATE TABLE table_name (
|
||||||
|
@ -321,15 +321,15 @@ CREATE TABLE Persons (
|
||||||
```
|
```
|
||||||
|
|
||||||
## Delete Table
|
## Delete Table
|
||||||
The `DROP TABLE` statement is used to drop an existing table in a database.
|
The `DROP TABLE` statement is used to drop an existing table in a database.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
DROP TABLE table_name;
|
DROP TABLE table_name;
|
||||||
```
|
```
|
||||||
|
|
||||||
## Change Table
|
## Change Table
|
||||||
The `ALTER TABLE` statement is used to add, delete, or modify columns in an existing table.
|
The `ALTER TABLE` statement is used to add, delete, or modify columns in an existing table.
|
||||||
The `ALTER TABLE` statement is also used to add and drop various constraints on an existing table.
|
The `ALTER TABLE` statement is also used to add and drop various constraints on an existing table.
|
||||||
|
|
||||||
Add Column:
|
Add Column:
|
||||||
```sql
|
```sql
|
||||||
|
@ -339,8 +339,8 @@ ADD Email varchar(255);
|
||||||
|
|
||||||
Drop Column:
|
Drop Column:
|
||||||
```sql
|
```sql
|
||||||
ALTER TABLE Customers
|
ALTER TABLE Customers
|
||||||
DROP COLUMN Email;
|
DROP COLUMN Email;
|
||||||
```
|
```
|
||||||
|
|
||||||
Rename Column:
|
Rename Column:
|
||||||
|
@ -356,7 +356,7 @@ ALTER COLUMN DateOfBirth year;
|
||||||
```
|
```
|
||||||
|
|
||||||
## Constraints
|
## Constraints
|
||||||
Constraints can be specified when the table is created with the `CREATE TABLE` statement, or after the table is created with the `ALTER TABLE` statement.
|
Constraints can be specified when the table is created with the `CREATE TABLE` statement, or after the table is created with the `ALTER TABLE` statement.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
CREATE TABLE table_name (
|
CREATE TABLE table_name (
|
||||||
|
@ -371,30 +371,30 @@ The following constraints are commonly used in SQL:
|
||||||
### NOT NULL
|
### NOT NULL
|
||||||
By default, a column can hold NULL values.
|
By default, a column can hold NULL values.
|
||||||
|
|
||||||
The `NOT NULL` constraint enforces a column to NOT accept NULL values.
|
The `NOT NULL` constraint enforces a column to NOT accept NULL values.
|
||||||
|
|
||||||
This enforces a field to always contain a value, which means that you cannot insert a new record, or update a record without adding a value to this field.
|
This enforces a field to always contain a value, which means that you cannot insert a new record, or update a record without adding a value to this field.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
CREATE TABLE Persons (
|
CREATE TABLE Persons (
|
||||||
ID int NOT NULL,
|
ID int NOT NULL,
|
||||||
LastName varchar(255) NOT NULL,
|
LastName varchar(255) NOT NULL,
|
||||||
FirstName varchar(255) NOT NULL,
|
FirstName varchar(255) NOT NULL,
|
||||||
Age int
|
Age int
|
||||||
);
|
);
|
||||||
```
|
```
|
||||||
|
|
||||||
### UNIQUE
|
### UNIQUE
|
||||||
The `UNIQUE` constraint ensures that all values in a column are different.
|
The `UNIQUE` constraint ensures that all values in a column are different.
|
||||||
|
|
||||||
Both the `UNIQUE` and `PRIMARY KEY` constraints provide a guarantee for uniqueness for a column or set of columns.
|
Both the `UNIQUE` and `PRIMARY KEY` constraints provide a guarantee for uniqueness for a column or set of columns.
|
||||||
|
|
||||||
A `PRIMARY KEY` constraint automatically has a `UNIQUE` constraint.
|
A `PRIMARY KEY` constraint automatically has a `UNIQUE` constraint.
|
||||||
|
|
||||||
However, you can have many `UNIQUE` constraints per table, but only one `PRIMARY KEY` constraint per table.
|
However, you can have many `UNIQUE` constraints per table, but only one `PRIMARY KEY` constraint per table.
|
||||||
|
|
||||||
### PRIMARY KEY
|
### PRIMARY KEY
|
||||||
The `PRIMARY KEY` constraint uniquely identifies each record in a table.
|
The `PRIMARY KEY` constraint uniquely identifies each record in a table.
|
||||||
|
|
||||||
Primary keys must contain UNIQUE values, and cannot contain NULL values.
|
Primary keys must contain UNIQUE values, and cannot contain NULL values.
|
||||||
|
|
||||||
|
@ -411,9 +411,9 @@ CREATE TABLE Persons (
|
||||||
```
|
```
|
||||||
|
|
||||||
### FOREIGN KEY
|
### FOREIGN KEY
|
||||||
The `FOREIGN KEY` constraint is used to prevent actions that would destroy links between tables.
|
The `FOREIGN KEY` constraint is used to prevent actions that would destroy links between tables.
|
||||||
|
|
||||||
A `FOREIGN KEY` is a field (or collection of fields) in one table, that refers to the `PRIMARY KEY` in another table.
|
A `FOREIGN KEY` is a field (or collection of fields) in one table, that refers to the `PRIMARY KEY` in another table.
|
||||||
|
|
||||||
The table with the foreign key is called the child table, and the table with the primary key is called the referenced or parent table.
|
The table with the foreign key is called the child table, and the table with the primary key is called the referenced or parent table.
|
||||||
|
|
||||||
|
@ -428,32 +428,32 @@ CREATE TABLE Orders (
|
||||||
```
|
```
|
||||||
|
|
||||||
### CHECK
|
### CHECK
|
||||||
The `CHECK` constraint is used to limit the value range that can be placed in a column.
|
The `CHECK` constraint is used to limit the value range that can be placed in a column.
|
||||||
|
|
||||||
If you define a `CHECK` constraint on a column it will allow only certain values for this column.
|
If you define a `CHECK` constraint on a column it will allow only certain values for this column.
|
||||||
|
|
||||||
If you define a `CHECK` constraint on a table it can limit the values in certain columns based on values in other columns in the row.
|
If you define a `CHECK` constraint on a table it can limit the values in certain columns based on values in other columns in the row.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
CREATE TABLE Persons (
|
CREATE TABLE Persons (
|
||||||
ID int NOT NULL,
|
ID int NOT NULL,
|
||||||
LastName varchar(255) NOT NULL,
|
LastName varchar(255) NOT NULL,
|
||||||
FirstName varchar(255),
|
FirstName varchar(255),
|
||||||
Age int,
|
Age int,
|
||||||
CHECK (Age>=18)
|
CHECK (Age>=18)
|
||||||
);
|
);
|
||||||
```
|
```
|
||||||
|
|
||||||
### DEFAULT
|
### DEFAULT
|
||||||
The `DEFAULT` constraint is used to set a default value for a column.
|
The `DEFAULT` constraint is used to set a default value for a column.
|
||||||
|
|
||||||
The default value will be added to all new records, if no other value is specified.
|
The default value will be added to all new records, if no other value is specified.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
CREATE TABLE Orders (
|
CREATE TABLE Orders (
|
||||||
ID int NOT NULL,
|
ID int NOT NULL,
|
||||||
OrderNumber int NOT NULL,
|
OrderNumber int NOT NULL,
|
||||||
OrderDate date DEFAULT GETDATE()
|
OrderDate date DEFAULT GETDATE()
|
||||||
);
|
);
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -463,17 +463,17 @@ Auto-increment allows a unique number to be generated automatically when a new r
|
||||||
Often this is the primary key field that we would like to be created automatically every time a new record is inserted.
|
Often this is the primary key field that we would like to be created automatically every time a new record is inserted.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
CREATE TABLE Persons (
|
CREATE TABLE Persons (
|
||||||
Personid int NOT NULL AUTO_INCREMENT,
|
Personid int NOT NULL AUTO_INCREMENT,
|
||||||
LastName varchar(255) NOT NULL,
|
LastName varchar(255) NOT NULL,
|
||||||
FirstName varchar(255),
|
FirstName varchar(255),
|
||||||
Age int,
|
Age int,
|
||||||
PRIMARY KEY (Personid)
|
PRIMARY KEY (Personid)
|
||||||
);
|
);
|
||||||
```
|
```
|
||||||
|
|
||||||
## Create Index
|
## Create Index
|
||||||
The `CREATE INDEX` statement is used to create indexes in tables.
|
The `CREATE INDEX` statement is used to create indexes in tables.
|
||||||
|
|
||||||
Indexes are used to retrieve data from the database more quickly than otherwise. The users cannot see the indexes, they are just used to speed up searches/queries.
|
Indexes are used to retrieve data from the database more quickly than otherwise. The users cannot see the indexes, they are just used to speed up searches/queries.
|
||||||
|
|
||||||
|
@ -483,20 +483,20 @@ ON table_name (column1, column2, ...);
|
||||||
```
|
```
|
||||||
|
|
||||||
## Dates
|
## Dates
|
||||||
**MySQL** comes with the following data types for storing a date or a date/time value in the database:
|
**MySQL** comes with the following data types for storing a date or a date/time value in the database:
|
||||||
- `DATE` - format YYYY-MM-DD
|
- `DATE` - format YYYY-MM-DD
|
||||||
- `DATETIME` - format: YYYY-MM-DD HH:MI:SS
|
- `DATETIME` - format: YYYY-MM-DD HH:MI:SS
|
||||||
- `TIMESTAMP` - format: YYYY-MM-DD HH:MI:SS
|
- `TIMESTAMP` - format: YYYY-MM-DD HH:MI:SS
|
||||||
- `YEAR` - format YYYY or YY
|
- `YEAR` - format YYYY or YY
|
||||||
|
|
||||||
## Data Types
|
## Data Types
|
||||||
### String
|
### String
|
||||||
| Data type | Description |
|
| Data type | Description |
|
||||||
| --------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| --------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| CHAR(size) | A FIXED length string (can contain letters, numbers, and special characters). The _size_ parameter specifies the column length in characters - can be from 0 to 255. Default is 1 |
|
| CHAR(size) | A FIXED length string (can contain letters, numbers, and special characters). The _size_ parameter specifies the column length in characters - can be from 0 to 255. Default is 1 |
|
||||||
| VARCHAR(size) | A VARIABLE length string (can contain letters, numbers, and special characters). The _size_ parameter specifies the maximum string length in characters - can be from 0 to 65535 |
|
| VARCHAR(size) | A VARIABLE length string (can contain letters, numbers, and special characters). The _size_ parameter specifies the maximum string length in characters - can be from 0 to 65535 |
|
||||||
| BINARY(size) | Equal to CHAR(), but stores binary byte strings. The _size_ parameter specifies the column length in bytes. Default is 1 |
|
| BINARY(size) | Equal to CHAR(), but stores binary byte strings. The _size_ parameter specifies the column length in bytes. Default is 1 |
|
||||||
| VARBINARY(size) | Equal to VARCHAR(), but stores binary byte strings. The _size_ parameter specifies the maximum column length in bytes. |
|
| VARBINARY(size) | Equal to VARCHAR(), but stores binary byte strings. The _size_ parameter specifies the maximum column length in bytes. |
|
||||||
| TINYBLOB | For BLOBs (Binary Large Objects). Max length: 255 bytes |
|
| TINYBLOB | For BLOBs (Binary Large Objects). Max length: 255 bytes |
|
||||||
| TINYTEXT | Holds a string with a maximum length of 255 characters |
|
| TINYTEXT | Holds a string with a maximum length of 255 characters |
|
||||||
| TEXT(size) | Holds a string with a maximum length of 65,535 bytes |
|
| TEXT(size) | Holds a string with a maximum length of 65,535 bytes |
|
||||||
|
@ -511,21 +511,21 @@ ON table_name (column1, column2, ...);
|
||||||
### Numeric
|
### Numeric
|
||||||
| Data type | Description |
|
| Data type | Description |
|
||||||
| ----------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ----------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| BIT(_size_) | A bit-value type. The number of bits per value is specified in _size_. The _size_ parameter can hold a value from 1 to 64. The default value for _size_ is 1. |
|
| BIT(_size_) | A bit-value type. The number of bits per value is specified in _size_. The _size_ parameter can hold a value from 1 to 64. The default value for _size_ is 1. |
|
||||||
| TINYINT(_size_) | A very small integer. Signed range is from -128 to 127. Unsigned range is from 0 to 255. The _size_ parameter specifies the maximum display width (which is 255) |
|
| TINYINT(_size_) | A very small integer. Signed range is from -128 to 127. Unsigned range is from 0 to 255. The _size_ parameter specifies the maximum display width (which is 255) |
|
||||||
| BOOL | Zero is considered as false, nonzero values are considered as true. |
|
| BOOL | Zero is considered as false, nonzero values are considered as true. |
|
||||||
| BOOLEAN | Equal to BOOL |
|
| BOOLEAN | Equal to BOOL |
|
||||||
| SMALLINT(_size_) | A small integer. Signed range is from -32768 to 32767. Unsigned range is from 0 to 65535. The _size_ parameter specifies the maximum display width (which is 255) |
|
| SMALLINT(_size_) | A small integer. Signed range is from -32768 to 32767. Unsigned range is from 0 to 65535. The _size_ parameter specifies the maximum display width (which is 255) |
|
||||||
| MEDIUMINT(_size_) | A medium integer. Signed range is from -8388608 to 8388607. Unsigned range is from 0 to 16777215. The _size_ parameter specifies the maximum display width (which is 255) |
|
| MEDIUMINT(_size_) | A medium integer. Signed range is from -8388608 to 8388607. Unsigned range is from 0 to 16777215. The _size_ parameter specifies the maximum display width (which is 255) |
|
||||||
| INT(_size_) | A medium integer. Signed range is from -2147483648 to 2147483647. Unsigned range is from 0 to 4294967295. The _size_ parameter specifies the maximum display width (which is 255) |
|
| INT(_size_) | A medium integer. Signed range is from -2147483648 to 2147483647. Unsigned range is from 0 to 4294967295. The _size_ parameter specifies the maximum display width (which is 255) |
|
||||||
| INTEGER(_size_) | Equal to INT(size) |
|
| INTEGER(_size_) | Equal to INT(size) |
|
||||||
| BIGINT(_size_) | A large integer. Signed range is from -9223372036854775808 to 9223372036854775807. Unsigned range is from 0 to 18446744073709551615. The _size_ parameter specifies the maximum display width (which is 255) |
|
| BIGINT(_size_) | A large integer. Signed range is from -9223372036854775808 to 9223372036854775807. Unsigned range is from 0 to 18446744073709551615. The _size_ parameter specifies the maximum display width (which is 255) |
|
||||||
| FLOAT(_size_, _d_) | A floating point number. The total number of digits is specified in _size_. The number of digits after the decimal point is specified in the _d_ parameter. This syntax is deprecated in MySQL 8.0.17, and it will be removed in future MySQL versions |
|
| FLOAT(_size_, _d_) | A floating point number. The total number of digits is specified in _size_. The number of digits after the decimal point is specified in the _d_ parameter. This syntax is deprecated in MySQL 8.0.17, and it will be removed in future MySQL versions |
|
||||||
| FLOAT(_p_) | A floating point number. MySQL uses the _p_ value to determine whether to use FLOAT or DOUBLE for the resulting data type. If _p_ is from 0 to 24, the data type becomes FLOAT(). If _p_ is from 25 to 53, the data type becomes DOUBLE() |
|
| FLOAT(_p_) | A floating point number. MySQL uses the _p_ value to determine whether to use FLOAT or DOUBLE for the resulting data type. If _p_ is from 0 to 24, the data type becomes FLOAT(). If _p_ is from 25 to 53, the data type becomes DOUBLE() |
|
||||||
| DOUBLE(_size_, _d_) | A normal-size floating point number. The total number of digits is specified in _size_. The number of digits after the decimal point is specified in the _d_ parameter |
|
| DOUBLE(_size_, _d_) | A normal-size floating point number. The total number of digits is specified in _size_. The number of digits after the decimal point is specified in the _d_ parameter |
|
||||||
| DOUBLE PRECISION(_size_, _d_) | |
|
| DOUBLE PRECISION(_size_, _d_) | |
|
||||||
| DECIMAL(_size_, _d_) | An exact fixed-point number. The total number of digits is specified in _size_. The number of digits after the decimal point is specified in the _d_ parameter. The maximum number for _size_ is 65. The maximum number for _d_ is 30. The default value for _size_ is 10. The default value for _d_ is 0. |
|
| DECIMAL(_size_, _d_) | An exact fixed-point number. The total number of digits is specified in _size_. The number of digits after the decimal point is specified in the _d_ parameter. The maximum number for _size_ is 65. The maximum number for _d_ is 30. The default value for _size_ is 10. The default value for _d_ is 0. |
|
||||||
| DEC(_size_, _d_) | Equal to DECIMAL(size,d) |
|
| DEC(_size_, _d_) | Equal to DECIMAL(size,d) |
|
||||||
|
|
||||||
### Date & Time
|
### Date & Time
|
||||||
| Data type | Description |
|
| Data type | Description |
|
||||||
|
@ -570,7 +570,7 @@ SELECT UPPER("SQL");
|
||||||
The `TRIM()` function removes leading and trailing spaces from a string. `LTRIM()` & `RTRIM()` remove leading and trailing spaces from the left or right respectively.
|
The `TRIM()` function removes leading and trailing spaces from a string. `LTRIM()` & `RTRIM()` remove leading and trailing spaces from the left or right respectively.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT TRIM(' SQL ') AS TrimmedString;
|
SELECT TRIM(' SQL ') AS TrimmedString;
|
||||||
```
|
```
|
||||||
|
|
||||||
### SUBSTRING()
|
### SUBSTRING()
|
||||||
|
@ -602,7 +602,7 @@ The `REVERSE()` function reverses a string and returns the result.
|
||||||
The `REPLACE()` function replaces all occurrences of a substring within a string, with a new substring.
|
The `REPLACE()` function replaces all occurrences of a substring within a string, with a new substring.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
REPLACE(string, from_string, new_string)
|
REPLACE(string, from_string, new_string)
|
||||||
```
|
```
|
||||||
|
|
||||||
### REPEAT()
|
### REPEAT()
|
||||||
|
@ -614,50 +614,50 @@ REPEAT(string, number)
|
||||||
|
|
||||||
## Numeric Functions
|
## Numeric Functions
|
||||||
### MIN() & MAX()
|
### MIN() & MAX()
|
||||||
The `MIN()` function returns the smallest value of the selected column.
|
The `MIN()` function returns the smallest value of the selected column.
|
||||||
|
|
||||||
The `MAX()` function returns the largest value of the selected column.
|
The `MAX()` function returns the largest value of the selected column.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT MIN(Price)
|
SELECT MIN(Price)
|
||||||
FROM Products;
|
FROM Products;
|
||||||
|
|
||||||
SELECT MAX(Price)
|
SELECT MAX(Price)
|
||||||
FROM Products;
|
FROM Products;
|
||||||
```
|
```
|
||||||
|
|
||||||
### COUNT()
|
### COUNT()
|
||||||
The `COUNT()` function returns the number of rows that matches a specified criterion.
|
The `COUNT()` function returns the number of rows that matches a specified criterion.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT COUNT(*)
|
SELECT COUNT(*)
|
||||||
FROM Products;
|
FROM Products;
|
||||||
```
|
```
|
||||||
|
|
||||||
### SUM()
|
### SUM()
|
||||||
The `SUM()` function returns the total sum of a numeric column.
|
The `SUM()` function returns the total sum of a numeric column.
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
```sql
|
```sql
|
||||||
SELECT SUM(Quantity) AS total
|
SELECT SUM(Quantity) AS total
|
||||||
FROM OrderDetails;
|
FROM OrderDetails;
|
||||||
```
|
```
|
||||||
|
|
||||||
Expressions:
|
Expressions:
|
||||||
```sql
|
```sql
|
||||||
SELECT SUM(Quantity * 10)
|
SELECT SUM(Quantity * 10)
|
||||||
FROM OrderDetails;
|
FROM OrderDetails;
|
||||||
```
|
```
|
||||||
|
|
||||||
### AVG()
|
### AVG()
|
||||||
The `AVG()` function returns the average value of a numeric column.
|
The `AVG()` function returns the average value of a numeric column.
|
||||||
|
|
||||||
```sql
|
```sql
|
||||||
SELECT AVG(Price)
|
SELECT AVG(Price)
|
||||||
FROM Products;
|
FROM Products;
|
||||||
|
|
||||||
SELECT * FROM Products
|
SELECT * FROM Products
|
||||||
WHERE price > (SELECT AVG(price) FROM Products);
|
WHERE price > (SELECT AVG(price) FROM Products);
|
||||||
```
|
```
|
||||||
|
|
||||||
## Date Functions
|
## Date Functions
|
||||||
|
|
|
@ -4,7 +4,7 @@ website: https://www.raspberrypi.com/products/raspberry-pi-4-model-b/
|
||||||
---
|
---
|
||||||
|
|
||||||
# Raspberry Pi 4
|
# Raspberry Pi 4
|
||||||
The Raspberry Pi 4 is a ARM single board computer. It supports Power over Ethernet and can be used as a desktop computer, robot brains, server, smart home hub, media centre, networked AI core, factory controller, and much more.
|
The Raspberry Pi 4 is a ARM single board computer. It supports Power over Ethernet and can be used as a desktop computer, robot brains, server, smart home hub, media centre, networked AI core, factory controller, and much more.
|
||||||
|
|
||||||
![Picture][Picture]
|
![Picture][Picture]
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@ website: https://citra-emu.org
|
||||||
repo: https://github.com/citra-emu/citra
|
repo: https://github.com/citra-emu/citra
|
||||||
---
|
---
|
||||||
# Citra
|
# Citra
|
||||||
**Citra** is an open-source emulator for the Nintendo 3DS capable of playing many of your favorite games.
|
**Citra** is an open-source emulator for the Nintendo 3DS capable of playing many of your favorite games.
|
||||||
|
|
||||||
![Screenshot][Screenshot]
|
![Screenshot][Screenshot]
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@ website: https://dolphin-emu.org
|
||||||
repo: https://github.com/dolphin-emu/dolphin
|
repo: https://github.com/dolphin-emu/dolphin
|
||||||
---
|
---
|
||||||
# Dolphin Emulator
|
# Dolphin Emulator
|
||||||
**Dolphin** is an emulator for two Nintendo video game consoles: the **GameCube** and the **Wii**. It allows PC gamers to enjoy games for these two consoles in **full HD** (1080p) with several enhancements: compatibility with all PC controllers, turbo speed, networked multiplayer, and even more!
|
**Dolphin** is an emulator for two Nintendo video game consoles: the **GameCube** and the **Wii**. It allows PC gamers to enjoy games for these two consoles in **full HD** (1080p) with several enhancements: compatibility with all PC controllers, turbo speed, networked multiplayer, and even more!
|
||||||
|
|
||||||
![Screenshot][Screenshot]
|
![Screenshot][Screenshot]
|
||||||
|
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -3,26 +3,26 @@ arch-wiki: https://wiki.archlinux.org/title/desktop_entries
|
||||||
obj: concept
|
obj: concept
|
||||||
---
|
---
|
||||||
# Desktop Entry
|
# Desktop Entry
|
||||||
The [XDG Desktop Entry specification](https://specifications.freedesktop.org/desktop-entry-spec/desktop-entry-spec-latest.html) defines a standard for applications to integrate into application menus of desktop environments implementing the [XDG Desktop Menu](https://specifications.freedesktop.org/menu-spec/menu-spec-latest.html) specification.
|
The [XDG Desktop Entry specification](https://specifications.freedesktop.org/desktop-entry-spec/desktop-entry-spec-latest.html) defines a standard for applications to integrate into application menus of desktop environments implementing the [XDG Desktop Menu](https://specifications.freedesktop.org/menu-spec/menu-spec-latest.html) specification.
|
||||||
|
|
||||||
## Basics
|
## Basics
|
||||||
Each desktop entry must have a `Type` and a `Name` key and can optionally define its appearance in the application menu.
|
Each desktop entry must have a `Type` and a `Name` key and can optionally define its appearance in the application menu.
|
||||||
|
|
||||||
The three available types are:
|
The three available types are:
|
||||||
### Application
|
### Application
|
||||||
Defines how to launch an application and what MIME types it supports (used by XDG MIME Applications. With XDG Autostart Application entries can be started automatically by placing them in specific directories. Application entries use the `.desktop` file extension.
|
Defines how to launch an application and what MIME types it supports (used by XDG MIME Applications. With XDG Autostart Application entries can be started automatically by placing them in specific directories. Application entries use the `.desktop` file extension.
|
||||||
|
|
||||||
### Link
|
### Link
|
||||||
Defines a shortcut to a `URL`. Link entries use the `.desktop` file extension.
|
Defines a shortcut to a `URL`. Link entries use the `.desktop` file extension.
|
||||||
|
|
||||||
### Directory
|
### Directory
|
||||||
Defines the appearance of a submenu in the application menu. Directory entries use the `.directory` file extension.
|
Defines the appearance of a submenu in the application menu. Directory entries use the `.directory` file extension.
|
||||||
|
|
||||||
## Application entry
|
## Application entry
|
||||||
Desktop entries for applications, or `.desktop` files, are generally a combination of meta information resources and a shortcut of an application. These files usually reside in `/usr/share/applications/` or `/usr/local/share/applications/` for applications installed system-wide, or `~/.local/share/applications/` for user-specific applications. User entries take precedence over system entries.
|
Desktop entries for applications, or `.desktop` files, are generally a combination of meta information resources and a shortcut of an application. These files usually reside in `/usr/share/applications/` or `/usr/local/share/applications/` for applications installed system-wide, or `~/.local/share/applications/` for user-specific applications. User entries take precedence over system entries.
|
||||||
|
|
||||||
### File example
|
### File example
|
||||||
Following is an example of its structure with additional comments. The example is only meant to give a quick impression, and does not show how to utilize all possible entry keys. The complete list of keys can be found in the [freedesktop specification](https://specifications.freedesktop.org/desktop-entry-spec/desktop-entry-spec-latest.html#recognized-keys).
|
Following is an example of its structure with additional comments. The example is only meant to give a quick impression, and does not show how to utilize all possible entry keys. The complete list of keys can be found in the [freedesktop specification](https://specifications.freedesktop.org/desktop-entry-spec/desktop-entry-spec-latest.html#recognized-keys).
|
||||||
|
|
||||||
```ini
|
```ini
|
||||||
[Desktop Entry]
|
[Desktop Entry]
|
||||||
|
|
|
@ -16,10 +16,10 @@ A JSON Pointer is a string of tokens separated by `/` characters, these tokens e
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
`/biscuits` would point to the array of biscuits and `/biscuits/1/name` would point to `"Choco Leibniz"`.
|
`/biscuits` would point to the array of biscuits and `/biscuits/1/name` would point to `"Choco Leibniz"`.
|
||||||
|
|
||||||
To point to the root of the document use an empty string for the pointer. The pointer `/` doesn’t point to the root, it points to a key of `""` on the root (which is totally valid in [JSON](../files/JSON.md)).
|
To point to the root of the document use an empty string for the pointer. The pointer `/` doesn’t point to the root, it points to a key of `""` on the root (which is totally valid in [JSON](../files/JSON.md)).
|
||||||
|
|
||||||
If you need to refer to a key with `~` or `/` in its name, you must escape the characters with `~0` and `~1` respectively. For example, to get `"baz"` from `{ "foo/bar~": "baz" }` you’d use the pointer `/foo~1bar~0`.
|
If you need to refer to a key with `~` or `/` in its name, you must escape the characters with `~0` and `~1` respectively. For example, to get `"baz"` from `{ "foo/bar~": "baz" }` you’d use the pointer `/foo~1bar~0`.
|
||||||
|
|
||||||
Finally, if you need to refer to the end of an array you can use `-` instead of an index. For example, to refer to the end of the array of biscuits above you would use `/biscuits/-`. This is useful when you need to insert a value at the end of an array.
|
Finally, if you need to refer to the end of an array you can use `-` instead of an index. For example, to refer to the end of the array of biscuits above you would use `/biscuits/-`. This is useful when you need to insert a value at the end of an array.
|
|
@ -8,13 +8,13 @@ A list of supported MIME Types can be found at `/etc/mime.types`
|
||||||
|
|
||||||
## Naming
|
## Naming
|
||||||
|
|
||||||
A media type consists of a _type_ and a _subtype_, which is further structured into a _tree_. A media type can optionally define a _suffix_ and _parameters_:
|
A media type consists of a _type_ and a _subtype_, which is further structured into a _tree_. A media type can optionally define a _suffix_ and _parameters_:
|
||||||
`type "/" [tree "."] subtype ["+" suffix]* [";" parameter]`
|
`type "/" [tree "."] subtype ["+" suffix]* [";" parameter]`
|
||||||
As of November 1996, the registered types were: `application`, `audio`, `image`, `message`, `multipart`, `text` and `video`. By December 2020, the registered types included the foregoing, plus `font`, `example`, and `model`.
|
As of November 1996, the registered types were: `application`, `audio`, `image`, `message`, `multipart`, `text` and `video`. By December 2020, the registered types included the foregoing, plus `font`, `example`, and `model`.
|
||||||
|
|
||||||
An unofficial top-level name in common use is `chemical`.
|
An unofficial top-level name in common use is `chemical`.
|
||||||
|
|
||||||
As an example, an [HTML](../internet/HTML.md) file might be designated `text/html; charset=UTF-8`. In this example, `text` is the type, `html` is the subtype, and `charset=UTF-8` is an optional parameter indicating the character encoding.
|
As an example, an [HTML](../internet/HTML.md) file might be designated `text/html; charset=UTF-8`. In this example, `text` is the type, `html` is the subtype, and `charset=UTF-8` is an optional parameter indicating the character encoding.
|
||||||
|
|
||||||
A subtype typically consists of a media format, but it may or must also contain other content, such as a tree prefix, producer, product or suffix, according to the different rules in registration trees.
|
A subtype typically consists of a media format, but it may or must also contain other content, such as a tree prefix, producer, product or suffix, according to the different rules in registration trees.
|
||||||
|
|
||||||
|
@ -48,7 +48,7 @@ Types, subtypes, and parameter names are case-insensitive. Parameter values are
|
||||||
| application/x-tar | tar | [TAR](../applications/cli/compression/tar.md) |
|
| application/x-tar | tar | [TAR](../applications/cli/compression/tar.md) |
|
||||||
| application/x-xz | xz | XZ Compression |
|
| application/x-xz | xz | XZ Compression |
|
||||||
| application/msgpack | - | [MessagePack](MessagePack.md) |
|
| application/msgpack | - | [MessagePack](MessagePack.md) |
|
||||||
| application/toml | .toml | [TOML](TOML.md) |
|
| application/toml | .toml | [TOML](TOML.md) |
|
||||||
|
|
||||||
### Audio
|
### Audio
|
||||||
| MIME Type | Extensions | Description |
|
| MIME Type | Extensions | Description |
|
||||||
|
|
|
@ -10,7 +10,7 @@ Markdown is a lightweight markup language that provides a simple and human-reada
|
||||||
# Syntax
|
# Syntax
|
||||||
## Basic Syntax
|
## Basic Syntax
|
||||||
### Headings
|
### Headings
|
||||||
To create a heading, add number signs (`#`) in front of a word or phrase. The number of number signs you use should correspond to the heading level. For example, to create a heading level three (`<h3>`), use three number signs (e.g., `### My Header`).
|
To create a heading, add number signs (`#`) in front of a word or phrase. The number of number signs you use should correspond to the heading level. For example, to create a heading level three (`<h3>`), use three number signs (e.g., `### My Header`).
|
||||||
```markdown
|
```markdown
|
||||||
# Heading 1
|
# Heading 1
|
||||||
## Heading 2
|
## Heading 2
|
||||||
|
@ -42,12 +42,12 @@ To emphasize text with bold and italics at the same time, add three asterisks or
|
||||||
```
|
```
|
||||||
|
|
||||||
### Blockquote
|
### Blockquote
|
||||||
To create a blockquote, add a `>` in front of a paragraph.
|
To create a blockquote, add a `>` in front of a paragraph.
|
||||||
```markdown
|
```markdown
|
||||||
> My blockquote
|
> My blockquote
|
||||||
```
|
```
|
||||||
|
|
||||||
Blockquotes can be nested. Add a `>>` in front of the paragraph you want to nest.
|
Blockquotes can be nested. Add a `>>` in front of the paragraph you want to nest.
|
||||||
|
|
||||||
Blockquotes can contain other Markdown formatted elements. Not all elements can be used — you’ll need to experiment to see which ones work.
|
Blockquotes can contain other Markdown formatted elements. Not all elements can be used — you’ll need to experiment to see which ones work.
|
||||||
|
|
||||||
|
@ -78,7 +78,7 @@ At the command prompt, type `nano`.
|
||||||
To create a horizontal rule, use three or more asterisks (`***`), dashes (`---`), or underscores (`___`) on a line by themselves.
|
To create a horizontal rule, use three or more asterisks (`***`), dashes (`---`), or underscores (`___`) on a line by themselves.
|
||||||
|
|
||||||
### Links
|
### Links
|
||||||
To create a link, enclose the link text in brackets (e.g., `[Duck Duck Go]`) and then follow it immediately with the [URL](../internet/URL.md) in parentheses (e.g., `(https://duckduckgo.com)`).
|
To create a link, enclose the link text in brackets (e.g., `[Duck Duck Go]`) and then follow it immediately with the [URL](../internet/URL.md) in parentheses (e.g., `(https://duckduckgo.com)`).
|
||||||
```markdown
|
```markdown
|
||||||
My favorite search engine is [Duck Duck Go](https://duckduckgo.com).
|
My favorite search engine is [Duck Duck Go](https://duckduckgo.com).
|
||||||
```
|
```
|
||||||
|
@ -88,7 +88,7 @@ Reference-style links are a special kind of link that make URLs easier to displa
|
||||||
The first part of a reference-style link is formatted with two sets of brackets. The first set of brackets surrounds the text that should appear linked. The second set of brackets displays a label used to point to the link you’re storing elsewhere in your document.
|
The first part of a reference-style link is formatted with two sets of brackets. The first set of brackets surrounds the text that should appear linked. The second set of brackets displays a label used to point to the link you’re storing elsewhere in your document.
|
||||||
|
|
||||||
The second part of a reference-style link is formatted with the following attributes:
|
The second part of a reference-style link is formatted with the following attributes:
|
||||||
1. The label, in brackets, followed immediately by a colon and at least one space (e.g., `[label]:` ).
|
1. The label, in brackets, followed immediately by a colon and at least one space (e.g., `[label]:` ).
|
||||||
2. The [URL](../internet/URL.md) for the link, which you can optionally enclose in angle brackets.
|
2. The [URL](../internet/URL.md) for the link, which you can optionally enclose in angle brackets.
|
||||||
3. The optional title for the link, which you can enclose in double quotes, single quotes, or parentheses.
|
3. The optional title for the link, which you can enclose in double quotes, single quotes, or parentheses.
|
||||||
|
|
||||||
|
@ -125,7 +125,7 @@ You can use a backslash to escape the following characters.
|
||||||
| \| | pipe |
|
| \| | pipe |
|
||||||
|
|
||||||
### HTML
|
### HTML
|
||||||
Many Markdown applications allow you to use [HTML](../internet/HTML.md) tags in Markdown-formatted text. This is helpful if you prefer certain [HTML](../internet/HTML.md) tags to Markdown syntax. For example, some people find it easier to use [HTML](../internet/HTML.md) tags for images. Using [HTML](../internet/HTML.md) is also helpful when you need to change the attributes of an element, like specifying the color of text or changing the width of an image.
|
Many Markdown applications allow you to use [HTML](../internet/HTML.md) tags in Markdown-formatted text. This is helpful if you prefer certain [HTML](../internet/HTML.md) tags to Markdown syntax. For example, some people find it easier to use [HTML](../internet/HTML.md) tags for images. Using [HTML](../internet/HTML.md) is also helpful when you need to change the attributes of an element, like specifying the color of text or changing the width of an image.
|
||||||
|
|
||||||
## Extented Syntax
|
## Extented Syntax
|
||||||
### Tables
|
### Tables
|
||||||
|
@ -138,7 +138,7 @@ To add a table, use three or more hyphens (`---`) to create each column’s head
|
||||||
```
|
```
|
||||||
|
|
||||||
### Fenced Code Blocks
|
### Fenced Code Blocks
|
||||||
To create code blocks use three backticks at the start and end of the code block (` ``` ``` `).
|
To create code blocks use three backticks at the start and end of the code block (` ``` ``` `).
|
||||||
|
|
||||||
Many Markdown processors support syntax highlighting for fenced code blocks. This feature allows you to add color highlighting for whatever language your code was written in. To add syntax highlighting, specify a language directly after the backticks on the first line of the fenced code block.
|
Many Markdown processors support syntax highlighting for fenced code blocks. This feature allows you to add color highlighting for whatever language your code was written in. To add syntax highlighting, specify a language directly after the backticks on the first line of the fenced code block.
|
||||||
|
|
||||||
|
@ -174,10 +174,10 @@ You can link to headings with custom IDs in the file by creating a standard link
|
||||||
| `[Heading IDs](#heading-ids)` | `<a href="#heading-ids">Heading IDs</a>` |
|
| `[Heading IDs](#heading-ids)` | `<a href="#heading-ids">Heading IDs</a>` |
|
||||||
|
|
||||||
### Strikethrough
|
### Strikethrough
|
||||||
You can strikethrough words by putting a horizontal line through the center of them. The result looks ~~like this~~. This feature allows you to indicate that certain words are a mistake not meant for inclusion in the document. To strikethrough words, use two tilde symbols (`~~`) before and after the words.
|
You can strikethrough words by putting a horizontal line through the center of them. The result looks ~~like this~~. This feature allows you to indicate that certain words are a mistake not meant for inclusion in the document. To strikethrough words, use two tilde symbols (`~~`) before and after the words.
|
||||||
|
|
||||||
### Task Lists
|
### Task Lists
|
||||||
Task lists (also referred to as _checklists_ and _todo_ lists) allow you to create a list of items with checkboxes. In Markdown applications that support task lists, checkboxes will be displayed next to the content. To create a task list, add dashes (`-`) and brackets with a space (`[ ]`) in front of task list items. To select a checkbox, add an `x` in between the brackets (`[x]`).
|
Task lists (also referred to as _checklists_ and _todo_ lists) allow you to create a list of items with checkboxes. In Markdown applications that support task lists, checkboxes will be displayed next to the content. To create a task list, add dashes (`-`) and brackets with a space (`[ ]`) in front of task list items. To select a checkbox, add an `x` in between the brackets (`[x]`).
|
||||||
|
|
||||||
```markdown
|
```markdown
|
||||||
- [x] Write the press release
|
- [x] Write the press release
|
||||||
|
@ -186,7 +186,7 @@ Task lists (also referred to as _checklists_ and _todo_ lists) allow you to
|
||||||
```
|
```
|
||||||
|
|
||||||
### Highlight
|
### Highlight
|
||||||
This isn’t common, but some Markdown processors allow you to highlight text. The result looks ==like this==. To highlight words, use two equal signs (`==`) before and after the words.
|
This isn’t common, but some Markdown processors allow you to highlight text. The result looks ==like this==. To highlight words, use two equal signs (`==`) before and after the words.
|
||||||
```markdown
|
```markdown
|
||||||
I need to highlight these ==very important words==.
|
I need to highlight these ==very important words==.
|
||||||
```
|
```
|
||||||
|
@ -205,9 +205,9 @@ Markdown doesn’t allow you to change the color of text, so again we need [HTML
|
||||||
```
|
```
|
||||||
|
|
||||||
### Comments
|
### Comments
|
||||||
Some people need the ability to write sentences in their Markdown files that _will not_ appear in the rendered output. These comments are essentially hidden text. The text is viewable by the author of the document, but it’s not printed on the webpage or [PDF](PDF.md). Markdown doesn’t natively support comments, but several enterprising individuals have devised a solution.
|
Some people need the ability to write sentences in their Markdown files that _will not_ appear in the rendered output. These comments are essentially hidden text. The text is viewable by the author of the document, but it’s not printed on the webpage or [PDF](PDF.md). Markdown doesn’t natively support comments, but several enterprising individuals have devised a solution.
|
||||||
|
|
||||||
To add a comment, place text inside brackets followed by a colon, a space, and a pound sign (e.g., `[comment]: #`). You should put blank lines before and after a comment.
|
To add a comment, place text inside brackets followed by a colon, a space, and a pound sign (e.g., `[comment]: #`). You should put blank lines before and after a comment.
|
||||||
|
|
||||||
```markdown
|
```markdown
|
||||||
Here's a paragraph that will be visible.
|
Here's a paragraph that will be visible.
|
||||||
|
@ -218,7 +218,7 @@ And here's another paragraph that's visible.
|
||||||
```
|
```
|
||||||
|
|
||||||
### Image Size
|
### Image Size
|
||||||
The Markdown syntax for images doesn’t allow you to specify the width and height of images. If you need to resize an image and your Markdown processor supports [HTML](../internet/HTML.md), you can use the `img` [HTML](../internet/HTML.md) tag with the `width` and `height` attributes to set the dimensions of an image in pixels.
|
The Markdown syntax for images doesn’t allow you to specify the width and height of images. If you need to resize an image and your Markdown processor supports [HTML](../internet/HTML.md), you can use the `img` [HTML](../internet/HTML.md) tag with the `width` and `height` attributes to set the dimensions of an image in pixels.
|
||||||
```html
|
```html
|
||||||
<img src="image.png" width="200" height="100">
|
<img src="image.png" width="200" height="100">
|
||||||
```
|
```
|
||||||
|
@ -226,22 +226,22 @@ The Markdown syntax for images doesn’t allow you to specify the width and he
|
||||||
### Symbols
|
### Symbols
|
||||||
Markdown doesn’t provide special syntax for symbols. However, in most cases, you can copy and paste whatever symbol you want to use into your Markdown document. For example, if you need to display Pi (π), just find the symbol on a webpage and copy and paste it into your document. The symbol should appear as expected in the rendered output.
|
Markdown doesn’t provide special syntax for symbols. However, in most cases, you can copy and paste whatever symbol you want to use into your Markdown document. For example, if you need to display Pi (π), just find the symbol on a webpage and copy and paste it into your document. The symbol should appear as expected in the rendered output.
|
||||||
|
|
||||||
Alternatively, if your Markdown application supports [HTML](../internet/HTML.md), you can use the [HTML](../internet/HTML.md) entity for whatever symbol you want to use. For example, if you want to display the copyright sign (©), you can copy and paste the [HTML](../internet/HTML.md) entity for copyright (`©`) into your Markdown document.
|
Alternatively, if your Markdown application supports [HTML](../internet/HTML.md), you can use the [HTML](../internet/HTML.md) entity for whatever symbol you want to use. For example, if you want to display the copyright sign (©), you can copy and paste the [HTML](../internet/HTML.md) entity for copyright (`©`) into your Markdown document.
|
||||||
|
|
||||||
Here’s a partial list of [HTML](../internet/HTML.md) entities for symbols:
|
Here’s a partial list of [HTML](../internet/HTML.md) entities for symbols:
|
||||||
- Copyright (©) — `©`
|
- Copyright (©) — `©`
|
||||||
- Registered trademark (®) — `®`
|
- Registered trademark (®) — `®`
|
||||||
- Trademark (™) — `™`
|
- Trademark (™) — `™`
|
||||||
- Euro (€) — `€`
|
- Euro (€) — `€`
|
||||||
- Left arrow (←) — `←`
|
- Left arrow (←) — `←`
|
||||||
- Up arrow (↑) — `↑`
|
- Up arrow (↑) — `↑`
|
||||||
- Right arrow (→) — `→`
|
- Right arrow (→) — `→`
|
||||||
- Down arrow (↓) — `↓`
|
- Down arrow (↓) — `↓`
|
||||||
- Degree (°) — `°`
|
- Degree (°) — `°`
|
||||||
- Pi (π) — `π`
|
- Pi (π) — `π`
|
||||||
|
|
||||||
### Line Breaks Within Table Cells
|
### Line Breaks Within Table Cells
|
||||||
You can separate paragraphs within a table cell by using one or more `<br>` [HTML](../internet/HTML.md) tags.
|
You can separate paragraphs within a table cell by using one or more `<br>` [HTML](../internet/HTML.md) tags.
|
||||||
|
|
||||||
## Frontmatter
|
## Frontmatter
|
||||||
Frontmatter allows you to add structured metadata to your markdown files. Add a [YAML](YAML.md) document embedded in a three-dotted block at the top of your file.
|
Frontmatter allows you to add structured metadata to your markdown files. Add a [YAML](YAML.md) document embedded in a three-dotted block at the top of your file.
|
||||||
|
|
|
@ -15,7 +15,7 @@ Editing and creation of Matroska files can be done using [MKVToolnix](../../appl
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
|
|
||||||
**_Matroska_** is designed with the future in mind. It incorporates features you would expect from a modern container format, like:
|
**_Matroska_** is designed with the future in mind. It incorporates features you would expect from a modern container format, like:
|
||||||
- Fast seeking in the file
|
- Fast seeking in the file
|
||||||
- Chapter entries
|
- Chapter entries
|
||||||
- Full metadata (tags) support
|
- Full metadata (tags) support
|
||||||
|
@ -28,5 +28,5 @@ Editing and creation of Matroska files can be done using [MKVToolnix](../../appl
|
||||||
## What file extensions does Matroska use?
|
## What file extensions does Matroska use?
|
||||||
- `.mkv`: Used for files that contain at least one video track (usually with at least one audio track and optionally with subtitle tracks). This is the most commonly used extension.
|
- `.mkv`: Used for files that contain at least one video track (usually with at least one audio track and optionally with subtitle tracks). This is the most commonly used extension.
|
||||||
- `.mka`: Used for audio only files, can contain any supported audio compression format, such as MP2, MP3, Vorbis, AAC, AC3, DTS, or PCM
|
- `.mka`: Used for audio only files, can contain any supported audio compression format, such as MP2, MP3, Vorbis, AAC, AC3, DTS, or PCM
|
||||||
- `.mk3d`: A special case of `.mkv` containing stereoscopic (3D) video
|
- `.mk3d`: A special case of `.mkv` containing stereoscopic (3D) video
|
||||||
- `.mks`: Used for files that only contain subtitles
|
- `.mks`: Used for files that only contain subtitles
|
|
@ -8,19 +8,19 @@ AV1 Image File Format (AVIF) is an open, royalty-free image file format specific
|
||||||
| Name | Value |
|
| Name | Value |
|
||||||
| ------------------- | ------------ |
|
| ------------------- | ------------ |
|
||||||
| Filename extension | .avif |
|
| Filename extension | .avif |
|
||||||
| Internet media type | `image/avif` |
|
| Internet media type | `image/avif` |
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
The AV1 Image File Format supports:
|
The AV1 Image File Format supports:
|
||||||
- Multiple color spaces, including:
|
- Multiple color spaces, including:
|
||||||
- HDR (with PQ or HLG transfer functions and BT.2020 color primaries, as part of BT.2100)
|
- HDR (with PQ or HLG transfer functions and BT.2020 color primaries, as part of BT.2100)
|
||||||
- SDR (with sRGB/ BT.709 / BT.601 or with wide color gamut
|
- SDR (with sRGB/ BT.709 / BT.601 or with wide color gamut
|
||||||
- Color space signaling via CICP (ITU-T H.273 and ISO/IEC 23091-2) or ICC profiles
|
- Color space signaling via CICP (ITU-T H.273 and ISO/IEC 23091-2) or ICC profiles
|
||||||
- Lossless compression and lossy compression
|
- Lossless compression and lossy compression
|
||||||
- 8-, 10-, and 12-bit color depths
|
- 8-, 10-, and 12-bit color depths
|
||||||
- Monochrome (alpha/depth) or multi-components
|
- Monochrome (alpha/depth) or multi-components
|
||||||
- 4:2:0, 4:2:2, 4:4:4 chroma subsampling and RGB
|
- 4:2:0, 4:2:2, 4:4:4 chroma subsampling and RGB
|
||||||
- Film grain synthesis
|
- Film grain synthesis
|
||||||
- Image sequences/animation
|
- Image sequences/animation
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
|
@ -20,51 +20,51 @@ body {
|
||||||
### Selector
|
### Selector
|
||||||
A CSS selector selects the [HTML](HTML.md) element(s) you want to style.
|
A CSS selector selects the [HTML](HTML.md) element(s) you want to style.
|
||||||
|
|
||||||
**Tag Selector**: Here, all `<p>` elements on the page will be center-aligned, with a red text color:
|
**Tag Selector**: Here, all `<p>` elements on the page will be center-aligned, with a red text color:
|
||||||
```css
|
```css
|
||||||
p {
|
p {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
color: red;
|
color: red;
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
**ID Selector**: The CSS rule below will be applied to the [HTML](HTML.md) element with id="para1":
|
**ID Selector**: The CSS rule below will be applied to the [HTML](HTML.md) element with id="para1":
|
||||||
```css
|
```css
|
||||||
#para1 {
|
#para1 {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
color: red;
|
color: red;
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
**Class Selector**: In this example all [HTML](HTML.md) elements with class="center" will be red and center-aligned:
|
**Class Selector**: In this example all [HTML](HTML.md) elements with class="center" will be red and center-aligned:
|
||||||
```css
|
```css
|
||||||
.center {
|
.center {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
color: red;
|
color: red;
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
**Tag+Class Selector**: In this example only `<p>` elements with class="center" will be red and center-aligned:
|
**Tag+Class Selector**: In this example only `<p>` elements with class="center" will be red and center-aligned:
|
||||||
```css
|
```css
|
||||||
p.center {
|
p.center {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
color: red;
|
color: red;
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
**All Selector**:
|
**All Selector**:
|
||||||
```css
|
```css
|
||||||
* {
|
* {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
color: blue;
|
color: blue;
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
**Multiple Selector**: In this example we have grouped the selectors:
|
**Multiple Selector**: In this example we have grouped the selectors:
|
||||||
```css
|
```css
|
||||||
h1, h2, p {
|
h1, h2, p {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
color: red;
|
color: red;
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -75,7 +75,7 @@ a:valid {} /* Apply to valid elements */
|
||||||
a:invalid {} /* Apply to invalid elements */
|
a:invalid {} /* Apply to invalid elements */
|
||||||
a:required {} /* Apply to required elements */
|
a:required {} /* Apply to required elements */
|
||||||
a:optional {} /* Apply to optional elements */
|
a:optional {} /* Apply to optional elements */
|
||||||
a:hover {} /* Apply to links on hover */
|
a:hover {} /* Apply to links on hover */
|
||||||
a:focus {} /* Apply to focused element */
|
a:focus {} /* Apply to focused element */
|
||||||
a:enabled {} /* Apply to enabled elements */
|
a:enabled {} /* Apply to enabled elements */
|
||||||
a:disabled {} /* Apply to disabled elements */
|
a:disabled {} /* Apply to disabled elements */
|
||||||
|
@ -86,8 +86,8 @@ CSS comments are not displayed in the browser, but they can help document your s
|
||||||
|
|
||||||
```css
|
```css
|
||||||
/* This is a single-line comment */
|
/* This is a single-line comment */
|
||||||
p {
|
p {
|
||||||
color: red; /* Set text color to red */
|
color: red; /* Set text color to red */
|
||||||
}
|
}
|
||||||
/* This is
|
/* This is
|
||||||
a multi-line
|
a multi-line
|
||||||
|
@ -110,12 +110,12 @@ a {
|
||||||
### Backgrounds
|
### Backgrounds
|
||||||
You can set a background color:
|
You can set a background color:
|
||||||
```css
|
```css
|
||||||
div {
|
div {
|
||||||
background-color: rgba(0, 128, 0, 0.3)
|
background-color: rgba(0, 128, 0, 0.3)
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
The `background-image` property specifies an image to use as the background of an element:
|
The `background-image` property specifies an image to use as the background of an element:
|
||||||
```css
|
```css
|
||||||
body {
|
body {
|
||||||
background-image: url("paper.gif");
|
background-image: url("paper.gif");
|
||||||
|
@ -124,16 +124,16 @@ body {
|
||||||
|
|
||||||
Add a graphical effect to the area behind an element:
|
Add a graphical effect to the area behind an element:
|
||||||
```css
|
```css
|
||||||
body {
|
body {
|
||||||
background-color: rgba(255, 255, 255, 0.4);
|
background-color: rgba(255, 255, 255, 0.4);
|
||||||
backdrop-filter: blur(5px);
|
backdrop-filter: blur(5px);
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
### Borders
|
### Borders
|
||||||
The CSS border properties allow you to specify the style, width, and color of an element's border.
|
The CSS border properties allow you to specify the style, width, and color of an element's border.
|
||||||
|
|
||||||
The `border-style` property specifies what kind of border to display:
|
The `border-style` property specifies what kind of border to display:
|
||||||
```css
|
```css
|
||||||
p.dotted {border-style: dotted;}
|
p.dotted {border-style: dotted;}
|
||||||
p.dashed {border-style: dashed;}
|
p.dashed {border-style: dashed;}
|
||||||
|
@ -162,7 +162,7 @@ p.two {
|
||||||
border-style: solid;
|
border-style: solid;
|
||||||
border-width: medium;
|
border-width: medium;
|
||||||
}
|
}
|
||||||
|
|
||||||
p.three {
|
p.three {
|
||||||
border-style: solid;
|
border-style: solid;
|
||||||
border-width: 25px 10px 4px 35px; /* 25px top, 10px right, 4px bottom and 35px left */
|
border-width: 25px 10px 4px 35px; /* 25px top, 10px right, 4px bottom and 35px left */
|
||||||
|
@ -190,9 +190,9 @@ p {
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
The `box-shadow` property attaches one or more shadows to an element (Syntax: `box-shadow: none|_h-offset v-offset blur spread color_ |inset|initial|inherit;`).
|
The `box-shadow` property attaches one or more shadows to an element (Syntax: `box-shadow: none|_h-offset v-offset blur spread color_ |inset|initial|inherit;`).
|
||||||
```css
|
```css
|
||||||
#example2 {box-shadow: 5px 10px #888888;}
|
#example2 {box-shadow: 5px 10px #888888;}
|
||||||
```
|
```
|
||||||
|
|
||||||
### Margins
|
### Margins
|
||||||
|
@ -209,7 +209,7 @@ p {
|
||||||
margin-right: 150px;
|
margin-right: 150px;
|
||||||
margin-left: 80px;
|
margin-left: 80px;
|
||||||
}
|
}
|
||||||
p { margin: 25px 50px 75px 100px;}
|
p { margin: 25px 50px 75px 100px;}
|
||||||
```
|
```
|
||||||
|
|
||||||
### Padding
|
### Padding
|
||||||
|
@ -360,57 +360,57 @@ The `opacity` property specifies the opacity/transparency of an element.
|
||||||
img {opacity: 0.5;}
|
img {opacity: 0.5;}
|
||||||
```
|
```
|
||||||
|
|
||||||
The `cursor` property specifies the mouse cursor to be displayed when pointing over an element.
|
The `cursor` property specifies the mouse cursor to be displayed when pointing over an element.
|
||||||
```css
|
```css
|
||||||
.alias {cursor: alias;}
|
.alias {cursor: alias;}
|
||||||
.all-scroll {cursor: all-scroll;}
|
.all-scroll {cursor: all-scroll;}
|
||||||
.auto {cursor: auto;}
|
.auto {cursor: auto;}
|
||||||
.cell {cursor: cell;}
|
.cell {cursor: cell;}
|
||||||
.col-resize {cursor: col-resize;}
|
.col-resize {cursor: col-resize;}
|
||||||
.context-menu {cursor: context-menu;}
|
.context-menu {cursor: context-menu;}
|
||||||
.copy {cursor: copy;}
|
.copy {cursor: copy;}
|
||||||
.crosshair {cursor: crosshair;}
|
.crosshair {cursor: crosshair;}
|
||||||
.default {cursor: default;}
|
.default {cursor: default;}
|
||||||
.e-resize {cursor: e-resize;}
|
.e-resize {cursor: e-resize;}
|
||||||
.ew-resize {cursor: ew-resize;}
|
.ew-resize {cursor: ew-resize;}
|
||||||
.grab {cursor: grab;}
|
.grab {cursor: grab;}
|
||||||
.grabbing {cursor: grabbing;}
|
.grabbing {cursor: grabbing;}
|
||||||
.help {cursor: help;}
|
.help {cursor: help;}
|
||||||
.move {cursor: move;}
|
.move {cursor: move;}
|
||||||
.n-resize {cursor: n-resize;}
|
.n-resize {cursor: n-resize;}
|
||||||
.ne-resize {cursor: ne-resize;}
|
.ne-resize {cursor: ne-resize;}
|
||||||
.nesw-resize {cursor: nesw-resize;}
|
.nesw-resize {cursor: nesw-resize;}
|
||||||
.ns-resize {cursor: ns-resize;}
|
.ns-resize {cursor: ns-resize;}
|
||||||
.nw-resize {cursor: nw-resize;}
|
.nw-resize {cursor: nw-resize;}
|
||||||
.nwse-resize {cursor: nwse-resize;}
|
.nwse-resize {cursor: nwse-resize;}
|
||||||
.no-drop {cursor: no-drop;}
|
.no-drop {cursor: no-drop;}
|
||||||
.none {cursor: none;}
|
.none {cursor: none;}
|
||||||
.not-allowed {cursor: not-allowed;}
|
.not-allowed {cursor: not-allowed;}
|
||||||
.pointer {cursor: pointer;}
|
.pointer {cursor: pointer;}
|
||||||
.progress {cursor: progress;}
|
.progress {cursor: progress;}
|
||||||
.row-resize {cursor: row-resize;}
|
.row-resize {cursor: row-resize;}
|
||||||
.s-resize {cursor: s-resize;}
|
.s-resize {cursor: s-resize;}
|
||||||
.se-resize {cursor: se-resize;}
|
.se-resize {cursor: se-resize;}
|
||||||
.sw-resize {cursor: sw-resize;}
|
.sw-resize {cursor: sw-resize;}
|
||||||
.text {cursor: text;}
|
.text {cursor: text;}
|
||||||
.url {cursor: url(myBall.cur),auto;}
|
.url {cursor: url(myBall.cur),auto;}
|
||||||
.w-resize {cursor: w-resize;}
|
.w-resize {cursor: w-resize;}
|
||||||
.wait {cursor: wait;}
|
.wait {cursor: wait;}
|
||||||
.zoom-in {cursor: zoom-in;}
|
.zoom-in {cursor: zoom-in;}
|
||||||
.zoom-out {cursor: zoom-out;}
|
.zoom-out {cursor: zoom-out;}
|
||||||
```
|
```
|
||||||
|
|
||||||
The `rotate` property allows you to rotate elements.
|
The `rotate` property allows you to rotate elements.
|
||||||
```css
|
```css
|
||||||
div {rotate: 30deg;}
|
div {rotate: 30deg;}
|
||||||
```
|
```
|
||||||
|
|
||||||
The `scale` property allows you to change the size of elements.
|
The `scale` property allows you to change the size of elements.
|
||||||
```css
|
```css
|
||||||
div {scale: 2;}
|
div {scale: 2;}
|
||||||
```
|
```
|
||||||
|
|
||||||
The `translate` property allows you to change the position of elements.
|
The `translate` property allows you to change the position of elements.
|
||||||
```css
|
```css
|
||||||
div {translate: 100px 20px;}
|
div {translate: 100px 20px;}
|
||||||
```
|
```
|
|
@ -25,38 +25,38 @@ Set-Cookie: <cookie-name>=<cookie-value>
|
||||||
## Cookie lifetime
|
## Cookie lifetime
|
||||||
The lifetime of a cookie can be defined in two ways:
|
The lifetime of a cookie can be defined in two ways:
|
||||||
|
|
||||||
- _Session_ cookies are deleted when the current session ends. The browser defines when the "current session" ends, and some browsers use _session restoring_ when restarting. This can cause session cookies to last indefinitely.
|
- _Session_ cookies are deleted when the current session ends. The browser defines when the "current session" ends, and some browsers use _session restoring_ when restarting. This can cause session cookies to last indefinitely.
|
||||||
- _Permanent_ cookies are deleted at a date specified by the `Expires` attribute, or after a period of time specified by the `Max-Age` attribute.
|
- _Permanent_ cookies are deleted at a date specified by the `Expires` attribute, or after a period of time specified by the `Max-Age` attribute.
|
||||||
|
|
||||||
```
|
```
|
||||||
Set-Cookie: id=a3fWa; Expires=Thu, 31 Oct 2021 07:28:00 GMT;
|
Set-Cookie: id=a3fWa; Expires=Thu, 31 Oct 2021 07:28:00 GMT;
|
||||||
```
|
```
|
||||||
|
|
||||||
## Restrict access to cookies
|
## Restrict access to cookies
|
||||||
You can ensure that cookies are sent securely and aren't accessed by unintended parties or scripts in one of two ways: with the `Secure` attribute and the `HttpOnly` attribute.
|
You can ensure that cookies are sent securely and aren't accessed by unintended parties or scripts in one of two ways: with the `Secure` attribute and the `HttpOnly` attribute.
|
||||||
|
|
||||||
A cookie with the `Secure` attribute is only sent to the server with an encrypted request over the HTTPS protocol. It's never sent with unsecured [HTTP](HTTP.md) (except on localhost), which means man-in-the-middle attackers can't access it easily. Insecure sites (with `http:` in the [URL](URL.md)) can't set cookies with the `Secure` attribute. However, don't assume that `Secure` prevents all access to sensitive information in cookies. For example, someone with access to the client's hard disk (or JavaScript if the `HttpOnly` attribute isn't set) can read and modify the information.
|
A cookie with the `Secure` attribute is only sent to the server with an encrypted request over the HTTPS protocol. It's never sent with unsecured [HTTP](HTTP.md) (except on localhost), which means man-in-the-middle attackers can't access it easily. Insecure sites (with `http:` in the [URL](URL.md)) can't set cookies with the `Secure` attribute. However, don't assume that `Secure` prevents all access to sensitive information in cookies. For example, someone with access to the client's hard disk (or JavaScript if the `HttpOnly` attribute isn't set) can read and modify the information.
|
||||||
|
|
||||||
A cookie with the `HttpOnly` attribute is inaccessible to the JavaScript `Document.cookie`) API; it's only sent to the server. For example, cookies that persist in server-side sessions don't need to be available to JavaScript and should have the `HttpOnly` attribute. This precaution helps mitigate cross-site scripting (XSS) attacks.
|
A cookie with the `HttpOnly` attribute is inaccessible to the JavaScript `Document.cookie`) API; it's only sent to the server. For example, cookies that persist in server-side sessions don't need to be available to JavaScript and should have the `HttpOnly` attribute. This precaution helps mitigate cross-site scripting (XSS) attacks.
|
||||||
|
|
||||||
```
|
```
|
||||||
Set-Cookie: id=a3fWa; Expires=Thu, 21 Oct 2021 07:28:00 GMT; Secure; HttpOnly
|
Set-Cookie: id=a3fWa; Expires=Thu, 21 Oct 2021 07:28:00 GMT; Secure; HttpOnly
|
||||||
```
|
```
|
||||||
|
|
||||||
## Define where cookies are sent
|
## Define where cookies are sent
|
||||||
The `Domain` and `Path` attributes define the _scope_ of a cookie: what URLs the cookies should be sent to.
|
The `Domain` and `Path` attributes define the _scope_ of a cookie: what URLs the cookies should be sent to.
|
||||||
|
|
||||||
### Domain attribute
|
### Domain attribute
|
||||||
The `Domain` attribute specifies which server can receive a cookie.
|
The `Domain` attribute specifies which server can receive a cookie.
|
||||||
|
|
||||||
If specified, then cookies are available on the server and its subdomains. For example, if you set `Domain=mozilla.org`, cookies are available on mozilla.org and its subdomains like `developer.mozilla.org`.
|
If specified, then cookies are available on the server and its subdomains. For example, if you set `Domain=mozilla.org`, cookies are available on mozilla.org and its subdomains like `developer.mozilla.org`.
|
||||||
|
|
||||||
If the server does not specify a `Domain`, the cookies are available on the server _but not on its subdomains_. Therefore, specifying `Domain` is less restrictive than omitting it. However, it can be helpful when subdomains need to share information about a user.
|
If the server does not specify a `Domain`, the cookies are available on the server _but not on its subdomains_. Therefore, specifying `Domain` is less restrictive than omitting it. However, it can be helpful when subdomains need to share information about a user.
|
||||||
|
|
||||||
### Path attribute
|
### Path attribute
|
||||||
The `Path` attribute indicates a [URL](URL.md) path that must exist in the requested [URL](URL.md) in order to send the `Cookie` header. The `%x2F` ("/") character is considered a directory separator, and subdirectories match as well.
|
The `Path` attribute indicates a [URL](URL.md) path that must exist in the requested [URL](URL.md) in order to send the `Cookie` header. The `%x2F` ("/") character is considered a directory separator, and subdirectories match as well.
|
||||||
|
|
||||||
For example, if you set `Path=/docs`, these request paths match:
|
For example, if you set `Path=/docs`, these request paths match:
|
||||||
- `/docs`
|
- `/docs`
|
||||||
- `/docs/`
|
- `/docs/`
|
||||||
- `/docs/Web/`
|
- `/docs/Web/`
|
||||||
|
@ -68,9 +68,9 @@ But these request paths don't:
|
||||||
- `/fr/docs`
|
- `/fr/docs`
|
||||||
|
|
||||||
### SameSite attribute
|
### SameSite attribute
|
||||||
The `SameSite` attribute lets servers specify whether/when cookies are sent with cross-site requests (where Site is defined by the registrable [domain](Domain.md) and the _scheme_: http or https). This provides some protection against cross-site request forgery attacks (CSRF). It takes three possible values: `Strict`, `Lax`, and `None`.
|
The `SameSite` attribute lets servers specify whether/when cookies are sent with cross-site requests (where Site is defined by the registrable [domain](Domain.md) and the _scheme_: http or https). This provides some protection against cross-site request forgery attacks (CSRF). It takes three possible values: `Strict`, `Lax`, and `None`.
|
||||||
|
|
||||||
With `Strict`, the browser only sends the cookie with requests from the cookie's origin site. `Lax` is similar, except the browser also sends the cookie when the user _navigates_ to the cookie's origin site (even if the user is coming from a different site). For example, by following a link from an external site. `None` specifies that cookies are sent on both originating and cross-site requests, but _only in secure contexts_ (i.e., if `SameSite=None` then the `Secure` attribute must also be set). If no `SameSite` attribute is set, the cookie is treated as `Lax`.
|
With `Strict`, the browser only sends the cookie with requests from the cookie's origin site. `Lax` is similar, except the browser also sends the cookie when the user _navigates_ to the cookie's origin site (even if the user is coming from a different site). For example, by following a link from an external site. `None` specifies that cookies are sent on both originating and cross-site requests, but _only in secure contexts_ (i.e., if `SameSite=None` then the `Secure` attribute must also be set). If no `SameSite` attribute is set, the cookie is treated as `Lax`.
|
||||||
|
|
||||||
```
|
```
|
||||||
Set-Cookie: mykey=myvalue; SameSite=Strict
|
Set-Cookie: mykey=myvalue; SameSite=Strict
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -3,46 +3,46 @@ source: https://developer.mozilla.org/en-US/docs/Web/HTML
|
||||||
obj: concept
|
obj: concept
|
||||||
---
|
---
|
||||||
|
|
||||||
**HTML** (HyperText Markup Language) is the most basic building block of the Web. It defines the meaning and structure of web content. Other technologies besides HTML are generally used to describe a web page's appearance/presentation ([CSS](https://developer.mozilla.org/en-US/docs/Web/CSS)) or functionality/behavior ([JavaScript](https://developer.mozilla.org/en-US/docs/Web/JavaScript)).
|
**HTML** (HyperText Markup Language) is the most basic building block of the Web. It defines the meaning and structure of web content. Other technologies besides HTML are generally used to describe a web page's appearance/presentation ([CSS](https://developer.mozilla.org/en-US/docs/Web/CSS)) or functionality/behavior ([JavaScript](https://developer.mozilla.org/en-US/docs/Web/JavaScript)).
|
||||||
|
|
||||||
"Hypertext" refers to links that connect web pages to one another, either within a single website or between websites. Links are a fundamental aspect of the Web. By uploading content to the Internet and linking it to pages created by other people, you become an active participant in the World Wide Web.
|
"Hypertext" refers to links that connect web pages to one another, either within a single website or between websites. Links are a fundamental aspect of the Web. By uploading content to the Internet and linking it to pages created by other people, you become an active participant in the World Wide Web.
|
||||||
|
|
||||||
HTML uses "markup" to annotate text, images, and other content for display in a Web browser. HTML markup includes special "elements" such as [`<head>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/head), [`<title>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/title), [`<body>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/body), [`<header>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/header), [`<footer>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/footer), [`<article>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/article), [`<section>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/section), [`<p>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/p), [`<div>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/div), [`<span>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/span), [`<img>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/img), [`<aside>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/aside), [`<audio>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/audio), [`<canvas>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/canvas), [`<datalist>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/datalist), [`<details>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/details), [`<embed>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/embed), [`<nav>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/nav), [`<search>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/search), [`<output>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/output), [`<progress>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/progress), [`<video>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/video), [`<ul>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/ul), [`<ol>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/ol), [`<li>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/li) and many others.
|
HTML uses "markup" to annotate text, images, and other content for display in a Web browser. HTML markup includes special "elements" such as [`<head>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/head), [`<title>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/title), [`<body>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/body), [`<header>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/header), [`<footer>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/footer), [`<article>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/article), [`<section>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/section), [`<p>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/p), [`<div>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/div), [`<span>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/span), [`<img>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/img), [`<aside>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/aside), [`<audio>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/audio), [`<canvas>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/canvas), [`<datalist>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/datalist), [`<details>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/details), [`<embed>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/embed), [`<nav>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/nav), [`<search>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/search), [`<output>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/output), [`<progress>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/progress), [`<video>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/video), [`<ul>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/ul), [`<ol>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/ol), [`<li>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/li) and many others.
|
||||||
|
|
||||||
An HTML element is set off from other text in a document by "tags", which consist of the element name surrounded by "`<`" and "`>`". The name of an element inside a tag is case-insensitive. That is, it can be written in uppercase, lowercase, or a mixture. For example, the `<title>` tag can be written as `<Title>`, `<TITLE>`, or in any other way. However, the convention and recommended practice is to write tags in lowercase.
|
An HTML element is set off from other text in a document by "tags", which consist of the element name surrounded by "`<`" and "`>`". The name of an element inside a tag is case-insensitive. That is, it can be written in uppercase, lowercase, or a mixture. For example, the `<title>` tag can be written as `<Title>`, `<TITLE>`, or in any other way. However, the convention and recommended practice is to write tags in lowercase.
|
||||||
|
|
||||||
# Elements
|
# Elements
|
||||||
## \<a>
|
## \<a>
|
||||||
The **`<a>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element (or _anchor_ element), with [its `href` attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/a#href), creates a hyperlink to web pages, files, email addresses, locations in the same page, or anything else a URL can address.
|
The **`<a>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element (or _anchor_ element), with [its `href` attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/a#href), creates a hyperlink to web pages, files, email addresses, locations in the same page, or anything else a URL can address.
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element's attributes include the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element's attributes include the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `download`
|
- `download`
|
||||||
Causes the browser to treat the linked URL as a download. Can be used with or without a `filename` value:
|
Causes the browser to treat the linked URL as a download. Can be used with or without a `filename` value:
|
||||||
|
|
||||||
Without a value, the browser will suggest a filename/extension, generated from various sources:
|
Without a value, the browser will suggest a filename/extension, generated from various sources:
|
||||||
- The [`Content-Disposition`](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Disposition) HTTP header
|
- The [`Content-Disposition`](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Disposition) HTTP header
|
||||||
- The final segment in the URL [path](https://developer.mozilla.org/en-US/docs/Web/API/URL/pathname)
|
- The final segment in the URL [path](https://developer.mozilla.org/en-US/docs/Web/API/URL/pathname)
|
||||||
- The [media type](https://developer.mozilla.org/en-US/docs/Glossary/MIME_type) (from the [`Content-Type`](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Type) header, the start of a [`data:` URL](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URLs), or [`Blob.type`](https://developer.mozilla.org/en-US/docs/Web/API/Blob/type) for a [`blob:` URL](https://developer.mozilla.org/en-US/docs/Web/API/URL/createObjectURL_static))
|
- The [media type](https://developer.mozilla.org/en-US/docs/Glossary/MIME_type) (from the [`Content-Type`](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Type) header, the start of a [`data:` URL](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URLs), or [`Blob.type`](https://developer.mozilla.org/en-US/docs/Web/API/Blob/type) for a [`blob:` URL](https://developer.mozilla.org/en-US/docs/Web/API/URL/createObjectURL_static))
|
||||||
- `filename`:
|
- `filename`:
|
||||||
defining a value suggests it as the filename. `/` and `\` characters are converted to underscores (`_`). Filesystems may forbid other characters in filenames, so browsers will adjust the suggested name if necessary.
|
defining a value suggests it as the filename. `/` and `\` characters are converted to underscores (`_`). Filesystems may forbid other characters in filenames, so browsers will adjust the suggested name if necessary.
|
||||||
- `href`
|
- `href`
|
||||||
The URL that the hyperlink points to. Links are not restricted to HTTP-based URLs — they can use any URL scheme supported by browsers:
|
The URL that the hyperlink points to. Links are not restricted to HTTP-based URLs — they can use any URL scheme supported by browsers:
|
||||||
- Sections of a page with document fragments
|
- Sections of a page with document fragments
|
||||||
- Specific text portions with [text fragments](https://developer.mozilla.org/en-US/docs/Web/Text_fragments)
|
- Specific text portions with [text fragments](https://developer.mozilla.org/en-US/docs/Web/Text_fragments)
|
||||||
- Pieces of media files with media fragments
|
- Pieces of media files with media fragments
|
||||||
- Telephone numbers with `tel:` URLs
|
- Telephone numbers with `tel:` URLs
|
||||||
- Email addresses with `mailto:` URLs
|
- Email addresses with `mailto:` URLs
|
||||||
|
|
||||||
## \<article>
|
## \<article>
|
||||||
The **`<article>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a self-contained composition in a document, page, application, or site, which is intended to be independently distributable or reusable (e.g., in syndication). Examples include: a forum post, a magazine or newspaper article, or a blog entry, a product card, a user-submitted comment, an interactive widget or gadget, or any other independent item of content.
|
The **`<article>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a self-contained composition in a document, page, application, or site, which is intended to be independently distributable or reusable (e.g., in syndication). Examples include: a forum post, a magazine or newspaper article, or a blog entry, a product card, a user-submitted comment, an interactive widget or gadget, or any other independent item of content.
|
||||||
|
|
||||||
## \<audio>
|
## \<audio>
|
||||||
The **`<audio>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is used to embed sound content in documents. It may contain one or more audio sources, represented using the `src` attribute or the [`<source>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/source) element: the browser will choose the most suitable one. It can also be the destination for streamed media, using a [`MediaStream`](https://developer.mozilla.org/en-US/docs/Web/API/MediaStream).
|
The **`<audio>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is used to embed sound content in documents. It may contain one or more audio sources, represented using the `src` attribute or the [`<source>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/source) element: the browser will choose the most suitable one. It can also be the destination for streamed media, using a [`MediaStream`](https://developer.mozilla.org/en-US/docs/Web/API/MediaStream).
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element's attributes include the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element's attributes include the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `autoplay`
|
- `autoplay`
|
||||||
A Boolean attribute: if specified, the audio will automatically begin playback as soon as it can do so, without waiting for the entire audio file to finish downloading.
|
A Boolean attribute: if specified, the audio will automatically begin playback as soon as it can do so, without waiting for the entire audio file to finish downloading.
|
||||||
|
@ -51,26 +51,26 @@ This element's attributes include the [global attributes](https://developer.moz
|
||||||
-`loop`
|
-`loop`
|
||||||
A Boolean attribute: if specified, the audio player will automatically seek back to the start upon reaching the end of the audio.
|
A Boolean attribute: if specified, the audio player will automatically seek back to the start upon reaching the end of the audio.
|
||||||
-`muted`
|
-`muted`
|
||||||
A Boolean attribute that indicates whether the audio will be initially silenced. Its default value is `false`.
|
A Boolean attribute that indicates whether the audio will be initially silenced. Its default value is `false`.
|
||||||
- `preload`
|
- `preload`
|
||||||
This [enumerated](https://developer.mozilla.org/en-US/docs/Glossary/Enumerated) attribute is intended to provide a hint to the browser about what the author thinks will lead to the best user experience. It may have one of the following values:
|
This [enumerated](https://developer.mozilla.org/en-US/docs/Glossary/Enumerated) attribute is intended to provide a hint to the browser about what the author thinks will lead to the best user experience. It may have one of the following values:
|
||||||
|
|
||||||
- `none`: Indicates that the audio should not be preloaded.
|
- `none`: Indicates that the audio should not be preloaded.
|
||||||
- `metadata`: Indicates that only audio metadata (e.g. length) is fetched.
|
- `metadata`: Indicates that only audio metadata (e.g. length) is fetched.
|
||||||
- `auto`: Indicates that the whole audio file can be downloaded, even if the user is not expected to use it.
|
- `auto`: Indicates that the whole audio file can be downloaded, even if the user is not expected to use it.
|
||||||
- _empty string_: A synonym of the `auto` value.
|
- _empty string_: A synonym of the `auto` value.
|
||||||
|
|
||||||
## \<b>
|
## \<b>
|
||||||
The **`<b>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is used to draw the reader's attention to the element's contents, which are not otherwise granted special importance. This was formerly known as the Boldface element, and most browsers still draw the text in boldface. However, you should not use `<b>` for styling text or granting importance. If you wish to create boldface text, you should use the CSS [`font-weight`](https://developer.mozilla.org/en-US/docs/Web/CSS/font-weight) property. If you wish to indicate an element is of special importance, you should use the [`<strong>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/strong) element.
|
The **`<b>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is used to draw the reader's attention to the element's contents, which are not otherwise granted special importance. This was formerly known as the Boldface element, and most browsers still draw the text in boldface. However, you should not use `<b>` for styling text or granting importance. If you wish to create boldface text, you should use the CSS [`font-weight`](https://developer.mozilla.org/en-US/docs/Web/CSS/font-weight) property. If you wish to indicate an element is of special importance, you should use the [`<strong>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/strong) element.
|
||||||
|
|
||||||
## \<blockquote>
|
## \<blockquote>
|
||||||
The **`<blockquote>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element indicates that the enclosed text is an extended quotation. Usually, this is rendered visually by indentation (see [Notes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/blockquote#usage_notes) for how to change it). A URL for the source of the quotation may be given using the `cite` attribute, while a text representation of the source can be given using the [`<cite>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/cite) element.
|
The **`<blockquote>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element indicates that the enclosed text is an extended quotation. Usually, this is rendered visually by indentation (see [Notes](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/blockquote#usage_notes) for how to change it). A URL for the source of the quotation may be given using the `cite` attribute, while a text representation of the source can be given using the [`<cite>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/cite) element.
|
||||||
|
|
||||||
## \<body>
|
## \<body>
|
||||||
The **`<body>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents the content of an HTML document. There can be only one `<body>` element in a document.
|
The **`<body>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents the content of an HTML document. There can be only one `<body>` element in a document.
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `onload`
|
- `onload`
|
||||||
Function to call when the document has finished loading.
|
Function to call when the document has finished loading.
|
||||||
|
@ -80,129 +80,129 @@ This element includes the [global attributes](https://developer.mozilla.org/en-
|
||||||
Function to call when network communication has been restored.
|
Function to call when network communication has been restored.
|
||||||
|
|
||||||
## \<br>
|
## \<br>
|
||||||
The **`<br>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element produces a line break in text (carriage-return). It is useful for writing a poem or an address, where the division of lines is significant.
|
The **`<br>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element produces a line break in text (carriage-return). It is useful for writing a poem or an address, where the division of lines is significant.
|
||||||
|
|
||||||
## \<button>
|
## \<button>
|
||||||
The **`<button>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is an interactive element activated by a user with a mouse, keyboard, finger, voice command, or other assistive technology. Once activated, it then performs an action, such as submitting a [form](https://developer.mozilla.org/en-US/docs/Learn/Forms) or opening a dialog.
|
The **`<button>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is an interactive element activated by a user with a mouse, keyboard, finger, voice command, or other assistive technology. Once activated, it then performs an action, such as submitting a [form](https://developer.mozilla.org/en-US/docs/Learn/Forms) or opening a dialog.
|
||||||
|
|
||||||
By default, HTML buttons are presented in a style resembling the platform the [user agent](https://developer.mozilla.org/en-US/docs/Glossary/User_agent) runs on, but you can change buttons' appearance with [CSS](https://developer.mozilla.org/en-US/docs/Web/CSS).
|
By default, HTML buttons are presented in a style resembling the platform the [user agent](https://developer.mozilla.org/en-US/docs/Glossary/User_agent) runs on, but you can change buttons' appearance with [CSS](https://developer.mozilla.org/en-US/docs/Web/CSS).
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element's attributes include the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element's attributes include the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `autofocus`
|
- `autofocus`
|
||||||
This Boolean attribute specifies that the button should have input [focus](https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/focus) when the page loads. **Only one element in a document can have this attribute.**
|
This Boolean attribute specifies that the button should have input [focus](https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/focus) when the page loads. **Only one element in a document can have this attribute.**
|
||||||
- `disabled`
|
- `disabled`
|
||||||
This Boolean attribute prevents the user from interacting with the button: it cannot be pressed or focused.
|
This Boolean attribute prevents the user from interacting with the button: it cannot be pressed or focused.
|
||||||
- `form`
|
- `form`
|
||||||
The [`<form>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/form) element to associate the button with (its _form owner_). The value of this attribute must be the `id` of a `<form>` in the same document. (If this attribute is not set, the `<button>` is associated with its ancestor `<form>` element, if any.)
|
The [`<form>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/form) element to associate the button with (its _form owner_). The value of this attribute must be the `id` of a `<form>` in the same document. (If this attribute is not set, the `<button>` is associated with its ancestor `<form>` element, if any.)
|
||||||
This attribute lets you associate `<button>` elements to `<form>`s anywhere in the document, not just inside a `<form>`. It can also override an ancestor `<form>` element.
|
This attribute lets you associate `<button>` elements to `<form>`s anywhere in the document, not just inside a `<form>`. It can also override an ancestor `<form>` element.
|
||||||
- `name`
|
- `name`
|
||||||
The name of the button, submitted as a pair with the button's `value` as part of the form data, when that button is used to submit the form.
|
The name of the button, submitted as a pair with the button's `value` as part of the form data, when that button is used to submit the form.
|
||||||
- `type`
|
- `type`
|
||||||
The default behavior of the button. Possible values are:
|
The default behavior of the button. Possible values are:
|
||||||
- `submit`: The button submits the form data to the server. This is the default if the attribute is not specified for buttons associated with a `<form>`, or if the attribute is an empty or invalid value.
|
- `submit`: The button submits the form data to the server. This is the default if the attribute is not specified for buttons associated with a `<form>`, or if the attribute is an empty or invalid value.
|
||||||
- `reset`: The button resets all the controls to their initial values, like [<input type="reset">](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/reset). (This behavior tends to annoy users.)
|
- `reset`: The button resets all the controls to their initial values, like [<input type="reset">](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/reset). (This behavior tends to annoy users.)
|
||||||
- `button`: The button has no default behavior, and does nothing when pressed by default. It can have client-side scripts listen to the element's events, which are triggered when the events occur.
|
- `button`: The button has no default behavior, and does nothing when pressed by default. It can have client-side scripts listen to the element's events, which are triggered when the events occur.
|
||||||
- `value`
|
- `value`
|
||||||
Defines the value associated with the button's `name` when it's submitted with the form data. This value is passed to the server in params when the form is submitted using this button.
|
Defines the value associated with the button's `name` when it's submitted with the form data. This value is passed to the server in params when the form is submitted using this button.
|
||||||
|
|
||||||
## \<code>
|
## \<code>
|
||||||
The **`<code>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element displays its contents styled in a fashion intended to indicate that the text is a short fragment of computer code. By default, the content text is displayed using the [user agent's](https://developer.mozilla.org/en-US/docs/Glossary/User_agent) default monospace font.
|
The **`<code>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element displays its contents styled in a fashion intended to indicate that the text is a short fragment of computer code. By default, the content text is displayed using the [user agent's](https://developer.mozilla.org/en-US/docs/Glossary/User_agent) default monospace font.
|
||||||
|
|
||||||
## \<data>
|
## \<data>
|
||||||
The **`<data>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element links a given piece of content with a machine-readable translation. If the content is time- or date-related, the [`<time>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/time) element must be used.
|
The **`<data>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element links a given piece of content with a machine-readable translation. If the content is time- or date-related, the [`<time>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/time) element must be used.
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element's attributes include the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element's attributes include the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `value`
|
- `value`
|
||||||
This attribute specifies the machine-readable translation of the content of the element.
|
This attribute specifies the machine-readable translation of the content of the element.
|
||||||
|
|
||||||
## \<del>
|
## \<del>
|
||||||
The **`<del>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a range of text that has been deleted from a document. This can be used when rendering "track changes" or source code diff information, for example. The [`<ins>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/ins) element can be used for the opposite purpose: to indicate text that has been added to the document.
|
The **`<del>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a range of text that has been deleted from a document. This can be used when rendering "track changes" or source code diff information, for example. The [`<ins>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/ins) element can be used for the opposite purpose: to indicate text that has been added to the document.
|
||||||
|
|
||||||
## \<details>
|
## \<details>
|
||||||
The **`<details>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element creates a disclosure widget in which information is visible only when the widget is toggled into an "open" state. A summary or label must be provided using the [`<summary>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/summary) element.
|
The **`<details>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element creates a disclosure widget in which information is visible only when the widget is toggled into an "open" state. A summary or label must be provided using the [`<summary>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/summary) element.
|
||||||
|
|
||||||
A disclosure widget is typically presented onscreen using a small triangle which rotates (or twists) to indicate open/closed status, with a label next to the triangle. The contents of the `<summary>` element are used as the label for the disclosure widget.
|
A disclosure widget is typically presented onscreen using a small triangle which rotates (or twists) to indicate open/closed status, with a label next to the triangle. The contents of the `<summary>` element are used as the label for the disclosure widget.
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `open`
|
- `open`
|
||||||
This Boolean attribute indicates whether the details — that is, the contents of the `<details>` element — are currently visible. The details are shown when this attribute exists, or hidden when this attribute is absent. By default this attribute is absent which means the details are not visible.
|
This Boolean attribute indicates whether the details — that is, the contents of the `<details>` element — are currently visible. The details are shown when this attribute exists, or hidden when this attribute is absent. By default this attribute is absent which means the details are not visible.
|
||||||
|
|
||||||
> **Note:** You have to remove this attribute entirely to make the details hidden. `open="false"` makes the details visible because this attribute is Boolean.
|
> **Note:** You have to remove this attribute entirely to make the details hidden. `open="false"` makes the details visible because this attribute is Boolean.
|
||||||
|
|
||||||
## \<div>
|
## \<div>
|
||||||
The **`<div>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is the generic container for flow content. It has no effect on the content or layout until styled in some way using [CSS](https://developer.mozilla.org/en-US/docs/Glossary/CSS).
|
The **`<div>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is the generic container for flow content. It has no effect on the content or layout until styled in some way using [CSS](https://developer.mozilla.org/en-US/docs/Glossary/CSS).
|
||||||
|
|
||||||
## \<em>
|
## \<em>
|
||||||
The **`<em>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element marks text that has stress emphasis. The `<em>` element can be nested, with each level of nesting indicating a greater degree of emphasis.
|
The **`<em>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element marks text that has stress emphasis. The `<em>` element can be nested, with each level of nesting indicating a greater degree of emphasis.
|
||||||
|
|
||||||
## \<embed>
|
## \<embed>
|
||||||
The **`<embed>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element embeds external content at the specified point in the document. This content is provided by an external application or other source of interactive content such as a browser plug-in.
|
The **`<embed>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element embeds external content at the specified point in the document. This content is provided by an external application or other source of interactive content such as a browser plug-in.
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element's attributes include the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element's attributes include the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `height`
|
- `height`
|
||||||
The displayed height of the resource, in [CSS pixels](https://drafts.csswg.org/css-values/#px). This must be an absolute value; percentages are _not_ allowed.
|
The displayed height of the resource, in [CSS pixels](https://drafts.csswg.org/css-values/#px). This must be an absolute value; percentages are _not_ allowed.
|
||||||
- `src`
|
- `src`
|
||||||
The URL of the resource being embedded.
|
The URL of the resource being embedded.
|
||||||
- `type`
|
- `type`
|
||||||
The [MIME type](https://developer.mozilla.org/en-US/docs/Glossary/MIME_type) to use to select the plug-in to instantiate.
|
The [MIME type](https://developer.mozilla.org/en-US/docs/Glossary/MIME_type) to use to select the plug-in to instantiate.
|
||||||
- `width`
|
- `width`
|
||||||
The displayed width of the resource, in [CSS pixels](https://drafts.csswg.org/css-values/#px). This must be an absolute value; percentages are _not_ allowed.
|
The displayed width of the resource, in [CSS pixels](https://drafts.csswg.org/css-values/#px). This must be an absolute value; percentages are _not_ allowed.
|
||||||
|
|
||||||
## \<footer>
|
## \<footer>
|
||||||
The **`<footer>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a footer for its nearest ancestor [sectioning content](https://developer.mozilla.org/en-US/docs/Web/HTML/Content_categories#sectioning_content) or [sectioning root](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/Heading_Elements#sectioning_root) element. A `<footer>` typically contains information about the author of the section, copyright data or links to related documents.
|
The **`<footer>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a footer for its nearest ancestor [sectioning content](https://developer.mozilla.org/en-US/docs/Web/HTML/Content_categories#sectioning_content) or [sectioning root](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/Heading_Elements#sectioning_root) element. A `<footer>` typically contains information about the author of the section, copyright data or links to related documents.
|
||||||
|
|
||||||
## \<form>
|
## \<form>
|
||||||
The **`<form>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a document section containing interactive controls for submitting information.
|
The **`<form>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a document section containing interactive controls for submitting information.
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `accept-charset`
|
- `accept-charset`
|
||||||
Space-separated [character encodings](https://developer.mozilla.org/en-US/docs/Glossary/Character_encoding) the server accepts. The browser uses them in the order in which they are listed. The default value means [the same encoding as the page](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Encoding). (In previous versions of HTML, character encodings could also be delimited by commas.)
|
Space-separated [character encodings](https://developer.mozilla.org/en-US/docs/Glossary/Character_encoding) the server accepts. The browser uses them in the order in which they are listed. The default value means [the same encoding as the page](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Encoding). (In previous versions of HTML, character encodings could also be delimited by commas.)
|
||||||
- `autocomplete`
|
- `autocomplete`
|
||||||
Indicates whether input elements can by default have their values automatically completed by the browser. `autocomplete` attributes on form elements override it on `<form>`. Possible values:
|
Indicates whether input elements can by default have their values automatically completed by the browser. `autocomplete` attributes on form elements override it on `<form>`. Possible values:
|
||||||
- `off`: The browser may not automatically complete entries. (Browsers tend to ignore this for suspected login forms; see [The autocomplete attribute and login fields](https://developer.mozilla.org/en-US/docs/Web/Security/Securing_your_site/Turning_off_form_autocompletion#the_autocomplete_attribute_and_login_fields).)
|
- `off`: The browser may not automatically complete entries. (Browsers tend to ignore this for suspected login forms; see [The autocomplete attribute and login fields](https://developer.mozilla.org/en-US/docs/Web/Security/Securing_your_site/Turning_off_form_autocompletion#the_autocomplete_attribute_and_login_fields).)
|
||||||
- `on`: The browser may automatically complete entries.
|
- `on`: The browser may automatically complete entries.
|
||||||
- `name`
|
- `name`
|
||||||
The name of the form. The value must not be the empty string, and must be unique among the `form` elements in the forms collection that it is in, if any.
|
The name of the form. The value must not be the empty string, and must be unique among the `form` elements in the forms collection that it is in, if any.
|
||||||
|
|
||||||
### Attributes for form submission
|
### Attributes for form submission
|
||||||
The following attributes control behavior during form submission.
|
The following attributes control behavior during form submission.
|
||||||
|
|
||||||
- `action`
|
- `action`
|
||||||
The URL that processes the form submission. This value can be overridden by a [`formaction`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/button#formaction) attribute on a [`<button>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/button), [`<input type="submit">`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/submit), or [`<input type="image">`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/image) element. This attribute is ignored when `method="dialog"` is set.
|
The URL that processes the form submission. This value can be overridden by a [`formaction`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/button#formaction) attribute on a [`<button>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/button), [`<input type="submit">`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/submit), or [`<input type="image">`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/image) element. This attribute is ignored when `method="dialog"` is set.
|
||||||
- `enctype`
|
- `enctype`
|
||||||
If the value of the `method` attribute is `post`, `enctype` is the [MIME type](https://en.wikipedia.org/wiki/Mime_type) of the form submission. Possible values:
|
If the value of the `method` attribute is `post`, `enctype` is the [MIME type](https://en.wikipedia.org/wiki/Mime_type) of the form submission. Possible values:
|
||||||
- `application/x-www-form-urlencoded`: The default value.
|
- `application/x-www-form-urlencoded`: The default value.
|
||||||
- `multipart/form-data`: Use this if the form contains [`<input>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input) elements with `type=file`.
|
- `multipart/form-data`: Use this if the form contains [`<input>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input) elements with `type=file`.
|
||||||
- `text/plain`: Useful for debugging purposes.
|
- `text/plain`: Useful for debugging purposes.
|
||||||
- `method`
|
- `method`
|
||||||
The [HTTP](https://developer.mozilla.org/en-US/docs/Web/HTTP) method to submit the form with. The only allowed methods/values are (case insensitive):
|
The [HTTP](https://developer.mozilla.org/en-US/docs/Web/HTTP) method to submit the form with. The only allowed methods/values are (case insensitive):
|
||||||
- `post`: The [`POST`](https://developer.mozilla.org/en-US/docs/Web/HTTP/Methods/POST) method; form data sent as the [request body](https://developer.mozilla.org/en-US/docs/Web/API/Request/body).
|
- `post`: The [`POST`](https://developer.mozilla.org/en-US/docs/Web/HTTP/Methods/POST) method; form data sent as the [request body](https://developer.mozilla.org/en-US/docs/Web/API/Request/body).
|
||||||
- `get` (default): The [`GET`](https://developer.mozilla.org/en-US/docs/Web/HTTP/Methods/GET); form data appended to the `action` URL with a `?` separator. Use this method when the form [has no side effects](https://developer.mozilla.org/en-US/docs/Glossary/Idempotent).
|
- `get` (default): The [`GET`](https://developer.mozilla.org/en-US/docs/Web/HTTP/Methods/GET); form data appended to the `action` URL with a `?` separator. Use this method when the form [has no side effects](https://developer.mozilla.org/en-US/docs/Glossary/Idempotent).
|
||||||
- `dialog`: When the form is inside a [`<dialog>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/dialog), closes the dialog and causes a `submit` event to be fired on submission, without submitting data or clearing the form.
|
- `dialog`: When the form is inside a [`<dialog>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/dialog), closes the dialog and causes a `submit` event to be fired on submission, without submitting data or clearing the form.
|
||||||
- `target`
|
- `target`
|
||||||
Indicates where to display the response after submitting the form. It is a name/keyword for a _browsing context_ (for example, tab, window, or iframe). The following keywords have special meanings:
|
Indicates where to display the response after submitting the form. It is a name/keyword for a _browsing context_ (for example, tab, window, or iframe). The following keywords have special meanings:
|
||||||
- `_self` (default): Load into the same browsing context as the current one.
|
- `_self` (default): Load into the same browsing context as the current one.
|
||||||
- `_blank`: Load into a new unnamed browsing context. This provides the same behavior as setting [`rel="noopener"`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/form#rel) which does not set [`window.opener`](https://developer.mozilla.org/en-US/docs/Web/API/Window/opener).
|
- `_blank`: Load into a new unnamed browsing context. This provides the same behavior as setting [`rel="noopener"`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/form#rel) which does not set [`window.opener`](https://developer.mozilla.org/en-US/docs/Web/API/Window/opener).
|
||||||
- `_parent`: Load into the parent browsing context of the current one. If no parent, behaves the same as `_self`.
|
- `_parent`: Load into the parent browsing context of the current one. If no parent, behaves the same as `_self`.
|
||||||
- `_top`: Load into the top-level browsing context (i.e., the browsing context that is an ancestor of the current one and has no parent). If no parent, behaves the same as `_self`.
|
- `_top`: Load into the top-level browsing context (i.e., the browsing context that is an ancestor of the current one and has no parent). If no parent, behaves the same as `_self`.
|
||||||
|
|
||||||
## \<h1>
|
## \<h1>
|
||||||
The **`<h1>`** to **`<h6>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) elements represent six levels of section headings. `<h1>` is the highest section level and `<h6>` is the lowest. By default, all heading elements create a [block-level](https://developer.mozilla.org/en-US/docs/Glossary/Block-level_content) box in the layout, starting on a new line and taking up the full width available in their containing block.
|
The **`<h1>`** to **`<h6>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) elements represent six levels of section headings. `<h1>` is the highest section level and `<h6>` is the lowest. By default, all heading elements create a [block-level](https://developer.mozilla.org/en-US/docs/Glossary/Block-level_content) box in the layout, starting on a new line and taking up the full width available in their containing block.
|
||||||
|
|
||||||
## \<head>
|
## \<head>
|
||||||
The **`<head>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element contains machine-readable information ([metadata](https://developer.mozilla.org/en-US/docs/Glossary/Metadata)) about the document, like its [title](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/title), [scripts](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/script), and [style sheets](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/style).
|
The **`<head>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element contains machine-readable information ([metadata](https://developer.mozilla.org/en-US/docs/Glossary/Metadata)) about the document, like its [title](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/title), [scripts](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/script), and [style sheets](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/style).
|
||||||
|
|
||||||
- Elements that can be used inside the `<head>`:
|
- Elements that can be used inside the `<head>`:
|
||||||
- [`<title>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/title)
|
- [`<title>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/title)
|
||||||
- [`<base>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/base)
|
- [`<base>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/base)
|
||||||
- [`<link>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/link)
|
- [`<link>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/link)
|
||||||
|
@ -213,80 +213,80 @@ The **`<head>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) el
|
||||||
- [`<template>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/template)
|
- [`<template>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/template)
|
||||||
|
|
||||||
## \<header>
|
## \<header>
|
||||||
The **`<header>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents introductory content, typically a group of introductory or navigational aids. It may contain some heading elements but also a logo, a search form, an author name, and other elements.
|
The **`<header>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents introductory content, typically a group of introductory or navigational aids. It may contain some heading elements but also a logo, a search form, an author name, and other elements.
|
||||||
|
|
||||||
## \<hr>
|
## \<hr>
|
||||||
The **`<hr>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a thematic break between paragraph-level elements: for example, a change of scene in a story, or a shift of topic within a section.
|
The **`<hr>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a thematic break between paragraph-level elements: for example, a change of scene in a story, or a shift of topic within a section.
|
||||||
|
|
||||||
## \<html>
|
## \<html>
|
||||||
The **`<html>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents the root (top-level element) of an HTML document, so it is also referred to as the _root element_. All other elements must be descendants of this element.
|
The **`<html>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents the root (top-level element) of an HTML document, so it is also referred to as the _root element_. All other elements must be descendants of this element.
|
||||||
|
|
||||||
## \<iframe>
|
## \<iframe>
|
||||||
The **`<iframe>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a nested [browsing context](https://developer.mozilla.org/en-US/docs/Glossary/Browsing_context), embedding another HTML page into the current one.
|
The **`<iframe>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a nested [browsing context](https://developer.mozilla.org/en-US/docs/Glossary/Browsing_context), embedding another HTML page into the current one.
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `height`
|
- `height`
|
||||||
The height of the frame in CSS pixels. Default is `150`.
|
The height of the frame in CSS pixels. Default is `150`.
|
||||||
- `loading`
|
- `loading`
|
||||||
Indicates how the browser should load the iframe:
|
Indicates how the browser should load the iframe:
|
||||||
- `eager`: Load the iframe immediately, regardless if it is outside the visible viewport (this is the default value).
|
- `eager`: Load the iframe immediately, regardless if it is outside the visible viewport (this is the default value).
|
||||||
- `lazy`: Defer loading of the iframe until it reaches a calculated distance from the viewport, as defined by the browser.
|
- `lazy`: Defer loading of the iframe until it reaches a calculated distance from the viewport, as defined by the browser.
|
||||||
- `name`
|
- `name`
|
||||||
A targetable name for the embedded browsing context. This can be used in the `target` attribute of the [`<a>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/a), [`<form>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/form), or [`<base>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/base) elements; the `formtarget` attribute of the [`<input>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input) or [`<button>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/button) elements; or the `windowName` parameter in the [`window.open()`](https://developer.mozilla.org/en-US/docs/Web/API/Window/open "window.open()") method.
|
A targetable name for the embedded browsing context. This can be used in the `target` attribute of the [`<a>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/a), [`<form>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/form), or [`<base>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/base) elements; the `formtarget` attribute of the [`<input>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input) or [`<button>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/button) elements; or the `windowName` parameter in the [`window.open()`](https://developer.mozilla.org/en-US/docs/Web/API/Window/open "window.open()") method.
|
||||||
- `src`
|
- `src`
|
||||||
The URL of the page to embed. Use a value of `about:blank` to embed an empty page that conforms to the [same-origin policy](https://developer.mozilla.org/en-US/docs/Web/Security/Same-origin_policy#inherited_origins). Also note that programmatically removing an `<iframe>`'s src attribute (e.g. via [`Element.removeAttribute()`](https://developer.mozilla.org/en-US/docs/Web/API/Element/removeAttribute)) causes `about:blank` to be loaded in the frame in Firefox (from version 65), Chromium-based browsers, and Safari/iOS.
|
The URL of the page to embed. Use a value of `about:blank` to embed an empty page that conforms to the [same-origin policy](https://developer.mozilla.org/en-US/docs/Web/Security/Same-origin_policy#inherited_origins). Also note that programmatically removing an `<iframe>`'s src attribute (e.g. via [`Element.removeAttribute()`](https://developer.mozilla.org/en-US/docs/Web/API/Element/removeAttribute)) causes `about:blank` to be loaded in the frame in Firefox (from version 65), Chromium-based browsers, and Safari/iOS.
|
||||||
- `width`
|
- `width`
|
||||||
The width of the frame in CSS pixels. Default is `300`.
|
The width of the frame in CSS pixels. Default is `300`.
|
||||||
|
|
||||||
## \<img>
|
## \<img>
|
||||||
The **`<img>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element embeds an image into the document.
|
The **`<img>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element embeds an image into the document.
|
||||||
|
|
||||||
- `alt`
|
- `alt`
|
||||||
Defines an alternative text description of the image.
|
Defines an alternative text description of the image.
|
||||||
- `height`
|
- `height`
|
||||||
The intrinsic height of the image, in pixels. Must be an integer without a unit.
|
The intrinsic height of the image, in pixels. Must be an integer without a unit.
|
||||||
- `src`
|
- `src`
|
||||||
The image [URL](https://developer.mozilla.org/en-US/docs/Glossary/URL). Mandatory for the `<img>` element. On [browsers](https://developer.mozilla.org/en-US/docs/Glossary/Browser) supporting `srcset`, `src` is treated like a candidate image with a pixel density descriptor `1x`, unless an image with this pixel density descriptor is already defined in `srcset`, or unless `srcset` contains `w` descriptors.
|
The image [URL](https://developer.mozilla.org/en-US/docs/Glossary/URL). Mandatory for the `<img>` element. On [browsers](https://developer.mozilla.org/en-US/docs/Glossary/Browser) supporting `srcset`, `src` is treated like a candidate image with a pixel density descriptor `1x`, unless an image with this pixel density descriptor is already defined in `srcset`, or unless `srcset` contains `w` descriptors.
|
||||||
- `width`
|
- `width`
|
||||||
The intrinsic width of the image in pixels. Must be an integer without a unit.
|
The intrinsic width of the image in pixels. Must be an integer without a unit.
|
||||||
|
|
||||||
## \<ins>
|
## \<ins>
|
||||||
The **`<ins>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a range of text that has been added to a document. You can use the [`<del>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/del) element to similarly represent a range of text that has been deleted from the document.
|
The **`<ins>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a range of text that has been added to a document. You can use the [`<del>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/del) element to similarly represent a range of text that has been deleted from the document.
|
||||||
|
|
||||||
## \<li>
|
## \<li>
|
||||||
The **`<li>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is used to represent an item in a list. It must be contained in a parent element: an ordered list ([`<ol>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/ol)), an unordered list ([`<ul>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/ul)), or a menu ([`<menu>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/menu)). In menus and unordered lists, list items are usually displayed using bullet points. In ordered lists, they are usually displayed with an ascending counter on the left, such as a number or letter.
|
The **`<li>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is used to represent an item in a list. It must be contained in a parent element: an ordered list ([`<ol>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/ol)), an unordered list ([`<ul>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/ul)), or a menu ([`<menu>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/menu)). In menus and unordered lists, list items are usually displayed using bullet points. In ordered lists, they are usually displayed with an ascending counter on the left, such as a number or letter.
|
||||||
|
|
||||||
## \<mark>
|
## \<mark>
|
||||||
The **`<mark>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents text which is **marked** or **highlighted** for reference or notation purposes due to the marked passage's relevance in the enclosing context.
|
The **`<mark>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents text which is **marked** or **highlighted** for reference or notation purposes due to the marked passage's relevance in the enclosing context.
|
||||||
|
|
||||||
## \<meta>
|
## \<meta>
|
||||||
The **`<meta>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents [metadata](https://developer.mozilla.org/en-US/docs/Glossary/Metadata) that cannot be represented by other HTML meta-related elements, like [`<base>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/base), [`<link>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/link), [`<script>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/script), [`<style>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/style) or [`<title>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/title).
|
The **`<meta>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents [metadata](https://developer.mozilla.org/en-US/docs/Glossary/Metadata) that cannot be represented by other HTML meta-related elements, like [`<base>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/base), [`<link>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/link), [`<script>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/script), [`<style>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/style) or [`<title>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/title).
|
||||||
|
|
||||||
```html
|
```html
|
||||||
<meta name="name" content="value">
|
<meta name="name" content="value">
|
||||||
```
|
```
|
||||||
|
|
||||||
## \<nav>
|
## \<nav>
|
||||||
The **`<nav>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a section of a page whose purpose is to provide navigation links, either within the current document or to other documents. Common examples of navigation sections are menus, tables of contents, and indexes.
|
The **`<nav>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a section of a page whose purpose is to provide navigation links, either within the current document or to other documents. Common examples of navigation sections are menus, tables of contents, and indexes.
|
||||||
|
|
||||||
## \<ol>
|
## \<ol>
|
||||||
The **`<ol>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents an ordered list of items — typically rendered as a numbered list.
|
The **`<ol>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents an ordered list of items — typically rendered as a numbered list.
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element also accepts the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element also accepts the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `reversed`
|
- `reversed`
|
||||||
This Boolean attribute specifies that the list's items are in reverse order. Items will be numbered from high to low.
|
This Boolean attribute specifies that the list's items are in reverse order. Items will be numbered from high to low.
|
||||||
- `start`
|
- `start`
|
||||||
An integer to start counting from for the list items. Always an Arabic numeral (1, 2, 3, etc.), even when the numbering `type` is letters or Roman numerals. For example, to start numbering elements from the letter "d" or the Roman numeral "iv," use `start="4"`.
|
An integer to start counting from for the list items. Always an Arabic numeral (1, 2, 3, etc.), even when the numbering `type` is letters or Roman numerals. For example, to start numbering elements from the letter "d" or the Roman numeral "iv," use `start="4"`.
|
||||||
|
|
||||||
## \<optgroup>
|
## \<optgroup>
|
||||||
The **`<optgroup>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element creates a grouping of options within a [`<select>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/select) element.
|
The **`<optgroup>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element creates a grouping of options within a [`<select>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/select) element.
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `disabled`
|
- `disabled`
|
||||||
If this Boolean attribute is set, none of the items in this option group is selectable. Often browsers grey out such control and it won't receive any browsing events, like mouse clicks or focus-related ones.
|
If this Boolean attribute is set, none of the items in this option group is selectable. Often browsers grey out such control and it won't receive any browsing events, like mouse clicks or focus-related ones.
|
||||||
|
@ -294,118 +294,118 @@ This element includes the [global attributes](https://developer.mozilla.org/en-
|
||||||
The name of the group of options, which the browser can use when labeling the options in the user interface. This attribute is mandatory if this element is used.
|
The name of the group of options, which the browser can use when labeling the options in the user interface. This attribute is mandatory if this element is used.
|
||||||
|
|
||||||
## \<option>
|
## \<option>
|
||||||
The **`<option>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is used to define an item contained in a [`<select>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/select), an [`<optgroup>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/optgroup), or a [`<datalist>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/datalist) element. As such, `<option>` can represent menu items in popups and other lists of items in an HTML document.
|
The **`<option>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is used to define an item contained in a [`<select>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/select), an [`<optgroup>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/optgroup), or a [`<datalist>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/datalist) element. As such, `<option>` can represent menu items in popups and other lists of items in an HTML document.
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `disabled`
|
- `disabled`
|
||||||
If this Boolean attribute is set, this option is not checkable. Often browsers grey out such control and it won't receive any browsing event, like mouse clicks or focus-related ones. If this attribute is not set, the element can still be disabled if one of its ancestors is a disabled [`<optgroup>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/optgroup) element.
|
If this Boolean attribute is set, this option is not checkable. Often browsers grey out such control and it won't receive any browsing event, like mouse clicks or focus-related ones. If this attribute is not set, the element can still be disabled if one of its ancestors is a disabled [`<optgroup>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/optgroup) element.
|
||||||
- `label`
|
- `label`
|
||||||
This attribute is text for the label indicating the meaning of the option. If the `label` attribute isn't defined, its value is that of the element text content.
|
This attribute is text for the label indicating the meaning of the option. If the `label` attribute isn't defined, its value is that of the element text content.
|
||||||
- `selected`
|
- `selected`
|
||||||
If present, this Boolean attribute indicates that the option is initially selected. If the `<option>` element is the descendant of a [`<select>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/select) element whose [`multiple`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/select#multiple) attribute is not set, only one single `<option>` of this [`<select>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/select) element may have the `selected` attribute.
|
If present, this Boolean attribute indicates that the option is initially selected. If the `<option>` element is the descendant of a [`<select>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/select) element whose [`multiple`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/select#multiple) attribute is not set, only one single `<option>` of this [`<select>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/select) element may have the `selected` attribute.
|
||||||
- `value`
|
- `value`
|
||||||
The content of this attribute represents the value to be submitted with the form, should this option be selected. If this attribute is omitted, the value is taken from the text content of the option element.
|
The content of this attribute represents the value to be submitted with the form, should this option be selected. If this attribute is omitted, the value is taken from the text content of the option element.
|
||||||
|
|
||||||
## \<p>
|
## \<p>
|
||||||
The **`<p>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a paragraph. Paragraphs are usually represented in visual media as blocks of text separated from adjacent blocks by blank lines and/or first-line indentation, but HTML paragraphs can be any structural grouping of related content, such as images or form fields.
|
The **`<p>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a paragraph. Paragraphs are usually represented in visual media as blocks of text separated from adjacent blocks by blank lines and/or first-line indentation, but HTML paragraphs can be any structural grouping of related content, such as images or form fields.
|
||||||
|
|
||||||
## \<pre>
|
## \<pre>
|
||||||
The **`<pre>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents preformatted text which is to be presented exactly as written in the HTML file. The text is typically rendered using a non-proportional, or [monospaced](https://en.wikipedia.org/wiki/Monospaced_font), font. Whitespace inside this element is displayed as written.
|
The **`<pre>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents preformatted text which is to be presented exactly as written in the HTML file. The text is typically rendered using a non-proportional, or [monospaced](https://en.wikipedia.org/wiki/Monospaced_font), font. Whitespace inside this element is displayed as written.
|
||||||
|
|
||||||
## \<progress>
|
## \<progress>
|
||||||
The **`<progress>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element displays an indicator showing the completion progress of a task, typically displayed as a progress bar.
|
The **`<progress>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element displays an indicator showing the completion progress of a task, typically displayed as a progress bar.
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `max`
|
- `max`
|
||||||
This attribute describes how much work the task indicated by the `progress` element requires. The `max` attribute, if present, must have a value greater than `0` and be a valid floating point number. The default value is `1`.
|
This attribute describes how much work the task indicated by the `progress` element requires. The `max` attribute, if present, must have a value greater than `0` and be a valid floating point number. The default value is `1`.
|
||||||
- `value`
|
- `value`
|
||||||
This attribute specifies how much of the task that has been completed. It must be a valid floating point number between `0` and `max`, or between `0` and `1` if `max` is omitted. If there is no `value` attribute, the progress bar is indeterminate; this indicates that an activity is ongoing with no indication of how long it is expected to take.
|
This attribute specifies how much of the task that has been completed. It must be a valid floating point number between `0` and `max`, or between `0` and `1` if `max` is omitted. If there is no `value` attribute, the progress bar is indeterminate; this indicates that an activity is ongoing with no indication of how long it is expected to take.
|
||||||
|
|
||||||
## \<s>
|
## \<s>
|
||||||
The **`<s>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element renders text with a strikethrough, or a line through it. Use the `<s>` element to represent things that are no longer relevant or no longer accurate. However, `<s>` is not appropriate when indicating document edits; for that, use the [`<del>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/del) and [`<ins>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/ins) elements, as appropriate.
|
The **`<s>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element renders text with a strikethrough, or a line through it. Use the `<s>` element to represent things that are no longer relevant or no longer accurate. However, `<s>` is not appropriate when indicating document edits; for that, use the [`<del>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/del) and [`<ins>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/ins) elements, as appropriate.
|
||||||
|
|
||||||
## \<section>
|
## \<section>
|
||||||
The **`<section>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a generic standalone section of a document, which doesn't have a more specific semantic element to represent it. Sections should always have a heading, with very few exceptions.
|
The **`<section>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a generic standalone section of a document, which doesn't have a more specific semantic element to represent it. Sections should always have a heading, with very few exceptions.
|
||||||
|
|
||||||
## \<selection>
|
## \<selection>
|
||||||
The **`<select>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a control that provides a menu of options.
|
The **`<select>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a control that provides a menu of options.
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `autocomplete`
|
- `autocomplete`
|
||||||
A string providing a hint for a [user agent's](https://developer.mozilla.org/en-US/docs/Glossary/User_agent) autocomplete feature. See [The HTML autocomplete attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete) for a complete list of values and details on how to use autocomplete.
|
A string providing a hint for a [user agent's](https://developer.mozilla.org/en-US/docs/Glossary/User_agent) autocomplete feature. See [The HTML autocomplete attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete) for a complete list of values and details on how to use autocomplete.
|
||||||
- `autofocus`
|
- `autofocus`
|
||||||
This Boolean attribute lets you specify that a form control should have input focus when the page loads. Only one form element in a document can have the `autofocus` attribute.
|
This Boolean attribute lets you specify that a form control should have input focus when the page loads. Only one form element in a document can have the `autofocus` attribute.
|
||||||
- `disabled`
|
- `disabled`
|
||||||
This Boolean attribute indicates that the user cannot interact with the control. If this attribute is not specified, the control inherits its setting from the containing element, for example [`<fieldset>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/fieldset); if there is no containing element with the `disabled` attribute set, then the control is enabled.
|
This Boolean attribute indicates that the user cannot interact with the control. If this attribute is not specified, the control inherits its setting from the containing element, for example [`<fieldset>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/fieldset); if there is no containing element with the `disabled` attribute set, then the control is enabled.
|
||||||
- `form`
|
- `form`
|
||||||
The [`<form>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/form) element to associate the `<select>` with (its _form owner_). The value of this attribute must be the [`id`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes#id) of a `<form>` in the same document. (If this attribute is not set, the `<select>` is associated with its ancestor `<form>` element, if any.)
|
The [`<form>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/form) element to associate the `<select>` with (its _form owner_). The value of this attribute must be the [`id`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes#id) of a `<form>` in the same document. (If this attribute is not set, the `<select>` is associated with its ancestor `<form>` element, if any.)
|
||||||
|
|
||||||
This attribute lets you associate `<select>` elements to `<form>`s anywhere in the document, not just inside a `<form>`. It can also override an ancestor `<form>` element.
|
This attribute lets you associate `<select>` elements to `<form>`s anywhere in the document, not just inside a `<form>`. It can also override an ancestor `<form>` element.
|
||||||
- `multiple`
|
- `multiple`
|
||||||
This Boolean attribute indicates that multiple options can be selected in the list. If it is not specified, then only one option can be selected at a time. When `multiple` is specified, most browsers will show a scrolling list box instead of a single line dropdown.
|
This Boolean attribute indicates that multiple options can be selected in the list. If it is not specified, then only one option can be selected at a time. When `multiple` is specified, most browsers will show a scrolling list box instead of a single line dropdown.
|
||||||
- `name`
|
- `name`
|
||||||
This attribute is used to specify the name of the control.
|
This attribute is used to specify the name of the control.
|
||||||
- `required`
|
- `required`
|
||||||
A Boolean attribute indicating that an option with a non-empty string value must be selected.
|
A Boolean attribute indicating that an option with a non-empty string value must be selected.
|
||||||
- `size`
|
- `size`
|
||||||
If the control is presented as a scrolling list box (e.g. when `multiple` is specified), this attribute represents the number of rows in the list that should be visible at one time. Browsers are not required to present a select element as a scrolled list box. The default value is `0`.
|
If the control is presented as a scrolling list box (e.g. when `multiple` is specified), this attribute represents the number of rows in the list that should be visible at one time. Browsers are not required to present a select element as a scrolled list box. The default value is `0`.
|
||||||
|
|
||||||
## \<source>
|
## \<source>
|
||||||
The **`<source>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element specifies multiple media resources for the [`<picture>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/picture), the [`<audio>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/audio) element, or the [`<video>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/video) element. It is a [void element](https://developer.mozilla.org/en-US/docs/Glossary/Void_element), meaning that it has no content and does not have a closing tag. It is commonly used to offer the same media content in multiple file formats in order to provide compatibility with a broad range of browsers given their differing support for [image file formats](https://developer.mozilla.org/en-US/docs/Web/Media/Formats/Image_types) and [media file formats](https://developer.mozilla.org/en-US/docs/Web/Media/Formats).
|
The **`<source>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element specifies multiple media resources for the [`<picture>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/picture), the [`<audio>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/audio) element, or the [`<video>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/video) element. It is a [void element](https://developer.mozilla.org/en-US/docs/Glossary/Void_element), meaning that it has no content and does not have a closing tag. It is commonly used to offer the same media content in multiple file formats in order to provide compatibility with a broad range of browsers given their differing support for [image file formats](https://developer.mozilla.org/en-US/docs/Web/Media/Formats/Image_types) and [media file formats](https://developer.mozilla.org/en-US/docs/Web/Media/Formats).
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `type`
|
- `type`
|
||||||
The [MIME media type of the image](https://developer.mozilla.org/en-US/docs/Web/Media/Formats/Image_types) or [other media type](https://developer.mozilla.org/en-US/docs/Web/Media/Formats/Containers), optionally with a [`codecs` parameter](https://developer.mozilla.org/en-US/docs/Web/Media/Formats/codecs_parameter).
|
The [MIME media type of the image](https://developer.mozilla.org/en-US/docs/Web/Media/Formats/Image_types) or [other media type](https://developer.mozilla.org/en-US/docs/Web/Media/Formats/Containers), optionally with a [`codecs` parameter](https://developer.mozilla.org/en-US/docs/Web/Media/Formats/codecs_parameter).
|
||||||
- `src`
|
- `src`
|
||||||
Required if the `source` element's parent is an [`<audio>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/audio) and [`<video>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/video) element, but not allowed if the `source` element's parent is a [`<picture>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/picture) element.
|
Required if the `source` element's parent is an [`<audio>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/audio) and [`<video>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/video) element, but not allowed if the `source` element's parent is a [`<picture>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/picture) element.
|
||||||
Address of the media resource.
|
Address of the media resource.
|
||||||
|
|
||||||
## \<span>
|
## \<span>
|
||||||
The **`<span>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is a generic inline container for phrasing content, which does not inherently represent anything. It can be used to group elements for styling purposes (using the [`class`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes#class) or [`id`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes#id) attributes), or because they share attribute values, such as [`lang`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes#lang). It should be used only when no other semantic element is appropriate. `<span>` is very much like a [`<div>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/div) element, but [`<div>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/div) is a [block-level element](https://developer.mozilla.org/en-US/docs/Glossary/Block-level_content) whereas a `<span>` is an [inline-level element](https://developer.mozilla.org/en-US/docs/Glossary/Inline-level_content).
|
The **`<span>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is a generic inline container for phrasing content, which does not inherently represent anything. It can be used to group elements for styling purposes (using the [`class`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes#class) or [`id`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes#id) attributes), or because they share attribute values, such as [`lang`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes#lang). It should be used only when no other semantic element is appropriate. `<span>` is very much like a [`<div>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/div) element, but [`<div>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/div) is a [block-level element](https://developer.mozilla.org/en-US/docs/Glossary/Block-level_content) whereas a `<span>` is an [inline-level element](https://developer.mozilla.org/en-US/docs/Glossary/Inline-level_content).
|
||||||
|
|
||||||
## \<strong>
|
## \<strong>
|
||||||
The **`<strong>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element indicates that its contents have strong importance, seriousness, or urgency. Browsers typically render the contents in bold type.
|
The **`<strong>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element indicates that its contents have strong importance, seriousness, or urgency. Browsers typically render the contents in bold type.
|
||||||
|
|
||||||
## \<style>
|
## \<style>
|
||||||
The **`<style>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element contains style information for a document, or part of a document. It contains CSS, which is applied to the contents of the document containing the `<style>` element.
|
The **`<style>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element contains style information for a document, or part of a document. It contains CSS, which is applied to the contents of the document containing the `<style>` element.
|
||||||
|
|
||||||
## \<sub>
|
## \<sub>
|
||||||
The **`<sub>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element specifies inline text which should be displayed as subscript for solely typographical reasons. Subscripts are typically rendered with a lowered baseline using smaller text.
|
The **`<sub>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element specifies inline text which should be displayed as subscript for solely typographical reasons. Subscripts are typically rendered with a lowered baseline using smaller text.
|
||||||
|
|
||||||
## \<sup>
|
## \<sup>
|
||||||
The **`<sup>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element specifies inline text which is to be displayed as superscript for solely typographical reasons. Superscripts are usually rendered with a raised baseline using smaller text.
|
The **`<sup>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element specifies inline text which is to be displayed as superscript for solely typographical reasons. Superscripts are usually rendered with a raised baseline using smaller text.
|
||||||
|
|
||||||
## \<table>
|
## \<table>
|
||||||
The **`<table>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents tabular data — that is, information presented in a two-dimensional table comprised of rows and columns of cells containing data.
|
The **`<table>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents tabular data — that is, information presented in a two-dimensional table comprised of rows and columns of cells containing data.
|
||||||
|
|
||||||
## \<tbody>
|
## \<tbody>
|
||||||
The **`<tbody>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element encapsulates a set of table rows ([`<tr>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/tr) elements), indicating that they comprise the body of the table ([`<table>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/table)).
|
The **`<tbody>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element encapsulates a set of table rows ([`<tr>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/tr) elements), indicating that they comprise the body of the table ([`<table>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/table)).
|
||||||
|
|
||||||
## \<td>
|
## \<td>
|
||||||
The **`<td>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element defines a cell of a table that contains data. It participates in the _table model_.
|
The **`<td>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element defines a cell of a table that contains data. It participates in the _table model_.
|
||||||
|
|
||||||
## \<th>
|
## \<th>
|
||||||
The **`<th>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element defines a cell as the header of a group of table cells. The exact nature of this group is defined by the [`scope`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/th#scope) and [`headers`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/th#headers) attributes.
|
The **`<th>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element defines a cell as the header of a group of table cells. The exact nature of this group is defined by the [`scope`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/th#scope) and [`headers`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/th#headers) attributes.
|
||||||
|
|
||||||
## \<thead>
|
## \<thead>
|
||||||
The **`<thead>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element defines a set of rows defining the head of the columns of the table.
|
The **`<thead>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element defines a set of rows defining the head of the columns of the table.
|
||||||
|
|
||||||
## \<tr>
|
## \<tr>
|
||||||
The **`<tr>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element defines a row of cells in a table. The row's cells can then be established using a mix of [`<td>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/td) (data cell) and [`<th>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/th) (header cell) elements.
|
The **`<tr>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element defines a row of cells in a table. The row's cells can then be established using a mix of [`<td>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/td) (data cell) and [`<th>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/th) (header cell) elements.
|
||||||
|
|
||||||
## \<textarea>
|
## \<textarea>
|
||||||
The **`<textarea>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a multi-line plain-text editing control, useful when you want to allow users to enter a sizeable amount of free-form text, for example a comment on a review or feedback form.
|
The **`<textarea>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents a multi-line plain-text editing control, useful when you want to allow users to enter a sizeable amount of free-form text, for example a comment on a review or feedback form.
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
This element includes the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `autocomplete`
|
- `autocomplete`
|
||||||
This attribute indicates whether the value of the control can be automatically completed by the browser. Possible values are:
|
This attribute indicates whether the value of the control can be automatically completed by the browser. Possible values are:
|
||||||
|
@ -414,11 +414,11 @@ This element includes the [global attributes](https://developer.mozilla.org/en-
|
||||||
- `autofocus`
|
- `autofocus`
|
||||||
This Boolean attribute lets you specify that a form control should have input focus when the page loads. Only one form-associated element in a document can have this attribute specified.
|
This Boolean attribute lets you specify that a form control should have input focus when the page loads. Only one form-associated element in a document can have this attribute specified.
|
||||||
- `cols`
|
- `cols`
|
||||||
The visible width of the text control, in average character widths. If it is specified, it must be a positive integer. If it is not specified, the default value is `20`.
|
The visible width of the text control, in average character widths. If it is specified, it must be a positive integer. If it is not specified, the default value is `20`.
|
||||||
- `disabled`
|
- `disabled`
|
||||||
This Boolean attribute indicates that the user cannot interact with the control. If this attribute is not specified, the control inherits its setting from the containing element, for example [`<fieldset>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/fieldset); if there is no containing element when the `disabled` attribute is set, the control is enabled.
|
This Boolean attribute indicates that the user cannot interact with the control. If this attribute is not specified, the control inherits its setting from the containing element, for example [`<fieldset>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/fieldset); if there is no containing element when the `disabled` attribute is set, the control is enabled.
|
||||||
- `form`
|
- `form`
|
||||||
The form element that the `<textarea>` element is associated with (its "form owner"). The value of the attribute must be the `id` of a form element in the same document. If this attribute is not specified, the `<textarea>` element must be a descendant of a form element. This attribute enables you to place `<textarea>` elements anywhere within a document, not just as descendants of form elements.
|
The form element that the `<textarea>` element is associated with (its "form owner"). The value of the attribute must be the `id` of a form element in the same document. If this attribute is not specified, the `<textarea>` element must be a descendant of a form element. This attribute enables you to place `<textarea>` elements anywhere within a document, not just as descendants of form elements.
|
||||||
- `maxlength`
|
- `maxlength`
|
||||||
The maximum string length (measured in UTF-16 code units) that the user can enter. If this value isn't specified, the user can enter an unlimited number of characters.
|
The maximum string length (measured in UTF-16 code units) that the user can enter. If this value isn't specified, the user can enter an unlimited number of characters.
|
||||||
- `minlength`
|
- `minlength`
|
||||||
|
@ -428,50 +428,50 @@ This element includes the [global attributes](https://developer.mozilla.org/en-
|
||||||
- `placeholder`
|
- `placeholder`
|
||||||
A hint to the user of what can be entered in the control. Carriage returns or line-feeds within the placeholder text must be treated as line breaks when rendering the hint.
|
A hint to the user of what can be entered in the control. Carriage returns or line-feeds within the placeholder text must be treated as line breaks when rendering the hint.
|
||||||
- `readonly`
|
- `readonly`
|
||||||
This Boolean attribute indicates that the user cannot modify the value of the control. Unlike the `disabled` attribute, the `readonly` attribute does not prevent the user from clicking or selecting in the control. The value of a read-only control is still submitted with the form.
|
This Boolean attribute indicates that the user cannot modify the value of the control. Unlike the `disabled` attribute, the `readonly` attribute does not prevent the user from clicking or selecting in the control. The value of a read-only control is still submitted with the form.
|
||||||
- `required`
|
- `required`
|
||||||
This attribute specifies that the user must fill in a value before submitting a form.
|
This attribute specifies that the user must fill in a value before submitting a form.
|
||||||
- `rows`
|
- `rows`
|
||||||
The number of visible text lines for the control. If it is specified, it must be a positive integer. If it is not specified, the default value is 2.
|
The number of visible text lines for the control. If it is specified, it must be a positive integer. If it is not specified, the default value is 2.
|
||||||
|
|
||||||
## \<title>
|
## \<title>
|
||||||
The **`<title>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element defines the document's title that is shown in a [browser](https://developer.mozilla.org/en-US/docs/Glossary/Browser)'s title bar or a page's tab. It only contains text; tags within the element are ignored.
|
The **`<title>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element defines the document's title that is shown in a [browser](https://developer.mozilla.org/en-US/docs/Glossary/Browser)'s title bar or a page's tab. It only contains text; tags within the element are ignored.
|
||||||
|
|
||||||
## \<ul>
|
## \<ul>
|
||||||
The **`<ul>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents an unordered list of items, typically rendered as a bulleted list.
|
The **`<ul>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element represents an unordered list of items, typically rendered as a bulleted list.
|
||||||
|
|
||||||
## \<video>
|
## \<video>
|
||||||
The **`<video>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element embeds a media player which supports video playback into the document. You can use `<video>` for audio content as well, but the [`<audio>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/audio) element may provide a more appropriate user experience.
|
The **`<video>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element embeds a media player which supports video playback into the document. You can use `<video>` for audio content as well, but the [`<audio>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/audio) element may provide a more appropriate user experience.
|
||||||
|
|
||||||
### Attributes
|
### Attributes
|
||||||
Like all other HTML elements, this element supports the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
Like all other HTML elements, this element supports the [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes).
|
||||||
|
|
||||||
- `autoplay`
|
- `autoplay`
|
||||||
A Boolean attribute; if specified, the video automatically begins to play back as soon as it can do so without stopping to finish loading the data.
|
A Boolean attribute; if specified, the video automatically begins to play back as soon as it can do so without stopping to finish loading the data.
|
||||||
- `controls`
|
- `controls`
|
||||||
If this attribute is present, the browser will offer controls to allow the user to control video playback, including volume, seeking, and pause/resume playback.
|
If this attribute is present, the browser will offer controls to allow the user to control video playback, including volume, seeking, and pause/resume playback.
|
||||||
- `height`
|
- `height`
|
||||||
The height of the video's display area, in [CSS pixels](https://drafts.csswg.org/css-values/#px) (absolute values only; [no percentages](https://html.spec.whatwg.org/multipage/embedded-content.html#dimension-attributes)).
|
The height of the video's display area, in [CSS pixels](https://drafts.csswg.org/css-values/#px) (absolute values only; [no percentages](https://html.spec.whatwg.org/multipage/embedded-content.html#dimension-attributes)).
|
||||||
- `loop`
|
- `loop`
|
||||||
A Boolean attribute; if specified, the browser will automatically seek back to the start upon reaching the end of the video.
|
A Boolean attribute; if specified, the browser will automatically seek back to the start upon reaching the end of the video.
|
||||||
- `muted`
|
- `muted`
|
||||||
A Boolean attribute that indicates the default setting of the audio contained in the video. If set, the audio will be initially silenced. Its default value is `false`, meaning that the audio will be played when the video is played.
|
A Boolean attribute that indicates the default setting of the audio contained in the video. If set, the audio will be initially silenced. Its default value is `false`, meaning that the audio will be played when the video is played.
|
||||||
- `poster`
|
- `poster`
|
||||||
A URL for an image to be shown while the video is downloading. If this attribute isn't specified, nothing is displayed until the first frame is available, then the first frame is shown as the poster frame.
|
A URL for an image to be shown while the video is downloading. If this attribute isn't specified, nothing is displayed until the first frame is available, then the first frame is shown as the poster frame.
|
||||||
- `src`
|
- `src`
|
||||||
The URL of the video to embed. This is optional; you may instead use the [`<source>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/source) element within the video block to specify the video to embed.
|
The URL of the video to embed. This is optional; you may instead use the [`<source>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/source) element within the video block to specify the video to embed.
|
||||||
- `width`
|
- `width`
|
||||||
The width of the video's display area, in [CSS pixels](https://drafts.csswg.org/css-values/#px) (absolute values only; [no percentages](https://html.spec.whatwg.org/multipage/embedded-content.html#dimension-attributes)).
|
The width of the video's display area, in [CSS pixels](https://drafts.csswg.org/css-values/#px) (absolute values only; [no percentages](https://html.spec.whatwg.org/multipage/embedded-content.html#dimension-attributes)).
|
||||||
|
|
||||||
### Events
|
### Events
|
||||||
|Event Name|Fired When|
|
|Event Name|Fired When|
|
||||||
|---|---|
|
|---|---|
|
||||||
|[`audioprocess`](https://developer.mozilla.org/en-US/docs/Web/API/ScriptProcessorNode/audioprocess_event "audioprocess") Deprecated|The input buffer of a [`ScriptProcessorNode`](https://developer.mozilla.org/en-US/docs/Web/API/ScriptProcessorNode) is ready to be processed.|
|
|[`audioprocess`](https://developer.mozilla.org/en-US/docs/Web/API/ScriptProcessorNode/audioprocess_event "audioprocess") Deprecated|The input buffer of a [`ScriptProcessorNode`](https://developer.mozilla.org/en-US/docs/Web/API/ScriptProcessorNode) is ready to be processed.|
|
||||||
|[`canplay`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/canplay_event "canplay")|The browser can play the media, but estimates that not enough data has been loaded to play the media up to its end without having to stop for further buffering of content.|
|
|[`canplay`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/canplay_event "canplay")|The browser can play the media, but estimates that not enough data has been loaded to play the media up to its end without having to stop for further buffering of content.|
|
||||||
|[`canplaythrough`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/canplaythrough_event "canplaythrough")|The browser estimates it can play the media up to its end without stopping for content buffering.|
|
|[`canplaythrough`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/canplaythrough_event "canplaythrough")|The browser estimates it can play the media up to its end without stopping for content buffering.|
|
||||||
|[`complete`](https://developer.mozilla.org/en-US/docs/Web/API/OfflineAudioContext/complete_event "complete")|The rendering of an [`OfflineAudioContext`](https://developer.mozilla.org/en-US/docs/Web/API/OfflineAudioContext) is terminated.|
|
|[`complete`](https://developer.mozilla.org/en-US/docs/Web/API/OfflineAudioContext/complete_event "complete")|The rendering of an [`OfflineAudioContext`](https://developer.mozilla.org/en-US/docs/Web/API/OfflineAudioContext) is terminated.|
|
||||||
|[`durationchange`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/durationchange_event "durationchange")|The `duration` attribute has been updated.|
|
|[`durationchange`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/durationchange_event "durationchange")|The `duration` attribute has been updated.|
|
||||||
|[`emptied`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/emptied_event "emptied")|The media has become empty; for example, this event is sent if the media has already been loaded (or partially loaded), and the [`load()`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/load) method is called to reload it.|
|
|[`emptied`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/emptied_event "emptied")|The media has become empty; for example, this event is sent if the media has already been loaded (or partially loaded), and the [`load()`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/load) method is called to reload it.|
|
||||||
|[`ended`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/ended_event "ended")back has stopped because the end of the media was reached.|
|
|[`ended`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/ended_event "ended")back has stopped because the end of the media was reached.|
|
||||||
|[`error`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/error_event "error")|An error occurred while fetching the media data, or the type of the resource is not a supported media format.|
|
|[`error`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/error_event "error")|An error occurred while fetching the media data, or the type of the resource is not a supported media format.|
|
||||||
|[`loadeddata`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/loadeddata_event "loadeddata")|The first frame of the media has finished loading.|
|
|[`loadeddata`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/loadeddata_event "loadeddata")|The first frame of the media has finished loading.|
|
||||||
|
@ -482,71 +482,71 @@ Like all other HTML elements, this element supports the [global attributes](htt
|
||||||
|[`playing`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/playing_event "playing")back is ready to start after having been paused or delayed due to lack of data.|
|
|[`playing`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/playing_event "playing")back is ready to start after having been paused or delayed due to lack of data.|
|
||||||
|[`progress`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/progress_event "progress")|Fired periodically as the browser loads a resource.|
|
|[`progress`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/progress_event "progress")|Fired periodically as the browser loads a resource.|
|
||||||
|[`ratechange`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/ratechange_event "ratechange")|The playback rate has changed.|
|
|[`ratechange`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/ratechange_event "ratechange")|The playback rate has changed.|
|
||||||
|[`seeked`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/seeked_event "seeked")|A _seek_ operation completed.|
|
|[`seeked`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/seeked_event "seeked")|A _seek_ operation completed.|
|
||||||
|[`seeking`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/seeking_event "seeking")|A _seek_ operation began.|
|
|[`seeking`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/seeking_event "seeking")|A _seek_ operation began.|
|
||||||
|[`stalled`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/stalled_event "stalled")|The user agent is trying to fetch media data, but data is unexpectedly not forthcoming.|
|
|[`stalled`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/stalled_event "stalled")|The user agent is trying to fetch media data, but data is unexpectedly not forthcoming.|
|
||||||
|[`suspend`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/suspend_event "suspend")|Media data loading has been suspended.|
|
|[`suspend`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/suspend_event "suspend")|Media data loading has been suspended.|
|
||||||
|[`timeupdate`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/timeupdate_event "timeupdate")|The time indicated by the `currentTime` attribute has been updated.|
|
|[`timeupdate`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/timeupdate_event "timeupdate")|The time indicated by the `currentTime` attribute has been updated.|
|
||||||
|[`volumechange`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/volumechange_event "volumechange")|The volume has changed.|
|
|[`volumechange`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/volumechange_event "volumechange")|The volume has changed.|
|
||||||
|[`waiting`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/waiting_event "waiting")back has stopped because of a temporary lack of data.|
|
|[`waiting`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/waiting_event "waiting")back has stopped because of a temporary lack of data.|
|
||||||
|
|
||||||
## \<script>
|
## \<script>
|
||||||
The **`<script>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is used to embed executable code or data; this is typically used to embed or refer to JavaScript code. The `<script>` element can also be used with other languages, such as [WebGL](https://developer.mozilla.org/en-US/docs/Web/API/WebGL_API)'s GLSL shader programming language and [JSON](https://developer.mozilla.org/en-US/docs/Glossary/JSON).
|
The **`<script>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is used to embed executable code or data; this is typically used to embed or refer to JavaScript code. The `<script>` element can also be used with other languages, such as [WebGL](https://developer.mozilla.org/en-US/docs/Web/API/WebGL_API)'s GLSL shader programming language and [JSON](https://developer.mozilla.org/en-US/docs/Glossary/JSON).
|
||||||
|
|
||||||
```html
|
```html
|
||||||
<script src="javascript.js"></script>
|
<script src="javascript.js"></script>
|
||||||
```
|
```
|
||||||
|
|
||||||
## \<input>
|
## \<input>
|
||||||
The **`<input>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is used to create interactive controls for web-based forms in order to accept data from the user; a wide variety of types of input data and control widgets are available, depending on the device and [user agent](https://developer.mozilla.org/en-US/docs/Glossary/User_agent). The `<input>` element is one of the most powerful and complex in all of HTML due to the sheer number of combinations of input types and attributes.
|
The **`<input>`** [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) element is used to create interactive controls for web-based forms in order to accept data from the user; a wide variety of types of input data and control widgets are available, depending on the device and [user agent](https://developer.mozilla.org/en-US/docs/Glossary/User_agent). The `<input>` element is one of the most powerful and complex in all of HTML due to the sheer number of combinations of input types and attributes.
|
||||||
|
|
||||||
The available types are as follows:
|
The available types are as follows:
|
||||||
|
|
||||||
| Type | Description |
|
| Type | Description |
|
||||||
| ------------------------------------------------------------------------------------------------ | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ------------------------------------------------------------------------------------------------ | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| [button](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/button) | A push button with no default behavior displaying the value of the [`value`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#value) attribute, empty by default. |
|
| [button](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/button) | A push button with no default behavior displaying the value of the [`value`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#value) attribute, empty by default. |
|
||||||
| [checkbox](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox) | A check box allowing single values to be selected/deselected. |
|
| [checkbox](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox) | A check box allowing single values to be selected/deselected. |
|
||||||
| [color](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/color) | A control for specifying a color; opening a color picker when active in supporting browsers. |
|
| [color](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/color) | A control for specifying a color; opening a color picker when active in supporting browsers. |
|
||||||
| [date](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/date) | A control for entering a date (year, month, and day, with no time). Opens a date picker or numeric wheels for year, month, day when active in supporting browsers. |
|
| [date](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/date) | A control for entering a date (year, month, and day, with no time). Opens a date picker or numeric wheels for year, month, day when active in supporting browsers. |
|
||||||
| [datetime-local](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/datetime-local) | A control for entering a date and time, with no time zone. Opens a date picker or numeric wheels for date- and time-components when active in supporting browsers. |
|
| [datetime-local](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/datetime-local) | A control for entering a date and time, with no time zone. Opens a date picker or numeric wheels for date- and time-components when active in supporting browsers. |
|
||||||
| [email](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/email) | A field for editing an email address. Looks like a `text` input, but has validation parameters and relevant keyboard in supporting browsers and devices with dynamic keyboards. |
|
| [email](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/email) | A field for editing an email address. Looks like a `text` input, but has validation parameters and relevant keyboard in supporting browsers and devices with dynamic keyboards. |
|
||||||
| [file](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/file) | A control that lets the user select a file. Use the [`accept`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#accept) attribute to define the types of files that the control can select. |
|
| [file](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/file) | A control that lets the user select a file. Use the [`accept`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#accept) attribute to define the types of files that the control can select. |
|
||||||
| [hidden](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/hidden) | A control that is not displayed but whose value is submitted to the server. There is an example in the next column, but it's hidden! |
|
| [hidden](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/hidden) | A control that is not displayed but whose value is submitted to the server. There is an example in the next column, but it's hidden! |
|
||||||
| [image](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/image) | A graphical `submit` button. Displays an image defined by the `src` attribute. The [`alt`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#alt) attribute displays if the image [`src`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#src) is missing. |
|
| [image](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/image) | A graphical `submit` button. Displays an image defined by the `src` attribute. The [`alt`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#alt) attribute displays if the image [`src`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#src) is missing. |
|
||||||
| [month](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/month) | A control for entering a month and year, with no time zone. |
|
| [month](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/month) | A control for entering a month and year, with no time zone. |
|
||||||
| [number](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/number) | A control for entering a number. Displays a spinner and adds default validation. Displays a numeric keypad in some devices with dynamic keypads. |
|
| [number](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/number) | A control for entering a number. Displays a spinner and adds default validation. Displays a numeric keypad in some devices with dynamic keypads. |
|
||||||
| [password](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/password) | A single-line text field whose value is obscured. Will alert user if site is not secure. |
|
| [password](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/password) | A single-line text field whose value is obscured. Will alert user if site is not secure. |
|
||||||
| [radio](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/radio) | A radio button, allowing a single value to be selected out of multiple choices with the same [`name`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#name) value. |
|
| [radio](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/radio) | A radio button, allowing a single value to be selected out of multiple choices with the same [`name`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#name) value. |
|
||||||
| [range](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range) | A control for entering a number whose exact value is not important. Displays as a range widget defaulting to the middle value. Used in conjunction [`min`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#min) and [`max`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#max) to define the range of acceptable values. |
|
| [range](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range) | A control for entering a number whose exact value is not important. Displays as a range widget defaulting to the middle value. Used in conjunction [`min`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#min) and [`max`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#max) to define the range of acceptable values. |
|
||||||
| [reset](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/reset) | A button that resets the contents of the form to default values. Not recommended. |
|
| [reset](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/reset) | A button that resets the contents of the form to default values. Not recommended. |
|
||||||
| [search](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/search) | A single-line text field for entering search strings. Line-breaks are automatically removed from the input value. May include a delete icon in supporting browsers that can be used to clear the field. Displays a search icon instead of enter key on some devices with dynamic keypads. |
|
| [search](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/search) | A single-line text field for entering search strings. Line-breaks are automatically removed from the input value. May include a delete icon in supporting browsers that can be used to clear the field. Displays a search icon instead of enter key on some devices with dynamic keypads. |
|
||||||
| [submit](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/submit) | A button that submits the form. |
|
| [submit](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/submit) | A button that submits the form. |
|
||||||
| [tel](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/tel) | A control for entering a telephone number. Displays a telephone keypad in some devices with dynamic keypads. |
|
| [tel](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/tel) | A control for entering a telephone number. Displays a telephone keypad in some devices with dynamic keypads. |
|
||||||
| [text](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/text) | The default value. A single-line text field. Line-breaks are automatically removed from the input value. |
|
| [text](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/text) | The default value. A single-line text field. Line-breaks are automatically removed from the input value. |
|
||||||
| [time](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/time) | A control for entering a time value with no time zone. |
|
| [time](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/time) | A control for entering a time value with no time zone. |
|
||||||
| [url](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/url) | A field for entering a URL. Looks like a `text` input, but has validation parameters and relevant keyboard in supporting browsers and devices with dynamic keyboards. |
|
| [url](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/url) | A field for entering a URL. Looks like a `text` input, but has validation parameters and relevant keyboard in supporting browsers and devices with dynamic keyboards. |
|
||||||
| [week](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/week) | A control for entering a date consisting of a week-year number and a week number with no time zone. |
|
| [week](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/week) | A control for entering a date consisting of a week-year number and a week number with no time zone. |
|
||||||
|
|
||||||
# Attributes
|
# Attributes
|
||||||
## Global Attributes
|
## Global Attributes
|
||||||
| Name | Description |
|
| Name | Description |
|
||||||
| --------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
| --------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
||||||
| autofocus | The **`autofocus`** [global attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes) is a Boolean attribute indicating that an element should be focused on page load, or when the [`<dialog>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/dialog) that it is part of is displayed. |
|
| autofocus | The **`autofocus`** [global attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes) is a Boolean attribute indicating that an element should be focused on page load, or when the [`<dialog>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/dialog) that it is part of is displayed. |
|
||||||
| class | The **`class`** [global attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes) is a space-separated list of the case-sensitive classes of the element. Classes allow CSS and JavaScript to select and access specific elements via the [class selectors](https://developer.mozilla.org/en-US/docs/Web/CSS/Class_selectors) or functions like the DOM method [`document.getElementsByClassName`](https://developer.mozilla.org/en-US/docs/Web/API/Document/getElementsByClassName). |
|
| class | The **`class`** [global attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes) is a space-separated list of the case-sensitive classes of the element. Classes allow CSS and JavaScript to select and access specific elements via the [class selectors](https://developer.mozilla.org/en-US/docs/Web/CSS/Class_selectors) or functions like the DOM method [`document.getElementsByClassName`](https://developer.mozilla.org/en-US/docs/Web/API/Document/getElementsByClassName). |
|
||||||
| data-* | The **`data-*`** [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes) form a class of attributes called **custom data attributes**, that allow proprietary information to be exchanged between the [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) and its [DOM](https://developer.mozilla.org/en-US/docs/Web/API/Document_Object_Model) representation by scripts. |
|
| data-* | The **`data-*`** [global attributes](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes) form a class of attributes called **custom data attributes**, that allow proprietary information to be exchanged between the [HTML](https://developer.mozilla.org/en-US/docs/Web/HTML) and its [DOM](https://developer.mozilla.org/en-US/docs/Web/API/Document_Object_Model) representation by scripts. |
|
||||||
| hidden | The **`hidden`** [global attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes) is an [enumerated](https://developer.mozilla.org/en-US/docs/Glossary/Enumerated) attribute indicating that the browser should not render the contents of the element. For example, it can be used to hide elements of the page that can't be used until the login process has been completed. |
|
| hidden | The **`hidden`** [global attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes) is an [enumerated](https://developer.mozilla.org/en-US/docs/Glossary/Enumerated) attribute indicating that the browser should not render the contents of the element. For example, it can be used to hide elements of the page that can't be used until the login process has been completed. |
|
||||||
| id | The **`id`** [global attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes) defines an identifier (ID) which must be unique in the whole document. Its purpose is to identify the element when linking (using a [fragment identifier](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Identifying_resources_on_the_Web#fragment)), scripting, or styling (with [CSS](https://developer.mozilla.org/en-US/docs/Glossary/CSS)). |
|
| id | The **`id`** [global attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes) defines an identifier (ID) which must be unique in the whole document. Its purpose is to identify the element when linking (using a [fragment identifier](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Identifying_resources_on_the_Web#fragment)), scripting, or styling (with [CSS](https://developer.mozilla.org/en-US/docs/Glossary/CSS)). |
|
||||||
| lang | The **`lang`** [global attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes) helps define the language of an element: the language that non-editable elements are written in, or the language that the editable elements should be written in by the user. The attribute contains a single "language tag" in the format defined in [RFC 5646: Tags for Identifying Languages (also known as BCP 47)](https://datatracker.ietf.org/doc/html/rfc5646). |
|
| lang | The **`lang`** [global attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes) helps define the language of an element: the language that non-editable elements are written in, or the language that the editable elements should be written in by the user. The attribute contains a single "language tag" in the format defined in [RFC 5646: Tags for Identifying Languages (also known as BCP 47)](https://datatracker.ietf.org/doc/html/rfc5646). |
|
||||||
| style | The **`style`** [global attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes) contains [CSS](https://developer.mozilla.org/en-US/docs/Web/CSS) styling declarations to be applied to the element. Note that it is recommended for styles to be defined in a separate file or files. This attribute and the [`<style>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/style) element have mainly the purpose of allowing for quick styling, for example for testing purposes. |
|
| style | The **`style`** [global attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes) contains [CSS](https://developer.mozilla.org/en-US/docs/Web/CSS) styling declarations to be applied to the element. Note that it is recommended for styles to be defined in a separate file or files. This attribute and the [`<style>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/style) element have mainly the purpose of allowing for quick styling, for example for testing purposes. |
|
||||||
|
|
||||||
## Normal Attributes
|
## Normal Attributes
|
||||||
| Name | Description |
|
| Name | Description |
|
||||||
| ----------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ----------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| disabled | The Boolean **`disabled`** attribute, when present, makes the element not mutable, focusable, or even submitted with the form. The user can neither edit nor focus on the control, nor its form control descendants. |
|
| disabled | The Boolean **`disabled`** attribute, when present, makes the element not mutable, focusable, or even submitted with the form. The user can neither edit nor focus on the control, nor its form control descendants. |
|
||||||
| max | The **`max`** attribute defines the maximum value that is acceptable and valid for the input containing the attribute. If the [`value`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#value) of the element is greater than this, the element fails [validation](https://developer.mozilla.org/en-US/docs/Learn/Forms/Form_validation). This value must be greater than or equal to the value of the [`min`](https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/min) attribute. If the `max` attribute is present but is not specified or is invalid, no `max` value is applied. If the `max` attribute is valid and a non-empty value is greater than the maximum allowed by the `max` attribute, constraint validation will prevent form submission. |
|
| max | The **`max`** attribute defines the maximum value that is acceptable and valid for the input containing the attribute. If the [`value`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#value) of the element is greater than this, the element fails [validation](https://developer.mozilla.org/en-US/docs/Learn/Forms/Form_validation). This value must be greater than or equal to the value of the [`min`](https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/min) attribute. If the `max` attribute is present but is not specified or is invalid, no `max` value is applied. If the `max` attribute is valid and a non-empty value is greater than the maximum allowed by the `max` attribute, constraint validation will prevent form submission. |
|
||||||
| maxlength | The **`maxlength`** attribute defines the maximum [string length](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/length) that the user can enter into an [`<input>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input) or [`<textarea>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/textarea). The attribute must have an integer value of 0 or higher. |
|
| maxlength | The **`maxlength`** attribute defines the maximum [string length](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/length) that the user can enter into an [`<input>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input) or [`<textarea>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/textarea). The attribute must have an integer value of 0 or higher. |
|
||||||
| min | The **`min`** attribute defines the minimum value that is acceptable and valid for the input containing the attribute. If the [`value`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#value) of the element is less than this, the element fails [validation](https://developer.mozilla.org/en-US/docs/Learn/Forms/Form_validation). This value must be less than or equal to the value of the `max` attribute. |
|
| min | The **`min`** attribute defines the minimum value that is acceptable and valid for the input containing the attribute. If the [`value`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#value) of the element is less than this, the element fails [validation](https://developer.mozilla.org/en-US/docs/Learn/Forms/Form_validation). This value must be less than or equal to the value of the `max` attribute. |
|
||||||
| minlength | The **`minlength`** attribute defines the minimum [string length](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/length) that the user can enter into an [`<input>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input) or [`<textarea>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/textarea). The attribute must have an integer value of 0 or higher. |
|
| minlength | The **`minlength`** attribute defines the minimum [string length](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/length) that the user can enter into an [`<input>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input) or [`<textarea>`](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/textarea). The attribute must have an integer value of 0 or higher. |
|
||||||
| placeholder | The **`placeholder`** attribute defines the text displayed in a form control when the control has no value. The placeholder text should provide a brief hint to the user as to the expected type of data that should be entered into the control. |
|
| placeholder | The **`placeholder`** attribute defines the text displayed in a form control when the control has no value. The placeholder text should provide a brief hint to the user as to the expected type of data that should be entered into the control. |
|
||||||
| readonly | The Boolean **`readonly`** attribute, when present, makes the element not mutable, meaning the user can not edit the control. |
|
| readonly | The Boolean **`readonly`** attribute, when present, makes the element not mutable, meaning the user can not edit the control. |
|
||||||
| required | The [Boolean](https://developer.mozilla.org/en-US/docs/Glossary/Boolean/HTML) **`required`** attribute, if present, indicates that the user must specify a value for the input before the owning form can be submitted. |
|
| required | The [Boolean](https://developer.mozilla.org/en-US/docs/Glossary/Boolean/HTML) **`required`** attribute, if present, indicates that the user must specify a value for the input before the owning form can be submitted. |
|
|
@ -9,14 +9,14 @@ htmx extends and generalizes the core idea of [HTML](HTML.md) as a hypertext, op
|
||||||
|
|
||||||
- Now any element, not just anchors and forms, can issue an [HTTP](HTTP.md) request
|
- Now any element, not just anchors and forms, can issue an [HTTP](HTTP.md) request
|
||||||
- Now any event, not just clicks or form submissions, can trigger requests
|
- Now any event, not just clicks or form submissions, can trigger requests
|
||||||
- Now any [HTTP](HTTP.md) verb, not just `GET` and `POST`, can be used
|
- Now any [HTTP](HTTP.md) verb, not just `GET` and `POST`, can be used
|
||||||
- Now any element, not just the entire window, can be the target for update by the request
|
- Now any element, not just the entire window, can be the target for update by the request
|
||||||
|
|
||||||
> **Note:** that when you are using htmx, on the server side you typically respond with _[HTML](HTML.md)_, not _[JSON](../files/JSON.md)_. This keeps you firmly within the [original web programming model](https://www.ics.uci.edu/~fielding/pubs/dissertation/rest_arch_style.htm), using [Hypertext As The Engine Of Application State](https://en.wikipedia.org/wiki/HATEOAS) without even needing to really understand that concept.
|
> **Note:** that when you are using htmx, on the server side you typically respond with _[HTML](HTML.md)_, not _[JSON](../files/JSON.md)_. This keeps you firmly within the [original web programming model](https://www.ics.uci.edu/~fielding/pubs/dissertation/rest_arch_style.htm), using [Hypertext As The Engine Of Application State](https://en.wikipedia.org/wiki/HATEOAS) without even needing to really understand that concept.
|
||||||
|
|
||||||
# Installing
|
# Installing
|
||||||
|
|
||||||
Htmx is a dependency-free, browser-oriented javascript library. This means that using it is as simple as adding a `<script>` tag to your document head. No need for complicated build steps or systems.
|
Htmx is a dependency-free, browser-oriented javascript library. This means that using it is as simple as adding a `<script>` tag to your document head. No need for complicated build steps or systems.
|
||||||
|
|
||||||
Via CDN:
|
Via CDN:
|
||||||
```html
|
```html
|
||||||
|
@ -27,25 +27,25 @@ Via CDN:
|
||||||
|
|
||||||
The next easiest way to install htmx is to simply copy it into your project.
|
The next easiest way to install htmx is to simply copy it into your project.
|
||||||
|
|
||||||
Download `htmx.min.js` [from unpkg.com](https://unpkg.com/htmx.org/dist/htmx.min.js) and add it to the appropriate directory in your project and include it where necessary with a `<script>` tag:
|
Download `htmx.min.js` [from unpkg.com](https://unpkg.com/htmx.org/dist/htmx.min.js) and add it to the appropriate directory in your project and include it where necessary with a `<script>` tag:
|
||||||
```html
|
```html
|
||||||
<script src="/path/to/htmx.min.js"></script>
|
<script src="/path/to/htmx.min.js"></script>
|
||||||
```
|
```
|
||||||
|
|
||||||
You can also add extensions this way, by downloading them from the `ext/` directory.
|
You can also add extensions this way, by downloading them from the `ext/` directory.
|
||||||
|
|
||||||
# AJAX
|
# AJAX
|
||||||
The core of htmx is a set of attributes that allow you to issue AJAX requests directly from [HTML](HTML.md):
|
The core of htmx is a set of attributes that allow you to issue AJAX requests directly from [HTML](HTML.md):
|
||||||
|
|
||||||
|Attribute|Description|
|
|Attribute|Description|
|
||||||
|---|---|
|
|---|---|
|
||||||
|[hx-get](https://htmx.org/attributes/hx-get/)|Issues a `GET` request to the given URL|
|
|[hx-get](https://htmx.org/attributes/hx-get/)|Issues a `GET` request to the given URL|
|
||||||
|[hx-post](https://htmx.org/attributes/hx-post/)|Issues a `POST` request to the given URL|
|
|[hx-post](https://htmx.org/attributes/hx-post/)|Issues a `POST` request to the given URL|
|
||||||
|[hx-put](https://htmx.org/attributes/hx-put/)|Issues a `PUT` request to the given URL|
|
|[hx-put](https://htmx.org/attributes/hx-put/)|Issues a `PUT` request to the given URL|
|
||||||
|[hx-patch](https://htmx.org/attributes/hx-patch/)|Issues a `PATCH` request to the given URL|
|
|[hx-patch](https://htmx.org/attributes/hx-patch/)|Issues a `PATCH` request to the given URL|
|
||||||
|[hx-delete](https://htmx.org/attributes/hx-delete/)|Issues a `DELETE` request to the given URL|
|
|[hx-delete](https://htmx.org/attributes/hx-delete/)|Issues a `DELETE` request to the given URL|
|
||||||
|
|
||||||
Each of these attributes takes a URL to issue an AJAX request to. The element will issue a request of the specified type to the given URL when the element is [triggered](https://htmx.org/docs/#triggers):
|
Each of these attributes takes a URL to issue an AJAX request to. The element will issue a request of the specified type to the given URL when the element is [triggered](https://htmx.org/docs/#triggers):
|
||||||
```html
|
```html
|
||||||
<div hx-put="/messages">
|
<div hx-put="/messages">
|
||||||
Put To Messages
|
Put To Messages
|
||||||
|
@ -57,14 +57,14 @@ This tells the browser:
|
||||||
|
|
||||||
### Triggering Requests
|
### Triggering Requests
|
||||||
By default, AJAX requests are triggered by the “natural” event of an element:
|
By default, AJAX requests are triggered by the “natural” event of an element:
|
||||||
- `input`, `textarea` & `select` are triggered on the `change` event
|
- `input`, `textarea` & `select` are triggered on the `change` event
|
||||||
- `form` is triggered on the `submit` event
|
- `form` is triggered on the `submit` event
|
||||||
- everything else is triggered by the `click` event
|
- everything else is triggered by the `click` event
|
||||||
|
|
||||||
If you want different behavior you can use the [hx-trigger](https://htmx.org/attributes/hx-trigger/) attribute to specify which event will cause the request.
|
If you want different behavior you can use the [hx-trigger](https://htmx.org/attributes/hx-trigger/) attribute to specify which event will cause the request.
|
||||||
|
|
||||||
#### Trigger Modifiers
|
#### Trigger Modifiers
|
||||||
A trigger can also have a few additional modifiers that change its behavior. For example, if you want a request to only happen once, you can use the `once` modifier for the trigger:
|
A trigger can also have a few additional modifiers that change its behavior. For example, if you want a request to only happen once, you can use the `once` modifier for the trigger:
|
||||||
```html
|
```html
|
||||||
<div hx-post="/mouse_entered" hx-trigger="mouseenter once">
|
<div hx-post="/mouse_entered" hx-trigger="mouseenter once">
|
||||||
[Here Mouse, Mouse!]
|
[Here Mouse, Mouse!]
|
||||||
|
@ -72,12 +72,12 @@ A trigger can also have a few additional modifiers that change its behavior. For
|
||||||
```
|
```
|
||||||
|
|
||||||
Other modifiers you can use for triggers are:
|
Other modifiers you can use for triggers are:
|
||||||
- `changed` - only issue a request if the value of the element has changed
|
- `changed` - only issue a request if the value of the element has changed
|
||||||
- `delay:<time interval>` - wait the given amount of time (e.g. `1s`) before issuing the request. If the event triggers again, the countdown is reset.
|
- `delay:<time interval>` - wait the given amount of time (e.g. `1s`) before issuing the request. If the event triggers again, the countdown is reset.
|
||||||
- `throttle:<time interval>` - wait the given amount of time (e.g. `1s`) before issuing the request. Unlike `delay` if a new event occurs before the time limit is hit the event will be discarded, so the request will trigger at the end of the time period.
|
- `throttle:<time interval>` - wait the given amount of time (e.g. `1s`) before issuing the request. Unlike `delay` if a new event occurs before the time limit is hit the event will be discarded, so the request will trigger at the end of the time period.
|
||||||
- `from:<CSS Selector>` - listen for the event on a different element. This can be used for things like keyboard shortcuts.
|
- `from:<CSS Selector>` - listen for the event on a different element. This can be used for things like keyboard shortcuts.
|
||||||
|
|
||||||
You can use these attributes to implement many common UX patterns, such as [Active Search](https://htmx.org/examples/active-search/):
|
You can use these attributes to implement many common UX patterns, such as [Active Search](https://htmx.org/examples/active-search/):
|
||||||
```html
|
```html
|
||||||
<input type="text" name="q"
|
<input type="text" name="q"
|
||||||
hx-get="/trigger_delay"
|
hx-get="/trigger_delay"
|
||||||
|
@ -87,23 +87,23 @@ You can use these attributes to implement many common UX patterns, such as [Act
|
||||||
>
|
>
|
||||||
<div id="search-results"></div>
|
<div id="search-results"></div>
|
||||||
```
|
```
|
||||||
This input will issue a request 500 milliseconds after a key up event if the input has been changed and inserts the results into the `div` with the id `search-results`.
|
This input will issue a request 500 milliseconds after a key up event if the input has been changed and inserts the results into the `div` with the id `search-results`.
|
||||||
|
|
||||||
Multiple triggers can be specified in the [hx-trigger](https://htmx.org/attributes/hx-trigger/) attribute, separated by commas.
|
Multiple triggers can be specified in the [hx-trigger](https://htmx.org/attributes/hx-trigger/) attribute, separated by commas.
|
||||||
|
|
||||||
#### Special Events
|
#### Special Events
|
||||||
htmx provides a few special events for use in [hx-trigger](https://htmx.org/attributes/hx-trigger/):
|
htmx provides a few special events for use in [hx-trigger](https://htmx.org/attributes/hx-trigger/):
|
||||||
|
|
||||||
- `load` - fires once when the element is first loaded
|
- `load` - fires once when the element is first loaded
|
||||||
- `revealed` - fires once when an element first scrolls into the viewport
|
- `revealed` - fires once when an element first scrolls into the viewport
|
||||||
- `intersect` - fires once when an element first intersects the viewport. This supports two additional options:
|
- `intersect` - fires once when an element first intersects the viewport. This supports two additional options:
|
||||||
- `root:<selector>` - a CSS selector of the root element for intersection
|
- `root:<selector>` - a CSS selector of the root element for intersection
|
||||||
- `threshold:<float>` - a floating point number between 0.0 and 1.0, indicating what amount of intersection to fire the event on
|
- `threshold:<float>` - a floating point number between 0.0 and 1.0, indicating what amount of intersection to fire the event on
|
||||||
|
|
||||||
You can also use custom events to trigger requests if you have an advanced use case.
|
You can also use custom events to trigger requests if you have an advanced use case.
|
||||||
|
|
||||||
#### Polling
|
#### Polling
|
||||||
If you want an element to poll the given URL rather than wait for an event, you can use the `every` syntax with the [`hx-trigger`](https://htmx.org/attributes/hx-trigger/) attribute:
|
If you want an element to poll the given URL rather than wait for an event, you can use the `every` syntax with the [`hx-trigger`](https://htmx.org/attributes/hx-trigger/) attribute:
|
||||||
```html
|
```html
|
||||||
<div hx-get="/news" hx-trigger="every 2s"></div>
|
<div hx-get="/news" hx-trigger="every 2s"></div>
|
||||||
```
|
```
|
||||||
|
@ -111,10 +111,10 @@ If you want an element to poll the given URL rather than wait for an event, you
|
||||||
This tells htmx
|
This tells htmx
|
||||||
> Every 2 seconds, issue a GET to /news and load the response into the div
|
> Every 2 seconds, issue a GET to /news and load the response into the div
|
||||||
|
|
||||||
If you want to stop polling from a server response you can respond with the [HTTP](HTTP.md) response code [`286`](https://en.wikipedia.org/wiki/86_(term)) and the element will cancel the polling.
|
If you want to stop polling from a server response you can respond with the [HTTP](HTTP.md) response code [`286`](https://en.wikipedia.org/wiki/86_(term)) and the element will cancel the polling.
|
||||||
|
|
||||||
#### Load Polling
|
#### Load Polling
|
||||||
Another technique that can be used to achieve polling in htmx is “load polling”, where an element specifies a `load` trigger along with a delay, and replaces itself with the response:
|
Another technique that can be used to achieve polling in htmx is “load polling”, where an element specifies a `load` trigger along with a delay, and replaces itself with the response:
|
||||||
```html
|
```html
|
||||||
<div hx-get="/messages"
|
<div hx-get="/messages"
|
||||||
hx-trigger="load delay:1s"
|
hx-trigger="load delay:1s"
|
||||||
|
@ -122,12 +122,12 @@ Another technique that can be used to achieve polling in htmx is “load polling
|
||||||
>
|
>
|
||||||
</div>
|
</div>
|
||||||
```
|
```
|
||||||
If the `/messages` end point keeps returning a div set up this way, it will keep “polling” back to the URL every second.
|
If the `/messages` end point keeps returning a div set up this way, it will keep “polling” back to the URL every second.
|
||||||
|
|
||||||
Load polling can be useful in situations where a poll has an end point at which point the polling terminates, such as when you are showing the user a [progress bar](https://htmx.org/examples/progress-bar/).
|
Load polling can be useful in situations where a poll has an end point at which point the polling terminates, such as when you are showing the user a [progress bar](https://htmx.org/examples/progress-bar/).
|
||||||
|
|
||||||
### Targets
|
### Targets
|
||||||
If you want the response to be loaded into a different element other than the one that made the request, you can use the [hx-target](https://htmx.org/attributes/hx-target/) attribute, which takes a CSS selector. Looking back at our Live Search example:
|
If you want the response to be loaded into a different element other than the one that made the request, you can use the [hx-target](https://htmx.org/attributes/hx-target/) attribute, which takes a CSS selector. Looking back at our Live Search example:
|
||||||
```html
|
```html
|
||||||
<input type="text" name="q"
|
<input type="text" name="q"
|
||||||
hx-get="/trigger_delay"
|
hx-get="/trigger_delay"
|
||||||
|
@ -137,18 +137,18 @@ If you want the response to be loaded into a different element other than the on
|
||||||
>
|
>
|
||||||
<div id="search-results"></div>
|
<div id="search-results"></div>
|
||||||
```
|
```
|
||||||
You can see that the results from the search are going to be loaded into `div#search-results`, rather than into the input tag.
|
You can see that the results from the search are going to be loaded into `div#search-results`, rather than into the input tag.
|
||||||
|
|
||||||
#### Extended CSS Selectors
|
#### Extended CSS Selectors
|
||||||
`hx-target`, and most attributes that take a CSS selector, support an “extended” CSS syntax:
|
`hx-target`, and most attributes that take a CSS selector, support an “extended” CSS syntax:
|
||||||
- You can use the `this` keyword, which indicates that the element that the `hx-target` attribute is on is the target
|
- You can use the `this` keyword, which indicates that the element that the `hx-target` attribute is on is the target
|
||||||
- The `closest <CSS selector>` syntax will find the [closest](https://developer.mozilla.org/docs/Web/API/Element/closest) ancestor element or itself, that matches the given CSS selector. (e.g. `closest tr` will target the closest table row to the element)
|
- The `closest <CSS selector>` syntax will find the [closest](https://developer.mozilla.org/docs/Web/API/Element/closest) ancestor element or itself, that matches the given CSS selector. (e.g. `closest tr` will target the closest table row to the element)
|
||||||
- The `next <CSS selector>` syntax will find the next element in the DOM matching the given CSS selector.
|
- The `next <CSS selector>` syntax will find the next element in the DOM matching the given CSS selector.
|
||||||
- The `previous <CSS selector>` syntax will find the previous element in the DOM the given CSS selector.
|
- The `previous <CSS selector>` syntax will find the previous element in the DOM the given CSS selector.
|
||||||
- `find <CSS selector>` which will find the first child descendant element that matches the given CSS selector. (e.g `find tr` would target the first child descendant row to the element)
|
- `find <CSS selector>` which will find the first child descendant element that matches the given CSS selector. (e.g `find tr` would target the first child descendant row to the element)
|
||||||
|
|
||||||
### Swapping
|
### Swapping
|
||||||
htmx offers a few different ways to swap the [HTML](HTML.md) returned into the DOM. By default, the content replaces the `innerHTML` of the target element. You can modify this by using the [hx-swap](https://htmx.org/attributes/hx-swap/) attribute with any of the following values:
|
htmx offers a few different ways to swap the [HTML](HTML.md) returned into the DOM. By default, the content replaces the `innerHTML` of the target element. You can modify this by using the [hx-swap](https://htmx.org/attributes/hx-swap/) attribute with any of the following values:
|
||||||
|
|
||||||
|Name|Description|
|
|Name|Description|
|
||||||
|---|---|
|
|---|---|
|
||||||
|
@ -159,23 +159,23 @@ htmx offers a few different ways to swap the [HTML](HTML.md) returned into the D
|
||||||
|`beforeend`|appends the content after the last child inside the target|
|
|`beforeend`|appends the content after the last child inside the target|
|
||||||
|`afterend`|appends the content after the target in the targets parent element|
|
|`afterend`|appends the content after the target in the targets parent element|
|
||||||
|`delete`|deletes the target element regardless of the response|
|
|`delete`|deletes the target element regardless of the response|
|
||||||
|`none`|does not append content from response ([Out of Band Swaps](https://htmx.org/docs/#oob_swaps) and [Response Headers](https://htmx.org/docs/#response-headers) will still be processed)|
|
|`none`|does not append content from response ([Out of Band Swaps](https://htmx.org/docs/#oob_swaps) and [Response Headers](https://htmx.org/docs/#response-headers) will still be processed)|
|
||||||
|
|
||||||
### Parameters
|
### Parameters
|
||||||
By default, an element that causes a request will include its value if it has one. If the element is a form it will include the values of all inputs within it.
|
By default, an element that causes a request will include its value if it has one. If the element is a form it will include the values of all inputs within it.
|
||||||
|
|
||||||
As with [HTML](HTML.md) forms, the `name` attribute of the input is used as the parameter name in the request that htmx sends.
|
As with [HTML](HTML.md) forms, the `name` attribute of the input is used as the parameter name in the request that htmx sends.
|
||||||
|
|
||||||
Additionally, if the element causes a non-`GET` request, the values of all the inputs of the nearest enclosing form will be included.
|
Additionally, if the element causes a non-`GET` request, the values of all the inputs of the nearest enclosing form will be included.
|
||||||
|
|
||||||
If you wish to include the values of other elements, you can use the [hx-include](https://htmx.org/attributes/hx-include/) attribute with a CSS selector of all the elements whose values you want to include in the request.
|
If you wish to include the values of other elements, you can use the [hx-include](https://htmx.org/attributes/hx-include/) attribute with a CSS selector of all the elements whose values you want to include in the request.
|
||||||
|
|
||||||
If you wish to filter out some parameters you can use the [hx-params](https://htmx.org/attributes/hx-params/) attribute.
|
If you wish to filter out some parameters you can use the [hx-params](https://htmx.org/attributes/hx-params/) attribute.
|
||||||
|
|
||||||
Finally, if you want to programmatically modify the parameters, you can use the [htmx:configRequest](https://htmx.org/events/#htmx:configRequest) event.
|
Finally, if you want to programmatically modify the parameters, you can use the [htmx:configRequest](https://htmx.org/events/#htmx:configRequest) event.
|
||||||
|
|
||||||
#### Extra Values
|
#### Extra Values
|
||||||
You can include extra values in a request using the [hx-vals](https://htmx.org/attributes/hx-vals/) (name-expression pairs in [JSON](../files/JSON.md) format) and [hx-vars](https://htmx.org/attributes/hx-vars/) attributes (comma-separated name-expression pairs that are dynamically computed).
|
You can include extra values in a request using the [hx-vals](https://htmx.org/attributes/hx-vals/) (name-expression pairs in [JSON](../files/JSON.md) format) and [hx-vars](https://htmx.org/attributes/hx-vars/) attributes (comma-separated name-expression pairs that are dynamically computed).
|
||||||
|
|
||||||
## Attribute Inheritance
|
## Attribute Inheritance
|
||||||
Most attributes in htmx are inherited: they apply to the element they are on as well as any children elements. This allows you to “hoist” attributes up the DOM to avoid code duplication. Consider the following htmx:
|
Most attributes in htmx are inherited: they apply to the element they are on as well as any children elements. This allows you to “hoist” attributes up the DOM to avoid code duplication. Consider the following htmx:
|
||||||
|
@ -188,7 +188,7 @@ Most attributes in htmx are inherited: they apply to the element they are on as
|
||||||
</button>
|
</button>
|
||||||
```
|
```
|
||||||
|
|
||||||
Here we have a duplicate `hx-confirm` attribute. We can hoist this attribute to a parent element:
|
Here we have a duplicate `hx-confirm` attribute. We can hoist this attribute to a parent element:
|
||||||
```html
|
```html
|
||||||
<div hx-confirm="Are you sure?">
|
<div hx-confirm="Are you sure?">
|
||||||
<button hx-delete="/account">
|
<button hx-delete="/account">
|
||||||
|
@ -200,9 +200,9 @@ Here we have a duplicate `hx-confirm` attribute. We can hoist this attribute t
|
||||||
</div>
|
</div>
|
||||||
```
|
```
|
||||||
|
|
||||||
This `hx-confirm` attribute will now apply to all htmx-powered elements within it.
|
This `hx-confirm` attribute will now apply to all htmx-powered elements within it.
|
||||||
|
|
||||||
Sometimes you wish to undo this inheritance. Consider if we had a cancel button to this group, but didn’t want it to be confirmed. We could add an `unset` directive on it like so:
|
Sometimes you wish to undo this inheritance. Consider if we had a cancel button to this group, but didn’t want it to be confirmed. We could add an `unset` directive on it like so:
|
||||||
```html
|
```html
|
||||||
<div hx-confirm="Are you sure?">
|
<div hx-confirm="Are you sure?">
|
||||||
<button hx-delete="/account">
|
<button hx-delete="/account">
|
||||||
|
@ -218,10 +218,10 @@ Sometimes you wish to undo this inheritance. Consider if we had a cancel button
|
||||||
```
|
```
|
||||||
The top two buttons would then show a confirm dialog, but the bottom cancel button would not.
|
The top two buttons would then show a confirm dialog, but the bottom cancel button would not.
|
||||||
|
|
||||||
Automatic inheritance can be disabled using the [`hx-disinherit`](https://htmx.org/attributes/hx-disinherit/) attribute.
|
Automatic inheritance can be disabled using the [`hx-disinherit`](https://htmx.org/attributes/hx-disinherit/) attribute.
|
||||||
|
|
||||||
## Boosting
|
## Boosting
|
||||||
Htmx supports “boosting” regular [HTML](HTML.md) anchors and forms with the [hx-boost](https://htmx.org/attributes/hx-boost/) attribute. This attribute will convert all anchor tags and forms into AJAX requests that, by default, target the body of the page.
|
Htmx supports “boosting” regular [HTML](HTML.md) anchors and forms with the [hx-boost](https://htmx.org/attributes/hx-boost/) attribute. This attribute will convert all anchor tags and forms into AJAX requests that, by default, target the body of the page.
|
||||||
|
|
||||||
Here is an example:
|
Here is an example:
|
||||||
```html
|
```html
|
||||||
|
@ -230,21 +230,21 @@ Here is an example:
|
||||||
</div>
|
</div>
|
||||||
```
|
```
|
||||||
|
|
||||||
The anchor tag in this div will issue an AJAX `GET` request to `/blog` and swap the response into the `body` tag.
|
The anchor tag in this div will issue an AJAX `GET` request to `/blog` and swap the response into the `body` tag.
|
||||||
|
|
||||||
## History Support
|
## History Support
|
||||||
Htmx provides a simple mechanism for interacting with the [browser history API](https://developer.mozilla.org/en-US/docs/Web/API/History_API):
|
Htmx provides a simple mechanism for interacting with the [browser history API](https://developer.mozilla.org/en-US/docs/Web/API/History_API):
|
||||||
|
|
||||||
If you want a given element to push its request URL into the browser navigation bar and add the current state of the page to the browser’s history, include the [hx-push-url](https://htmx.org/attributes/hx-push-url/) attribute:
|
If you want a given element to push its request URL into the browser navigation bar and add the current state of the page to the browser’s history, include the [hx-push-url](https://htmx.org/attributes/hx-push-url/) attribute:
|
||||||
```html
|
```html
|
||||||
<a hx-get="/blog" hx-push-url="true">Blog</a>
|
<a hx-get="/blog" hx-push-url="true">Blog</a>
|
||||||
```
|
```
|
||||||
|
|
||||||
When a user clicks on this link, htmx will snapshot the current DOM and store it before it makes a request to /blog. It then does the swap and pushes a new location onto the history stack.
|
When a user clicks on this link, htmx will snapshot the current DOM and store it before it makes a request to /blog. It then does the swap and pushes a new location onto the history stack.
|
||||||
|
|
||||||
When a user hits the back button, htmx will retrieve the old content from storage and swap it back into the target, simulating “going back” to the previous state. If the location is not found in the cache, htmx will make an ajax request to the given URL, with the header `HX-History-Restore-Request` set to true, and expects back the [HTML](HTML.md) needed for the entire page. Alternatively, if the `htmx.config.refreshOnHistoryMiss` config variable is set to true, it will issue a hard browser refresh.
|
When a user hits the back button, htmx will retrieve the old content from storage and swap it back into the target, simulating “going back” to the previous state. If the location is not found in the cache, htmx will make an ajax request to the given URL, with the header `HX-History-Restore-Request` set to true, and expects back the [HTML](HTML.md) needed for the entire page. Alternatively, if the `htmx.config.refreshOnHistoryMiss` config variable is set to true, it will issue a hard browser refresh.
|
||||||
|
|
||||||
**NOTE:** If you push a URL into the history, you **must** be able to navigate to that URL and get a full page back! A user could copy and paste the URL into an email, or new tab. Additionally, htmx will need the entire page when restoring history if the page is not in the history cache.
|
**NOTE:** If you push a URL into the history, you **must** be able to navigate to that URL and get a full page back! A user could copy and paste the URL into an email, or new tab. Additionally, htmx will need the entire page when restoring history if the page is not in the history cache.
|
||||||
|
|
||||||
# Request & Responses
|
# Request & Responses
|
||||||
### Request Headers
|
### Request Headers
|
||||||
|
@ -256,19 +256,19 @@ htmx includes a number of useful headers in requests:
|
||||||
| `HX-Trigger` | will be set to the id of the element that triggered the request |
|
| `HX-Trigger` | will be set to the id of the element that triggered the request |
|
||||||
| `HX-Trigger-Name` | will be set to the name of the element that triggered the request |
|
| `HX-Trigger-Name` | will be set to the name of the element that triggered the request |
|
||||||
| `HX-Target` | will be set to the id of the target element |
|
| `HX-Target` | will be set to the id of the target element |
|
||||||
| `HX-Prompt` | will be set to the value entered by the user when prompted via [hx-prompt](https://htmx.org/attributes/hx-prompt/) |
|
| `HX-Prompt` | will be set to the value entered by the user when prompted via [hx-prompt](https://htmx.org/attributes/hx-prompt/) |
|
||||||
|
|
||||||
### Response Headers
|
### Response Headers
|
||||||
htmx supports some htmx-specific response headers:
|
htmx supports some htmx-specific response headers:
|
||||||
|
|
||||||
- `HX-Push` - pushes a new URL into the browser’s address bar
|
- `HX-Push` - pushes a new URL into the browser’s address bar
|
||||||
- `HX-Redirect` - triggers a client-side redirect to a new location
|
- `HX-Redirect` - triggers a client-side redirect to a new location
|
||||||
- `HX-Location` - triggers a client-side redirect to a new location that acts as a swap
|
- `HX-Location` - triggers a client-side redirect to a new location that acts as a swap
|
||||||
- `HX-Refresh` - if set to “true” the client side will do a full refresh of the page
|
- `HX-Refresh` - if set to “true” the client side will do a full refresh of the page
|
||||||
- `HX-Trigger` - triggers client side events
|
- `HX-Trigger` - triggers client side events
|
||||||
- `HX-Trigger-After-Swap` - triggers client side events after the swap step
|
- `HX-Trigger-After-Swap` - triggers client side events after the swap step
|
||||||
- `HX-Trigger-After-Settle` - triggers client side events after the settle step
|
- `HX-Trigger-After-Settle` - triggers client side events after the settle step
|
||||||
|
|
||||||
For more on the `HX-Trigger` headers, see [`HX-Trigger` Response Headers](https://htmx.org/headers/hx-trigger/).
|
For more on the `HX-Trigger` headers, see [`HX-Trigger` Response Headers](https://htmx.org/headers/hx-trigger/).
|
||||||
|
|
||||||
Submitting a form via htmx has the benefit of no longer needing the [Post/Redirect/Get Pattern](https://en.wikipedia.org/wiki/Post/Redirect/Get). After successfully processing a POST request on the server, you don’t need to return a [HTTP 302 (Redirect)](https://en.wikipedia.org/wiki/HTTP_302). You can directly return the new [HTML](HTML.md) fragment.
|
Submitting a form via htmx has the benefit of no longer needing the [Post/Redirect/Get Pattern](https://en.wikipedia.org/wiki/Post/Redirect/Get). After successfully processing a POST request on the server, you don’t need to return a [HTTP 302 (Redirect)](https://en.wikipedia.org/wiki/HTTP_302). You can directly return the new [HTML](HTML.md) fragment.
|
|
@ -5,9 +5,9 @@ rfc: https://datatracker.ietf.org/doc/html/rfc7519
|
||||||
---
|
---
|
||||||
|
|
||||||
# [Json](../files/JSON.md) Web Token (JWT)
|
# [Json](../files/JSON.md) Web Token (JWT)
|
||||||
[JSON](../files/JSON.md) Web Token (JWT) is an open standard ([RFC 7519](https://tools.ietf.org/html/rfc7519)) that defines a compact and self-contained way for securely transmitting information between parties as a [JSON](../files/JSON.md) object. This information can be verified and trusted because it is digitally signed. JWTs can be signed using a secret (with the **HMAC** algorithm) or a public/private key pair using **RSA** or **ECDSA**.
|
[JSON](../files/JSON.md) Web Token (JWT) is an open standard ([RFC 7519](https://tools.ietf.org/html/rfc7519)) that defines a compact and self-contained way for securely transmitting information between parties as a [JSON](../files/JSON.md) object. This information can be verified and trusted because it is digitally signed. JWTs can be signed using a secret (with the **HMAC** algorithm) or a public/private key pair using **RSA** or **ECDSA**.
|
||||||
|
|
||||||
Signed tokens can verify the _integrity_ of the claims contained within it, while encrypted tokens _hide_ those claims from other parties. When tokens are signed using public/private key pairs, the signature also certifies that only the party holding the private key is the one that signed it.
|
Signed tokens can verify the _integrity_ of the claims contained within it, while encrypted tokens _hide_ those claims from other parties. When tokens are signed using public/private key pairs, the signature also certifies that only the party holding the private key is the one that signed it.
|
||||||
|
|
||||||
[JSON](../files/JSON.md) Web Token can be stored in a [Cookie](Cookie.md)
|
[JSON](../files/JSON.md) Web Token can be stored in a [Cookie](Cookie.md)
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@ Therefore, a JWT typically looks like the following.
|
||||||
`xxxxx.yyyyy.zzzzz`
|
`xxxxx.yyyyy.zzzzz`
|
||||||
|
|
||||||
### Header
|
### Header
|
||||||
The header _typically_ consists of two parts: the type of the token, which is JWT, and the signing algorithm being used, such as HMAC SHA256 or RSA.
|
The header _typically_ consists of two parts: the type of the token, which is JWT, and the signing algorithm being used, such as HMAC SHA256 or RSA.
|
||||||
|
|
||||||
For example:
|
For example:
|
||||||
```
|
```
|
||||||
|
@ -31,15 +31,15 @@ For example:
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
Then, this [JSON](../files/JSON.md) is **Base64Url** encoded to form the first part of the JWT.
|
Then, this [JSON](../files/JSON.md) is **Base64Url** encoded to form the first part of the JWT.
|
||||||
|
|
||||||
### Payload
|
### Payload
|
||||||
The second part of the token is the payload, which contains the claims. Claims are statements about an entity (typically, the user) and additional data. There are three types of claims: _registered_, _public_, and _private_ claims.
|
The second part of the token is the payload, which contains the claims. Claims are statements about an entity (typically, the user) and additional data. There are three types of claims: _registered_, _public_, and _private_ claims.
|
||||||
|
|
||||||
- [**Registered claims**](https://tools.ietf.org/html/rfc7519#section-4.1): These are a set of predefined claims which are not mandatory but recommended, to provide a set of useful, interoperable claims. Some of them are: **iss** (issuer), **exp** (expiration time), **sub** (subject), **aud** (audience), and [others](https://tools.ietf.org/html/rfc7519#section-4.1).
|
- [**Registered claims**](https://tools.ietf.org/html/rfc7519#section-4.1): These are a set of predefined claims which are not mandatory but recommended, to provide a set of useful, interoperable claims. Some of them are: **iss** (issuer), **exp** (expiration time), **sub** (subject), **aud** (audience), and [others](https://tools.ietf.org/html/rfc7519#section-4.1).
|
||||||
> Notice that the claim names are only three characters long as JWT is meant to be compact.
|
> Notice that the claim names are only three characters long as JWT is meant to be compact.
|
||||||
- [**Public claims**](https://tools.ietf.org/html/rfc7519#section-4.2): These can be defined at will by those using JWTs. But to avoid collisions they should be defined in the [IANA JSON Web Token Registry](https://www.iana.org/assignments/jwt/jwt.xhtml) or be defined as a URI that contains a collision resistant namespace.
|
- [**Public claims**](https://tools.ietf.org/html/rfc7519#section-4.2): These can be defined at will by those using JWTs. But to avoid collisions they should be defined in the [IANA JSON Web Token Registry](https://www.iana.org/assignments/jwt/jwt.xhtml) or be defined as a URI that contains a collision resistant namespace.
|
||||||
- [**Private claims**](https://tools.ietf.org/html/rfc7519#section-4.3): These are the custom claims created to share information between parties that agree on using them and are neither _registered_ or _public_ claims.
|
- [**Private claims**](https://tools.ietf.org/html/rfc7519#section-4.3): These are the custom claims created to share information between parties that agree on using them and are neither _registered_ or _public_ claims.
|
||||||
|
|
||||||
An example payload could be:
|
An example payload could be:
|
||||||
```
|
```
|
||||||
|
@ -50,7 +50,7 @@ An example payload could be:
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
The payload is then **Base64Url** encoded to form the second part of the [JSON](../files/JSON.md) Web Token.
|
The payload is then **Base64Url** encoded to form the second part of the [JSON](../files/JSON.md) Web Token.
|
||||||
|
|
||||||
### Signature
|
### Signature
|
||||||
To create the signature part you have to take the encoded header, the encoded payload, a secret, the algorithm specified in the header, and sign that.
|
To create the signature part you have to take the encoded header, the encoded payload, a secret, the algorithm specified in the header, and sign that.
|
||||||
|
|
|
@ -55,24 +55,24 @@ The 64-bit binary fixed-point timestamps used by NTP consist of a 32-bit part fo
|
||||||
NTPv4 introduces a 128-bit date format: 64 bits for the second and 64 bits for the fractional-second. The most-significant 32-bits of this format is the Era Number which resolves rollover ambiguity in most cases. According to Mills, "The 64-bit value for the fraction is enough to resolve the amount of time it takes a photon to pass an electron at the speed of light. The 64-bit second value is enough to provide unambiguous time representation until the universe goes dim."
|
NTPv4 introduces a 128-bit date format: 64 bits for the second and 64 bits for the fractional-second. The most-significant 32-bits of this format is the Era Number which resolves rollover ambiguity in most cases. According to Mills, "The 64-bit value for the fraction is enough to resolve the amount of time it takes a photon to pass an electron at the speed of light. The 64-bit second value is enough to provide unambiguous time representation until the universe goes dim."
|
||||||
|
|
||||||
## Clock synchronization algorithm
|
## Clock synchronization algorithm
|
||||||
A typical NTP client regularly polls one or more NTP servers. The client must compute its time offset and round-trip delay. Time offset _θ_ is positive or negative (client time > server time) difference in absolute time between the two clocks. It is defined by:
|
A typical NTP client regularly polls one or more NTP servers. The client must compute its time offset and round-trip delay. Time offset _θ_ is positive or negative (client time > server time) difference in absolute time between the two clocks. It is defined by:
|
||||||
${\displaystyle \theta ={\frac {(t_{1}-t_{0})+(t_{2}-t_{3})}{2}},}$
|
${\displaystyle \theta ={\frac {(t_{1}-t_{0})+(t_{2}-t_{3})}{2}},}$
|
||||||
|
|
||||||
and the round-trip delay _δ_ by:
|
and the round-trip delay _δ_ by:
|
||||||
${\displaystyle \delta ={(t_{3}-t_{0})-(t_{2}-t_{1})},}$
|
${\displaystyle \delta ={(t_{3}-t_{0})-(t_{2}-t_{1})},}$
|
||||||
|
|
||||||
where
|
where
|
||||||
- $t_{0}$ is the client's timestamp of the request packet transmission,
|
- $t_{0}$ is the client's timestamp of the request packet transmission,
|
||||||
- $t_{1}$ is the server's timestamp of the request packet reception,
|
- $t_{1}$ is the server's timestamp of the request packet reception,
|
||||||
- $t_{2}$ is the server's timestamp of the response packet transmission and
|
- $t_{2}$ is the server's timestamp of the response packet transmission and
|
||||||
- $t_{3}$ is the client's timestamp of the response packet reception.
|
- $t_{3}$ is the client's timestamp of the response packet reception.
|
||||||
|
|
||||||
To derive the expression for the offset, note that for the request packet,
|
To derive the expression for the offset, note that for the request packet,
|
||||||
${\displaystyle t_{0}+\theta +\delta /2=t_{1}}$
|
${\displaystyle t_{0}+\theta +\delta /2=t_{1}}$
|
||||||
and for the response packet,
|
and for the response packet,
|
||||||
${\displaystyle t_{3}+\theta -\delta /2=t_{2}}$
|
${\displaystyle t_{3}+\theta -\delta /2=t_{2}}$
|
||||||
|
|
||||||
Solving for _θ_ yields the definition of the time offset.
|
Solving for _θ_ yields the definition of the time offset.
|
||||||
|
|
||||||
The values for θ and δ are passed through filters and subjected to statistical analysis ("mitigation"). Outliers are discarded and an estimate of time offset is derived from the best three remaining candidates. The clock frequency is then adjusted to reduce the offset gradually ("discipline"), creating a feedback loop.
|
The values for θ and δ are passed through filters and subjected to statistical analysis ("mitigation"). Outliers are discarded and an estimate of time offset is derived from the best three remaining candidates. The clock frequency is then adjusted to reduce the offset gradually ("discipline"), creating a feedback loop.
|
||||||
|
|
||||||
|
|
|
@ -10,15 +10,15 @@ Users of the Tor network run an onion proxy software on their machines, which pr
|
||||||
As an overlay network it is similiar to [i2p](../internet/I2P.md).
|
As an overlay network it is similiar to [i2p](../internet/I2P.md).
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
Start/enable `tor.service`. Alternatively, launch it with `sudo -u tor /usr/bin/tor`.
|
Start/enable `tor.service`. Alternatively, launch it with `sudo -u tor /usr/bin/tor`.
|
||||||
|
|
||||||
To use a program over Tor, configure it to use `127.0.0.1` or `localhost` as a SOCKS5 proxy, with port `9050` for plain Tor with standard settings.
|
To use a program over Tor, configure it to use `127.0.0.1` or `localhost` as a SOCKS5 proxy, with port `9050` for plain Tor with standard settings.
|
||||||
|
|
||||||
The proxy supports remote DNS resolution: use `socks5**h**://localhost:9050` for DNS resolution from the exit node (instead of `socks5` for a local DNS resolution).
|
The proxy supports remote DNS resolution: use `socks5**h**://localhost:9050` for DNS resolution from the exit node (instead of `socks5` for a local DNS resolution).
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
|
|
||||||
Tor reads its configurations from the file `/etc/tor/torrc` by default, or if the latter is not found, from `$HOME/.torrc`. The configuration options are explained on the [Tor website](https://torproject.org/docs/tor-manual.html.en). The default configuration should work fine for most Tor users.
|
Tor reads its configurations from the file `/etc/tor/torrc` by default, or if the latter is not found, from `$HOME/.torrc`. The configuration options are explained on the [Tor website](https://torproject.org/docs/tor-manual.html.en). The default configuration should work fine for most Tor users.
|
||||||
|
|
||||||
## Hidden Services
|
## Hidden Services
|
||||||
Hidden Services are web services behind an onion domain.
|
Hidden Services are web services behind an onion domain.
|
||||||
|
|
|
@ -6,7 +6,7 @@ source: https://developer.mozilla.org/en-US/docs/Learn/Common_questions/Web_mech
|
||||||
# URL
|
# URL
|
||||||
The target of an [HTTP](HTTP.md) request is called a "resource", whose nature isn't defined further; it can be a document, a photo, or anything else. Each resource is identified by a Uniform Resource Identifier ([URI](https://developer.mozilla.org/en-US/docs/Glossary/URI)) used throughout [HTTP](HTTP.md) for identifying resources.
|
The target of an [HTTP](HTTP.md) request is called a "resource", whose nature isn't defined further; it can be a document, a photo, or anything else. Each resource is identified by a Uniform Resource Identifier ([URI](https://developer.mozilla.org/en-US/docs/Glossary/URI)) used throughout [HTTP](HTTP.md) for identifying resources.
|
||||||
|
|
||||||
The most common form of URI is the Uniform Resource Locator ([URL](https://developer.mozilla.org/en-US/docs/Glossary/URL)), which is known as the _web address_.
|
The most common form of URI is the Uniform Resource Locator ([URL](https://developer.mozilla.org/en-US/docs/Glossary/URL)), which is known as the _web address_.
|
||||||
|
|
||||||
# Syntax
|
# Syntax
|
||||||
URL: `http://www.example.com:80/path/to/myfile.html?key1=value1&key2=value2#SomewhereInTheDocument`
|
URL: `http://www.example.com:80/path/to/myfile.html?key1=value1&key2=value2#SomewhereInTheDocument`
|
||||||
|
@ -14,7 +14,7 @@ URL: `http://www.example.com:80/path/to/myfile.html?key1=value1&key2=value2#Some
|
||||||
URLs can be absolute like the above or relative like `../parent/path`.
|
URLs can be absolute like the above or relative like `../parent/path`.
|
||||||
|
|
||||||
## Scheme or Protocol
|
## Scheme or Protocol
|
||||||
`http://` is the protocol. It indicates which protocol the browser must use. Usually it is the [HTTP](HTTP.md) protocol or its secured version, HTTPS. The Web requires one of these two, but browsers also know how to handle other protocols such as `mailto:` (to open a mail client) or `ftp:` to handle a file transfer, so don't be surprised if you see such protocols. Common schemes are:
|
`http://` is the protocol. It indicates which protocol the browser must use. Usually it is the [HTTP](HTTP.md) protocol or its secured version, HTTPS. The Web requires one of these two, but browsers also know how to handle other protocols such as `mailto:` (to open a mail client) or `ftp:` to handle a file transfer, so don't be surprised if you see such protocols. Common schemes are:
|
||||||
|
|
||||||
| Scheme | Description |
|
| Scheme | Description |
|
||||||
| ----------- | ------------------------------------------------------------------------------------------------- |
|
| ----------- | ------------------------------------------------------------------------------------------------- |
|
||||||
|
@ -31,16 +31,16 @@ URLs can be absolute like the above or relative like `../parent/path`.
|
||||||
| ws/wss | [WebSocket connections (Secure)](https://developer.mozilla.org/en-US/docs/Web/API/WebSockets_API) |
|
| ws/wss | [WebSocket connections (Secure)](https://developer.mozilla.org/en-US/docs/Web/API/WebSockets_API) |
|
||||||
|
|
||||||
## Domain
|
## Domain
|
||||||
`www.example.com` is the [domain](Domain.md) name or authority that governs the namespace. It indicates which Web server is being requested. Alternatively, it is possible to directly use an [IP address](https://developer.mozilla.org/en-US/docs/Glossary/IP_Address), but because it is less convenient, it is not often used on the Web.
|
`www.example.com` is the [domain](Domain.md) name or authority that governs the namespace. It indicates which Web server is being requested. Alternatively, it is possible to directly use an [IP address](https://developer.mozilla.org/en-US/docs/Glossary/IP_Address), but because it is less convenient, it is not often used on the Web.
|
||||||
|
|
||||||
## Port
|
## Port
|
||||||
`:80` is the port in this instance. It indicates the technical "gate" used to access the resources on the web server. It is usually omitted if the web server uses the standard ports of the [HTTP](HTTP.md) protocol (80 for [HTTP](HTTP.md) and 443 for HTTPS) to grant access to its resources. Otherwise, it is mandatory.
|
`:80` is the port in this instance. It indicates the technical "gate" used to access the resources on the web server. It is usually omitted if the web server uses the standard ports of the [HTTP](HTTP.md) protocol (80 for [HTTP](HTTP.md) and 443 for HTTPS) to grant access to its resources. Otherwise, it is mandatory.
|
||||||
|
|
||||||
## Path
|
## Path
|
||||||
`/path/to/myfile.html` is the path to the resource on the Web server. In the early days of the Web, a path like this represented a physical file location on the Web server. Nowadays, it is mostly an abstraction handled by Web servers without any physical reality.
|
`/path/to/myfile.html` is the path to the resource on the Web server. In the early days of the Web, a path like this represented a physical file location on the Web server. Nowadays, it is mostly an abstraction handled by Web servers without any physical reality.
|
||||||
|
|
||||||
## Query
|
## Query
|
||||||
`?key1=value1&key2=value2` are extra parameters provided to the Web server. Those parameters are a list of key/value pairs separated with the `&` symbol. The Web server can use those parameters to do extra stuff before returning the resource to the user. Each Web server has its own rules regarding parameters, and the only reliable way to know how a specific Web server is handling parameters is by asking the Web server owner.
|
`?key1=value1&key2=value2` are extra parameters provided to the Web server. Those parameters are a list of key/value pairs separated with the `&` symbol. The Web server can use those parameters to do extra stuff before returning the resource to the user. Each Web server has its own rules regarding parameters, and the only reliable way to know how a specific Web server is handling parameters is by asking the Web server owner.
|
||||||
|
|
||||||
## Fragment
|
## Fragment
|
||||||
`#SomewhereInTheDocument` is an anchor to another part of the resource itself. An anchor represents a sort of "bookmark" inside the resource, giving the browser the directions to show the content located at that "bookmarked" spot. On an [HTML](HTML.md) document, for example, the browser will scroll to the point where the anchor is defined; on a video or audio document, the browser will try to go to the time the anchor represents. It is worth noting that the part after the `#`, also known as the fragment identifier, is never sent to the server with the request.
|
`#SomewhereInTheDocument` is an anchor to another part of the resource itself. An anchor represents a sort of "bookmark" inside the resource, giving the browser the directions to show the content located at that "bookmarked" spot. On an [HTML](HTML.md) document, for example, the browser will scroll to the point where the anchor is defined; on a video or audio document, the browser will try to go to the time the anchor represents. It is worth noting that the part after the `#`, also known as the fragment identifier, is never sent to the server with the request.
|
||||||
|
|
|
@ -66,4 +66,4 @@ Type=oneshot
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
```
|
```
|
||||||
|
|
||||||
Then activate this new service by starting `wol@<interface>.service`.
|
Then activate this new service by starting `wol@<interface>.service`.
|
||||||
|
|
|
@ -8,5 +8,5 @@ Arch is a very minimal [Linux](Linux.md) Distribution. It features many [package
|
||||||
|
|
||||||
Installation of Arch Linux is typically done manually following the Wiki. Additionally there are install scripts like this one:
|
Installation of Arch Linux is typically done manually following the Wiki. Additionally there are install scripts like this one:
|
||||||
```shell
|
```shell
|
||||||
curl -L matmoul.github.io/archfi | bash
|
curl -L matmoul.github.io/archfi | bash
|
||||||
```
|
```
|
|
@ -17,7 +17,7 @@ A typical Linux system has, among others, the following directories:
|
||||||
| ---------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ---------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| `/` | This is the root directory. This is where the whole tree starts. |
|
| `/` | This is the root directory. This is where the whole tree starts. |
|
||||||
| `/bin` | This directory contains executable programs which are needed in single user mode and to bring the system up or repair it. |
|
| `/bin` | This directory contains executable programs which are needed in single user mode and to bring the system up or repair it. |
|
||||||
| `/boot` | Contains static files for the boot loader. This directory holds only the files which are needed during the boot process. The operating system kernel (initrd for example) must be located in either `/` or `/boot`. |
|
| `/boot` | Contains static files for the boot loader. This directory holds only the files which are needed during the boot process. The operating system kernel (initrd for example) must be located in either `/` or `/boot`. |
|
||||||
| `/dev` | Special or device files, which refer to physical devices. |
|
| `/dev` | Special or device files, which refer to physical devices. |
|
||||||
| `/etc` | Contains configuration files which are local to the machine. |
|
| `/etc` | Contains configuration files which are local to the machine. |
|
||||||
| `/home` | On machines with home directories for users, these are usually beneath this directory, directly or not. |
|
| `/home` | On machines with home directories for users, these are usually beneath this directory, directly or not. |
|
||||||
|
@ -26,15 +26,15 @@ A typical Linux system has, among others, the following directories:
|
||||||
| _`/lost+found`_ | This comes from [Ext4](filesystems/Ext4.md). This directory contains items lost in the filesystem. |
|
| _`/lost+found`_ | This comes from [Ext4](filesystems/Ext4.md). This directory contains items lost in the filesystem. |
|
||||||
| `/media` | This directory contains mount points for removable media such as CD and DVD disks or USB sticks. |
|
| `/media` | This directory contains mount points for removable media such as CD and DVD disks or USB sticks. |
|
||||||
| `/mnt` | This directory is a mount point for a temporarily mounted filesystem. |
|
| `/mnt` | This directory is a mount point for a temporarily mounted filesystem. |
|
||||||
| `/proc` | This is a mount point for the _proc_ filesystem, which provides information about running processes and the kernel. |
|
| `/proc` | This is a mount point for the _proc_ filesystem, which provides information about running processes and the kernel. |
|
||||||
| `/root` | This directory is usually the home directory for the root user (optional). |
|
| `/root` | This directory is usually the home directory for the root user (optional). |
|
||||||
| `/run` | This directory contains information which describes the system since it was booted. Once this purpose was served by `/var/run` and programs may continue to use it. |
|
| `/run` | This directory contains information which describes the system since it was booted. Once this purpose was served by `/var/run` and programs may continue to use it. |
|
||||||
| `/sbin` | Like `/bin`, this directory holds commands needed to boot the system, but which are usually not executed by normal users. |
|
| `/sbin` | Like `/bin`, this directory holds commands needed to boot the system, but which are usually not executed by normal users. |
|
||||||
| `/sys` | This is a mount point for the _sysfs_ filesystem, which provides information about the kernel like _/proc_, but better structured, following the formalism of kobject infrastructure. |
|
| `/sys` | This is a mount point for the _sysfs_ filesystem, which provides information about the kernel like _/proc_, but better structured, following the formalism of kobject infrastructure. |
|
||||||
| `/tmp` | This directory contains temporary files which may be deleted with no notice, such as by a regular job or at system boot up. |
|
| `/tmp` | This directory contains temporary files which may be deleted with no notice, such as by a regular job or at system boot up. |
|
||||||
| `/usr` | This directory is usually mounted from a separate partition. It should hold only shareable, read-only data, so that it can be mounted by various machines running Linux. |
|
| `/usr` | This directory is usually mounted from a separate partition. It should hold only shareable, read-only data, so that it can be mounted by various machines running Linux. |
|
||||||
| `/usr/bin` | This is the primary directory for executable programs. Most programs executed by normal users which are not needed for booting or for repairing the system and which are not installed locally should be placed in this directory. |
|
| `/usr/bin` | This is the primary directory for executable programs. Most programs executed by normal users which are not needed for booting or for repairing the system and which are not installed locally should be placed in this directory. |
|
||||||
| `/usr/etc` | Site-wide configuration files to be shared between several machines may be stored in this directory. However, commands should always reference those files using the `/etc` directory. Links from files in `/etc` should point to the appropriate files in `/usr/etc`. |
|
| `/usr/etc` | Site-wide configuration files to be shared between several machines may be stored in this directory. However, commands should always reference those files using the `/etc` directory. Links from files in `/etc` should point to the appropriate files in `/usr/etc`. |
|
||||||
| `/usr/include` | Include files for the C compiler. |
|
| `/usr/include` | Include files for the C compiler. |
|
||||||
| `/usr/lib` | Object libraries, including dynamic libraries, plus some executables which usually are not invoked directly. More complicated programs may have whole subdirectories there. |
|
| `/usr/lib` | Object libraries, including dynamic libraries, plus some executables which usually are not invoked directly. More complicated programs may have whole subdirectories there. |
|
||||||
| `/usr/share` | This directory contains subdirectories with specific application data, that can be shared among different architectures of the same OS. |
|
| `/usr/share` | This directory contains subdirectories with specific application data, that can be shared among different architectures of the same OS. |
|
||||||
|
|
|
@ -59,7 +59,7 @@ $ mergerfs.fsck -v -f manual /path/to/dir
|
||||||
```
|
```
|
||||||
|
|
||||||
## mergerfs.dup
|
## mergerfs.dup
|
||||||
Duplicates files & directories across branches in a pool. The file selected for duplication is picked by the `dup` option. Files will be copied to drives with the most free space. Deleted from others if `prune` is enabled.
|
Duplicates files & directories across branches in a pool. The file selected for duplication is picked by the `dup` option. Files will be copied to drives with the most free space. Deleted from others if `prune` is enabled.
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
usage: mergerfs.dup [<options>] <dir>
|
usage: mergerfs.dup [<options>] <dir>
|
||||||
|
@ -91,7 +91,7 @@ optional arguments:
|
||||||
```
|
```
|
||||||
|
|
||||||
## mergerfs.dedup
|
## mergerfs.dedup
|
||||||
Finds and removes duplicate files across mergerfs pool's branches. Use the `ignore`, `dedup`, and `strict` options to target specific use cases.
|
Finds and removes duplicate files across mergerfs pool's branches. Use the `ignore`, `dedup`, and `strict` options to target specific use cases.
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
usage: mergerfs.dedup [<options>] <dir>
|
usage: mergerfs.dedup [<options>] <dir>
|
||||||
|
|
|
@ -3,7 +3,7 @@ repo: https://github.com/trapexit/mergerfs
|
||||||
obj: filesystem
|
obj: filesystem
|
||||||
---
|
---
|
||||||
# MergerFS
|
# MergerFS
|
||||||
**mergerfs** is a union filesystem geared towards simplifying storage and management of files across numerous commodity storage devices. It is similar to **mhddfs**, **unionfs**, and **aufs**.
|
**mergerfs** is a union filesystem geared towards simplifying storage and management of files across numerous commodity storage devices. It is similar to **mhddfs**, **unionfs**, and **aufs**.
|
||||||
|
|
||||||
Usage: `mergerfs -o<options> <branches> <mountpoint>`
|
Usage: `mergerfs -o<options> <branches> <mountpoint>`
|
||||||
|
|
||||||
|
@ -54,7 +54,7 @@ WantedBy=default.target
|
||||||
```
|
```
|
||||||
|
|
||||||
## Options
|
## Options
|
||||||
These options are the same regardless of whether you use them with the `mergerfs` commandline program, in fstab, or in a config file.
|
These options are the same regardless of whether you use them with the `mergerfs` commandline program, in fstab, or in a config file.
|
||||||
|
|
||||||
| mount option | description |
|
| mount option | description |
|
||||||
| ----------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
| ----------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
||||||
|
@ -132,29 +132,29 @@ These options are the same regardless of whether you use them with the `mergerf
|
||||||
### branches
|
### branches
|
||||||
The 'branches' argument is a colon (':') delimited list of paths to be pooled together. It does not matter if the paths are on the same or different filesystems nor does it matter the filesystem type (within reason). Used and available space will not be duplicated for paths on the same filesystem and any features which aren't supported by the underlying filesystem (such as file attributes or extended attributes) will return the appropriate errors.
|
The 'branches' argument is a colon (':') delimited list of paths to be pooled together. It does not matter if the paths are on the same or different filesystems nor does it matter the filesystem type (within reason). Used and available space will not be duplicated for paths on the same filesystem and any features which aren't supported by the underlying filesystem (such as file attributes or extended attributes) will return the appropriate errors.
|
||||||
|
|
||||||
Branches currently have two options which can be set. A type which impacts whether or not the branch is included in a policy calculation and a individual minfreespace value. The values are set by prepending an `=` at the end of a branch designation and using commas as delimiters. Example: `/mnt/drive=RW,1234`
|
Branches currently have two options which can be set. A type which impacts whether or not the branch is included in a policy calculation and a individual minfreespace value. The values are set by prepending an `=` at the end of a branch designation and using commas as delimiters. Example: `/mnt/drive=RW,1234`
|
||||||
|
|
||||||
#### branch mode
|
#### branch mode
|
||||||
- RW: (read/write) - Default behavior. Will be eligible in all policy categories.
|
- RW: (read/write) - Default behavior. Will be eligible in all policy categories.
|
||||||
- RO: (read-only) - Will be excluded from `create` and `action` policies. Same as a read-only mounted filesystem would be (though faster to process).
|
- RO: (read-only) - Will be excluded from `create` and `action` policies. Same as a read-only mounted filesystem would be (though faster to process).
|
||||||
- NC: (no-create) - Will be excluded from `create` policies. You can't create on that branch but you can change or delete.
|
- NC: (no-create) - Will be excluded from `create` policies. You can't create on that branch but you can change or delete.
|
||||||
|
|
||||||
#### globbing
|
#### globbing
|
||||||
To make it easier to include multiple branches mergerfs supports [globbing](http://linux.die.net/man/7/glob). **The globbing tokens MUST be escaped when using via the shell else the shell itself will apply the glob itself.**
|
To make it easier to include multiple branches mergerfs supports [globbing](http://linux.die.net/man/7/glob). **The globbing tokens MUST be escaped when using via the shell else the shell itself will apply the glob itself.**
|
||||||
```
|
```
|
||||||
# mergerfs /mnt/hdd\*:/mnt/ssd /media
|
# mergerfs /mnt/hdd\*:/mnt/ssd /media
|
||||||
```
|
```
|
||||||
|
|
||||||
The above line will use all mount points in /mnt prefixed with **hdd** and **ssd**.
|
The above line will use all mount points in /mnt prefixed with **hdd** and **ssd**.
|
||||||
|
|
||||||
To have the pool mounted at boot or otherwise accessible from related tools use **/etc/fstab**.
|
To have the pool mounted at boot or otherwise accessible from related tools use **/etc/fstab**.
|
||||||
```
|
```
|
||||||
# <file system> <mount point> <type> <options> <dump> <pass>
|
# <file system> <mount point> <type> <options> <dump> <pass>
|
||||||
/mnt/hdd*:/mnt/ssd /media fuse.mergerfs minfreespace=16G 0 0
|
/mnt/hdd*:/mnt/ssd /media fuse.mergerfs minfreespace=16G 0 0
|
||||||
```
|
```
|
||||||
|
|
||||||
## Functions, Categories and Policies
|
## Functions, Categories and Policies
|
||||||
The POSIX filesystem API is made up of a number of functions. **creat**, **stat**, **chown**, etc. For ease of configuration in mergerfs most of the core functions are grouped into 3 categories: **action**, **create**, and **search**. These functions and categories can be assigned a policy which dictates which branch is chosen when performing that function.
|
The POSIX filesystem API is made up of a number of functions. **creat**, **stat**, **chown**, etc. For ease of configuration in mergerfs most of the core functions are grouped into 3 categories: **action**, **create**, and **search**. These functions and categories can be assigned a policy which dictates which branch is chosen when performing that function.
|
||||||
|
|
||||||
### Functions and their Category classifications
|
### Functions and their Category classifications
|
||||||
| Category | FUSE Functions |
|
| Category | FUSE Functions |
|
||||||
|
@ -171,22 +171,22 @@ A policy's behavior differs, as mentioned above, based on the function it is use
|
||||||
|
|
||||||
| Policy | Description |
|
| Policy | Description |
|
||||||
| --------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| --------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| all | Search: For **mkdir**, **mknod**, and **symlink** it will apply to all branches. **create** works like **ff**. |
|
| all | Search: For **mkdir**, **mknod**, and **symlink** it will apply to all branches. **create** works like **ff**. |
|
||||||
| epall (existing path, all) | For **mkdir**, **mknod**, and **symlink** it will apply to all found. **create** works like **epff** (but more expensive because it doesn't stop after finding a valid branch). |
|
| epall (existing path, all) | For **mkdir**, **mknod**, and **symlink** it will apply to all found. **create** works like **epff** (but more expensive because it doesn't stop after finding a valid branch). |
|
||||||
| epff (existing path, first found) | Given the order of the branches, as defined at mount time or configured at runtime, act on the first one found where the relative path exists. |
|
| epff (existing path, first found) | Given the order of the branches, as defined at mount time or configured at runtime, act on the first one found where the relative path exists. |
|
||||||
| eplfs (existing path, least free space) | Of all the branches on which the relative path exists choose the branch with the least free space. |
|
| eplfs (existing path, least free space) | Of all the branches on which the relative path exists choose the branch with the least free space. |
|
||||||
| eplus (existing path, least used space) | Of all the branches on which the relative path exists choose the branch with the least used space. |
|
| eplus (existing path, least used space) | Of all the branches on which the relative path exists choose the branch with the least used space. |
|
||||||
| epmfs (existing path, most free space) | Of all the branches on which the relative path exists choose the branch with the most free space. |
|
| epmfs (existing path, most free space) | Of all the branches on which the relative path exists choose the branch with the most free space. |
|
||||||
| eppfrd (existing path, percentage free random distribution) | Like **pfrd** but limited to existing paths. |
|
| eppfrd (existing path, percentage free random distribution) | Like **pfrd** but limited to existing paths. |
|
||||||
| eprand (existing path, random) | Calls **epall** and then randomizes. Returns 1. |
|
| eprand (existing path, random) | Calls **epall** and then randomizes. Returns 1. |
|
||||||
| ff (first found) | Given the order of the branches, as defined at mount time or configured at runtime, act on the first one found. |
|
| ff (first found) | Given the order of the branches, as defined at mount time or configured at runtime, act on the first one found. |
|
||||||
| lfs (least free space) | Pick the branch with the least available free space. |
|
| lfs (least free space) | Pick the branch with the least available free space. |
|
||||||
| lus (least used space) | Pick the branch with the least used space. |
|
| lus (least used space) | Pick the branch with the least used space. |
|
||||||
| mfs (most free space) | Pick the branch with the most available free space. |
|
| mfs (most free space) | Pick the branch with the most available free space. |
|
||||||
| msplfs (most shared path, least free space) | Like **eplfs** but if it fails to find a branch it will try again with the parent directory. Continues this pattern till finding one. |
|
| msplfs (most shared path, least free space) | Like **eplfs** but if it fails to find a branch it will try again with the parent directory. Continues this pattern till finding one. |
|
||||||
| msplus (most shared path, least used space) | Like **eplus** but if it fails to find a branch it will try again with the parent directory. Continues this pattern till finding one. |
|
| msplus (most shared path, least used space) | Like **eplus** but if it fails to find a branch it will try again with the parent directory. Continues this pattern till finding one. |
|
||||||
| mspmfs (most shared path, most free space) | Like **epmfs** but if it fails to find a branch it will try again with the parent directory. Continues this pattern till finding one. |
|
| mspmfs (most shared path, most free space) | Like **epmfs** but if it fails to find a branch it will try again with the parent directory. Continues this pattern till finding one. |
|
||||||
| msppfrd (most shared path, percentage free random distribution) | Like **eppfrd** but if it fails to find a branch it will try again with the parent directory. Continues this pattern till finding one. |
|
| msppfrd (most shared path, percentage free random distribution) | Like **eppfrd** but if it fails to find a branch it will try again with the parent directory. Continues this pattern till finding one. |
|
||||||
| newest | Pick the file / directory with the largest mtime. |
|
| newest | Pick the file / directory with the largest mtime. |
|
||||||
| pfrd (percentage free random distribution) | Chooses a branch at random with the likelihood of selection based on a branch's available space relative to the total. |
|
| pfrd (percentage free random distribution) | Chooses a branch at random with the likelihood of selection based on a branch's available space relative to the total. |
|
||||||
| rand (random) | Calls **all** and then randomizes. Returns 1 branch. |
|
| rand (random) | Calls **all** and then randomizes. Returns 1 branch. |
|
|
@ -3,30 +3,30 @@ arch-wiki: https://wiki.archlinux.org/title/RAID
|
||||||
obj: concept
|
obj: concept
|
||||||
---
|
---
|
||||||
# RAID
|
# RAID
|
||||||
Redundant Array of Independent Disks (RAID) is a storage technology that combines multiple disk drive components (typically disk drives or partitions thereof) into a logical unit. Depending on the RAID implementation, this logical unit can be a file system or an additional transparent layer that can hold several partitions. Data is distributed across the drives in one of several ways called RAID levels, depending on the level of redundancy and performance required. The RAID level chosen can thus prevent data loss in the event of a hard disk failure, increase performance or be a combination of both.
|
Redundant Array of Independent Disks (RAID) is a storage technology that combines multiple disk drive components (typically disk drives or partitions thereof) into a logical unit. Depending on the RAID implementation, this logical unit can be a file system or an additional transparent layer that can hold several partitions. Data is distributed across the drives in one of several ways called RAID levels, depending on the level of redundancy and performance required. The RAID level chosen can thus prevent data loss in the event of a hard disk failure, increase performance or be a combination of both.
|
||||||
|
|
||||||
## RAID Levels
|
## RAID Levels
|
||||||
### RAID 0
|
### RAID 0
|
||||||
Uses striping to combine disks. Even though it _does not provide redundancy_, it is still considered RAID. It does, however, _provide a big speed benefit_. If the speed increase is worth the possibility of data loss, choose this RAID level. On a server, RAID 1 and RAID 5 arrays are more appropriate. The size of a RAID 0 array block device is the size of the smallest component partition times the number of component partitions.
|
Uses striping to combine disks. Even though it _does not provide redundancy_, it is still considered RAID. It does, however, _provide a big speed benefit_. If the speed increase is worth the possibility of data loss, choose this RAID level. On a server, RAID 1 and RAID 5 arrays are more appropriate. The size of a RAID 0 array block device is the size of the smallest component partition times the number of component partitions.
|
||||||
|
|
||||||
### RAID 1
|
### RAID 1
|
||||||
The most straightforward RAID level: straight mirroring. As with other RAID levels, it only makes sense if the partitions are on different physical disk drives. If one of those drives fails, the block device provided by the RAID array will continue to function as normal. The example will be using RAID 1 for everything except swap and temporary data. Please note that with a software implementation, the RAID 1 level is the only option for the boot partition, because bootloaders reading the boot partition do not understand RAID, but a RAID 1 component partition can be read as a normal partition. The size of a RAID 1 array block device is the size of the smallest component partition.
|
The most straightforward RAID level: straight mirroring. As with other RAID levels, it only makes sense if the partitions are on different physical disk drives. If one of those drives fails, the block device provided by the RAID array will continue to function as normal. The example will be using RAID 1 for everything except swap and temporary data. Please note that with a software implementation, the RAID 1 level is the only option for the boot partition, because bootloaders reading the boot partition do not understand RAID, but a RAID 1 component partition can be read as a normal partition. The size of a RAID 1 array block device is the size of the smallest component partition.
|
||||||
|
|
||||||
### RAID 5
|
### RAID 5
|
||||||
Requires 3 or more physical drives, and provides the redundancy of RAID 1 combined with the speed and size benefits of RAID 0. RAID 5 uses striping, like RAID 0, but also stores parity blocks _distributed across each member disk_. In the event of a failed disk, these parity blocks are used to reconstruct the data on a replacement disk. RAID 5 can withstand the loss of one member disk.
|
Requires 3 or more physical drives, and provides the redundancy of RAID 1 combined with the speed and size benefits of RAID 0. RAID 5 uses striping, like RAID 0, but also stores parity blocks _distributed across each member disk_. In the event of a failed disk, these parity blocks are used to reconstruct the data on a replacement disk. RAID 5 can withstand the loss of one member disk.
|
||||||
|
|
||||||
### RAID 6
|
### RAID 6
|
||||||
Requires 4 or more physical drives, and provides the benefits of RAID 5 but with security against two drive failures. RAID 6 also uses striping, like RAID 5, but stores two distinct parity blocks _distributed across each member disk_. In the event of a failed disk, these parity blocks are used to reconstruct the data on a replacement disk. RAID 6 can withstand the loss of two member disks. The robustness against unrecoverable read errors is somewhat better, because the array still has parity blocks when rebuilding from a single failed drive. However, given the overhead, RAID 6 is costly and in most settings RAID 10 in far2 layout (see below) provides better speed benefits and robustness, and is therefore preferred.
|
Requires 4 or more physical drives, and provides the benefits of RAID 5 but with security against two drive failures. RAID 6 also uses striping, like RAID 5, but stores two distinct parity blocks _distributed across each member disk_. In the event of a failed disk, these parity blocks are used to reconstruct the data on a replacement disk. RAID 6 can withstand the loss of two member disks. The robustness against unrecoverable read errors is somewhat better, because the array still has parity blocks when rebuilding from a single failed drive. However, given the overhead, RAID 6 is costly and in most settings RAID 10 in far2 layout (see below) provides better speed benefits and robustness, and is therefore preferred.
|
||||||
|
|
||||||
## Using RAID
|
## Using RAID
|
||||||
Software RAID is the easiest implementation as it does not rely on obscure proprietary firmware and software to be used. The array is managed by the operating system either by:
|
Software RAID is the easiest implementation as it does not rely on obscure proprietary firmware and software to be used. The array is managed by the operating system either by:
|
||||||
|
|
||||||
- an abstraction layer (e.g. mdadm);
|
- an abstraction layer (e.g. mdadm);
|
||||||
- a logical volume manager (e.g. [LVM](LVM.md));
|
- a logical volume manager (e.g. [LVM](LVM.md));
|
||||||
- a component of a file system (e.g. [ZFS](ZFS.md), [Btrfs](Btrfs.md))
|
- a component of a file system (e.g. [ZFS](ZFS.md), [Btrfs](Btrfs.md))
|
||||||
|
|
||||||
## Installation
|
## Installation
|
||||||
_mdadm_ is used for administering pure software RAID using plain block devices: the underlying hardware does not provide any RAID logic, just a supply of disks. _mdadm_ will work with any collection of block devices. Even if unusual. For example, one can thus make a RAID array from a collection of thumb drives.
|
_mdadm_ is used for administering pure software RAID using plain block devices: the underlying hardware does not provide any RAID logic, just a supply of disks. _mdadm_ will work with any collection of block devices. Even if unusual. For example, one can thus make a RAID array from a collection of thumb drives.
|
||||||
|
|
||||||
**Erase disks**
|
**Erase disks**
|
||||||
```shell
|
```shell
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
obj: filesystem
|
obj: filesystem
|
||||||
---
|
---
|
||||||
# SquashFS
|
# SquashFS
|
||||||
**Squashfs** is a compressed read-only [file system](Filesystems.md) for [Linux](../Linux.md).
|
**Squashfs** is a compressed read-only [file system](Filesystems.md) for [Linux](../Linux.md).
|
||||||
|
|
||||||
## Creation
|
## Creation
|
||||||
```shell
|
```shell
|
||||||
|
|
|
@ -6,7 +6,7 @@ obj: filesystem
|
||||||
---
|
---
|
||||||
|
|
||||||
# ZFS
|
# ZFS
|
||||||
[ZFS](https://en.wikipedia.org/wiki/ZFS "wikipedia:ZFS") is an advanced filesystem.
|
[ZFS](https://en.wikipedia.org/wiki/ZFS "wikipedia:ZFS") is an advanced filesystem.
|
||||||
|
|
||||||
## ZPool
|
## ZPool
|
||||||
**Create a pool***
|
**Create a pool***
|
||||||
|
|
|
@ -3,10 +3,10 @@ obj: concept
|
||||||
---
|
---
|
||||||
|
|
||||||
# mkinitcpio
|
# mkinitcpio
|
||||||
The initial ramdisk is in essence a very small environment (early userspace) which loads various kernel modules and sets up necessary things before handing over control to `init`. This makes it possible to have, for example, encrypted root file systems and root file systems on a software [RAID](filesystems/RAID.md) array. _mkinitcpio_ allows for easy extension with custom hooks, has autodetection at runtime, and many other features.
|
The initial ramdisk is in essence a very small environment (early userspace) which loads various kernel modules and sets up necessary things before handing over control to `init`. This makes it possible to have, for example, encrypted root file systems and root file systems on a software [RAID](filesystems/RAID.md) array. _mkinitcpio_ allows for easy extension with custom hooks, has autodetection at runtime, and many other features.
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
The primary configuration file for _mkinitcpio_ is `/etc/mkinitcpio.conf`. Additionally, preset definitions are provided by kernel packages in the `/etc/mkinitcpio.d` directory (e.g. `/etc/mkinitcpio.d/linux.preset`).
|
The primary configuration file for _mkinitcpio_ is `/etc/mkinitcpio.conf`. Additionally, preset definitions are provided by kernel packages in the `/etc/mkinitcpio.d` directory (e.g. `/etc/mkinitcpio.d/linux.preset`).
|
||||||
|
|
||||||
`MODULES`
|
`MODULES`
|
||||||
Kernel modules to be loaded before any boot hooks are run.
|
Kernel modules to be loaded before any boot hooks are run.
|
||||||
|
@ -24,40 +24,40 @@ Hooks are scripts that execute in the initial ramdisk.
|
||||||
Used to compress the initramfs image.
|
Used to compress the initramfs image.
|
||||||
|
|
||||||
### MODULES
|
### MODULES
|
||||||
The `MODULES` array is used to specify modules to load before anything else is done.
|
The `MODULES` array is used to specify modules to load before anything else is done.
|
||||||
|
|
||||||
Modules suffixed with a `?` will not throw errors if they are not found. This might be useful for custom kernels that compile in modules which are listed explicitly in a hook or configuration file.
|
Modules suffixed with a `?` will not throw errors if they are not found. This might be useful for custom kernels that compile in modules which are listed explicitly in a hook or configuration file.
|
||||||
|
|
||||||
### BINARIES and FILES
|
### BINARIES and FILES
|
||||||
These options allow users to add files to the image. Both `BINARIES` and `FILES` are added before hooks are run, and may be used to override files used or provided by a hook. `BINARIES` are auto-located within a standard `PATH` and are dependency-parsed, meaning any required libraries will also be added. `FILES` are added _as-is_. For example:
|
These options allow users to add files to the image. Both `BINARIES` and `FILES` are added before hooks are run, and may be used to override files used or provided by a hook. `BINARIES` are auto-located within a standard `PATH` and are dependency-parsed, meaning any required libraries will also be added. `FILES` are added _as-is_. For example:
|
||||||
```
|
```
|
||||||
FILES=(/etc/modprobe.d/modprobe.conf)
|
FILES=(/etc/modprobe.d/modprobe.conf)
|
||||||
|
|
||||||
BINARIES=(kexec)
|
BINARIES=(kexec)
|
||||||
```
|
```
|
||||||
Note that as both `BINARIES` and `FILES` are Bash arrays, multiple entries can be added delimited with spaces.
|
Note that as both `BINARIES` and `FILES` are Bash arrays, multiple entries can be added delimited with spaces.
|
||||||
|
|
||||||
### HOOKS
|
### HOOKS
|
||||||
The `HOOKS` array is the most important setting in the file. Hooks are small scripts which describe what will be added to the image. For some hooks, they will also contain a runtime component which provides additional behavior, such as starting a daemon, or assembling a stacked block device. Hooks are referred to by their name, and executed in the order they exist in the `HOOKS` array of the configuration file.
|
The `HOOKS` array is the most important setting in the file. Hooks are small scripts which describe what will be added to the image. For some hooks, they will also contain a runtime component which provides additional behavior, such as starting a daemon, or assembling a stacked block device. Hooks are referred to by their name, and executed in the order they exist in the `HOOKS` array of the configuration file.
|
||||||
|
|
||||||
The default `HOOKS` setting should be sufficient for most simple, single disk setups. For root devices which are stacked or multi-block devices such as [LVM](filesystems/LVM.md), [RAID](filesystems/RAID.md), or [dm-crypt](filesystems/LUKS.md), see the respective wiki pages for further necessary configuration.
|
The default `HOOKS` setting should be sufficient for most simple, single disk setups. For root devices which are stacked or multi-block devices such as [LVM](filesystems/LVM.md), [RAID](filesystems/RAID.md), or [dm-crypt](filesystems/LUKS.md), see the respective wiki pages for further necessary configuration.
|
||||||
|
|
||||||
#### Common Hooks
|
#### Common Hooks
|
||||||
| Hook | Feature |
|
| Hook | Feature |
|
||||||
| --------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| --------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| **base** | Sets up all initial directories and installs base utilities and libraries. Always keep this hook as the first hook unless you know what you are doing, as it provides critical busybox init when not using **[systemd](systemd/Systemd.md)** hook. Optional when using the **[systemd](systemd/Systemd.md)** hook as it only provides a busybox recovery shell. |
|
| **base** | Sets up all initial directories and installs base utilities and libraries. Always keep this hook as the first hook unless you know what you are doing, as it provides critical busybox init when not using **[systemd](systemd/Systemd.md)** hook. Optional when using the **[systemd](systemd/Systemd.md)** hook as it only provides a busybox recovery shell. |
|
||||||
| **udev** | Adds udevd, udevadm, and a small subset of udev rules to your image. |
|
| **udev** | Adds udevd, udevadm, and a small subset of udev rules to your image. |
|
||||||
| **usr** | Adds support for /usr on a separate partition. |
|
| **usr** | Adds support for /usr on a separate partition. |
|
||||||
| **resume** | Tries to resume from the "suspend to disk" state. |
|
| **resume** | Tries to resume from the "suspend to disk" state. |
|
||||||
| **btrfs** | Sets the required modules to enable [Btrfs](filesystems/Btrfs.md) for using multiple devices with [Btrfs](filesystems/Btrfs.md). You need to have btrfs-progs installed to use this. This hook is not required for using [Btrfs](filesystems/Btrfs.md) on a single device. |
|
| **btrfs** | Sets the required modules to enable [Btrfs](filesystems/Btrfs.md) for using multiple devices with [Btrfs](filesystems/Btrfs.md). You need to have btrfs-progs installed to use this. This hook is not required for using [Btrfs](filesystems/Btrfs.md) on a single device. |
|
||||||
| **autodetect** | Shrinks your initramfs to a smaller size by creating a whitelist of modules from a scan of sysfs. Be sure to verify included modules are correct and none are missing. This hook must be run before other subsystem hooks in order to take advantage of auto-detection. Any hooks placed before 'autodetect' will be installed in full. |
|
| **autodetect** | Shrinks your initramfs to a smaller size by creating a whitelist of modules from a scan of sysfs. Be sure to verify included modules are correct and none are missing. This hook must be run before other subsystem hooks in order to take advantage of auto-detection. Any hooks placed before 'autodetect' will be installed in full. |
|
||||||
| **modconf** | Includes modprobe configuration files from `/etc/modprobe.d/` and `/usr/lib/modprobe.d/`. |
|
| **modconf** | Includes modprobe configuration files from `/etc/modprobe.d/` and `/usr/lib/modprobe.d/`. |
|
||||||
| **block** | Adds all block device modules, formerly separately provided by the _fw_, _mmc_, _pata_, _sata_, _scsi_, _usb_, and _virtio_ hooks. |
|
| **block** | Adds all block device modules, formerly separately provided by the _fw_, _mmc_, _pata_, _sata_, _scsi_, _usb_, and _virtio_ hooks. |
|
||||||
| **net** | Adds the necessary modules for a network device. |
|
| **net** | Adds the necessary modules for a network device. |
|
||||||
| **dmraid** | Provides support for fakeRAID root devices. You must have dmraid installed to use this. Note that it is preferred to use mdadm with the mdadm_udev hook with fakeRAID if your controller supports it. |
|
| **dmraid** | Provides support for fakeRAID root devices. You must have dmraid installed to use this. Note that it is preferred to use mdadm with the mdadm_udev hook with fakeRAID if your controller supports it. |
|
||||||
| **keyboard** | Adds the necessary modules for keyboard devices. Use this if you have an USB or serial keyboard and need it in early userspace (either for entering encryption passphrases or for use in an interactive shell). As a side effect, modules for some non-keyboard input devices might be added too, but this should not be relied on. Supersedes old _usbinput_ hook. |
|
| **keyboard** | Adds the necessary modules for keyboard devices. Use this if you have an USB or serial keyboard and need it in early userspace (either for entering encryption passphrases or for use in an interactive shell). As a side effect, modules for some non-keyboard input devices might be added too, but this should not be relied on. Supersedes old _usbinput_ hook. |
|
||||||
| **keymap** | Adds the specified keymap(s) from `/etc/vconsole.conf` to the initramfs. If you use system encryption "[Dm-crypt](filesystems/LUKS.md)/Encrypting an entire system"), especially full-disk encryption, make sure you add it before the `encrypt` hook. |
|
| **keymap** | Adds the specified keymap(s) from `/etc/vconsole.conf` to the initramfs. If you use system encryption "[Dm-crypt](filesystems/LUKS.md)/Encrypting an entire system"), especially full-disk encryption, make sure you add it before the `encrypt` hook. |
|
||||||
| **encrypt** | Adds the `dm_crypt` kernel module and the `cryptsetup` tool to the image. |
|
| **encrypt** | Adds the `dm_crypt` kernel module and the `cryptsetup` tool to the image. |
|
||||||
| **lvm2** | Adds the device mapper kernel module and the `lvm` tool to the image. |
|
| **lvm2** | Adds the device mapper kernel module and the `lvm` tool to the image. |
|
||||||
| **fsck** | Adds the fsck binary and file system-specific helpers to allow running fsck against your root device (and `/usr` if separate) prior to mounting. If added after the **autodetect** hook, only the helper specific to your root file system will be added. Usage of this hook is **strongly** recommended, and it is required with a separate `/usr` partition. It is highly recommended that if you include this hook that you also include any necessary modules to ensure your keyboard will work in early userspace. |
|
| **fsck** | Adds the fsck binary and file system-specific helpers to allow running fsck against your root device (and `/usr` if separate) prior to mounting. If added after the **autodetect** hook, only the helper specific to your root file system will be added. Usage of this hook is **strongly** recommended, and it is required with a separate `/usr` partition. It is highly recommended that if you include this hook that you also include any necessary modules to ensure your keyboard will work in early userspace. |
|
||||||
| **filesystems** | This includes necessary file system modules into your image. This hook is **required** unless you specify your file system modules in `MODULES`. |
|
| **filesystems** | This includes necessary file system modules into your image. This hook is **required** unless you specify your file system modules in `MODULES`. |
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
obj: concept
|
obj: concept
|
||||||
---
|
---
|
||||||
|
|
||||||
Mounts are _systemd_ unit files with a suffix of _.mount_. A unit configuration file whose name ends in ".mount" encodes information about a file system mount point controlled and supervised by systemd.
|
Mounts are _systemd_ unit files with a suffix of _.mount_. A unit configuration file whose name ends in ".mount" encodes information about a file system mount point controlled and supervised by systemd.
|
||||||
|
|
||||||
Mount Unit files like every unit file include the `[Unit]` and `[Install]` sections. Additionally all mount information is in the `[Mount]` section.
|
Mount Unit files like every unit file include the `[Unit]` and `[Install]` sections. Additionally all mount information is in the `[Mount]` section.
|
||||||
|
|
||||||
|
|
|
@ -4,12 +4,12 @@ arch-wiki: https://wiki.archlinux.org/title/Systemd/Timers
|
||||||
---
|
---
|
||||||
|
|
||||||
# Systemd Timers
|
# Systemd Timers
|
||||||
Timers are _systemd_ unit files with a suffix of _.timer_. Timers are like other unit configuration files and are loaded from the same paths but include a `[Timer]` section which defines when and how the timer activates. Timers are defined as one of two types:
|
Timers are _systemd_ unit files with a suffix of _.timer_. Timers are like other unit configuration files and are loaded from the same paths but include a `[Timer]` section which defines when and how the timer activates. Timers are defined as one of two types:
|
||||||
|
|
||||||
- **Realtime timers** (a.k.a. wallclock timers) activate on a calendar event, the same way that cronjobs do. The option `OnCalendar=` is used to define them.
|
- **Realtime timers** (a.k.a. wallclock timers) activate on a calendar event, the same way that cronjobs do. The option `OnCalendar=` is used to define them.
|
||||||
- **Monotonic timers** activate after a time span relative to a varying starting point. They stop if the computer is temporarily suspended or shut down. There are number of different monotonic timers but all have the form: `On_Type_Sec=`. Common monotonic timers include `OnBootSec` and `OnUnitActiveSec`.
|
- **Monotonic timers** activate after a time span relative to a varying starting point. They stop if the computer is temporarily suspended or shut down. There are number of different monotonic timers but all have the form: `On_Type_Sec=`. Common monotonic timers include `OnBootSec` and `OnUnitActiveSec`.
|
||||||
|
|
||||||
For each _.timer_ file, a matching _.service_ file exists (e.g. `foo.timer` and `foo.service`). The _.timer_ file activates and controls the _.service_ file. The _.service_ does not require an `[Install]` section as it is the _timer_ units that are enabled. If necessary, it is possible to control a differently-named unit using the `Unit=` option in the timer's `[Timer]` section.
|
For each _.timer_ file, a matching _.service_ file exists (e.g. `foo.timer` and `foo.service`). The _.timer_ file activates and controls the _.service_ file. The _.service_ does not require an `[Install]` section as it is the _timer_ units that are enabled. If necessary, it is possible to control a differently-named unit using the `Unit=` option in the timer's `[Timer]` section.
|
||||||
|
|
||||||
List timers:
|
List timers:
|
||||||
```shell
|
```shell
|
||||||
|
@ -36,7 +36,7 @@ WantedBy=timers.target
|
||||||
|
|
||||||
### Realtime timer
|
### Realtime timer
|
||||||
|
|
||||||
A timer which starts once a week (at 12:00am on Monday). When activated, it triggers the service immediately if it missed the last start time (option `Persistent=true`), for example due to the system being powered off:
|
A timer which starts once a week (at 12:00am on Monday). When activated, it triggers the service immediately if it missed the last start time (option `Persistent=true`), for example due to the system being powered off:
|
||||||
|
|
||||||
`/etc/systemd/system/foo.timer`
|
`/etc/systemd/system/foo.timer`
|
||||||
```
|
```
|
||||||
|
@ -51,12 +51,12 @@ Persistent=true
|
||||||
WantedBy=timers.target
|
WantedBy=timers.target
|
||||||
```
|
```
|
||||||
|
|
||||||
When more specific dates and times are required, `OnCalendar` events uses the following format:
|
When more specific dates and times are required, `OnCalendar` events uses the following format:
|
||||||
|
|
||||||
`DayOfWeek Year-Month-Day Hour:Minute:Second`
|
`DayOfWeek Year-Month-Day Hour:Minute:Second`
|
||||||
|
|
||||||
An asterisk may be used to specify any value and commas may be used to list possible values. Two values separated by `..` indicate a contiguous range.
|
An asterisk may be used to specify any value and commas may be used to list possible values. Two values separated by `..` indicate a contiguous range.
|
||||||
|
|
||||||
In the below example the service is run the first four days of each month at 12:00 PM, but _only_ if that day is a Monday or a Tuesday.
|
In the below example the service is run the first four days of each month at 12:00 PM, but _only_ if that day is a Monday or a Tuesday.
|
||||||
|
|
||||||
`OnCalendar=Mon,Tue *-*-01..04 12:00:00`
|
`OnCalendar=Mon,Tue *-*-01..04 12:00:00`
|
|
@ -34,12 +34,12 @@ systemctl --failed
|
||||||
|
|
||||||
Start unit:
|
Start unit:
|
||||||
```shell
|
```shell
|
||||||
systemctl start unit
|
systemctl start unit
|
||||||
```
|
```
|
||||||
|
|
||||||
Stop unit:
|
Stop unit:
|
||||||
```shell
|
```shell
|
||||||
systemctl stop unit
|
systemctl stop unit
|
||||||
```
|
```
|
||||||
|
|
||||||
Restart unit:
|
Restart unit:
|
||||||
|
@ -54,14 +54,14 @@ systemctl daemon-reload
|
||||||
|
|
||||||
Enable/Disable (Start at boot) unit:
|
Enable/Disable (Start at boot) unit:
|
||||||
```shell
|
```shell
|
||||||
systemctl enable unit
|
systemctl enable unit
|
||||||
systemctl disable unit
|
systemctl disable unit
|
||||||
```
|
```
|
||||||
|
|
||||||
Mask (forbid running) unit:
|
Mask (forbid running) unit:
|
||||||
```shell
|
```shell
|
||||||
systemctl mask unit
|
systemctl mask unit
|
||||||
systemctl unmask unit
|
systemctl unmask unit
|
||||||
```
|
```
|
||||||
|
|
||||||
## Power Management
|
## Power Management
|
||||||
|
@ -87,14 +87,14 @@ Stored in:
|
||||||
- `~/.config/systemd/user/`: units used by local users
|
- `~/.config/systemd/user/`: units used by local users
|
||||||
|
|
||||||
### Service types
|
### Service types
|
||||||
There are several different start-up types to consider when writing a custom service file. This is set with the `Type=` parameter in the `[Service]` section:
|
There are several different start-up types to consider when writing a custom service file. This is set with the `Type=` parameter in the `[Service]` section:
|
||||||
|
|
||||||
- `Type=simple` (default): _systemd_ considers the service to be started up immediately. The process must not fork. Do not use this type if other services need to be ordered on this service, unless it is socket activated.
|
- `Type=simple` (default): _systemd_ considers the service to be started up immediately. The process must not fork. Do not use this type if other services need to be ordered on this service, unless it is socket activated.
|
||||||
- `Type=forking`: _systemd_ considers the service started up once the process forks and the parent has exited. For classic daemons use this type unless you know that it is not necessary. You should specify `PIDFile=` as well so _systemd_ can keep track of the main process.
|
- `Type=forking`: _systemd_ considers the service started up once the process forks and the parent has exited. For classic daemons use this type unless you know that it is not necessary. You should specify `PIDFile=` as well so _systemd_ can keep track of the main process.
|
||||||
- `Type=oneshot`: this is useful for scripts that do a single job and then exit. You may want to set `RemainAfterExit=yes` as well so that _systemd_ still considers the service as active after the process has exited.
|
- `Type=oneshot`: this is useful for scripts that do a single job and then exit. You may want to set `RemainAfterExit=yes` as well so that _systemd_ still considers the service as active after the process has exited.
|
||||||
- `Type=notify`: identical to `Type=simple`, but with the stipulation that the daemon will send a signal to _systemd_ when it is ready. The reference implementation for this notification is provided by _libsystemd-daemon.so_.
|
- `Type=notify`: identical to `Type=simple`, but with the stipulation that the daemon will send a signal to _systemd_ when it is ready. The reference implementation for this notification is provided by _libsystemd-daemon.so_.
|
||||||
- `Type=dbus`: the service is considered ready when the specified `BusName` appears on DBus's system bus.
|
- `Type=dbus`: the service is considered ready when the specified `BusName` appears on DBus's system bus.
|
||||||
- `Type=idle`: _systemd_ will delay execution of the service binary until all jobs are dispatched. Other than that behavior is very similar to `Type=simple`.
|
- `Type=idle`: _systemd_ will delay execution of the service binary until all jobs are dispatched. Other than that behavior is very similar to `Type=simple`.
|
||||||
|
|
||||||
#### Example
|
#### Example
|
||||||
```
|
```
|
||||||
|
@ -117,32 +117,32 @@ LimitNOFILE=4096
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
```
|
```
|
||||||
|
|
||||||
### The `[Unit]` section
|
### The `[Unit]` section
|
||||||
The Unit sectoin contains details and description about the unit itself. In our case, it contains details about the service. Details like 'what is it's description', 'what are it's dependencies' and more.
|
The Unit sectoin contains details and description about the unit itself. In our case, it contains details about the service. Details like 'what is it's description', 'what are it's dependencies' and more.
|
||||||
|
|
||||||
Below are the fields the Unit section has:
|
Below are the fields the Unit section has:
|
||||||
- `Description`: Human-readable title of the systemd service.
|
- `Description`: Human-readable title of the systemd service.
|
||||||
- `After`: Set dependency on a service. For example, if you are configuring Apache web server, you want the server to start after the network is online. This typically includes targets or other services.
|
- `After`: Set dependency on a service. For example, if you are configuring Apache web server, you want the server to start after the network is online. This typically includes targets or other services.
|
||||||
- `Before`: Start current service before specified service. This too, like `After`, includes targets or other services.
|
- `Before`: Start current service before specified service. This too, like `After`, includes targets or other services.
|
||||||
|
|
||||||
### The `[Service]` section
|
### The `[Service]` section
|
||||||
The Service section contains details about the execution and termination of service.
|
The Service section contains details about the execution and termination of service.
|
||||||
|
|
||||||
Below are the fields the Service section can have:
|
Below are the fields the Service section can have:
|
||||||
- `ExecStart`: The command that needs to be executed when the service starts.
|
- `ExecStart`: The command that needs to be executed when the service starts.
|
||||||
- `ExecReload`: This is an optional field. It specifies how a service is restarted. For services that perform disk I/O (especially writing to disk, like a database), it is best to gracefully kill them and start again. Use this field in case you wish to have a specific restart mechanism.
|
- `ExecReload`: This is an optional field. It specifies how a service is restarted. For services that perform disk I/O (especially writing to disk, like a database), it is best to gracefully kill them and start again. Use this field in case you wish to have a specific restart mechanism.
|
||||||
- `Type`: The process start-up type for this systemd service. Options are `simple`, `exec`, `forking`, `oneshot`, `dbus`, `notify` and `idle`.
|
- `Type`: The process start-up type for this systemd service. Options are `simple`, `exec`, `forking`, `oneshot`, `dbus`, `notify` and `idle`.
|
||||||
- `Restart`: This is another optional field but one that you will very likely use. This specifies if a service should be restarted--depending on circumstances--or not. The available options are `no`, `on-success`, `on-failure`, `on-abnormal`, `on-watchdog`, `on-abort` and `always`.
|
- `Restart`: This is another optional field but one that you will very likely use. This specifies if a service should be restarted--depending on circumstances--or not. The available options are `no`, `on-success`, `on-failure`, `on-abnormal`, `on-watchdog`, `on-abort` and `always`.
|
||||||
- `Environment`: [Environment Variables](Environment%20Variables.md)
|
- `Environment`: [Environment Variables](Environment%20Variables.md)
|
||||||
- `User`: The user that should run the process
|
- `User`: The user that should run the process
|
||||||
- `WorkingDirectory`: Working directory of the process
|
- `WorkingDirectory`: Working directory of the process
|
||||||
|
|
||||||
### The `[Install]` section
|
### The `[Install]` section
|
||||||
The Install section, as the name says, handles the installation of a systemd service/unit file. This is used when you run either `systemctl enable` and `systemctl disable` command for enable/disable a service.
|
The Install section, as the name says, handles the installation of a systemd service/unit file. This is used when you run either `systemctl enable` and `systemctl disable` command for enable/disable a service.
|
||||||
|
|
||||||
Below are the fields the Install section has:
|
Below are the fields the Install section has:
|
||||||
- `WantedBy`: This is similar to the `After` and `Before` fields, but the main difference is that this is used to specify systemd-equivalent "runlevels". The `default.target` is when all the system initialization is complete--when the user is asked to log in. Most user-facing services (like Apache, cron, GNOME-stuff, etc) use this target.
|
- `WantedBy`: This is similar to the `After` and `Before` fields, but the main difference is that this is used to specify systemd-equivalent "runlevels". The `default.target` is when all the system initialization is complete--when the user is asked to log in. Most user-facing services (like Apache, cron, GNOME-stuff, etc) use this target.
|
||||||
- `RequiredBy`: This field might feel very similar to `WantedBy`, but the main difference is that this field specifies _hard dependencies_. Meaning, if a dependency, this service will fail.
|
- `RequiredBy`: This field might feel very similar to `WantedBy`, but the main difference is that this field specifies _hard dependencies_. Meaning, if a dependency, this service will fail.
|
||||||
|
|
||||||
### Other Unit Types
|
### Other Unit Types
|
||||||
Systemd supports other unit types than `.service`.
|
Systemd supports other unit types than `.service`.
|
||||||
|
|
|
@ -20,7 +20,7 @@ bootctl update
|
||||||
```
|
```
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
The loader configuration is stored in the file `_esp_/loader/loader.conf`
|
The loader configuration is stored in the file `_esp_/loader/loader.conf`
|
||||||
Example:
|
Example:
|
||||||
```
|
```
|
||||||
default arch.conf
|
default arch.conf
|
||||||
|
@ -30,7 +30,7 @@ editor no
|
||||||
```
|
```
|
||||||
|
|
||||||
### Adding loaders
|
### Adding loaders
|
||||||
_systemd-boot_ will search for boot menu items in `_esp_/loader/entries/*.conf`
|
_systemd-boot_ will search for boot menu items in `_esp_/loader/entries/*.conf`
|
||||||
|
|
||||||
Values:
|
Values:
|
||||||
- `title` : Name
|
- `title` : Name
|
||||||
|
|
|
@ -4,6 +4,6 @@ website: https://grapheneos.org
|
||||||
---
|
---
|
||||||
|
|
||||||
# GrapheneOS
|
# GrapheneOS
|
||||||
GrapheneOS is a privacy and security focused mobile OS with [Android](Android.md) app compatibility developed as a non-profit open source project. It's focused on the research and development of privacy and security technology including substantial improvements to sandboxing, exploit mitigations and the permission model.
|
GrapheneOS is a privacy and security focused mobile OS with [Android](Android.md) app compatibility developed as a non-profit open source project. It's focused on the research and development of privacy and security technology including substantial improvements to sandboxing, exploit mitigations and the permission model.
|
||||||
|
|
||||||
GrapheneOS is designed to work on Google Pixel devices, offering a secure and privacy-focused alternative to the stock [Android](Android.md) experience.
|
GrapheneOS is designed to work on Google Pixel devices, offering a secure and privacy-focused alternative to the stock [Android](Android.md) experience.
|
|
@ -5,9 +5,9 @@ This module asserts that given expressions are true with an optional custom mess
|
||||||
| Parameter | Type | Description |
|
| Parameter | Type | Description |
|
||||||
| ----------- | --------------------------------- | ---------------------------------------------------------------------------------------- |
|
| ----------- | --------------------------------- | ---------------------------------------------------------------------------------------- |
|
||||||
| **fail_msg** | string | The customized message used for a failing assertion |
|
| **fail_msg** | string | The customized message used for a failing assertion |
|
||||||
| **quiet** | boolean | Set this to `true` to avoid verbose output |
|
| **quiet** | boolean | Set this to `true` to avoid verbose output |
|
||||||
| **success_msg** | string | The customized message used for a successful assertion |
|
| **success_msg** | string | The customized message used for a successful assertion |
|
||||||
| **that** | list / elements=string / required | A list of string expressions of the same form that can be passed to the ‘when’ statement |
|
| **that** | list / elements=string / required | A list of string expressions of the same form that can be passed to the ‘when’ statement |
|
||||||
|
|
||||||
## Examples
|
## Examples
|
||||||
```yaml
|
```yaml
|
||||||
|
|
|
@ -9,16 +9,16 @@ This module will insert/update/remove a block of multi-line text surrounded by c
|
||||||
| **block** | string | "" | The text to insert inside the marker lines. If it is missing or an empty string, the block will be removed as if state were specified to absent. |
|
| **block** | string | "" | The text to insert inside the marker lines. If it is missing or an empty string, the block will be removed as if state were specified to absent. |
|
||||||
| **create** | boolean | false | Create a new file if it does not exist. |
|
| **create** | boolean | false | Create a new file if it does not exist. |
|
||||||
| **group** | string | - | Name of the group that should own the filesystem object, as would be fed to chown. When left unspecified, it uses the current group of the current user unless you are root, in which case it can preserve the previous ownership. |
|
| **group** | string | - | Name of the group that should own the filesystem object, as would be fed to chown. When left unspecified, it uses the current group of the current user unless you are root, in which case it can preserve the previous ownership. |
|
||||||
| **insertafter** | string | "EOF" | If specified and no begin/ending marker lines are found, the block will be inserted after the last match of specified regular expression. A special value is available; EOF for inserting the block at the end of the file. If specified regular expression has no matches, EOF will be used instead. The presence of the multiline flag (?m) in the regular expression controls whether the match is done line by line or with multiple lines. This behaviour was added in ansible-core 2.14. |
|
| **insertafter** | string | "EOF" | If specified and no begin/ending marker lines are found, the block will be inserted after the last match of specified regular expression. A special value is available; EOF for inserting the block at the end of the file. If specified regular expression has no matches, EOF will be used instead. The presence of the multiline flag (?m) in the regular expression controls whether the match is done line by line or with multiple lines. This behaviour was added in ansible-core 2.14. |
|
||||||
| **insertbefore** | string | - | If specified and no begin/ending marker lines are found, the block will be inserted before the last match of specified regular expression. A special value is available; BOF for inserting the block at the beginning of the file. If specified regular expression has no matches, the block will be inserted at the end of the file. The presence of the multiline flag (?m) in the regular expression controls whether the match is done line by line or with multiple lines. This behaviour was added in ansible-core 2.14. |
|
| **insertbefore** | string | - | If specified and no begin/ending marker lines are found, the block will be inserted before the last match of specified regular expression. A special value is available; BOF for inserting the block at the beginning of the file. If specified regular expression has no matches, the block will be inserted at the end of the file. The presence of the multiline flag (?m) in the regular expression controls whether the match is done line by line or with multiple lines. This behaviour was added in ansible-core 2.14. |
|
||||||
| **marker** | string | "# {mark} ANSIBLE MANAGED BLOCK" | The marker line template. {mark} will be replaced with the values in marker_begin (default=”BEGIN”) and marker_end (default=”END”). Using a custom marker without the {mark} variable may result in the block being repeatedly inserted on subsequent playbook runs. Multi-line markers are not supported and will result in the block being repeatedly inserted on subsequent playbook runs. A newline is automatically appended by the module to marker_begin and marker_end. |
|
| **marker** | string | "# {mark} ANSIBLE MANAGED BLOCK" | The marker line template. {mark} will be replaced with the values in marker_begin (default=”BEGIN”) and marker_end (default=”END”). Using a custom marker without the {mark} variable may result in the block being repeatedly inserted on subsequent playbook runs. Multi-line markers are not supported and will result in the block being repeatedly inserted on subsequent playbook runs. A newline is automatically appended by the module to marker_begin and marker_end. |
|
||||||
| **marker_begin** | string | "BEGIN" | This will be inserted at `{mark}` in the opening ansible block marker. |
|
| **marker_begin** | string | "BEGIN" | This will be inserted at `{mark}` in the opening ansible block marker. |
|
||||||
| **marker_end** | string | "END" | This will be inserted at `{mark}` in the closing ansible block marker. |
|
| **marker_end** | string | "END" | This will be inserted at `{mark}` in the closing ansible block marker. |
|
||||||
| **mode** | any | - | The permissions the resulting filesystem object should have. For those used to _/usr/bin/chmod_ remember that modes are actually octal numbers. You must give Ansible enough information to parse them correctly. For consistent results, quote octal numbers (for example, `'644'` or `'1777'`) so Ansible receives a string and can do its own conversion from string into number. Adding a leading zero (for example, `0755`) works sometimes, but can fail in loops and some other circumstances. Giving Ansible a number without following either of these rules will end up with a decimal number which will have unexpected results. As of Ansible 1.8, the mode may be specified as a symbolic mode (for example, `u+rwx` or `u=rw,g=r,o=r`). If `mode` is not specified and the destination filesystem object **does not** exist, the default `umask` on the system will be used when setting the mode for the newly created filesystem object. If `mode` is not specified and the destination filesystem object **does** exist, the mode of the existing filesystem object will be used. |
|
| **mode** | any | - | The permissions the resulting filesystem object should have. For those used to _/usr/bin/chmod_ remember that modes are actually octal numbers. You must give Ansible enough information to parse them correctly. For consistent results, quote octal numbers (for example, `'644'` or `'1777'`) so Ansible receives a string and can do its own conversion from string into number. Adding a leading zero (for example, `0755`) works sometimes, but can fail in loops and some other circumstances. Giving Ansible a number without following either of these rules will end up with a decimal number which will have unexpected results. As of Ansible 1.8, the mode may be specified as a symbolic mode (for example, `u+rwx` or `u=rw,g=r,o=r`). If `mode` is not specified and the destination filesystem object **does not** exist, the default `umask` on the system will be used when setting the mode for the newly created filesystem object. If `mode` is not specified and the destination filesystem object **does** exist, the mode of the existing filesystem object will be used. |
|
||||||
| **owner** | string | - | Name of the user that should own the filesystem object, as would be fed to chown. When left unspecified, it uses the current user unless you are root, in which case it can preserve the previous ownership. Specifying a numeric username will be assumed to be a user ID and not a username. Avoid numeric usernames to avoid this confusion. |
|
| **owner** | string | - | Name of the user that should own the filesystem object, as would be fed to chown. When left unspecified, it uses the current user unless you are root, in which case it can preserve the previous ownership. Specifying a numeric username will be assumed to be a user ID and not a username. Avoid numeric usernames to avoid this confusion. |
|
||||||
| **path** | path / required | - | The file to modify. |
|
| **path** | path / required | - | The file to modify. |
|
||||||
| **state** | string | "present" | Whether the block should be there or not. **Choices:** (`"absent"`, `"present"`) |
|
| **state** | string | "present" | Whether the block should be there or not. **Choices:** (`"absent"`, `"present"`) |
|
||||||
| **validate** | string | - | The validation command to run before copying the updated file into the final destination. A temporary file path is used to validate, passed in through ‘%s’ which must be present as in the examples below. Also, the command is passed securely so [shell](../../../applications/cli/Shell.md) features such as expansion and pipes will not work. |
|
| **validate** | string | - | The validation command to run before copying the updated file into the final destination. A temporary file path is used to validate, passed in through ‘%s’ which must be present as in the examples below. Also, the command is passed securely so [shell](../../../applications/cli/Shell.md) features such as expansion and pipes will not work. |
|
||||||
|
|
||||||
## Examples
|
## Examples
|
||||||
```yaml
|
```yaml
|
||||||
|
|
|
@ -1,23 +1,23 @@
|
||||||
# ansible.builtin.copy
|
# ansible.builtin.copy
|
||||||
The `copy` module copies a file from the local or remote machine to a location on the remote machine.
|
The `copy` module copies a file from the local or remote machine to a location on the remote machine.
|
||||||
|
|
||||||
## Parameter
|
## Parameter
|
||||||
| Parameter | Type | Default | Description |
|
| Parameter | Type | Default | Description |
|
||||||
| ---------------- | --------------- | ------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
| ---------------- | --------------- | ------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||||||
| **attributes** | string | - | The attributes the resulting filesystem object should have. To get supported flags look at the man page for [chattr](../../../applications/cli/system/chattr.md) on the target system. The = operator is assumed as default, otherwise + or - operators need to be included in the string. |
|
| **attributes** | string | - | The attributes the resulting filesystem object should have. To get supported flags look at the man page for [chattr](../../../applications/cli/system/chattr.md) on the target system. The = operator is assumed as default, otherwise + or - operators need to be included in the string. |
|
||||||
| **backup** | boolean | false | Create a backup file including the timestamp information so you can get the original file back if you somehow clobbered it incorrectly. |
|
| **backup** | boolean | false | Create a backup file including the timestamp information so you can get the original file back if you somehow clobbered it incorrectly. |
|
||||||
| **checksum** | string | - | SHA1 checksum of the file being transferred. Used to validate that the copy of the file was successful. If this is not provided, ansible will use the local calculated checksum of the src file. |
|
| **checksum** | string | - | SHA1 checksum of the file being transferred. Used to validate that the copy of the file was successful. If this is not provided, ansible will use the local calculated checksum of the src file. |
|
||||||
| **content** | string | - | When used instead of src, sets the contents of a file directly to the specified value. Works only when dest is a file. Creates the file if it does not exist. For advanced formatting or if content contains a variable, use the ansible.builtin.template module. |
|
| **content** | string | - | When used instead of src, sets the contents of a file directly to the specified value. Works only when dest is a file. Creates the file if it does not exist. For advanced formatting or if content contains a variable, use the ansible.builtin.template module. |
|
||||||
| **decrypt** | boolean | true | This option controls the autodecryption of source files using vault. |
|
| **decrypt** | boolean | true | This option controls the autodecryption of source files using vault. |
|
||||||
| **dest** | path / required | - | Remote absolute path where the file should be copied to. If `src` is a directory, this must be a directory too. If `dest` is a non-existent path and if either `dest` ends with “/” or `src` is a directory, `dest` is created. If _dest_ is a relative path, the starting directory is determined by the remote host. If `src` and `dest` are files, the parent directory of `dest` is not created and the task fails if it does not already exist. |
|
| **dest** | path / required | - | Remote absolute path where the file should be copied to. If `src` is a directory, this must be a directory too. If `dest` is a non-existent path and if either `dest` ends with “/” or `src` is a directory, `dest` is created. If _dest_ is a relative path, the starting directory is determined by the remote host. If `src` and `dest` are files, the parent directory of `dest` is not created and the task fails if it does not already exist. |
|
||||||
| **follow** | boolean | false | This flag indicates that filesystem links in the destination, if they exist, should be followed. |
|
| **follow** | boolean | false | This flag indicates that filesystem links in the destination, if they exist, should be followed. |
|
||||||
| **force** | boolean | true | Influence whether the remote file must always be replaced. If `true`, the remote file will be replaced when contents are different than the source. If `false`, the file will only be transferred if the destination does not exist. |
|
| **force** | boolean | true | Influence whether the remote file must always be replaced. If `true`, the remote file will be replaced when contents are different than the source. If `false`, the file will only be transferred if the destination does not exist. |
|
||||||
| **group** | string | - | Name of the group that should own the filesystem object, as would be fed to chown. When left unspecified, it uses the current group of the current user unless you are root, in which case it can preserve the previous ownership. |
|
| **group** | string | - | Name of the group that should own the filesystem object, as would be fed to chown. When left unspecified, it uses the current group of the current user unless you are root, in which case it can preserve the previous ownership. |
|
||||||
| **local_follow** | boolean | true | This flag indicates that filesystem links in the source tree, if they exist, should be followed. |
|
| **local_follow** | boolean | true | This flag indicates that filesystem links in the source tree, if they exist, should be followed. |
|
||||||
| **mode** | any | - | The permissions the resulting filesystem object should have. For those used to _/usr/bin/chmod_ remember that modes are actually octal numbers. You must give Ansible enough information to parse them correctly. For consistent results, quote octal numbers (for example, `'644'` or `'1777'`) so Ansible receives a string and can do its own conversion from string into number. Adding a leading zero (for example, `0755`) works sometimes, but can fail in loops and some other circumstances. Giving Ansible a number without following either of these rules will end up with a decimal number which will have unexpected results. As of Ansible 1.8, the mode may be specified as a symbolic mode (for example, `u+rwx` or `u=rw,g=r,o=r`). If `mode` is not specified and the destination filesystem object **does not** exist, the default `umask` on the system will be used when setting the mode for the newly created filesystem object. If `mode` is not specified and the destination filesystem object **does** exist, the mode of the existing filesystem object will be used. |
|
| **mode** | any | - | The permissions the resulting filesystem object should have. For those used to _/usr/bin/chmod_ remember that modes are actually octal numbers. You must give Ansible enough information to parse them correctly. For consistent results, quote octal numbers (for example, `'644'` or `'1777'`) so Ansible receives a string and can do its own conversion from string into number. Adding a leading zero (for example, `0755`) works sometimes, but can fail in loops and some other circumstances. Giving Ansible a number without following either of these rules will end up with a decimal number which will have unexpected results. As of Ansible 1.8, the mode may be specified as a symbolic mode (for example, `u+rwx` or `u=rw,g=r,o=r`). If `mode` is not specified and the destination filesystem object **does not** exist, the default `umask` on the system will be used when setting the mode for the newly created filesystem object. If `mode` is not specified and the destination filesystem object **does** exist, the mode of the existing filesystem object will be used. |
|
||||||
| **owner** | string | - | Name of the user that should own the filesystem object, as would be fed to chown. When left unspecified, it uses the current user unless you are root, in which case it can preserve the previous ownership. Specifying a numeric username will be assumed to be a user ID and not a username. Avoid numeric usernames to avoid this confusion. |
|
| **owner** | string | - | Name of the user that should own the filesystem object, as would be fed to chown. When left unspecified, it uses the current user unless you are root, in which case it can preserve the previous ownership. Specifying a numeric username will be assumed to be a user ID and not a username. Avoid numeric usernames to avoid this confusion. |
|
||||||
| **src** | path | - | Local path to a file to copy to the remote server. This can be absolute or relative. If path is a directory, it is copied recursively. In this case, if path ends with “/”, only inside contents of that directory are copied to destination. Otherwise, if it does not end with “/”, the directory itself with all contents is copied. This behavior is similar to the rsync command line tool. |
|
| **src** | path | - | Local path to a file to copy to the remote server. This can be absolute or relative. If path is a directory, it is copied recursively. In this case, if path ends with “/”, only inside contents of that directory are copied to destination. Otherwise, if it does not end with “/”, the directory itself with all contents is copied. This behavior is similar to the rsync command line tool. |
|
||||||
| **validate** | string | - | The validation command to run before copying the updated file into the final destination. A temporary file path is used to validate, passed in through ‘%s’ which must be present as in the examples below. Also, the command is passed securely so shell features such as expansion and pipes will not work. |
|
| **validate** | string | - | The validation command to run before copying the updated file into the final destination. A temporary file path is used to validate, passed in through ‘%s’ which must be present as in the examples below. Also, the command is passed securely so shell features such as expansion and pipes will not work. |
|
||||||
|
|
||||||
## Return Values
|
## Return Values
|
||||||
| Value | Type | When | Description |
|
| Value | Type | When | Description |
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue