Files
tubestation/tools/lint/hooks.py
Andrew Halberstadt 408093ed28 Bug 1361972 - Add a pre-push and pre-commit mozlint hooks r=standard8
This adds pre-push and pre-commit hooks for both hg and git. All
four possibilities are implemented in the same file.

To enable a pre-push hg hook, add the following to hgrc:

    [hooks]
    pre-push.lint = python:/path/to/gecko/tools/lint/hooks.py:hg


To enable a pre-commit hg hook, add the following to hgrc:

    [hooks]
    pretxncommit.lint = python:/path/to/gecko/tools/lint/hooks.py:hg


To enable a pre-push git hook, run the following command:

    $ ln -s /path/to/gecko/tools/lint/hooks.py .git/hooks/pre-push


To enable a pre-commit git hook, run the following command:

    $ ln -s /path/to/gecko/tools/lint/hooks.py .git/hooks/pre-commit


MozReview-Commit-ID: DUxCKN2fiag
2017-06-30 18:29:42 -07:00

40 lines
1.1 KiB
Python

#!/usr/bin/env python
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
import os
import subprocess
import sys
here = os.path.dirname(os.path.realpath(__file__))
topsrcdir = os.path.join(here, os.pardir, os.pardir)
def run_mozlint(hooktype, args):
cmd = [os.path.join(topsrcdir, 'mach'), 'lint']
if 'commit' in hooktype:
# don't prevent commits, just display the lint results
subprocess.call(cmd + ['--workdir=staged'])
return False
elif 'push' in hooktype:
return subprocess.call(cmd + ['--outgoing'] + args)
print("warning: '{}' is not a valid mozlint hooktype".format(hooktype))
return False
def hg(ui, repo, **kwargs):
hooktype = kwargs['hooktype']
return run_mozlint(hooktype, kwargs.get('pats', []))
def git(args=sys.argv[1:]):
hooktype = os.path.basename(__file__)
return run_mozlint(hooktype, args[:1])
if __name__ == '__main__':
sys.exit(git())