mirror of
https://github.com/servo/servo.git
synced 2025-06-06 16:45:39 +00:00
Make tidy aware of Rust multiline strings
As a result of tighter and more correct handling of character literals, this now catches a few kinds of syntax involving lifetimes that were previously missed, so those have been updated.
This commit is contained in:
parent
5c797d1943
commit
c9dafda03a
6 changed files with 55 additions and 15 deletions
|
@ -467,15 +467,6 @@ def check_rust(file_name, lines):
|
|||
prev_indent = indent
|
||||
indent = len(original_line) - len(line)
|
||||
|
||||
# Hack for components/selectors/build.rs
|
||||
if multi_line_string:
|
||||
if line.startswith('"#'):
|
||||
multi_line_string = False
|
||||
else:
|
||||
continue
|
||||
if line.endswith('r#"'):
|
||||
multi_line_string = True
|
||||
|
||||
is_attribute = re.search(r"#\[.*\]", line)
|
||||
is_comment = re.search(r"^//|^/\*|^\*", line)
|
||||
|
||||
|
@ -494,6 +485,14 @@ def check_rust(file_name, lines):
|
|||
line = merged_lines + line
|
||||
merged_lines = ''
|
||||
|
||||
if multi_line_string:
|
||||
line, count = re.subn(
|
||||
r'^(\\.|[^"\\])*?"', '', line, count=1)
|
||||
if count == 1:
|
||||
multi_line_string = False
|
||||
else:
|
||||
continue
|
||||
|
||||
# Ignore attributes, comments, and imports
|
||||
# Keep track of whitespace to enable checking for a merged import block
|
||||
if import_block:
|
||||
|
@ -504,9 +503,17 @@ def check_rust(file_name, lines):
|
|||
import_block = False
|
||||
|
||||
# get rid of strings and chars because cases like regex expression, keep attributes
|
||||
if not is_attribute:
|
||||
if not is_attribute and not is_comment:
|
||||
line = re.sub(r'"(\\.|[^\\"])*?"', '""', line)
|
||||
line = re.sub(r"'(\\.|[^\\'])*?'", "''", line)
|
||||
line = re.sub(
|
||||
r"'(\\.|[^\\']|(\\x[0-9a-fA-F]{2})|(\\u{[0-9a-fA-F]{1,6}}))'",
|
||||
"''", line)
|
||||
# If, after parsing all single-line strings, we still have
|
||||
# an odd number of double quotes, this line starts a
|
||||
# multiline string
|
||||
if line.count('"') % 2 == 1:
|
||||
line = re.sub(r'"(\\.|[^\\"])*?$', '""', line)
|
||||
multi_line_string = True
|
||||
|
||||
# get rid of comments
|
||||
line = re.sub('//.*?$|/\*.*?$|^\*.*?$', '//', line)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue