2021-07-04 16:12:17 -05:00
|
|
|
local Runner = require("tests.indent.common").Runner
|
2021-11-20 15:14:56 +01:00
|
|
|
local XFAIL = require("tests.indent.common").XFAIL
|
2021-04-22 20:53:30 +02:00
|
|
|
|
2021-04-23 00:41:44 +02:00
|
|
|
-- will use both c/ and cpp/
|
2021-07-04 16:12:17 -05:00
|
|
|
local run = Runner:new(it, "tests/indent", {
|
2021-04-22 20:53:30 +02:00
|
|
|
tabstop = 4,
|
|
|
|
|
shiftwidth = 4,
|
|
|
|
|
softtabstop = 0,
|
|
|
|
|
expandtab = true,
|
2021-07-04 16:12:17 -05:00
|
|
|
filetype = "cpp",
|
2021-04-23 00:41:44 +02:00
|
|
|
})
|
2021-04-22 21:23:24 +02:00
|
|
|
|
2021-07-04 16:12:17 -05:00
|
|
|
describe("indent C++:", function()
|
|
|
|
|
describe("whole file:", function()
|
2021-11-20 15:14:56 +01:00
|
|
|
run:whole_file({ "c/", "cpp/" }, {
|
|
|
|
|
expected_failures = {
|
|
|
|
|
-- C
|
|
|
|
|
"c/ternary.c",
|
|
|
|
|
"c/string.c",
|
|
|
|
|
"c/preproc_func.c",
|
|
|
|
|
"c/preproc_cond.c",
|
|
|
|
|
"c/no_braces.c",
|
|
|
|
|
"c/label.c",
|
|
|
|
|
"c/func.c",
|
|
|
|
|
"c/expr.c",
|
|
|
|
|
"c/comment.c",
|
|
|
|
|
"c/array.c",
|
|
|
|
|
-- C++
|
|
|
|
|
"cpp/access.cpp",
|
|
|
|
|
"cpp/stream.cpp",
|
|
|
|
|
},
|
|
|
|
|
})
|
2021-04-22 20:53:30 +02:00
|
|
|
end)
|
|
|
|
|
|
2021-07-04 16:12:17 -05:00
|
|
|
describe("new line:", function()
|
2021-11-20 15:14:56 +01:00
|
|
|
run:new_line("cpp/access.cpp", { on_line = 3, text = "protected:", indent = 0 }, "expected failure", XFAIL)
|
2021-07-04 16:12:17 -05:00
|
|
|
run:new_line("cpp/class.cpp", { on_line = 2, text = "using T = int;", indent = 4 })
|
|
|
|
|
run:new_line("cpp/stream.cpp", { on_line = 5, text = "<< x + 3", indent = 8 })
|
2021-04-22 20:53:30 +02:00
|
|
|
|
|
|
|
|
-- TODO: find a clean way to import these from c_spec.lua
|
2021-07-04 16:12:17 -05:00
|
|
|
run:new_line("c/array.c", { on_line = 2, text = "0,", indent = 4 })
|
|
|
|
|
run:new_line("c/cond.c", { on_line = 3, text = "x++;", indent = 8 })
|
|
|
|
|
run:new_line("c/cond.c", { on_line = 8, text = "x++;", indent = 8 })
|
|
|
|
|
run:new_line("c/expr.c", { on_line = 10, text = "2 *", indent = 8 })
|
|
|
|
|
run:new_line("c/func.c", { on_line = 17, text = "int z,", indent = 4 })
|
2021-11-20 15:14:56 +01:00
|
|
|
run:new_line("c/label.c", { on_line = 3, text = "normal:", indent = 0 }, "expected failure", XFAIL)
|
2021-07-04 16:12:17 -05:00
|
|
|
run:new_line("c/loop.c", { on_line = 3, text = "x++;", indent = 8 })
|
|
|
|
|
run:new_line("c/preproc_cond.c", { on_line = 5, text = "x++;", indent = 4 })
|
|
|
|
|
run:new_line("c/preproc_func.c", { on_line = 3, text = "x++; \\", indent = 8 })
|
2021-11-20 15:14:56 +01:00
|
|
|
run:new_line("c/string.c", { on_line = 1, text = "brave new \\", indent = 0 }, "expected failure", XFAIL)
|
2021-07-04 16:12:17 -05:00
|
|
|
run:new_line("c/string.c", { on_line = 4, text = '"brave new "', indent = 4 })
|
|
|
|
|
run:new_line("c/struct.c", { on_line = 4, text = "int y;", indent = 8 })
|
|
|
|
|
run:new_line("c/switch.c", { on_line = 3, text = "x++;", indent = 12 })
|
|
|
|
|
run:new_line("c/ternary.c", { on_line = 4, text = ": (x == 0) : 0", indent = 8 })
|
2021-04-22 20:53:30 +02:00
|
|
|
-- the line after inserted one will be left with wrong indent but we only care about the inserted one
|
2021-11-20 15:14:56 +01:00
|
|
|
run:new_line("c/no_braces.c", { on_line = 4, text = "x++;", indent = 8 }, "expected failure", XFAIL)
|
2021-07-04 16:12:17 -05:00
|
|
|
run:new_line("c/no_braces.c", { on_line = 7, text = "x++;", indent = 8 })
|
|
|
|
|
run:new_line("c/no_braces.c", { on_line = 10, text = "x++;", indent = 8 })
|
2021-04-22 20:53:30 +02:00
|
|
|
end)
|
|
|
|
|
end)
|