mirror of
https://github.com/pre-commit/pre-commit.git
synced 2026-01-14 21:10:27 -06:00
improve xargs when running windows batch files
This commit is contained in:
@@ -137,6 +137,16 @@ def xargs(
|
||||
except parse_shebang.ExecutableNotFoundError as e:
|
||||
return e.to_output()[:2]
|
||||
|
||||
# on windows, batch files have a separate length limit than windows itself
|
||||
if (
|
||||
sys.platform == 'win32' and
|
||||
cmd[0].lower().endswith(('.bat', '.cmd'))
|
||||
): # pragma: win32 cover
|
||||
# this is implementation details but the command gets translated into
|
||||
# full/path/to/cmd.exe /c *cmd
|
||||
cmd_exe = parse_shebang.find_executable('cmd.exe')
|
||||
_max_length = 8192 - len(cmd_exe) - len(' /c ')
|
||||
|
||||
partitions = partition(cmd, varargs, target_concurrency, _max_length)
|
||||
|
||||
def run_cmd_partition(
|
||||
|
||||
@@ -195,3 +195,12 @@ def test_xargs_color_true_makes_tty():
|
||||
)
|
||||
assert retcode == 0
|
||||
assert out == b'True\n'
|
||||
|
||||
|
||||
@pytest.mark.xfail(os.name == 'posix', reason='nt only')
|
||||
@pytest.mark.parametrize('filename', ('t.bat', 't.cmd', 'T.CMD'))
|
||||
def test_xargs_with_batch_files(tmpdir, filename):
|
||||
f = tmpdir.join(filename)
|
||||
f.write('echo it works\n')
|
||||
retcode, out = xargs.xargs((str(f),), ('x',) * 8192)
|
||||
assert retcode == 0, (retcode, out)
|
||||
|
||||
Reference in New Issue
Block a user