mirror of
https://github.com/pre-commit/pre-commit.git
synced 2026-01-18 06:55:25 -06:00
Merge remote-tracking branch 'origin/master' into performance_test
Conflicts: pre_commit/languages/python.py
This commit is contained in:
@@ -6,3 +6,11 @@
|
||||
-
|
||||
id: pyflakes
|
||||
files: '*.py'
|
||||
|
||||
-
|
||||
repo: git@github.com:pre-commit/jshint
|
||||
sha: 191734354d1191e3771c004c3e905a94728d0349
|
||||
hooks:
|
||||
-
|
||||
id: jshint
|
||||
files: '*.js'
|
||||
6
pre_commit/languages/helpers.py
Normal file
6
pre_commit/languages/helpers.py
Normal file
@@ -0,0 +1,6 @@
|
||||
|
||||
def run_hook(env, hook, file_args):
|
||||
return env.run(
|
||||
' '.join([hook['entry']] + hook.get('args', []) + list(file_args)),
|
||||
retcode=None,
|
||||
)
|
||||
@@ -1,7 +1,44 @@
|
||||
import contextlib
|
||||
from plumbum import local
|
||||
|
||||
from pre_commit.languages import helpers
|
||||
from pre_commit.languages import python
|
||||
|
||||
|
||||
NODE_ENV = 'node_env'
|
||||
|
||||
|
||||
class NodeEnv(object):
|
||||
def __init__(self, py_env):
|
||||
self.py_env = py_env
|
||||
self.env_prefix = '. {0}/bin/activate &&'.format(NODE_ENV)
|
||||
|
||||
def run(self, cmd, **kwargs):
|
||||
return self.py_env.run(' '.join([self.env_prefix, cmd]), **kwargs)
|
||||
|
||||
|
||||
@contextlib.contextmanager
|
||||
def in_env(py_env):
|
||||
yield NodeEnv(py_env)
|
||||
|
||||
|
||||
def install_environment():
|
||||
raise NotImplementedError
|
||||
assert local.path('package.json').exists()
|
||||
|
||||
if local.path('node_env').exists():
|
||||
return
|
||||
|
||||
local['virtualenv'][python.PY_ENV]()
|
||||
|
||||
with python.in_env() as python_env:
|
||||
python_env.run('pip install nodeenv')
|
||||
python_env.run('nodeenv {0}'.format(NODE_ENV))
|
||||
|
||||
with in_env(python_env) as node_env:
|
||||
node_env.run('npm install -g')
|
||||
|
||||
|
||||
def run_hook(hook, file_args):
|
||||
raise NotImplementedError
|
||||
with python.in_env() as py_env:
|
||||
with in_env(py_env) as node_env:
|
||||
return helpers.run_hook(node_env, hook, file_args)
|
||||
@@ -1,6 +1,7 @@
|
||||
|
||||
import contexlib
|
||||
import contextlib
|
||||
from plumbum import local
|
||||
from pre_commit.languages import helpers
|
||||
|
||||
PY_ENV = 'py_env'
|
||||
|
||||
@@ -9,22 +10,11 @@ class PythonEnv(object):
|
||||
def __init__(self):
|
||||
self.env_prefix = '. {0}/bin/activate &&'.format(PY_ENV)
|
||||
|
||||
def run(self, cmd):
|
||||
return local['bash']['-c', ' '.join([self.env_prefix, cmd])]()
|
||||
def run(self, cmd, **kwargs):
|
||||
return local['bash']['-c', ' '.join([self.env_prefix, cmd])].run(**kwargs)
|
||||
|
||||
|
||||
NODE_ENV = 'node_env'
|
||||
|
||||
class NodeEnv(object):
|
||||
def __init__(self, py_env):
|
||||
self.py_env = py_env
|
||||
self.env_prefix = '. {0}/bin/activate &&'.format(NODE_ENV)
|
||||
|
||||
def run(self, cmd):
|
||||
return self.py_env.run(' '.join(self.env_prefix, cmd))
|
||||
|
||||
|
||||
@contexlib.contextmanager
|
||||
@contextlib.contextmanager
|
||||
def in_env():
|
||||
yield PythonEnv()
|
||||
|
||||
@@ -44,6 +34,4 @@ def install_environment():
|
||||
def run_hook(hook, file_args):
|
||||
# TODO: batch filenames
|
||||
with in_env() as env:
|
||||
env = env
|
||||
# MAGIC
|
||||
pass
|
||||
return helpers.run_hook(env, hook, file_args)
|
||||
|
||||
Reference in New Issue
Block a user