A library that allows a user to extract an arbitrary number of lines of "front-matter" from the start of any multiline string.
Note that absolutely no parsing of extracted front-matter is performed; this is designed to output its results for another library to then parse.
This project follows Semantic Versioning principals starting with v1.0.0
To use this library:
Extractor
extract()
(for a String
), orcollect()
(for a Vec<&str>
)| Method | Description |
| ---------------------------------------- | ---------------------------------------------------------------- |
| select_by_terminator(terminator: &str)
| Selects lines until the first one equal to terminator
is found |
| select_by_prefix(prefix: &str)
| Selects consecutive lines starting with prefix
|
| select_by_line_count(count: usize)
| Selects count
lines |
| Method | Description |
| ---------------------------- | -------------------------------------------------------------- |
| strip_prefix(prefix: &str)
| Strips the given prefix
from all returned lines |
| strip_whitespace()
| Strips leading and trailing whitespace from all returned lines |
| discard_first_line()
| Skips the first line to be returned |
| discard_last_line()
| Skips the last line to be returned |
Given a variable input
with the following text:
```md root: child1: true
This is an example Markdown file. ```
... and the following code:
```rust use extract_frontmatter::Extractor;
let mut extractor = Extractor::new(input); extractor.selectbyterminator("---");
let output: String = extractor.extract(); ```
... the variable output
will contain:
yml
root:
child1: true
child2: two