Commit 3990c419 authored by skym@chromium.org's avatar skym@chromium.org

Moving swap IWYU from <algorithm> to <utility>.

In C++11 std::swap was moved from <algorithm> to <utility>. As such,
lint needed to be updated to look for/suggest <utility> when it finds
std::swap. The IWYU logic is a little bit different for <utility>
functions, including swap, because they do not typically include
template parameters, unlike most other std:: functions. Reworked the
existing algorithm pattern to be more generic and support multiple
differet headers. Did not rename/all caps _re_pattern_templates as it
is referenced/modified outside of cpplint.py.

BUG=584689

Review URL: https://codereview.chromium.org/1673543004

git-svn-id: svn://svn.chromium.org/chrome/trunk/tools/depot_tools@298622 0039d316-1c4b-4281-b951-d872f2087c98
parent 8b61f11e
...@@ -5498,18 +5498,26 @@ _HEADERS_CONTAINING_TEMPLATES = ( ...@@ -5498,18 +5498,26 @@ _HEADERS_CONTAINING_TEMPLATES = (
('<slist>', ('slist',)), ('<slist>', ('slist',)),
) )
_HEADERS_MAYBE_TEMPLATES = (
('<algorithm>', ('copy', 'max', 'min', 'min_element', 'sort',
'transform',
)),
('<utility>', ('swap',)),
)
_RE_PATTERN_STRING = re.compile(r'\bstring\b') _RE_PATTERN_STRING = re.compile(r'\bstring\b')
_re_pattern_algorithm_header = [] _re_pattern_headers_maybe_templates = []
for _template in ('copy', 'max', 'min', 'min_element', 'sort', 'swap', for _header, _templates in _HEADERS_MAYBE_TEMPLATES:
'transform'): for _template in _templates:
# Match max<type>(..., ...), max(..., ...), but not foo->max, foo.max or # Match max<type>(..., ...), max(..., ...), but not foo->max, foo.max or
# type::max(). # type::max().
_re_pattern_algorithm_header.append( _re_pattern_headers_maybe_templates.append(
(re.compile(r'[^>.]\b' + _template + r'(<.*?>)?\([^\)]'), (re.compile(r'[^>.]\b' + _template + r'(<.*?>)?\([^\)]'),
_template, _template,
'<algorithm>')) _header))
# Other scripts may reach in and modify this pattern.
_re_pattern_templates = [] _re_pattern_templates = []
for _header, _templates in _HEADERS_CONTAINING_TEMPLATES: for _header, _templates in _HEADERS_CONTAINING_TEMPLATES:
for _template in _templates: for _template in _templates:
...@@ -5636,7 +5644,7 @@ def CheckForIncludeWhatYouUse(filename, clean_lines, include_state, error, ...@@ -5636,7 +5644,7 @@ def CheckForIncludeWhatYouUse(filename, clean_lines, include_state, error,
if prefix.endswith('std::') or not prefix.endswith('::'): if prefix.endswith('std::') or not prefix.endswith('::'):
required['<string>'] = (linenum, 'string') required['<string>'] = (linenum, 'string')
for pattern, template, header in _re_pattern_algorithm_header: for pattern, template, header in _re_pattern_headers_maybe_templates:
if pattern.search(line): if pattern.search(line):
required[header] = (linenum, template) required[header] = (linenum, template)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment