aboutsummaryrefslogtreecommitdiffstats
path: root/src/construct/heading_atx.rs (follow)
Commit message (Collapse)AuthorAgeFilesLines
* Remove unneeded branchLibravatar Titus Wormer2023-05-181-6/+1
|
* Refactor to always resolve edit mapsLibravatar Titus Wormer2022-10-291-0/+1
| | | | This will probably catch some confusing bugs, such as ad1b3e6.
* Remove some unused codeLibravatar Titus Wormer2022-10-131-14/+11
|
* Add support for turning mdast to hastLibravatar Titus Wormer2022-09-281-3/+3
|
* Fix to prefer flow over definitions, setext headingsLibravatar Titus Wormer2022-09-141-2/+5
| | | | | | | | | | | | | | An undocumented part of CommonMark is how to deal with things in definition labels or definition titles (which both can span multiple lines). Can flow (or containers?) interrupt them? They can according to the `cmark` reference parser, so this was implemented here. This adds a new `Content` content type, which houses zero or more definitions, and then zero-or-one paragraphs. Content can be followed by a setext heading underline, which either turns into a setext heading when the content ends in a paragraph, or turns into the start of the following paragraph when it is followed by content that starts with a paragraph, or turns into a stray paragraph.
* Add support for GFM strikethroughLibravatar Titus Wormer2022-08-221-2/+2
|
* Refactor to move more things to `util/`Libravatar Titus Wormer2022-08-191-1/+1
|
* Add `no_std + alloc`Libravatar Titus Wormer2022-08-161-0/+1
|
* Refactor to proof docs, grammarsLibravatar Titus Wormer2022-08-151-12/+20
|
* Refactor to move `content` to `construct`Libravatar Titus Wormer2022-08-151-1/+1
|
* Refactor to attempt less if never neededLibravatar Titus Wormer2022-08-121-10/+14
|
* Refactor to improve enteringLibravatar Titus Wormer2022-08-121-2/+9
|
* Remove `match` statements if clumsyLibravatar Titus Wormer2022-08-121-11/+13
|
* Refactor to improve docs of each functionLibravatar Titus Wormer2022-08-121-4/+4
|
* Refactor attempts to remove unneeded state nameLibravatar Titus Wormer2022-08-111-7/+7
|
* Refactor to move `space_or_tab_eol` to own fileLibravatar Titus Wormer2022-08-111-4/+4
|
* Remove boxes around resolversLibravatar Titus Wormer2022-08-111-1/+2
|
* Refactor to move some code to `event.rs`Libravatar Titus Wormer2022-08-111-32/+32
|
* Refactor to move some code to `state.rs`Libravatar Titus Wormer2022-08-111-14/+15
|
* Add `State::Retry`Libravatar Titus Wormer2022-08-101-6/+6
|
* Rename `State::Fn` to `State::Next`Libravatar Titus Wormer2022-08-101-21/+9
|
* Add support for passing `ok`, `nok` as separate states to attemptsLibravatar Titus Wormer2022-08-091-3/+15
|
* Rewrite algorithm to not pass around boxed functionsLibravatar Titus Wormer2022-08-091-23/+26
| | | | | | * Pass state names from an enum around instead of boxed functions * Refactor to simplify attempts a lot * Use a subtokenizer for the the `document` content type
* Refactor to remove most closuresLibravatar Titus Wormer2022-08-021-9/+13
|
* Fix bug on empty heading (atx)Libravatar Titus Wormer2022-08-011-29/+31
|
* Refactor to improve statesLibravatar Titus Wormer2022-07-291-12/+16
| | | | | | | | | | | | * Remove custom kind wrappers, use plain bytes instead * Remove `Into`s, use the explicit expected types instead * Refactor to use `slice.as_str` in most places * Remove unneeded unique check before adding a definition * Use a shared CDATA prefix in constants * Inline byte checks into matches * Pass bytes back from parser instead of whole parse state * Refactor to work more often on bytes * Rename custom `size` to `len`
* Refactor to work on bytes (`u8`)Libravatar Titus Wormer2022-07-291-8/+8
|
* Refactor to work on `char`sLibravatar Titus Wormer2022-07-281-12/+10
| | | | | | | | | | | | | | | Previously, a custom char implementation was used. This was easier to work with, as sometimes “virtual” characters are injected, or characters are ignored. This replaces that with working on actual `char`s. In the hope of in the future working on `u8`s, even. This simplifies the state machine somewhat, as only `\n` is fed, regardless of whether it was a CRLF, CR, or LF. It also feeds `' '` instead of virtual spaces. The BOM, if present, is now available as a `ByteOrderMark` event.
* Refactor to not pass codes aroundLibravatar Titus Wormer2022-07-251-25/+25
|
* Remove no longer needed field in `State::Ok`Libravatar Titus Wormer2022-07-251-1/+1
|
* Improve performance w/ a single feed loopLibravatar Titus Wormer2022-07-251-1/+1
|
* Refactor to use a single shared edit mapLibravatar Titus Wormer2022-07-221-8/+4
|
* Refactor to remove unneeded tuples in every statesLibravatar Titus Wormer2022-07-221-19/+16
|
* Refactor to pass ints instead of vecs aroundLibravatar Titus Wormer2022-07-221-7/+7
|
* Refactor to move `index` field to `point`Libravatar Titus Wormer2022-07-211-2/+0
|
* Refactor to move some event fields to `link`Libravatar Titus Wormer2022-07-211-6/+2
|
* Refactor to share edit mapLibravatar Titus Wormer2022-07-201-6/+6
|
* Refactor to use less vecs for eventsLibravatar Titus Wormer2022-07-201-2/+2
|
* Refactor to remove cloning in `edit_map`Libravatar Titus Wormer2022-07-191-1/+1
|
* Add support for turning off constructsLibravatar Titus Wormer2022-07-181-3/+12
|
* Refactor examples of statesLibravatar Titus Wormer2022-07-181-10/+13
|
* Refactor to move token types to `token`Libravatar Titus Wormer2022-07-071-20/+19
|
* Refactor code styleLibravatar Titus Wormer2022-07-051-1/+1
|
* Make paragraphs really fastLibravatar Titus Wormer2022-07-011-3/+6
| | | | | | | | | | | | | | | | | | The approach that `micromark-js` takes is as follows: to parse a paragraph, check whether each line starts with something else. If it does, exit, otherwise continue. That is slow, because our actual flow parser does similar things: the work was being done twice. To fix this, this commit introduces parsing each line of a paragraph separately. And finally, when done with flow, combining adjacent paragraphs. This same mechanism is reused for setext headings. Additionally, this commit adds support for interrupting things (or not). E.g., HTML (flow, complete) cannot interrupt paragraphs. Definitions cannot interrupt paragraphs, and connect be interrupted either, but they can follow each other.
* Fix jumps in `edit_map`Libravatar Titus Wormer2022-06-281-25/+82
| | | | | | | | | * Use resolve more often (e.g., heading (atx, setext)) * Fix to link whole phrasing (e.g., one big chunk of text in heading (atx, setext), titles, labels) * Replace `ChunkText`, `ChunkString`, with `event.content_type: Option<ContentType>` * Refactor to externalize `edit_map` from `label`
* Refactor to not use `pub` when not neededLibravatar Titus Wormer2022-06-221-1/+1
|
* Add `attempt_opt` to tokenizerLibravatar Titus Wormer2022-06-221-4/+14
|
* Rename `Whitespace` token to `SpaceOrTab`Libravatar Titus Wormer2022-06-221-3/+3
|
* Add docs for token typesLibravatar Titus Wormer2022-06-221-0/+7
|
* Add improved whitespace handlingLibravatar Titus Wormer2022-06-201-29/+23
| | | | | | * add several helpers for parsing betwen x and y `space_or_tab`s * use those helpers in a bunch of places * move initial indent parsing to flow constructs themselves