Kaydet (Commit) cea7e559 authored tarafından Georg Brandl's avatar Georg Brandl

Merged revisions 83393,83396,83398,83404-83405,83408 via svnmerge from

svn+ssh://svn.python.org/python/branches/py3k

........
  r83393 | georg.brandl | 2010-08-01 10:35:29 +0200 (So, 01 Aug 2010) | 1 line

  #1690103: fix initial namespace for code run with trace.main().
........
  r83396 | georg.brandl | 2010-08-01 10:52:32 +0200 (So, 01 Aug 2010) | 1 line

  #4810: document "--" option separator in timeit help.
........
  r83398 | georg.brandl | 2010-08-01 11:06:34 +0200 (So, 01 Aug 2010) | 1 line

  #8826: the "expires" attribute value is a date string with spaces, but apparently not all user-agents put it in quotes.  Handle that as a special case.
........
  r83404 | georg.brandl | 2010-08-01 16:25:22 +0200 (So, 01 Aug 2010) | 1 line

  #6439: fix argument type for PySys_SetArgvEx() and Py_SetProgramName() in Demo/embed code.
........
  r83405 | georg.brandl | 2010-08-01 16:38:17 +0200 (So, 01 Aug 2010) | 1 line

  #4943: do not try to include drive letters (and colons) when looking for a probably module name.
........
  r83408 | georg.brandl | 2010-08-01 17:30:56 +0200 (So, 01 Aug 2010) | 1 line

  #5551: symbolic links never can be mount points.  Fixes the fix for #1713.
........
üst afef78f8
...@@ -22,7 +22,7 @@ CPPFLAGS= $(INCLUDES) ...@@ -22,7 +22,7 @@ CPPFLAGS= $(INCLUDES)
LIBPYTHON= $(blddir)/libpython$(VERSION).a LIBPYTHON= $(blddir)/libpython$(VERSION).a
# XXX edit LIBS (in particular) to match $(blddir)/Modules/Makefile # XXX edit LIBS (in particular) to match $(blddir)/Modules/Makefile
LIBS= -lnsl -ldl -lreadline -ltermcap -lieee -lpthread -lutil LIBS= -lnsl -ldl -lreadline -lieee -lpthread -lutil
LDFLAGS= -Xlinker -export-dynamic LDFLAGS= -Xlinker -export-dynamic
SYSLIBS= -lm SYSLIBS= -lm
MODLIBS= MODLIBS=
......
...@@ -22,8 +22,17 @@ main(int argc, char **argv) ...@@ -22,8 +22,17 @@ main(int argc, char **argv)
/* Define sys.argv. It is up to the application if you /* Define sys.argv. It is up to the application if you
want this; you can also let it undefined (since the Python want this; you can also let it undefined (since the Python
code is generally not a main program it has no business code is generally not a main program it has no business
touching sys.argv...) */ touching sys.argv...)
PySys_SetArgv(2, args);
If the third argument is true, sys.path is modified to include
either the directory containing the script named by argv[0], or
the current working directory. This can be risky; if you run
an application embedding Python in a directory controlled by
someone else, attackers could put a Trojan-horse module in the
directory (say, a file named os.py) that your application would
then import and run.
*/
PySys_SetArgvEx(2, args, 0);
/* Do some application specific code */ /* Do some application specific code */
printf("Hello, brave new world\n\n"); printf("Hello, brave new world\n\n");
......
...@@ -19,7 +19,7 @@ main(int argc, char **argv) ...@@ -19,7 +19,7 @@ main(int argc, char **argv)
count = atoi(argv[2]); count = atoi(argv[2]);
} }
Py_SetProgramName(argv[0]); Py_SetProgramName(L"loop");
/* uncomment this if you don't want to load site.py */ /* uncomment this if you don't want to load site.py */
/* Py_NoSiteFlag = 1; */ /* Py_NoSiteFlag = 1; */
......
...@@ -439,19 +439,21 @@ class Morsel(dict): ...@@ -439,19 +439,21 @@ class Morsel(dict):
# #
_LegalCharsPatt = r"[\w\d!#%&'~_`><@,:/\$\*\+\-\.\^\|\)\(\?\}\{\=]" _LegalCharsPatt = r"[\w\d!#%&'~_`><@,:/\$\*\+\-\.\^\|\)\(\?\}\{\=]"
_CookiePattern = re.compile( _CookiePattern = re.compile(r"""
r"(?x)" # This is a Verbose pattern (?x) # This is a verbose pattern
r"(?P<key>" # Start of group 'key' (?P<key> # Start of group 'key'
""+ _LegalCharsPatt +"+?" # Any word of at least one letter, nongreedy """ + _LegalCharsPatt + r"""+? # Any word of at least one letter
r")" # End of group 'key' ) # End of group 'key'
r"\s*=\s*" # Equal Sign \s*=\s* # Equal Sign
r"(?P<val>" # Start of group 'val' (?P<val> # Start of group 'val'
r'"(?:[^\\"]|\\.)*"' # Any doublequoted string "(?:[^\\"]|\\.)*" # Any doublequoted string
r"|" # or | # or
""+ _LegalCharsPatt +"*" # Any word or empty string \w{3},\s[\w\d-]{9,11}\s[\d:]{8}\sGMT # Special case for "expires" attr
r")" # End of group 'val' | # or
r"\s*;?" # Probably ending in a semi-colon """ + _LegalCharsPatt + r"""* # Any word or empty string
, re.ASCII) # May be removed if safe. ) # End of group 'val'
\s*;? # Probably ending in a semi-colon
""", re.ASCII) # May be removed if safe.
# At long last, here is the cookie class. # At long last, here is the cookie class.
......
...@@ -197,6 +197,9 @@ def samestat(s1, s2): ...@@ -197,6 +197,9 @@ def samestat(s1, s2):
def ismount(path): def ismount(path):
"""Test whether a path is a mount point""" """Test whether a path is a mount point"""
if islink(path):
# A symlink can never be a mount point
return False
try: try:
s1 = os.lstat(path) s1 = os.lstat(path)
if isinstance(path, bytes): if isinstance(path, bytes):
......
...@@ -65,6 +65,36 @@ class CookieTests(unittest.TestCase): ...@@ -65,6 +65,36 @@ class CookieTests(unittest.TestCase):
</script> </script>
""") """)
def test_special_attrs(self):
# 'expires'
C = cookies.SimpleCookie('Customer="WILE_E_COYOTE"')
C['Customer']['expires'] = 0
# can't test exact output, it always depends on current date/time
self.assertTrue(C.output().endswith('GMT'))
# loading 'expires'
C = cookies.SimpleCookie()
C.load('Customer="W"; expires=Wed, 01-Jan-2010 00:00:00 GMT')
self.assertEqual(C['Customer']['expires'],
'Wed, 01-Jan-2010 00:00:00 GMT')
C = cookies.SimpleCookie()
C.load('Customer="W"; expires=Wed, 01-Jan-98 00:00:00 GMT')
self.assertEqual(C['Customer']['expires'],
'Wed, 01-Jan-98 00:00:00 GMT')
# 'max-age'
C = cookies.SimpleCookie('Customer="WILE_E_COYOTE"')
C['Customer']['max-age'] = 10
self.assertEqual(C.output(),
'Set-Cookie: Customer="WILE_E_COYOTE"; Max-Age=10')
# others
C = cookies.SimpleCookie('Customer="WILE_E_COYOTE"')
C['Customer']['secure'] = True
C['Customer']['httponly'] = True
self.assertEqual(C.output(),
'Set-Cookie: Customer="WILE_E_COYOTE"; httponly; secure')
def test_quoted_meta(self): def test_quoted_meta(self):
# Try cookie with quoted meta-data # Try cookie with quoted meta-data
C = cookies.SimpleCookie() C = cookies.SimpleCookie()
......
...@@ -9,7 +9,7 @@ the Python Cookbook, published by O'Reilly. ...@@ -9,7 +9,7 @@ the Python Cookbook, published by O'Reilly.
Library usage: see the Timer class. Library usage: see the Timer class.
Command line usage: Command line usage:
python timeit.py [-n N] [-r N] [-s S] [-t] [-c] [-h] [statement] python timeit.py [-n N] [-r N] [-s S] [-t] [-c] [-h] [--] [statement]
Options: Options:
-n/--number N: how many times to execute 'statement' (default: see below) -n/--number N: how many times to execute 'statement' (default: see below)
...@@ -19,6 +19,7 @@ Options: ...@@ -19,6 +19,7 @@ Options:
-c/--clock: use time.clock() (default on Windows) -c/--clock: use time.clock() (default on Windows)
-v/--verbose: print raw timing results; repeat for more digits precision -v/--verbose: print raw timing results; repeat for more digits precision
-h/--help: print this usage message and exit -h/--help: print this usage message and exit
--: separate options from statement, use when statement starts with -
statement: statement to be timed (default 'pass') statement: statement to be timed (default 'pass')
A multi-line statement may be given by specifying each line as a A multi-line statement may be given by specifying each line as a
......
...@@ -192,11 +192,13 @@ def fullmodname(path): ...@@ -192,11 +192,13 @@ def fullmodname(path):
base = path[len(longest) + 1:] base = path[len(longest) + 1:]
else: else:
base = path base = path
# the drive letter is never part of the module name
drive, base = os.path.splitdrive(base)
base = base.replace(os.sep, ".") base = base.replace(os.sep, ".")
if os.altsep: if os.altsep:
base = base.replace(os.altsep, ".") base = base.replace(os.altsep, ".")
filename, ext = os.path.splitext(base) filename, ext = os.path.splitext(base)
return filename return filename.lstrip(".")
class CoverageResults: class CoverageResults:
def __init__(self, counts=None, calledfuncs=None, infile=None, def __init__(self, counts=None, calledfuncs=None, infile=None,
...@@ -799,7 +801,14 @@ def main(argv=None): ...@@ -799,7 +801,14 @@ def main(argv=None):
try: try:
with open(progname) as fp: with open(progname) as fp:
code = compile(fp.read(), progname, 'exec') code = compile(fp.read(), progname, 'exec')
t.run(code) # try to emulate __main__ namespace as much as possible
globs = {
'__file__': progname,
'__name__': '__main__',
'__package__': None,
'__cached__': None,
}
t.runctx(code, globs, globs)
except IOError as err: except IOError as err:
_err_exit("Cannot run file %r because: %s" % (sys.argv[0], err)) _err_exit("Cannot run file %r because: %s" % (sys.argv[0], err))
except SystemExit: except SystemExit:
......
...@@ -84,6 +84,13 @@ C-API ...@@ -84,6 +84,13 @@ C-API
Library Library
------- -------
- Issue #1713: Fix os.path.ismount(), which returned true for symbolic links
across devices.
- Issue #8826: Properly load old-style "expires" attribute in http.cookies.
- Issue #1690103: Fix initial namespace for code run with trace.main().
- Issue #9448: Fix a leak of OS resources (mutexes or semaphores) when - Issue #9448: Fix a leak of OS resources (mutexes or semaphores) when
re-initializing a buffered IO object by calling its ``__init__`` method. re-initializing a buffered IO object by calling its ``__init__`` method.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment