Commit b845decc authored by Benjamin Peterson's avatar Benjamin Peterson

merge heads

parents 0a9a6363 5ceef131
...@@ -151,6 +151,13 @@ The module defines the following functions and data items: ...@@ -151,6 +151,13 @@ The module defines the following functions and data items:
.. versionadded:: 3.3 .. versionadded:: 3.3
.. function:: clock_settime(clk_id, time)
Set the time of the specified clock *clk_id*.
.. versionadded:: 3.3
.. data:: CLOCK_REALTIME .. data:: CLOCK_REALTIME
System-wide real-time clock. Setting this clock requires appropriate System-wide real-time clock. Setting this clock requires appropriate
...@@ -159,6 +166,15 @@ The module defines the following functions and data items: ...@@ -159,6 +166,15 @@ The module defines the following functions and data items:
.. versionadded:: 3.3 .. versionadded:: 3.3
.. data:: CLOCK_HIGHRES
The Solaris OS has a CLOCK_HIGHRES timer that attempts to use an optimal
hardware source, and may give close to nanosecond resolution. CLOCK_HIGHRES
is the nonadjustable, high-resolution clock.
.. versionadded:: 3.3
.. data:: CLOCK_MONOTONIC .. data:: CLOCK_MONOTONIC
Clock that cannot be set and represents monotonic time since some Clock that cannot be set and represents monotonic time since some
......
...@@ -927,6 +927,9 @@ def _find_and_load(name, import_): ...@@ -927,6 +927,9 @@ def _find_and_load(name, import_):
if parent: if parent:
if parent not in sys.modules: if parent not in sys.modules:
import_(parent) import_(parent)
# Crazy side-effects!
if name in sys.modules:
return sys.modules[name]
# Backwards-compatibility; be nicer to skip the dict lookup. # Backwards-compatibility; be nicer to skip the dict lookup.
parent_module = sys.modules[parent] parent_module = sys.modules[parent]
try: try:
......
...@@ -27,6 +27,19 @@ class ParentModuleTests(unittest.TestCase): ...@@ -27,6 +27,19 @@ class ParentModuleTests(unittest.TestCase):
with self.assertRaises(ImportError): with self.assertRaises(ImportError):
import_util.import_('sys.no_submodules_here') import_util.import_('sys.no_submodules_here')
def test_module_not_package_but_side_effects(self):
# If a module injects something into sys.modules as a side-effect, then
# pick up on that fact.
name = 'mod'
subname = name + '.b'
def module_injection():
sys.modules[subname] = 'total bunk'
mock_modules = util.mock_modules('mod',
module_code={'mod': module_injection})
with mock_modules as mock:
with util.import_state(meta_path=[mock]):
submodule = import_util.import_(subname)
def test_main(): def test_main():
from test.support import run_unittest from test.support import run_unittest
......
...@@ -47,6 +47,17 @@ class TimeTestCase(unittest.TestCase): ...@@ -47,6 +47,17 @@ class TimeTestCase(unittest.TestCase):
self.assertGreater(res, 0.0) self.assertGreater(res, 0.0)
self.assertLessEqual(res, 1.0) self.assertLessEqual(res, 1.0)
@unittest.skipUnless(hasattr(time, 'clock_settime'),
'need time.clock_settime()')
def test_clock_settime(self):
t = time.clock_gettime(time.CLOCK_REALTIME)
try:
time.clock_settime(time.CLOCK_REALTIME, t)
except PermissionError:
pass
self.assertRaises(OSError, time.clock_settime, time.CLOCK_MONOTONIC, 0)
def test_conversions(self): def test_conversions(self):
self.assertEqual(time.ctime(self.t), self.assertEqual(time.ctime(self.t),
time.asctime(time.localtime(self.t))) time.asctime(time.localtime(self.t)))
......
...@@ -1510,7 +1510,7 @@ current_context(void) ...@@ -1510,7 +1510,7 @@ current_context(void)
#define CURRENT_CONTEXT_ADDR(ctx) \ #define CURRENT_CONTEXT_ADDR(ctx) \
ctx = CTX(current_context()) ctx = CTX(current_context())
/* Return current context, increment reference */ /* Return a new reference to the current context */
static PyObject * static PyObject *
PyDec_GetCurrentContext(void) PyDec_GetCurrentContext(void)
{ {
...@@ -1614,7 +1614,7 @@ current_context(void) ...@@ -1614,7 +1614,7 @@ current_context(void)
ctx = CTX(_c_t_x_o_b_j); \ ctx = CTX(_c_t_x_o_b_j); \
} }
/* Return current context, increment reference */ /* Return a new reference to the current context */
static PyObject * static PyObject *
PyDec_GetCurrentContext(void) PyDec_GetCurrentContext(void)
{ {
...@@ -1759,7 +1759,7 @@ static PyTypeObject PyDecContextManager_Type = ...@@ -1759,7 +1759,7 @@ static PyTypeObject PyDecContextManager_Type =
0, /* tp_print */ 0, /* tp_print */
(getattrfunc) 0, /* tp_getattr */ (getattrfunc) 0, /* tp_getattr */
(setattrfunc) 0, /* tp_setattr */ (setattrfunc) 0, /* tp_setattr */
0, /* tp_compare */ 0, /* tp_reserved */
(reprfunc) 0, /* tp_repr */ (reprfunc) 0, /* tp_repr */
0, /* tp_as_number */ 0, /* tp_as_number */
0, /* tp_as_sequence */ 0, /* tp_as_sequence */
...@@ -2699,7 +2699,7 @@ ctx_create_decimal(PyObject *context, PyObject *args) ...@@ -2699,7 +2699,7 @@ ctx_create_decimal(PyObject *context, PyObject *args)
/******************************************************************************/ /******************************************************************************/
/* Implicit conversions to Decimal */ /* Implicit conversions to Decimal */
/******************************************************************************/ /******************************************************************************/
/* Try to convert PyObject v to a new PyDecObject conv. If the conversion /* Try to convert PyObject v to a new PyDecObject conv. If the conversion
...@@ -2796,7 +2796,7 @@ convert_op(int type_err, PyObject **conv, PyObject *v, PyObject *context) ...@@ -2796,7 +2796,7 @@ convert_op(int type_err, PyObject **conv, PyObject *v, PyObject *context)
/******************************************************************************/ /******************************************************************************/
/* Implicit conversions to Decimal for comparison */ /* Implicit conversions to Decimal for comparison */
/******************************************************************************/ /******************************************************************************/
/* Convert rationals for comparison */ /* Convert rationals for comparison */
......
...@@ -158,6 +158,33 @@ PyDoc_STRVAR(clock_gettime_doc, ...@@ -158,6 +158,33 @@ PyDoc_STRVAR(clock_gettime_doc,
"clock_gettime(clk_id) -> floating point number\n\ "clock_gettime(clk_id) -> floating point number\n\
\n\ \n\
Return the time of the specified clock clk_id."); Return the time of the specified clock clk_id.");
static PyObject *
time_clock_settime(PyObject *self, PyObject *args)
{
clockid_t clk_id;
PyObject *obj;
struct timespec tp;
int ret;
if (!PyArg_ParseTuple(args, "iO:clock_settime", &clk_id, &obj))
return NULL;
if (_PyTime_ObjectToTimespec(obj, &tp.tv_sec, &tp.tv_nsec) == -1)
return NULL;
ret = clock_settime((clockid_t)clk_id, &tp);
if (ret != 0) {
PyErr_SetFromErrno(PyExc_IOError);
return NULL;
}
Py_RETURN_NONE;
}
PyDoc_STRVAR(clock_settime_doc,
"clock_settime(clk_id, time)\n\
\n\
Set the time of the specified clock clk_id.");
#endif #endif
#ifdef HAVE_CLOCK_GETRES #ifdef HAVE_CLOCK_GETRES
...@@ -962,6 +989,9 @@ PyInit_timezone(PyObject *m) { ...@@ -962,6 +989,9 @@ PyInit_timezone(PyObject *m) {
#ifdef CLOCK_MONOTONIC_RAW #ifdef CLOCK_MONOTONIC_RAW
PyModule_AddIntMacro(m, CLOCK_MONOTONIC_RAW); PyModule_AddIntMacro(m, CLOCK_MONOTONIC_RAW);
#endif #endif
#ifdef CLOCK_HIGHRES
PyModule_AddIntMacro(m, CLOCK_HIGHRES);
#endif
#ifdef CLOCK_PROCESS_CPUTIME_ID #ifdef CLOCK_PROCESS_CPUTIME_ID
PyModule_AddIntMacro(m, CLOCK_PROCESS_CPUTIME_ID); PyModule_AddIntMacro(m, CLOCK_PROCESS_CPUTIME_ID);
#endif #endif
...@@ -980,6 +1010,9 @@ static PyMethodDef time_methods[] = { ...@@ -980,6 +1010,9 @@ static PyMethodDef time_methods[] = {
#ifdef HAVE_CLOCK_GETTIME #ifdef HAVE_CLOCK_GETTIME
{"clock_gettime", time_clock_gettime, METH_VARARGS, clock_gettime_doc}, {"clock_gettime", time_clock_gettime, METH_VARARGS, clock_gettime_doc},
#endif #endif
#ifdef HAVE_CLOCK_GETTIME
{"clock_settime", time_clock_settime, METH_VARARGS, clock_settime_doc},
#endif
#ifdef HAVE_CLOCK_GETRES #ifdef HAVE_CLOCK_GETRES
{"clock_getres", time_clock_getres, METH_VARARGS, clock_getres_doc}, {"clock_getres", time_clock_getres, METH_VARARGS, clock_getres_doc},
#endif #endif
......
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