summaryrefslogtreecommitdiffstats
path: root/vendor/indoc/README.md
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
commit698f8c2f01ea549d77d7dc3338a12e04c11057b9 (patch)
tree173a775858bd501c378080a10dca74132f05bc50 /vendor/indoc/README.md
parentInitial commit. (diff)
downloadrustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.tar.xz
rustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.zip
Adding upstream version 1.64.0+dfsg1.upstream/1.64.0+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'vendor/indoc/README.md')
-rw-r--r--vendor/indoc/README.md150
1 files changed, 150 insertions, 0 deletions
diff --git a/vendor/indoc/README.md b/vendor/indoc/README.md
new file mode 100644
index 000000000..795d5ab86
--- /dev/null
+++ b/vendor/indoc/README.md
@@ -0,0 +1,150 @@
+Indented Documents (indoc)
+==========================
+
+[<img alt="github" src="https://img.shields.io/badge/github-dtolnay/indoc-8da0cb?style=for-the-badge&labelColor=555555&logo=github" height="20">](https://github.com/dtolnay/indoc)
+[<img alt="crates.io" src="https://img.shields.io/crates/v/indoc.svg?style=for-the-badge&color=fc8d62&logo=rust" height="20">](https://crates.io/crates/indoc)
+[<img alt="docs.rs" src="https://img.shields.io/badge/docs.rs-indoc-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo=" height="20">](https://docs.rs/indoc)
+[<img alt="build status" src="https://img.shields.io/github/workflow/status/dtolnay/indoc/CI/master?style=for-the-badge" height="20">](https://github.com/dtolnay/indoc/actions?query=branch%3Amaster)
+
+This crate provides a procedural macro for indented string literals. The
+`indoc!()` macro takes a multiline string literal and un-indents it at compile
+time so the leftmost non-space character is in the first column.
+
+```toml
+[dependencies]
+indoc = "1.0"
+```
+
+*Compiler requirement: rustc 1.45 or greater.*
+
+<br>
+
+## Using indoc
+
+```rust
+use indoc::indoc;
+
+fn main() {
+ let testing = indoc! {"
+ def hello():
+ print('Hello, world!')
+
+ hello()
+ "};
+ let expected = "def hello():\n print('Hello, world!')\n\nhello()\n";
+ assert_eq!(testing, expected);
+}
+```
+
+Indoc also works with raw string literals:
+
+```rust
+use indoc::indoc;
+
+fn main() {
+ let testing = indoc! {r#"
+ def hello():
+ print("Hello, world!")
+
+ hello()
+ "#};
+ let expected = "def hello():\n print(\"Hello, world!\")\n\nhello()\n";
+ assert_eq!(testing, expected);
+}
+```
+
+And byte string literals:
+
+```rust
+use indoc::indoc;
+
+fn main() {
+ let testing = indoc! {b"
+ def hello():
+ print('Hello, world!')
+
+ hello()
+ "};
+ let expected = b"def hello():\n print('Hello, world!')\n\nhello()\n";
+ assert_eq!(testing[..], expected[..]);
+}
+```
+
+<br>
+
+## Formatting macros
+
+The indoc crate exports four additional macros to substitute conveniently for
+the standard library's formatting macros:
+
+- `formatdoc!($fmt, ...)`&ensp;&mdash;&ensp;equivalent to `format!(indoc!($fmt), ...)`
+- `printdoc!($fmt, ...)`&ensp;&mdash;&ensp;equivalent to `print!(indoc!($fmt), ...)`
+- `eprintdoc!($fmt, ...)`&ensp;&mdash;&ensp;equivalent to `eprint!(indoc!($fmt), ...)`
+- `writedoc!($dest, $fmt, ...)`&ensp;&mdash;&ensp;equivalent to `write!($dest, indoc!($fmt), ...)`
+
+```rust
+use indoc::printdoc;
+
+fn main() {
+ printdoc! {"
+ GET {url}
+ Accept: {mime}
+ ",
+ url = "http://localhost:8080",
+ mime = "application/json",
+ }
+}
+```
+
+<br>
+
+## Explanation
+
+The following rules characterize the behavior of the `indoc!()` macro:
+
+1. Count the leading spaces of each line, ignoring the first line and any lines
+ that are empty or contain spaces only.
+2. Take the minimum.
+3. If the first line is empty i.e. the string begins with a newline, remove the
+ first line.
+4. Remove the computed number of spaces from the beginning of each line.
+
+<br>
+
+## Unindent
+
+Indoc's indentation logic is available in the `unindent` crate. This may be
+useful for processing strings that are not statically known at compile time.
+
+The crate exposes two functions:
+
+- `unindent(&str) -> String`
+- `unindent_bytes(&[u8]) -> Vec<u8>`
+
+```rust
+use unindent::unindent;
+
+fn main() {
+ let indented = "
+ line one
+ line two";
+ assert_eq!("line one\nline two", unindent(indented));
+}
+```
+
+<br>
+
+#### License
+
+<sup>
+Licensed under either of <a href="LICENSE-APACHE">Apache License, Version
+2.0</a> or <a href="LICENSE-MIT">MIT license</a> at your option.
+</sup>
+
+<br>
+
+<sub>
+Unless you explicitly state otherwise, any contribution intentionally submitted
+for inclusion in this crate by you, as defined in the Apache-2.0 license, shall
+be dual licensed as above, without any additional terms or conditions.
+</sub>