-
Notifications
You must be signed in to change notification settings - Fork 16
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Also renamed newline.py to eofnewline.py.
- Loading branch information
Showing
5 changed files
with
180 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,106 @@ | ||
import os | ||
|
||
from wpiformat.config import Config | ||
from wpiformat.bracenewline import BraceNewline | ||
|
||
|
||
def test_bracenewline(): | ||
task = BraceNewline() | ||
|
||
inputs = [] | ||
outputs = [] | ||
|
||
# Brackets on same line | ||
inputs.append(("./Test.cpp", | ||
"void func1() {}" + os.linesep + \ | ||
"void func2() {}" + os.linesep)) | ||
outputs.append(( | ||
"void func1() {}" + os.linesep + \ | ||
os.linesep + \ | ||
"void func2() {}" + os.linesep, True, True)) | ||
|
||
# Brackets on next line | ||
inputs.append(("./Test.cpp", | ||
"void func1() {" + os.linesep + \ | ||
"}" + os.linesep + \ | ||
"void func2() {" + os.linesep + \ | ||
"}" + os.linesep)) | ||
outputs.append(( | ||
"void func1() {" + os.linesep + \ | ||
"}" + os.linesep + \ | ||
os.linesep + \ | ||
"void func2() {" + os.linesep + \ | ||
"}" + os.linesep, True, True)) | ||
|
||
# Comments after brackets | ||
inputs.append(("./Test.cpp", | ||
"void func1() {" + os.linesep + \ | ||
"} // This is a comment" + os.linesep + \ | ||
"void func2() {" + os.linesep + \ | ||
"} /* This is a comment */" + os.linesep + \ | ||
"void func3() {" + os.linesep + \ | ||
"}" + os.linesep)) | ||
outputs.append(( | ||
"void func1() {" + os.linesep + \ | ||
"} // This is a comment" + os.linesep + \ | ||
os.linesep + \ | ||
"void func2() {" + os.linesep + \ | ||
"} /* This is a comment */" + os.linesep + \ | ||
os.linesep + \ | ||
"void func3() {" + os.linesep + \ | ||
"}" + os.linesep, True, True)) | ||
|
||
# Don't add line separators to uncondensed if statements (after last brace | ||
# is OK) | ||
inputs.append(("./Test.cpp", | ||
"void func1() {" + os.linesep + \ | ||
" if (1) {" + os.linesep + \ | ||
" }" + os.linesep + \ | ||
" else {" + os.linesep + \ | ||
" }" + os.linesep + \ | ||
"}" + os.linesep)) | ||
outputs.append((inputs[len(inputs) - 1][1], False, True)) | ||
|
||
# Don't add line separators to condensed if statements (after last brace | ||
# is OK) | ||
inputs.append(("./Test.cpp", | ||
"void func1() {" + os.linesep + \ | ||
" if (1) {" + os.linesep + \ | ||
" } else if () {" + os.linesep + \ | ||
" } else {" + os.linesep + \ | ||
" // comment" + os.linesep + \ | ||
" }" + os.linesep + \ | ||
"}" + os.linesep)) | ||
outputs.append((inputs[len(inputs) - 1][1], False, True)) | ||
|
||
# Don't add line separators before #endif statements | ||
inputs.append(("./Main.cpp", | ||
"using decay_t = typename decay<T>::type;" + os.linesep + \ | ||
"} // namespace std" + os.linesep + \ | ||
"#endif" + os.linesep)) | ||
outputs.append((inputs[len(inputs) - 1][1], False, True)) | ||
|
||
# Don't insert line separators within multiline comments | ||
inputs.append(("./Main.java", | ||
"/* to fine tune the pid loop." + os.linesep + \ | ||
" *" + os.linesep + \ | ||
" * @return the {@link PIDController} used by this {@link PIDSubsystem}" + os.linesep + \ | ||
" */" + os.linesep + \ | ||
"public PIDController getPIDController() {" + os.linesep)) | ||
outputs.append((inputs[len(inputs) - 1][1], False, True)) | ||
|
||
# Don't insert line separators within single line comments | ||
inputs.append(("./Main.java", | ||
"// @return the {@link PIDController} used by this {@link PIDSubsystem}" + os.linesep + \ | ||
"public PIDController getPIDController() {" + os.linesep)) | ||
outputs.append((inputs[len(inputs) - 1][1], False, True)) | ||
|
||
assert len(inputs) == len(outputs) | ||
|
||
config_file = Config(os.path.abspath(os.getcwd()), ".styleguide") | ||
for i in range(len(inputs)): | ||
output, file_changed, success = task.run_pipeline( | ||
config_file, inputs[i][0], inputs[i][1]) | ||
assert output == outputs[i][0] | ||
assert file_changed == outputs[i][1] | ||
assert success == outputs[i][2] |
6 changes: 3 additions & 3 deletions
6
wpiformat/test/test_newline.py → wpiformat/test/test_eofnewline.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,66 @@ | ||
"""This task ensures braces are followed by two line separators.""" | ||
|
||
import re | ||
|
||
from wpiformat.task import Task | ||
|
||
|
||
class BraceNewline(Task): | ||
|
||
def should_process_file(self, config_file, name): | ||
return config_file.is_c_file(name) or config_file.is_cpp_file( | ||
name) or name.endswith("java") | ||
|
||
def run_pipeline(self, config_file, name, lines): | ||
linesep = Task.get_linesep(lines) | ||
|
||
comment_regex = re.compile("//|/\*|\*/") | ||
|
||
lines_list = lines.split(linesep) | ||
|
||
in_multiline_comment = False | ||
for i in range(len(lines_list)): | ||
match = comment_regex.search(lines_list[i]) | ||
if not match: | ||
line = lines_list[i].rstrip() | ||
else: | ||
# While in a multiline comment, we only care about "*/" | ||
if in_multiline_comment: | ||
if match.group() == "*/": | ||
line = lines_list[i][ | ||
match.start() + len("*/"):].rstrip() | ||
in_multiline_comment = False | ||
else: | ||
line = lines_list[i][0:match.start()].rstrip() | ||
|
||
# If multiline comment is starting | ||
if match.group() == "/*": | ||
line = lines_list[i][0:match.start()] | ||
in_multiline_comment = True | ||
|
||
# If comment ends on same line, handle it immediately | ||
comment_end = lines_list[i].find("*/") | ||
if comment_end != -1: | ||
line += lines_list[i][comment_end + len("*/"):] | ||
line = line.rstrip() | ||
in_multiline_comment = False | ||
|
||
if in_multiline_comment: | ||
continue | ||
|
||
# If line with "}" isn't at end of file | ||
if i + 1 < len(lines_list) and line.endswith("}"): | ||
next_line = lines_list[i + 1].lstrip() | ||
|
||
# If next line is already empty, there's nothing to do | ||
if len(next_line) > 0: | ||
if next_line[0] != "}" and "else" not in next_line and "#endif" not in next_line: | ||
lines_list.insert(i + 1, "") | ||
i += 1 | ||
|
||
output = linesep.join(lines_list) | ||
|
||
if output != lines: | ||
return (output, True, True) | ||
else: | ||
return (lines, False, True) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters