diff --git a/technology/applications/cli/fd.md b/technology/applications/cli/fd.md index c72ff9d..995bae8 100644 --- a/technology/applications/cli/fd.md +++ b/technology/applications/cli/fd.md @@ -4,20 +4,38 @@ os: linux repo: https://github.com/sharkdp/fd --- # fd -#refactor `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 -Flags: -```shell --H, --hidden Include hidden files --d, --max-depth Limit recursion --e, --extension Search by extension --x, --exec ... Execute command for every search result. -The following placeholders are substituted before the command is executed: -'{}':   path (of the current search result) -'{/}':  basename -'{//}': parent directory -'{.}':  path without file extension -'{/.}': basename without file extension -``` \ No newline at end of file +Usage: `fd [OPTIONS] [pattern] [path]...` + +### Options +| Option | Description | +| ----------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `-H, --hidden` | Include hidden directories and files in the search results | +| `-I, --no-ignore` | Show search results from files and directories that would otherwise be ignored by `.gitignore`, `.ignore`, `.fdignore` | +| `-u, --unrestricted` | Perform an unrestricted search, including ignored and hidden files. This is an alias for `--no-ignore --hidden`. | +| `-s, --case-sensitive` | Perform a case-sensitive search. By default, fd uses case-insensitive searches, unless the pattern contains an uppercase character (smart case). | +| `-i, --ignore-case` | Perform a case-insensitive search. By default, fd uses case-insensitive searches, unless the pattern contains an uppercase character (smart case). | +| `-l, --list-details` | Use a detailed listing format like `ls -l`. This is basically an alias for `--exec-batch ls -l` with some additional `ls` options. This can be used to see more metadata, to show symlink targets and to achieve a deterministic sort order. | +| `-L, --follow` | By default, fd does not descend into symlinked directories. Using this flag, symbolic links are also traversed. Flag can be overriden with `--no-follow`. | +| `-0, --print0` | Separate search results by the null character (instead of newlines). Useful for piping results to `xargs`. | +| `-d, --max-depth ` | Limit the directory traversal to a given depth. By default, there is no limit on the search depth. | +| `--min-depth ` | Only show search results starting at the given depth. | +| `--exact-depth ` | Only show search results at the exact given depth. This is an alias for `--min-depth --max-depth `. | +| `-E, --exclude ` | Exclude files/directories that match the given glob pattern. This overrides any other ignore logic. Multiple exclude patterns can be specified. | +| `-t, --type ` | Filter the search by type:
- `f` or `file`: regular files
- `d` or `directory`: directories
- `l` or `symlink`: symbolic links
- `s` or `socket`: socket
- `p` or `pipe`: named pipe (FIFO)
- `x` or `executable`: executables
- `e` or `empty`: empty files or directories

This option can be specified more than once to include multiple file types. | +| `-e, --extension ` | (Additionally) filter search results by their file extension. Multiple allowable file extensions can be specified. | +| `-S, --size ` | Limit results based on the size of files using the format `<+->`.
- `+`: file size must be greater than or equal to this
- `-`: file size must be less than or equal to this
If neither `+` nor `-` is specified, file size must be exactly equal to this. | +| `--changed-within ` | Filter results based on the file modification time. Files with modification times greater than the argument are returned. The argument can be provided as a specific point in time (`YYYY-MM-DD HH:MM:SS`) or as a duration (`10h`, `1d`, `35min`). If the time is not specified, it defaults to `00:00:00`. `--change-newer-than`, `--newer`, or `--changed-after` can be used as aliases.

Examples:
- `--changed-within 2weeks`
- `--change-newer-than '2018-10-27 10:00:00'`
- `--newer 2018-10-27`
- `--changed-after 1day` | +| `--changed-before ` | Filter results based on the file modification time. Files with modification times less than the argument are returned. | +| `-o, --owner ` | Filter files by their user and/or group. Format: `[(user/uid)][:(group/gid)]`. Either side is optional. Precede either side with a `!` to exclude files instead.

Examples:
- `--owner john`
- `--owner :students`
- `--owner '!john:students'` | +| `-x, --exec ...` | Execute a command for each search result in parallel (use `--threads=1` for sequential command execution). All positional arguments following `--exec` are considered to be arguments to the command - not to fd. It is therefore recommended to place the `-x`/`--exec` option last.

