mirror of
https://github.com/typst/typst
synced 2025-08-08 04:07:56 +08:00
support sub enum
This commit is contained in:
parent
e7ebdb15dc
commit
897de73e3e
@ -107,15 +107,13 @@ fn markup_expr(p: &mut Parser, at_start: bool, nesting: &mut usize) {
|
|||||||
SyntaxKind::Star => strong(p),
|
SyntaxKind::Star => strong(p),
|
||||||
SyntaxKind::Underscore => emph(p),
|
SyntaxKind::Underscore => emph(p),
|
||||||
SyntaxKind::HeadingMarker if at_start => heading(p),
|
SyntaxKind::HeadingMarker if at_start => heading(p),
|
||||||
SyntaxKind::ListMarker if at_start => list_item(p),
|
SyntaxKind::ListMarker => list_item(p),
|
||||||
SyntaxKind::EnumMarker if at_start => enum_item(p),
|
SyntaxKind::EnumMarker => enum_item(p),
|
||||||
SyntaxKind::TermMarker if at_start => term_item(p),
|
SyntaxKind::TermMarker if at_start => term_item(p),
|
||||||
SyntaxKind::RefMarker => reference(p),
|
SyntaxKind::RefMarker => reference(p),
|
||||||
SyntaxKind::Dollar => equation(p),
|
SyntaxKind::Dollar => equation(p),
|
||||||
|
|
||||||
SyntaxKind::HeadingMarker
|
SyntaxKind::HeadingMarker
|
||||||
| SyntaxKind::ListMarker
|
|
||||||
| SyntaxKind::EnumMarker
|
|
||||||
| SyntaxKind::TermMarker
|
| SyntaxKind::TermMarker
|
||||||
| SyntaxKind::Colon => p.convert_and_eat(SyntaxKind::Text),
|
| SyntaxKind::Colon => p.convert_and_eat(SyntaxKind::Text),
|
||||||
|
|
||||||
@ -157,7 +155,14 @@ fn heading(p: &mut Parser) {
|
|||||||
|
|
||||||
/// Parses an item in a bullet list: `- ...`.
|
/// Parses an item in a bullet list: `- ...`.
|
||||||
fn list_item(p: &mut Parser) {
|
fn list_item(p: &mut Parser) {
|
||||||
p.with_nl_mode(AtNewline::RequireColumn(p.current_column()), |p| {
|
let mut column = 0;
|
||||||
|
for i in (0..p.current_start()).rev() {
|
||||||
|
if p.text.chars().nth(i) == Some('\n') {
|
||||||
|
column = i;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
p.with_nl_mode(AtNewline::RequireColumn(p.current_start() - column), |p| {
|
||||||
let m = p.marker();
|
let m = p.marker();
|
||||||
p.assert(SyntaxKind::ListMarker);
|
p.assert(SyntaxKind::ListMarker);
|
||||||
markup(p, false, false, syntax_set!(RightBracket, End));
|
markup(p, false, false, syntax_set!(RightBracket, End));
|
||||||
@ -167,7 +172,14 @@ fn list_item(p: &mut Parser) {
|
|||||||
|
|
||||||
/// Parses an item in an enumeration (numbered list): `+ ...` or `1. ...`.
|
/// Parses an item in an enumeration (numbered list): `+ ...` or `1. ...`.
|
||||||
fn enum_item(p: &mut Parser) {
|
fn enum_item(p: &mut Parser) {
|
||||||
p.with_nl_mode(AtNewline::RequireColumn(p.current_column()), |p| {
|
let mut column = 0;
|
||||||
|
for i in (0..p.current_start()).rev() {
|
||||||
|
if p.text.chars().nth(i) == Some('\n') {
|
||||||
|
column = i;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
p.with_nl_mode(AtNewline::RequireColumn(p.current_start() - column), |p| {
|
||||||
let m = p.marker();
|
let m = p.marker();
|
||||||
p.assert(SyntaxKind::EnumMarker);
|
p.assert(SyntaxKind::EnumMarker);
|
||||||
markup(p, false, false, syntax_set!(RightBracket, End));
|
markup(p, false, false, syntax_set!(RightBracket, End));
|
||||||
|
@ -192,3 +192,15 @@ a + 0.
|
|||||||
+ f
|
+ f
|
||||||
#align(right)[+ align]
|
#align(right)[+ align]
|
||||||
+ h
|
+ h
|
||||||
|
|
||||||
|
|
||||||
|
--- issue-5719-sub-enum-numbering ---
|
||||||
|
#set enum(numbering: "(a)")
|
||||||
|
|
||||||
|
+ first main
|
||||||
|
+ + first sub
|
||||||
|
+ second sub
|
||||||
|
|
||||||
|
- first main
|
||||||
|
- - first sub
|
||||||
|
- second sub
|
||||||
|
Loading…
x
Reference in New Issue
Block a user