1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
# os.py -- either mac or posix depending on what system we're on.
# This exports:
# - all functions from either posix or mac, e.g., os.unlink, os.stat, etc.
# - os.path is either module posixpath or macpath
# - os.name is either 'posix' or 'mac'
# - os.curdir is a string representing the current directory ('.' or ':')
# - os.pardir is a string representing the parent directory ('..' or '::')
# - os.sep is the (or a most common) pathname separator ('/' or ':')
# Programs that import and use 'os' stand a better chance of being
# portable between different platforms. Of course, they must then
# only use functions that are defined by all platforms (e.g., unlink
# and opendir), and leave all pathname manipulation to os.path
# (e.g., split and join).
# XXX This will need to distinguish between real posix and MS-DOS emulation
try:
from posix import *
try:
from posix import _exit
except ImportError:
pass
name = 'posix'
curdir = '.'
pardir = '..'
sep = '/'
import posixpath
path = posixpath
del posixpath
except ImportError:
from mac import *
name = 'mac'
curdir = ':'
pardir = '::'
sep = ':'
import macpath
path = macpath
del macpath
def execl(file, *args):
execv(file, args)
def execle(file, *args):
env = args[-1]
execve(file, args[:-1], env)
def execlp(file, *args):
execvp(file, args)
def execvp(file, args):
if '/' in file:
execv(file, args)
return
ENOENT = 2
if environ.has_key('PATH'):
import string
PATH = string.splitfields(environ['PATH'], ':')
else:
PATH = ['', '/bin', '/usr/bin']
exc, arg = (ENOENT, 'No such file or directory')
for dir in PATH:
fullname = path.join(dir, file)
try:
execv(fullname, args)
except error, (errno, msg):
if errno != ENOENT:
exc, arg = error, (errno, msg)
raise exc, arg
|