##// END OF EJS Templates
Fix equals sign and clarify where the number of restart attempts comes from
Fix equals sign and clarify where the number of restart attempts comes from

File last commit:

r17689:28d7cb7c
r18235:b839870a
Show More
process.py
123 lines | 3.6 KiB | text/x-python | PythonLexer
Brian Granger
Work to address the review comments on Fernando's branch....
r2498 # encoding: utf-8
"""
Utilities for working with external processes.
"""
#-----------------------------------------------------------------------------
Matthias BUSSONNIER
update copyright to 2011/20xx-2011...
r5390 # Copyright (C) 2008-2011 The IPython Development Team
Brian Granger
Work to address the review comments on Fernando's branch....
r2498 #
# Distributed under the terms of the BSD License. The full license is in
# the file COPYING, distributed as part of this software.
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
# Imports
#-----------------------------------------------------------------------------
Fernando Perez
Fully refactored subprocess handling on all platforms....
r2908 from __future__ import print_function
Brian Granger
Work to address the review comments on Fernando's branch....
r2498
Fernando Perez
Fully refactored subprocess handling on all platforms....
r2908 # Stdlib
Brian Granger
Work to address the review comments on Fernando's branch....
r2498 import os
import sys
Fernando Perez
Fully refactored subprocess handling on all platforms....
r2908 # Our own
if sys.platform == 'win32':
Thomas Kluyver
Check for pids when listing nbserver processes
r17181 from ._process_win32 import _find_cmd, system, getoutput, arg_split, check_pid
Doug Blank
Minimal changes to import IPython from IronPython
r15154 elif sys.platform == 'cli':
Amin Bandali
Add .NET implementation of check_pid
r17689 from ._process_cli import _find_cmd, system, getoutput, arg_split, check_pid
Fernando Perez
Fully refactored subprocess handling on all platforms....
r2908 else:
Thomas Kluyver
Check for pids when listing nbserver processes
r17181 from ._process_posix import _find_cmd, system, getoutput, arg_split, check_pid
Jörgen Stenarson
Moved arg_split to _process_win32.py and _process_posix.py.
r5517
Paul Ivanov
initial test for the embedding
r14184 from ._process_common import getoutputerror, get_output_error_code, process_handler
Thomas Kluyver
Python 3 compatibility for os.getcwdu()
r13447 from . import py3compat
Brian Granger
Work to address the review comments on Fernando's branch....
r2498
#-----------------------------------------------------------------------------
# Code
#-----------------------------------------------------------------------------
class FindCmdError(Exception):
pass
def find_cmd(cmd):
"""Find absolute path to executable cmd in a cross platform manner.
Bernardo B. Marques
remove all trailling spaces
r4872
Brian Granger
Work to address the review comments on Fernando's branch....
r2498 This function tries to determine the full path to a command line program
using `which` on Unix/Linux/OS X and `win32api` on Windows. Most of the
MinRK
remove special case for 'python' in find_cmd
r10696 time it will use the version that is first on the users `PATH`.
Brian Granger
Work to address the review comments on Fernando's branch....
r2498
Warning, don't use this to find IPython command line programs as there
is a risk you will find the wrong one. Instead find those using the
following code and looking for the application itself::
Bernardo B. Marques
remove all trailling spaces
r4872
Brian Granger
Work to address the review comments on Fernando's branch....
r2498 from IPython.utils.path import get_ipython_module_path
from IPython.utils.process import pycmd2argv
Fernando Perez
Fix all remaining imports that used `IPython.frontend`.
r11024 argv = pycmd2argv(get_ipython_module_path('IPython.terminal.ipapp'))
Brian Granger
Work to address the review comments on Fernando's branch....
r2498
Parameters
----------
cmd : str
The command line program to look for.
"""
try:
Fernando Perez
Fully refactored subprocess handling on all platforms....
r2908 path = _find_cmd(cmd).rstrip()
Brian Granger
Work to address the review comments on Fernando's branch....
r2498 except OSError:
raise FindCmdError('command could not be found: %s' % cmd)
# which returns empty if not found
Thomas Kluyver
Fix some more tests for Python 3.
r4898 if path == '':
Brian Granger
Work to address the review comments on Fernando's branch....
r2498 raise FindCmdError('command could not be found: %s' % cmd)
return os.path.abspath(path)
Takafumi Arakaki
Add tests for IPython.lib.latextools
r7858 def is_cmd_found(cmd):
"""Check whether executable `cmd` exists or not and return a bool."""
try:
find_cmd(cmd)
return True
except FindCmdError:
return False
Brian Granger
Work to address the review comments on Fernando's branch....
r2498 def pycmd2argv(cmd):
r"""Take the path of a python command and return a list (argv-style).
This only works on Python based command line programs and will find the
location of the ``python`` executable using ``sys.executable`` to make
sure the right version is used.
For a given path ``cmd``, this returns [cmd] if cmd's extension is .exe,
Bernardo B. Marques
remove all trailling spaces
r4872 .com or .bat, and [, cmd] otherwise.
Brian Granger
Work to address the review comments on Fernando's branch....
r2498
Parameters
----------
cmd : string
The path of the command.
Returns
-------
argv-style list.
"""
ext = os.path.splitext(cmd)[1]
if ext in ['.exe', '.com', '.bat']:
return [cmd]
else:
Jörgen Stenarson
Removing unecessary checks for win32
r6141 return [sys.executable, cmd]
Brian Granger
Work to address the review comments on Fernando's branch....
r2498
def abbrev_cwd():
""" Return abbreviated version of cwd, e.g. d:mydir """
Thomas Kluyver
Python 3 compatibility for os.getcwdu()
r13447 cwd = py3compat.getcwd().replace('\\','/')
Brian Granger
Work to address the review comments on Fernando's branch....
r2498 drivepart = ''
tail = cwd
if sys.platform == 'win32':
if len(cwd) < 4:
return cwd
drivepart,tail = os.path.splitdrive(cwd)
parts = tail.split('/')
if len(parts) > 2:
tail = '/'.join(parts[-2:])
return (drivepart + (
cwd == '/' and '/' or tail))