aboutsummaryrefslogtreecommitdiffstats
path: root/src/event.rs (unfollow)
Commit message (Collapse)AuthorFilesLines
2022-08-22Add support for GFM task list itemLibravatar Titus Wormer1-1/+78
2022-08-22Add support for GFM strikethroughLibravatar Titus Wormer1-2/+57
2022-08-18Add support for GFM autolink literalsLibravatar Titus Wormer1-89/+180
2022-08-16Add support for frontmatterLibravatar Titus Wormer1-1/+91
2022-08-15Refactor to proof docs, grammarsLibravatar Titus Wormer1-4/+10
2022-08-15Add missing mark of `SpaceOrTab` as void eventLibravatar Titus Wormer1-1/+2
2022-08-15Add derive of `Eq` where possibleLibravatar Titus Wormer1-6/+6
2022-08-15Refactor to move `content` to `construct`Libravatar Titus Wormer1-47/+47
2022-08-15Refactor to rename list construct to list itemLibravatar Titus Wormer1-6/+6
2022-08-12Refactor to improve enteringLibravatar Titus Wormer1-1/+1
2022-08-12Refactor to improve docs of each functionLibravatar Titus Wormer1-3/+7
2022-08-11Refactor to move `space_or_tab_eol` to own fileLibravatar Titus Wormer1-182/+182
2022-08-11Refactor to move some code to `event.rs`Libravatar Titus Wormer1-43/+101
2022-07-28Refactor to work on `char`sLibravatar Titus Wormer1-1/+13
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.
2022-07-26Refactor to drastically improve perf around whitespaceLibravatar Titus Wormer1-43/+5
2022-07-18Remove unneeded tokenLibravatar Titus Wormer1-22/+2
2022-07-18Fix token that should be voidLibravatar Titus Wormer1-0/+44
2022-07-15Remove unneeded tokenLibravatar Titus Wormer1-20/+1
2022-07-15Refactor to sort, document lists in tokenLibravatar Titus Wormer1-9/+130
2022-07-12Fix a lot of list thingsLibravatar Titus Wormer1-1/+3
* Add `ListItem`, `ListOrdered`, and `ListUnordered` tokens * Add support for multiline list items * Add support for tight lists * Fix bug where 10 digit long list item values worked * Fix skip bug when skipping over nested events
2022-07-12Add initial support for listsLibravatar Titus Wormer1-0/+7
2022-07-07Refactor to move token types to `token`Libravatar Titus Wormer1-883/+169
2022-07-07Fix some small to dosLibravatar Titus Wormer1-1/+2
2022-07-07Add docs for block quote tokensLibravatar Titus Wormer1-1/+76
2022-07-07Fix order of tokensLibravatar Titus Wormer1-77/+77
2022-07-07Add basic support for block quotesLibravatar Titus Wormer1-12/+26
2022-07-07Add support for `Flow` content typeLibravatar Titus Wormer1-0/+2
2022-07-07Add `go_until` to tokenizerLibravatar Titus Wormer1-7/+37
2022-07-05Refactor to do some to dosLibravatar Titus Wormer1-18/+130
2022-07-05Refactor code styleLibravatar Titus Wormer1-78/+0
2022-07-04Add support for unicode punctuationLibravatar Titus Wormer1-1/+1
2022-07-04Update list of todosLibravatar Titus Wormer1-2/+0
2022-07-04Add support for attention (emphasis, strong)Libravatar Titus Wormer1-0/+9
2022-07-01Make paragraphs really fastLibravatar Titus Wormer1-0/+3
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.
2022-06-30Add support for trimming whitespace around string, textLibravatar Titus Wormer1-1/+8
This commit introduces trimming initial and final whitespace around the whole string or text, or around line endings inside that string or text. * Add `register_resolver_before`, to run resolvers earlier than others, used for labels * Add resolver to merge `data` events, which are the most frequent token that occurs, and can happen adjacently. In `micromark-js` this sped up parsing a lot * Fix a bug where a virtual space was not seen as an okay event * Refactor to enable all turned off whitespace tests
2022-06-30Add docs on resolver, clean feedLibravatar Titus Wormer1-77/+97
2022-06-30Refactor to reorder token typesLibravatar Titus Wormer1-303/+303
2022-06-30Add docs to image, link, and other media tokensLibravatar Titus Wormer1-16/+434
2022-06-29Refactor to externalize handlers of compilerLibravatar Titus Wormer1-1/+1
2022-06-28Fix jumps in `edit_map`Libravatar Titus Wormer1-33/+16
* 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`
2022-06-24Add link, images (resource)Libravatar Titus Wormer1-5/+106
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
2022-06-22Refactor some unneeded assignmentsLibravatar Titus Wormer1-3/+1
2022-06-22Add `attempt_opt` to tokenizerLibravatar Titus Wormer1-35/+30
2022-06-22Rename `Whitespace` token to `SpaceOrTab`Libravatar Titus Wormer1-15/+15
2022-06-22Refactor to improve tokenizer, add docsLibravatar Titus Wormer1-144/+58
2022-06-22Add docs for token typesLibravatar Titus Wormer1-6/+1102
2022-06-21Add support for passing token types to destination, label, titleLibravatar Titus Wormer1-1/+1
2022-06-21Refactor to improve a bunch of statesLibravatar Titus Wormer1-0/+1
* Improve passing stuff around * Add traits to enums for markers and such * Fix “life time” stuff I didn’t understand
2022-06-21Update todo listLibravatar Titus Wormer1-16/+23
2022-06-21Add support for inferring line ending, configurableLibravatar Titus Wormer1-2/+4
* Rename `CompileOptions` to `Options` * Add support for an optional default line ending style * Add support for inferring the used line ending style