The following placeholders are substituted before the command is executed:
- `{}`: path (of the current search result)
- `{/}`: basename
- `{//}`: parent directory
- `{.}`: path without file extension
- `{/.}`: basename without file extension

If no placeholder is present, an implicit `{}` at the end is assumed. | +| `-X, --exec-batch ...` | Execute the given command once, with all search results as arguments. One of the following placeholders is substituted before the command is executed:

- `{}`: path (of all search results)
- `{/}`: basename
- `{//}`: parent directory
- `{.}`: path without file extension
- `{/.}`: basename without file extension

If no placeholder is present, an implicit `{}` at the end is assumed. | +| `--batch-size ` | Maximum number of arguments to pass to the command given with `-X`. If the number of results is greater than the given size, the command given with `-X` is run again with remaining arguments. A batch size of zero means there is no limit (default), but note that batching might still happen due to OS restrictions on the maximum length of command lines. | +| `--ignore-file ` | Add a custom ignore-file in `.gitignore` format. These files have a low precedence. | +| `-j, --threads ` | Set number of threads to use for searching & executing (default: number of available CPU cores) | +| `--max-results ` | Limit the number of search results to `count` and quit immediately. | +| `-1` | Limit the search to a single result and quit immediately. This is an alias for `--max-results=1`. | +| `-q, --quiet` | When the flag is present, the program does not print anything and will return with an exit code of 0 if there is at least one match. Otherwise, the exit code will be 1. | +| `--one-file-system` | By default, fd will traverse the file system tree as far as other options dictate. With this flag, fd ensures that it does not descend into a different file system than the one it started in. | diff --git a/technology/applications/cli/ripgrep.md b/technology/applications/cli/ripgrep.md index 2def3fc..c8d971b 100644 --- a/technology/applications/cli/ripgrep.md +++ b/technology/applications/cli/ripgrep.md @@ -4,7 +4,43 @@ os: - linux repo: https://github.com/BurntSushi/ripgrep --- + # ripgrep -#refactor -[Repo](https://github.com/BurntSushi/ripgrep) -ripgrep is a line-oriented search tool that recursively searches the current directory for a regex 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. \ No newline at end of file +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 +```shell +rg [OPTIONS] PATTERN [PATH ...] +rg [OPTIONS] -e PATTERN ... [PATH ...] +rg [OPTIONS] -f PATTERNFILE ... [PATH ...] +``` + +### Options +| Option | Description | +| ------------------------------------ | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `-e PATTERN, --regexp=PATTERN` | A pattern to search for. This option can be provided multiple times, where all patterns given are searched, in addition to any patterns provided by `-f/--file`. Lines matching at least one of the provided patterns are printed. | +| `-f PATTERNFILE, --file=PATTERNFILE` | Search for patterns from the given file, with one pattern per line. When this flag is used multiple times or in combination with the `-e/--regexp` flag, then all patterns provided are searched. Empty pattern lines will match all input lines, and the newline is not counted as part of the pattern. | +| `--pre=COMMAND` | For each input `PATH`, this flag causes ripgrep to search the standard output of ` ` instead of the contents of `PATH`. This option expects the `COMMAND` program to either be a path or to be available in your `$PATH`. | +| `-z, --search-zip` | This flag instructs ripgrep to search in compressed files. | +| `-s, --case-sensitive` | Execute the search case sensitively. This is the default mode. | +| `-i, --ignore-case` | When this flag is provided, all patterns will be searched case insensitively. | +| `-v, --invert-match` | This flag inverts matching. That is, instead of printing lines that match, ripgrep will print lines that don't match. | +| `-x, --line-regexp` | When enabled, ripgrep will only show matches surrounded by line boundaries. This is equivalent to surrounding every pattern with `^` and `$`. In other words, this only prints lines where the entire line participates in a match. | +| `-m NUM, --max-count=NUM` | Limit the number of matching lines per file searched to NUM. | +| `-U, --multiline` | This flag enable searching across multiple lines. | +| `-S, --smart-case` | This flag instructs ripgrep to searches case insensitively if the pattern is all lowercase. Otherwise, ripgrep will search case sensitively. | +| `--stop-on-nonmatch` | Enabling this option will cause ripgrep to stop reading a file once it encounters a non-matching line after it has encountered a matching line. This is useful if it is expected that all matches in a given file will be on sequential lines, for example due to the lines being sorted. | +| `-j NUM, --threads=NUM` | This flag sets the approximate number of threads to use. A value of 0 (which is the default) causes ripgrep to choose the thread count using heuristics. | +| `-L, --follow` | This flag instructs ripgrep to follow symbolic links while traversing directories. This behavior is disabled by default.
This flag can be disabled with `--no-follow`. | +| `-., --hidden` | Search hidden files and directories. By default, hidden files and directories are skipped. Note that if a hidden file or a directory is whitelisted in an ignore file, then it will be searched even if this flag isn't provided. Similarly if a hidden file or directory is given explicitly as an argumnet to ripgrep.
This flag can be disabled with `--no-hidden`. | +| `-g GLOB, --glob=GLOB` | Include or exclude files and directories for searching that match the given glob. This always overrides any other ignore logic. Multiple glob flags may be used. Globbing rules match `.gitignore` globs. Precede a glob with a `!` to exclude it. If multiple globs match a file or directory, the glob given later in the command line takes precedence. | +| `--ignore-file=PATH` | Specifies a path to one or more gitignore formatted rules files. These patterns are applied after the patterns found in `.gitignore`, `.rgignore` and `.ignore` are applied and are matched relative to the current working directory. Multiple additional ignore files can be specified by using this flag repeatedly. When specifying multiple ignore files, earlier files have lower precedence than later files. | +| `-d NUM, --max-depth=NUM` | This flag limits the depth of directory traversal to NUM levels beyond the paths given. A value of 0 only searches the explicitly given paths themselves. | +| `-A NUM, --after-context=NUM` | Show NUM lines after each match. | +| `-B NUM, --before-context=NUM` | Show NUM lines before each match. | +| `-C NUM, --context=NUM` | Show NUM lines before and after each match. This is equivalent to providing both the `-B/--before-context` and `-A/--after-context` flags with the same value. | +| `-c, --count` | This flag suppresses normal output and shows the number of lines that match the given patterns for each file searched. Each file containing a match has its path and count printed on each line. | +| `--count-matches` | This flag suppresses normal output and shows the number of individual matches of the given patterns for each file searched. Each file containing matches has its path and match count printed on each line. Note that this reports the total number of individual matches and not the number of lines that match. | +| `-l, --files-with-matches` | Print only the paths with at least one match and suppress match contents. | +| `--files-without-match` | Print the paths that contain zero matches and suppress match contents. | +| `--json` | Enable printing results in a [JSON](../../files/JSON.md) Lines format. When this flag is provided, ripgrep will emit a sequence of messages, each encoded as a [JSON](../../files/JSON.md) object. | diff --git a/technology/files/JSON.md b/technology/files/JSON.md index 4793ca9..1f022c5 100644 --- a/technology/files/JSON.md +++ b/technology/files/JSON.md @@ -4,11 +4,12 @@ obj: concept --- # JSON -#refactor JSON (JavaScript Object Notation) is a lightweight data interchange format that is easy for humans to read and write and easy for machines to parse and generate. It is often used for exchanging data between a web server and a web application, as well as between different programming languages. JSON is commonly used in web development to transfer data between a web server and a web application. For example, when a web application makes a request to a web server, the server might respond with a JSON object or array containing the requested data. +Some technologies have been built on top of JSON like [JWT](../internet/JWT.md), [JSONPatch](../tools/JSONPatch.md) or [JSON Schema](../tools/JSON%20Schema.md). + ## JSON Syntax JSON is built on two structures: objects and arrays. An object is an unordered set of key/value pairs, while an array is an ordered collection of values. diff --git a/technology/tools/GPG.md b/technology/tools/GPG.md index 98e7253..98338b6 100644 --- a/technology/tools/GPG.md +++ b/technology/tools/GPG.md @@ -6,8 +6,6 @@ obj: application # GPG gpg is the OpenPGP part of the GNU Privacy Guard (GnuPG). It is a tool to provide digital encryption and signing services using the OpenPGP standard. gpg features complete key management and all the bells and whistles you would expect from a full OpenPGP implementation. -#refactor add options + refactor - ## Commands **Sign:**