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
// autocorrect: false
use super::*;
use autocorrect_derive::GrammarParser;
use pest::Parser as P;
use pest_derive::Parser;
#[derive(GrammarParser, Parser)]
#[grammar = "../grammar/scala.pest"]
struct ScalaParser;
#[cfg(test)]
mod tests {
use super::*;
use indoc::indoc;
use pretty_assertions::assert_eq;
#[test]
fn it_format_scala() {
let example = indoc! {r###"
/*
多行注释第1行
多行comment第2行
*/
object Test {
val str1: String = "字符串Hello你好"
var string_literal: String = s"$str1你好"
var multiline_str: String = """这是str第1行
这是str第2行"""
// 正则regexp不应该处理
val pattern = new Regex("[\w]1正则")
val pattern1 = "1正则".r
def main(args: Array[String]) {
println( greeting )
}
}
"###};
let expect = indoc! {r###"
/*
多行注释第 1 行
多行 comment 第 2 行
*/
object Test {
val str1: String = "字符串 Hello 你好"
var string_literal: String = s"$str1你好"
var multiline_str: String = """这是 str 第 1 行
这是 str 第 2 行"""
// 正则 regexp 不应该处理
val pattern = new Regex("[\w]1正则")
val pattern1 = "1正则".r
def main(args: Array[String]) {
println( greeting )
}
}
"###};
assert_eq!(expect, format_for(example, "scala").to_string());
}
}