Revert 246124 "gn: Fix clang plugin on ios."
[chromium-blink-merge.git] / media / PRESUBMIT.py
blob255769720f4f86dd98f64aa352c14a4ba27d5420
1 # Copyright 2013 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file.
5 """Top-level presubmit script for Chromium media component.
7 See http://dev.chromium.org/developers/how-tos/depottools/presubmit-scripts
8 for more details about the presubmit API built into gcl.
9 """
11 def _FilterFile(affected_file):
12 """Return true if the file could contain code requiring a presubmit check."""
13 return affected_file.LocalPath().endswith(
14 ('.h', '.cc', '.cpp', '.cxx', '.mm'))
17 def _CheckForUseOfWrongClock(input_api, output_api):
18 """Make sure new lines of media code don't use a clock susceptible to skew."""
20 # Regular expression that should detect any explicit references to the
21 # base::Time type (or base::Clock/DefaultClock), whether in using decls,
22 # typedefs, or to call static methods.
23 base_time_type_pattern = r'(^|\W)base::(Time|Clock|DefaultClock)(\W|$)'
25 # Regular expression that should detect references to the base::Time class
26 # members, such as a call to base::Time::Now.
27 base_time_member_pattern = r'(^|\W)(Time|Clock|DefaultClock)::'
29 # Regular expression to detect "using base::Time" declarations. We want to
30 # prevent these from triggerring a warning. For example, it's perfectly
31 # reasonable for code to be written like this:
33 # using base::Time;
34 # ...
35 # int64 foo_us = foo_s * Time::kMicrosecondsPerSecond;
36 using_base_time_decl_pattern = r'^\s*using\s+(::)?base::Time\s*;'
38 # Regular expression to detect references to the kXXX constants in the
39 # base::Time class. We want to prevent these from triggerring a warning.
40 base_time_konstant_pattern = r'(^|\W)Time::k\w+'
42 problem_re = input_api.re.compile(
43 r'(' + base_time_type_pattern + r')|(' + base_time_member_pattern + r')')
44 exception_re = input_api.re.compile(
45 r'(' + using_base_time_decl_pattern + r')|(' +
46 base_time_konstant_pattern + r')')
47 problems = []
48 for f in input_api.AffectedSourceFiles(_FilterFile):
49 for line_number, line in f.ChangedContents():
50 if problem_re.search(line):
51 if not exception_re.search(line):
52 problems.append(
53 ' %s:%d\n %s' % (f.LocalPath(), line_number, line.strip()))
55 if problems:
56 return [output_api.PresubmitPromptOrNotify(
57 'You added one or more references to the base::Time class and/or one\n'
58 'of its member functions (or base::Clock/DefaultClock). In media\n'
59 'code, it is rarely correct to use a clock susceptible to time skew!\n'
60 'Instead, could you use base::TimeTicks to track the passage of\n'
61 'real-world time?\n\n' +
62 '\n'.join(problems))]
63 else:
64 return []
67 def _CheckForMessageLoopProxy(input_api, output_api):
68 """Make sure media code only uses MessageLoopProxy for accessing the current
69 loop."""
71 message_loop_proxy_re = input_api.re.compile(
72 r'\bMessageLoopProxy(?!::current\(\))')
74 problems = []
75 for f in input_api.AffectedSourceFiles(_FilterFile):
76 for line_number, line in f.ChangedContents():
77 if message_loop_proxy_re.search(line):
78 problems.append('%s:%d' % (f.LocalPath(), line_number))
80 if problems:
81 return [output_api.PresubmitError(
82 'MessageLoopProxy should only be used for accessing the current loop.\n'
83 'Use the TaskRunner interfaces instead as they are more explicit about\n'
84 'the run-time characteristics. In most cases, SingleThreadTaskRunner\n'
85 'is a drop-in replacement for MessageLoopProxy.', problems)]
87 return []
90 def _CheckChange(input_api, output_api):
91 results = []
92 results.extend(_CheckForUseOfWrongClock(input_api, output_api))
93 results.extend(_CheckForMessageLoopProxy(input_api, output_api))
94 return results
97 def CheckChangeOnUpload(input_api, output_api):
98 return _CheckChange(input_api, output_api)
101 def CheckChangeOnCommit(input_api, output_api):
102 return _CheckChange(input_api, output_api)