Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
b845decc
Commit
b845decc
authored
Apr 03, 2012
by
Benjamin Peterson
Browse files
Options
Browse Files
Download
Plain Diff
merge heads
parents
0a9a6363
5ceef131
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
81 additions
and
5 deletions
+81
-5
Doc/library/time.rst
Doc/library/time.rst
+16
-0
Lib/importlib/_bootstrap.py
Lib/importlib/_bootstrap.py
+3
-0
Lib/importlib/test/import_/test_packages.py
Lib/importlib/test/import_/test_packages.py
+13
-0
Lib/test/test_time.py
Lib/test/test_time.py
+11
-0
Modules/_decimal/_decimal.c
Modules/_decimal/_decimal.c
+5
-5
Modules/timemodule.c
Modules/timemodule.c
+33
-0
No files found.
Doc/library/time.rst
View file @
b845decc
...
@@ -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
...
...
Lib/importlib/_bootstrap.py
View file @
b845decc
...
@@ -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
:
...
...
Lib/importlib/test/import_/test_packages.py
View file @
b845decc
...
@@ -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
...
...
Lib/test/test_time.py
View file @
b845decc
...
@@ -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
)))
...
...
Modules/_decimal/_decimal.c
View file @
b845decc
...
@@ -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 */
...
...
Modules/timemodule.c
View file @
b845decc
...
@@ -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
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment