Commit d05ab352 authored by scottmg@chromium.org's avatar scottmg@chromium.org

Add canned presubmit check for GN formatting

Requires https://codereview.chromium.org/779883002/ to be landed/rolled before it's useful.

R=dpranke@chromium.org
BUG=348474

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

git-svn-id: svn://svn.chromium.org/chrome/trunk/tools/depot_tools@293269 0039d316-1c4b-4281-b951-d872f2087c98
parent 34edb9bf
...@@ -30,7 +30,7 @@ def main(args): ...@@ -30,7 +30,7 @@ def main(args):
print >> sys.stderr, 'gn.py: Could not find gn executable at: %s' % gn_path print >> sys.stderr, 'gn.py: Could not find gn executable at: %s' % gn_path
return 2 return 2
else: else:
return subprocess.call([gn_path] + sys.argv[1:]) return subprocess.call([gn_path] + args[1:])
if __name__ == '__main__': if __name__ == '__main__':
......
...@@ -1113,3 +1113,22 @@ def CheckPatchFormatted(input_api, output_api): ...@@ -1113,3 +1113,22 @@ def CheckPatchFormatted(input_api, output_api):
# As this is just a warning, ignore all other errors if the user # As this is just a warning, ignore all other errors if the user
# happens to have a broken clang-format, doesn't use git, etc etc. # happens to have a broken clang-format, doesn't use git, etc etc.
return [] return []
def CheckGNFormatted(input_api, output_api):
import gn
affected_files = input_api.AffectedFiles(
include_deletes=False,
file_filter=lambda x: x.LocalPath().endswith('.gn') or
x.LocalPath().endswith('.gni'))
warnings = []
for f in affected_files:
cmd = ['gn', 'format', '--dry-run', f.AbsoluteLocalPath()]
rc = gn.main(cmd)
if rc == 2:
warnings.append(output_api.PresubmitPromptWarning(
'%s requires formatting. Please run `gn format --in-place %s`.' % (
f.AbsoluteLocalPath(), f.LocalPath())))
# It's just a warning, so ignore other types of failures assuming they'll be
# caught elsewhere.
return warnings
...@@ -1878,6 +1878,7 @@ class CannedChecksUnittest(PresubmitTestsBase): ...@@ -1878,6 +1878,7 @@ class CannedChecksUnittest(PresubmitTestsBase):
'CheckLicense', 'CheckLicense',
'CheckOwners', 'CheckOwners',
'CheckPatchFormatted', 'CheckPatchFormatted',
'CheckGNFormatted',
'CheckRietveldTryJobExecution', 'CheckRietveldTryJobExecution',
'CheckSingletonInHeaders', 'CheckSingletonInHeaders',
'CheckSvnModifiedDirectories', 'CheckSvnModifiedDirectories',
......
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