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
f532d941
Commit
f532d941
authored
Nov 17, 2013
by
Serhiy Storchaka
Browse files
Options
Browse Files
Download
Plain Diff
Merge heads
parents
4725dc3f
f41d0cc2
Changes
10
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
104 additions
and
17 deletions
+104
-17
.hgtags
.hgtags
+2
-0
Doc/library/dbm.rst
Doc/library/dbm.rst
+22
-16
Doc/library/string.rst
Doc/library/string.rst
+1
-1
Lib/dbm/dumb.py
Lib/dbm/dumb.py
+6
-0
Lib/test/test_dbm_dumb.py
Lib/test/test_dbm_dumb.py
+13
-0
Lib/test/test_dbm_gnu.py
Lib/test/test_dbm_gnu.py
+11
-0
Lib/test/test_dbm_ndbm.py
Lib/test/test_dbm_ndbm.py
+13
-0
Misc/NEWS
Misc/NEWS
+3
-0
Modules/_dbmmodule.c
Modules/_dbmmodule.c
+17
-0
Modules/_gdbmmodule.c
Modules/_gdbmmodule.c
+16
-0
No files found.
.hgtags
View file @
f532d941
...
...
@@ -116,6 +116,8 @@ bd8afb90ebf28ba4edc901d4a235f75e7bbc79fd v3.3.0
d9893d13c6289aa03d33559ec67f97dcbf5c9e3c v3.3.1
d047928ae3f6314a13b6137051315453d0ae89b6 v3.3.2
fd53c500f8b80f54f3ecedec9da2e8c7e52a6888 v3.3.3rc1
d32442c0e60dfbd71234e807d3d1dedd227495a9 v3.3.3rc2
c3896275c0f61b2510a6c7e6c458a750359a91b8 v3.3.3
46535f65e7f3bcdcf176f36d34bc1fed719ffd2b v3.4.0a1
9265a2168e2cb2a84785d8717792acc661e6b692 v3.4.0a2
dd9cdf90a5073510877e9dd5112f8e6cf20d5e89 v3.4.0a3
...
...
Doc/library/dbm.rst
View file @
f532d941
...
...
@@ -73,33 +73,39 @@ Key and values are always stored as bytes. This means that when
strings are used they are implicitly converted to the default encoding before
being stored.
These objects also support being used in a :keyword:`with` statement, which
will automatically close them when done.
.. versionchanged:: 3.4
Added native support for the context management protocol to the objects
returned by :func:`.open`.
The following example records some hostnames and a corresponding title, and
then prints out the contents of the database::
import dbm
# Open database, creating it if necessary.
db = dbm.open('cache', 'c')
with dbm.open('cache', 'c') as db:
# Record some values
db[b'hello'] = b'there'
db['www.python.org'] = 'Python Website'
db['www.cnn.com'] = 'Cable News Network'
# Record some values
db[b'hello'] = b'there'
db['www.python.org'] = 'Python Website'
db['www.cnn.com'] = 'Cable News Network'
# Note that the keys are considered bytes now.
assert db[b'www.python.org'] == b'Python Website'
# Notice how the value is now in bytes.
assert db['www.cnn.com'] == b'Cable News Network'
# Note that the keys are considered bytes now.
assert db[b'www.python.org'] == b'Python Website'
# Notice how the value is now in bytes.
assert db['www.cnn.com'] == b'Cable News Network'
# Often-used methods of the dict interface work too.
print(db.get('python.org', b'not present'))
# Often-used methods of the dict interface work too.
print(db.get('python.org', b'not present'))
# Storing a non-string key or value will raise an exception (most
# likely a TypeError).
db['www.yahoo.com'] = 4
# Storing a non-string key or value will raise an exception (most
# likely a TypeError).
db['www.yahoo.com'] = 4
# Close when done.
db.close()
# db is automatically closed when leaving the with statement.
..
seealso::
...
...
Doc/library/string.rst
View file @
f532d941
...
...
@@ -300,7 +300,7 @@ The general form of a *standard format specifier* is:
precision: `integer`
type: "b" | "c" | "d" | "e" | "E" | "f" | "F" | "g" | "G" | "n" | "o" | "s" | "x" | "X" | "%"
If a valid *align* value is specified, it can be prece
e
ded by a *fill*
If a valid *align* value is specified, it can be preceded by a *fill*
character that can be any character and defaults to a space if omitted.
Note that it is not possible to use ``{`` and ``}`` as *fill* char while
using the :meth:`str.format` method; this limitation however doesn't
...
...
Lib/dbm/dumb.py
View file @
f532d941
...
...
@@ -236,6 +236,12 @@ class _Database(collections.MutableMapping):
if
hasattr
(
self
.
_os
,
'chmod'
):
self
.
_os
.
chmod
(
file
,
self
.
_mode
)
def
__enter__
(
self
):
return
self
def
__exit__
(
self
,
*
args
):
self
.
close
()
def
open
(
file
,
flag
=
None
,
mode
=
0o666
):
"""Open the database file, filename, and return corresponding object.
...
...
Lib/test/test_dbm_dumb.py
View file @
f532d941
...
...
@@ -184,6 +184,19 @@ class DumbDBMTestCase(unittest.TestCase):
self
.
assertEqual
(
expected
,
got
)
f
.
close
()
def
test_context_manager
(
self
):
with
dumbdbm
.
open
(
_fname
,
'c'
)
as
db
:
db
[
"dumbdbm context manager"
]
=
"context manager"
with
dumbdbm
.
open
(
_fname
,
'r'
)
as
db
:
self
.
assertEqual
(
list
(
db
.
keys
()),
[
b"dumbdbm context manager"
])
# This currently just raises AttributeError rather than a specific
# exception like the GNU or NDBM based implementations. See
# http://bugs.python.org/issue19385 for details.
with
self
.
assertRaises
(
Exception
):
db
.
keys
()
def
tearDown
(
self
):
_delete_files
()
...
...
Lib/test/test_dbm_gnu.py
View file @
f532d941
...
...
@@ -81,6 +81,17 @@ class TestGdbm(unittest.TestCase):
size2
=
os
.
path
.
getsize
(
filename
)
self
.
assertTrue
(
size1
>
size2
>=
size0
)
def
test_context_manager
(
self
):
with
gdbm
.
open
(
filename
,
'c'
)
as
db
:
db
[
"gdbm context manager"
]
=
"context manager"
with
gdbm
.
open
(
filename
,
'r'
)
as
db
:
self
.
assertEqual
(
list
(
db
.
keys
()),
[
b"gdbm context manager"
])
with
self
.
assertRaises
(
gdbm
.
error
)
as
cm
:
db
.
keys
()
self
.
assertEqual
(
str
(
cm
.
exception
),
"GDBM object has already been closed"
)
if
__name__
==
'__main__'
:
unittest
.
main
()
Lib/test/test_dbm_ndbm.py
View file @
f532d941
...
...
@@ -37,5 +37,18 @@ class DbmTestCase(unittest.TestCase):
except
error
:
self
.
fail
()
def
test_context_manager
(
self
):
with
dbm
.
ndbm
.
open
(
self
.
filename
,
'c'
)
as
db
:
db
[
"ndbm context manager"
]
=
"context manager"
with
dbm
.
ndbm
.
open
(
self
.
filename
,
'r'
)
as
db
:
self
.
assertEqual
(
list
(
db
.
keys
()),
[
b"ndbm context manager"
])
with
self
.
assertRaises
(
dbm
.
ndbm
.
error
)
as
cm
:
db
.
keys
()
self
.
assertEqual
(
str
(
cm
.
exception
),
"DBM object has already been closed"
)
if
__name__
==
'__main__'
:
unittest
.
main
()
Misc/NEWS
View file @
f532d941
...
...
@@ -50,6 +50,9 @@ Core and Builtins
Library
-------
-
Issue
#
19282
:
dbm
.
open
now
supports
the
context
manager
protocol
.
(
Inital
patch
by
Claudiu
Popa
)
-
Issue
#
8311
:
Added
support
for
writing
any
bytes
-
like
objects
in
the
aifc
,
sunau
,
and
wave
modules
.
...
...
Modules/_dbmmodule.c
View file @
f532d941
...
...
@@ -313,6 +313,21 @@ dbm_setdefault(dbmobject *dp, PyObject *args)
return
defvalue
;
}
static
PyObject
*
dbm__enter__
(
PyObject
*
self
,
PyObject
*
args
)
{
Py_INCREF
(
self
);
return
self
;
}
static
PyObject
*
dbm__exit__
(
PyObject
*
self
,
PyObject
*
args
)
{
_Py_IDENTIFIER
(
close
);
return
_PyObject_CallMethodId
(
self
,
&
PyId_close
,
NULL
);
}
static
PyMethodDef
dbm_methods
[]
=
{
{
"close"
,
(
PyCFunction
)
dbm__close
,
METH_NOARGS
,
"close()
\n
Close the database."
},
...
...
@@ -325,6 +340,8 @@ static PyMethodDef dbm_methods[] = {
"setdefault(key[, default]) -> value
\n
"
"Return the value for key if present, otherwise default. If key
\n
"
"is not in the database, it is inserted with default as the value."
},
{
"__enter__"
,
dbm__enter__
,
METH_NOARGS
,
NULL
},
{
"__exit__"
,
dbm__exit__
,
METH_VARARGS
,
NULL
},
{
NULL
,
NULL
}
/* sentinel */
};
...
...
Modules/_gdbmmodule.c
View file @
f532d941
...
...
@@ -425,6 +425,20 @@ dbm_sync(dbmobject *dp, PyObject *unused)
return
Py_None
;
}
static
PyObject
*
dbm__enter__
(
PyObject
*
self
,
PyObject
*
args
)
{
Py_INCREF
(
self
);
return
self
;
}
static
PyObject
*
dbm__exit__
(
PyObject
*
self
,
PyObject
*
args
)
{
_Py_IDENTIFIER
(
close
);
return
_PyObject_CallMethodId
(
self
,
&
PyId_close
,
NULL
);
}
static
PyMethodDef
dbm_methods
[]
=
{
{
"close"
,
(
PyCFunction
)
dbm_close
,
METH_NOARGS
,
dbm_close__doc__
},
{
"keys"
,
(
PyCFunction
)
dbm_keys
,
METH_NOARGS
,
dbm_keys__doc__
},
...
...
@@ -434,6 +448,8 @@ static PyMethodDef dbm_methods[] = {
{
"sync"
,
(
PyCFunction
)
dbm_sync
,
METH_NOARGS
,
dbm_sync__doc__
},
{
"get"
,
(
PyCFunction
)
dbm_get
,
METH_VARARGS
,
dbm_get__doc__
},
{
"setdefault"
,(
PyCFunction
)
dbm_setdefault
,
METH_VARARGS
,
dbm_setdefault__doc__
},
{
"__enter__"
,
dbm__enter__
,
METH_NOARGS
,
NULL
},
{
"__exit__"
,
dbm__exit__
,
METH_VARARGS
,
NULL
},
{
NULL
,
NULL
}
/* sentinel */
};
...
...
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