summaryrefslogtreecommitdiffstats
path: root/PRESUBMIT.py
diff options
context:
space:
mode:
authorjoaodasilva@chromium.org <joaodasilva@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-03-22 21:44:41 +0000
committerjoaodasilva@chromium.org <joaodasilva@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-03-22 21:44:41 +0000
commit7bbc7d1ca0dd48a6383687324c4ebb6df7f6d9c5 (patch)
tree2b7d8c1eb3474dd4120830306ab64e353638139e /PRESUBMIT.py
parentb31117886d85c32c31adffbd08d6cad074932dce (diff)
downloadchromium_src-7bbc7d1ca0dd48a6383687324c4ebb6df7f6d9c5.zip
chromium_src-7bbc7d1ca0dd48a6383687324c4ebb6df7f6d9c5.tar.gz
chromium_src-7bbc7d1ca0dd48a6383687324c4ebb6df7f6d9c5.tar.bz2
Added presubmit warning for ScopedAllowIO uses
BUG=119550 TEST=Adding new uses of ScopedAllowIO triggers a presubmit warning Review URL: http://codereview.chromium.org/9826024 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@128312 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'PRESUBMIT.py')
-rw-r--r--PRESUBMIT.py18
1 files changed, 18 insertions, 0 deletions
diff --git a/PRESUBMIT.py b/PRESUBMIT.py
index b042b7c..87f0894 100644
--- a/PRESUBMIT.py
+++ b/PRESUBMIT.py
@@ -183,6 +183,23 @@ def _CheckNoFRIEND_TEST(input_api, output_api):
'FRIEND_TEST_ALL_PREFIXES() instead.\n' + '\n'.join(problems))]
+def _CheckNoScopedAllowIO(input_api, output_api):
+ """Make sure that ScopedAllowIO is not used."""
+ problems = []
+
+ file_filter = lambda f: f.LocalPath().endswith(('.cc', '.h'))
+ for f in input_api.AffectedFiles(file_filter=file_filter):
+ for line_num, line in f.ChangedContents():
+ if 'ScopedAllowIO' in line:
+ problems.append(' %s:%d' % (f.LocalPath(), line_num))
+
+ if not problems:
+ return []
+ return [output_api.PresubmitPromptWarning('New code should not use '
+ 'ScopedAllowIO. Post a task to the blocking pool or the FILE thread '
+ 'instead.\n' + '\n'.join(problems))]
+
+
def _CommonChecks(input_api, output_api):
"""Checks common to both upload and commit."""
results = []
@@ -196,6 +213,7 @@ def _CommonChecks(input_api, output_api):
results.extend(_CheckNoNewWStrings(input_api, output_api))
results.extend(_CheckNoDEPSGIT(input_api, output_api))
results.extend(_CheckNoFRIEND_TEST(input_api, output_api))
+ results.extend(_CheckNoScopedAllowIO(input_api, output_api))
return results