1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
// use itertools::Itertools;
// use tracing::debug;
// use tracing::instrument;
// use typst::syntax::SyntaxKind;
// use typst::syntax::SyntaxKind::*;
// use typst::syntax::{parse, LinkedNode};
// use Option::None;
// mod config;
// pub use config::Config;
// mod utils;
// mod content_blocks;
// //formatting stuff starts here
// mod args;
// mod code_blocks;
// mod context;
// use context::Ctx;
// pub fn format(s: &str, config: Config) -> String {
//     let init = parse(s);
//     let mut context = Ctx::from_config(config);
//     let root = LinkedNode::new(&init);
//     visit(&root, &mut context)
// }
// /// This is recursively called on the AST, the formatting is bottom up,
// /// nodes will decide based on the size of their children and the max line length
// /// how they will be formatted.
// ///
// /// One assumed rule is that no kind should be formatting with surrounded space
// #[instrument(skip_all,name = "V" , ret, fields(kind = format!("{:?}",node.kind())))]
// fn visit(node: &LinkedNode, ctx: &mut Ctx) -> String {
//     let mut res: Vec<String> = vec![];
//     for child in node.children() {
//         let child_fmt = visit(&child, ctx);
//         res.push(child_fmt);
//     }
//     let res = match node.kind() {
//         Named => format_named_args(node, &res, ctx),
//         CodeBlock => code_blocks::format_code_blocks(node, &res, ctx),
//         ContentBlock => content_blocks::format_content_blocks(node, &res, ctx),
//         Args | Params | Dict | Array => args::format_args(node, &res, ctx),
//         LetBinding => format_let_binding(node, &res, ctx),
//         _ => format_default(node, &res, ctx),
//     };
//     if node.children().count() == 0 {
//         debug!("visiting token {:?}", node.kind());
//     } else {
//         debug!("visiting parent: {:?}", node.kind());
//     }
//     res
// }
// /// formats a node for which no specific function was found. Last resort.
// /// For the text of the node:
// /// Trim spaces for Space nodes if they contain a linebreak.
// /// avoids:
// /// - putting two consecutive spaces.
// /// - putting more than two consecutive newlines.
// ///
// /// For the already formatted children, change nothing.
// #[instrument(skip_all, ret)]
// fn format_default(node: &LinkedNode, children: &[String], ctx: &mut Ctx) -> String {
//     debug!("::format_default: {:?}", node.kind());
//     let mut res = String::new();
//     debug!(
//         "with children: {:?}",
//         node.children().map(|c| c.kind()).collect_vec()
//     );
//     ctx.push_in(node.text(), &mut res);
//     for s in children {
//         ctx.push_raw_in(s, &mut res);
//     }
//     res
// }
// #[instrument(skip_all, ret)]
// pub(crate) fn format_named_args(parent: &LinkedNode, children: &[String], ctx: &mut Ctx) -> String {
//     let mut res = String::new();
//     for (s, node) in children.iter().zip(parent.children()) {
//         match node.kind() {
//             Colon => res.push_str(": "),
//             Space => {}
//             _ => {
//                 ctx.push_raw_in(s, &mut res);
//             }
//         }
//     }
//     res
// }
// #[instrument(skip_all, ret)]
// pub(crate) fn format_let_binding(
//     parent: &LinkedNode,
//     children: &[String],
//     ctx: &mut Ctx,
// ) -> String {
//     let mut res = String::new();
//     for (s, node) in children.iter().zip(parent.children()) {
//         match node.kind() {
//             Eq => {
//                 ctx.push_in(" ", &mut res);
//                 ctx.push_in(s, &mut res);
//                 ctx.push_in(" ", &mut res);
//             }
//             Space => ctx.push_in(s, &mut res),
//             _ => {
//                 ctx.push_raw_in(s, &mut res);
//             }
//         }
//     }
//     res
// }
// #[cfg(test)]
// mod tests;