Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | Add support for GFM footnotes | Titus Wormer | 2022-08-25 | 1 | -6/+6 |
| | |||||
* | Add support for GFM strikethrough | Titus Wormer | 2022-08-22 | 1 | -1/+1 |
| | |||||
* | Refactor to proof docs, grammars | Titus Wormer | 2022-08-15 | 1 | -17/+25 |
| | |||||
* | Refactor to move `content` to `construct` | Titus Wormer | 2022-08-15 | 1 | -2/+2 |
| | |||||
* | Refactor to attempt less if never needed | Titus Wormer | 2022-08-12 | 1 | -37/+55 |
| | |||||
* | Refactor to improve docs of each function | Titus Wormer | 2022-08-12 | 1 | -12/+12 |
| | |||||
* | Refactor attempts to remove unneeded state name | Titus Wormer | 2022-08-11 | 1 | -31/+20 |
| | |||||
* | Refactor to handle definitions when parsing | Titus Wormer | 2022-08-11 | 1 | -3/+34 |
| | |||||
* | Refactor to move `space_or_tab_eol` to own file | Titus Wormer | 2022-08-11 | 1 | -16/+17 |
| | |||||
* | Refactor to move some code to `event.rs` | Titus Wormer | 2022-08-11 | 1 | -56/+56 |
| | |||||
* | Refactor to move some code to `state.rs` | Titus Wormer | 2022-08-11 | 1 | -21/+22 |
| | |||||
* | Refactor internal docs, code style of tokenizer | Titus Wormer | 2022-08-11 | 1 | -4/+9 |
| | |||||
* | Rename `State::Fn` to `State::Next` | Titus Wormer | 2022-08-10 | 1 | -26/+26 |
| | |||||
* | Add support for passing `ok`, `nok` as separate states to attempts | Titus Wormer | 2022-08-09 | 1 | -16/+43 |
| | |||||
* | Rewrite algorithm to not pass around boxed functions | Titus Wormer | 2022-08-09 | 1 | -33/+39 |
| | | | | | | * 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 closures | Titus Wormer | 2022-08-02 | 1 | -45/+50 |
| | |||||
* | Refactor to improve states | Titus Wormer | 2022-07-29 | 1 | -10/+11 |
| | | | | | | | | | | | | * 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`) | Titus Wormer | 2022-07-29 | 1 | -4/+4 |
| | |||||
* | Refactor to work on `char`s | Titus Wormer | 2022-07-28 | 1 | -5/+5 |
| | | | | | | | | | | | | | | | 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 around | Titus Wormer | 2022-07-25 | 1 | -30/+27 |
| | |||||
* | Remove no longer needed field in `State::Ok` | Titus Wormer | 2022-07-25 | 1 | -2/+2 |
| | |||||
* | Improve performance w/ a single feed loop | Titus Wormer | 2022-07-25 | 1 | -4/+2 |
| | |||||
* | Refactor to remove unneeded tuples in every states | Titus Wormer | 2022-07-22 | 1 | -25/+22 |
| | |||||
* | Refactor to pass ints instead of vecs around | Titus Wormer | 2022-07-22 | 1 | -8/+8 |
| | |||||
* | Add support for turning off constructs | Titus Wormer | 2022-07-18 | 1 | -3/+3 |
| | |||||
* | Refactor examples of states | Titus Wormer | 2022-07-18 | 1 | -32/+38 |
| | |||||
* | Refactor to move token types to `token` | Titus Wormer | 2022-07-07 | 1 | -33/+34 |
| | |||||
* | Refactor code style | Titus Wormer | 2022-07-05 | 1 | -2/+2 |
| | |||||
* | Make paragraphs really fast | Titus Wormer | 2022-07-01 | 1 | -2/+15 |
| | | | | | | | | | | | | | | | | | | 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. | ||||
* | Refactor to reorder token types | Titus Wormer | 2022-07-01 | 1 | -4/+4 |
| | |||||
* | Refactor to clean and document `space_or_tab` | Titus Wormer | 2022-07-01 | 1 | -3/+3 |
| | |||||
* | Refactor some docs, fix some grammar | Titus Wormer | 2022-06-30 | 1 | -4/+4 |
| | |||||
* | Fix a bunch of bugs with definitions, references | Titus Wormer | 2022-06-29 | 1 | -1/+1 |
| | | | | | | | | | * Fix bug where whitespace after `:` was not allowed, it is * Fix bug where escapes in labels did not work due to typo * Fix to prefer first definition * Fix whitespace after definitions * Fix matching by adding normalizing * Fix reference from being output as data | ||||
* | Add some more crosslinks to docs | Titus Wormer | 2022-06-28 | 1 | -13/+10 |
| | |||||
* | Add docs to label end | Titus Wormer | 2022-06-28 | 1 | -22/+6 |
| | |||||
* | Add link, images (resource) | Titus Wormer | 2022-06-24 | 1 | -102/+34 |
| | | | | | | | | | | | | This is still some messy code that needs cleaning up, but it adds support for links and images, of the resource kind (`[a](b)`). References (`[a][b]`) are parsed and will soon be supported, but need matching. * Fix bug to pad percent-encoded bytes when normalizing urls * Fix bug with escapes counting as balancing in destination * Add `space_or_tab_one_line_ending`, to parse whitespace including up to one line ending (but not a blank line) * Add `ParserState` to share codes, definitions, etc | ||||
* | Refactor to not use `pub` when not needed | Titus Wormer | 2022-06-22 | 1 | -1/+1 |
| | |||||
* | Add docs on normalizing identifiers, matching | Titus Wormer | 2022-06-22 | 1 | -7/+37 |
| | |||||
* | Add support for normalizing identifiers | Titus Wormer | 2022-06-22 | 1 | -5/+0 |
| | |||||
* | Add docs on encoding to definition, destination | Titus Wormer | 2022-06-22 | 1 | -1/+9 |
| | |||||
* | Add `attempt_opt` to tokenizer | Titus Wormer | 2022-06-22 | 1 | -9/+11 |
| | |||||
* | Rename `Whitespace` token to `SpaceOrTab` | Titus Wormer | 2022-06-22 | 1 | -3/+3 |
| | |||||
* | Add docs for token types | Titus Wormer | 2022-06-22 | 1 | -0/+18 |
| | |||||
* | Add support for capping destination (raw) balance | Titus Wormer | 2022-06-21 | 1 | -0/+1 |
| | |||||
* | Add support for passing token types to destination, label, title | Titus Wormer | 2022-06-21 | 1 | -5/+48 |
| | |||||
* | Refactor to improve a bunch of states | Titus Wormer | 2022-06-21 | 1 | -7/+5 |
| | | | | | | * Improve passing stuff around * Add traits to enums for markers and such * Fix “life time” stuff I didn’t understand | ||||
* | Add improved whitespace handling | Titus Wormer | 2022-06-20 | 1 | -64/+32 |
| | | | | | | * 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 | ||||
* | Add paragraph | Titus Wormer | 2022-06-20 | 1 | -1/+4 |
| | |||||
* | Remove unneeded `pub` keywords | Titus Wormer | 2022-06-20 | 1 | -23/+14 |
| | |||||
* | Add docs to destination, label, title | Titus Wormer | 2022-06-20 | 1 | -1/+1 |
| |