-
Notifications
You must be signed in to change notification settings - Fork 667
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Serialize FileIO and TextIOWrapper and Universe #2723
Merged
Merged
Changes from 3 commits
Commits
Show all changes
120 commits
Select commit
Hold shift + click to select a range
931d9b5
Merge pull request #1 from MDAnalysis/develop
yuxuanzhuang d69ce98
Merge remote-tracking branch 'mda_origin/develop' into develop
yuxuanzhuang 432edf3
add pickle function to fileio, textio
yuxuanzhuang bf55bf3
add basic test for pickle io
yuxuanzhuang cd9a485
add comments
yuxuanzhuang f33629f
xfail on python2
yuxuanzhuang aca4496
add doc and exception for pickle_open
yuxuanzhuang cd4ffe3
add doc for textio fileio class
yuxuanzhuang ec5bd3c
add parallel test for textio
yuxuanzhuang f6515ee
pep8
yuxuanzhuang cf29764
add an extra bufferlayer for FileIO for fast access
yuxuanzhuang 6b09e20
Merge remote-tracking branch 'mda_origin/develop' into serialize_io
yuxuanzhuang c29c316
ditch py2
yuxuanzhuang db47e27
pep8 and doc
yuxuanzhuang 7e9d6d3
add test for unsupported mode
yuxuanzhuang eb83a7c
pep8
yuxuanzhuang 0baa868
typo
yuxuanzhuang c8e63b2
pickle reorder
yuxuanzhuang 658b446
pickle_open as context manager
yuxuanzhuang 1aa6003
format
yuxuanzhuang f2738bc
move pickle-io to a separate file
yuxuanzhuang 001f3b8
doc
yuxuanzhuang d0374f5
FileIOPicklable class now only supports name as input, (preventing us…
yuxuanzhuang 8c62df8
pickle open doc and add fspath for the filename
yuxuanzhuang 94f1f8d
absolute import
yuxuanzhuang acbadec
more doc
yuxuanzhuang 7043d2d
more pep8 and format
yuxuanzhuang 546b05d
Merge remote-tracking branch 'mda_origin/develop' into serialize_io
yuxuanzhuang c259143
sphinx mark up
yuxuanzhuang a016a65
add pickle_open example
yuxuanzhuang 401e6ae
changelog
yuxuanzhuang 9225c71
sphinx more
yuxuanzhuang 46c43af
add context manager approach text
yuxuanzhuang 21fe5aa
add match for test valueerror
yuxuanzhuang 821c822
typo
yuxuanzhuang 5e25380
Merge branch 'develop' into serialize_io
yuxuanzhuang 2541a3e
tell error and fileio cov
yuxuanzhuang 1003cd3
Merge branch 'serialize_io' of https://github.com/yuxuanzhuang/mdanal…
yuxuanzhuang 1b7a798
Merge branch 'develop' into serialize_io
yuxuanzhuang b79d282
remove future import
yuxuanzhuang d909d63
merge to develop
yuxuanzhuang cafc596
sphinx block code
yuxuanzhuang 2db1ef2
typo
yuxuanzhuang 33ef68a
Merge branch 'develop' into serialize_io
yuxuanzhuang 24f2a34
Merge branch 'develop' into serialize_io
yuxuanzhuang 84baca9
pickle open pdb and xyz
yuxuanzhuang 108ebde
Merge branch 'serialize_io' of https://github.com/yuxuanzhuang/mdanal…
yuxuanzhuang 7cb40ad
add pickle support to universe, add test, add chainreader
yuxuanzhuang 352ab96
fix misc issues
yuxuanzhuang 356986f
remove python2 legacy bz2
yuxuanzhuang e5ef732
remove fail test for offset
yuxuanzhuang aa6e40d
issue raised in changelog
yuxuanzhuang 43a62d5
pep8
yuxuanzhuang 2559625
add pickle func to ReaderBase and set offset
yuxuanzhuang 507f8f5
add test for bz2 gzip and class check
yuxuanzhuang 26fcfe9
add test for gsd, ncdf
yuxuanzhuang 405a6dc
add test for trajectory.next after pickling
yuxuanzhuang 2380a47
older gsd file
yuxuanzhuang dab38c1
move gsd, ncdf to coord
yuxuanzhuang 5c07901
add chainreader state
yuxuanzhuang b324791
test timestep
yuxuanzhuang 49f959d
doc
yuxuanzhuang 773524d
add doc version change
yuxuanzhuang b7e4ef0
chainreader fix
yuxuanzhuang 9d376b7
docstring error
yuxuanzhuang 11cceb4
check dt before pickle
yuxuanzhuang a3130f5
add pickle test to base
yuxuanzhuang faf1e01
Merge branch 'develop' into serialize_io
yuxuanzhuang df7eb86
add chemfiles pickle
yuxuanzhuang 72ba276
doc
yuxuanzhuang aa62ff0
doc add note
yuxuanzhuang 04be63d
merge to develop
yuxuanzhuang f01769f
merge to develop
yuxuanzhuang 5a2b28d
change chain getstate
yuxuanzhuang b5f5270
add in-line comments
yuxuanzhuang e1facfb
pep8
yuxuanzhuang cba4456
add chemfile test
yuxuanzhuang 5622b51
pep8
yuxuanzhuang 46cda48
raise error with mode
yuxuanzhuang 5e2ee79
change to read_step
yuxuanzhuang b23b2fb
change to almost_equal
yuxuanzhuang cd03058
save frame
yuxuanzhuang 3ce8ba7
save frame pep
yuxuanzhuang a5da2f7
add doc for pickle
yuxuanzhuang 5a9ad4d
timestep pickle doc
yuxuanzhuang bc60aa7
doc serialize
yuxuanzhuang 01fc644
doc sphinx
yuxuanzhuang 84eb61f
pickle u with getsetstate
yuxuanzhuang 9f18ccd
pep
yuxuanzhuang 8d07004
Merge branch 'develop' into serialize_io
yuxuanzhuang e37c84a
warning on cfg
yuxuanzhuang 2d3de99
sep files
yuxuanzhuang 67b65d1
merge to develop
yuxuanzhuang 18d146b
sep to two files
yuxuanzhuang 8679e50
fixed failed merge in CHANGELOG
orbeckst 0ceffe5
removed superfluous blank lines from CHANGELOG
orbeckst 688041c
xdr dcd seek error
yuxuanzhuang 204545b
Merge branch 'serialize_io' of https://github.com/yuxuanzhuang/mdanal…
yuxuanzhuang 3c71f8a
Merge remote-tracking branch 'mda_origin/develop' into serialize_io
yuxuanzhuang f2239bb
current frame xdr/dcd
yuxuanzhuang 78c93a0
Merge branch 'develop' into serialize_io
orbeckst c0d241e
remove tests not needed
yuxuanzhuang 68b1c2a
pep
yuxuanzhuang 4061434
Merge branch 'develop' into serialize_io
yuxuanzhuang d457491
test title more accurate
yuxuanzhuang 4c70dcb
Merge remote-tracking branch 'mda_origin/develop' into serialize_io
yuxuanzhuang 0496ca1
misc
yuxuanzhuang df061fc
gsd dim
yuxuanzhuang abe92da
add test for runtimee pickle
yuxuanzhuang b3469fe
add test for runtimee pickle
yuxuanzhuang b12eb0d
pep
yuxuanzhuang fae4797
doc pickle_reader
yuxuanzhuang 52a981e
mock chemfiles
yuxuanzhuang c4ec287
chemfiles mock when not found
yuxuanzhuang 8804e5b
doc revised
yuxuanzhuang c99867f
add pickle test to single_framereader
yuxuanzhuang a70bc8b
add pickle test to fhiams
yuxuanzhuang bc487a5
test doc
yuxuanzhuang a1bb47e
test doc title
yuxuanzhuang 5ace1e0
test doc title 2
yuxuanzhuang File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -80,9 +80,12 @@ class FileIOPicklable(io.FileIO): | |
Parameters | ||
---------- | ||
name : str | ||
a filename given a text or byte string. | ||
either a text or byte string giving the name (and the path | ||
if the file isn't in the current working directory) of the file to | ||
be opened. | ||
mode : str | ||
only reading ('r') mode works. | ||
only reading ('r') mode works. It exists to be consistent | ||
with a wider API. | ||
|
||
Example | ||
------- | ||
|
@@ -227,12 +230,14 @@ class BZ2Picklable(bz2.BZ2File): | |
Note | ||
---- | ||
This class only supports reading files in binary mode. If you need to open | ||
to open a compressed file in text mode, use the :func:`bz2_pickle_open`. | ||
to open a compressed file in text mode, use :func:`bz2_pickle_open`. | ||
|
||
Parameters | ||
---------- | ||
name : str | ||
a filename given a text or byte string. | ||
either a text or byte string giving the name (and the path | ||
if the file isn't in the current working directory) of the file to | ||
be opened. | ||
mode : str | ||
can only be 'r', 'rb' to make pickle work. | ||
|
||
|
@@ -292,7 +297,9 @@ class GzipPicklable(gzip.GzipFile): | |
Parameters | ||
---------- | ||
name : str | ||
a filename given a text or byte string. | ||
either a text or byte string giving the name (and the path | ||
if the file isn't in the current working directory) of the file to | ||
be opened. | ||
mode : str | ||
can only be 'r', 'rb' to make pickle work. | ||
|
||
|
@@ -334,14 +341,16 @@ def __setstate__(self, args): | |
def pickle_open(name, mode='rt'): | ||
"""Open file and return a stream with pickle function implemented. | ||
|
||
orbeckst marked this conversation as resolved.
Show resolved
Hide resolved
|
||
This function returns either BufferIOPicklable or TextIOPicklable wrapped | ||
FileIOPicklable object given different reading mode. It can be used as a | ||
context manager, and replace the built-in :func:`open` function | ||
in read mode that only returns an unpicklable file object. | ||
This function returns a FileIOPicklable object wrapped in a | ||
BufferIOPicklable class when given the "rb" reading mode, | ||
or a FileIOPicklable object wrapped in a TextIOPicklable class with the "r" | ||
or "rt" reading mode. It can be used as a context manager, and replace the | ||
built-in :func:`open` function in read mode that only returns an | ||
unpicklable file object. | ||
In order to serialize a :class:`MDAnalysis.core.Universe`, this function | ||
can used to open trajectory/topology files--an object composition approach, | ||
as opposed to class inheritance, which is more flexible and easier for | ||
pickle implementation for new readers. | ||
can used to open trajectory/topology files. This object composition is more | ||
flexible and easier than class inheritance to implement pickling | ||
for new readers. | ||
|
||
Note | ||
---- | ||
|
@@ -350,7 +359,9 @@ def pickle_open(name, mode='rt'): | |
Parameters | ||
---------- | ||
name : str | ||
a filename given a text or byte string. | ||
either a text or byte string giving the name (and the path | ||
if the file isn't in the current working directory) of the file to | ||
be opened. | ||
mode: {'r', 'rt', 'rb'} (optional) | ||
'r': open for reading in text mode; | ||
'rt': read in text mode (default); | ||
|
@@ -390,7 +401,7 @@ def pickle_open(name, mode='rt'): | |
""" | ||
yuxuanzhuang marked this conversation as resolved.
Show resolved
Hide resolved
|
||
if mode not in {'r', 'rt', 'rb'}: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. actually. A different idea here could be to fall back to the standard open function in case of writing. |
||
raise ValueError("Only read mode ('r', 'rt', 'rb') " | ||
"iles can be pickled.") | ||
"files can be pickled.") | ||
name = os.fspath(name) | ||
orbeckst marked this conversation as resolved.
Show resolved
Hide resolved
|
||
raw = FileIOPicklable(name) | ||
if mode == 'rb': | ||
|
@@ -403,10 +414,12 @@ def bz2_pickle_open(name, mode='rb'): | |
"""Open a bzip2-compressed file in binary or text mode | ||
with pickle function implemented. | ||
|
||
This function returns either BZ2Picklable or TextIOPicklable wrapped | ||
BZ2Picklable object given different reading mode. It can be used as a | ||
context manager, and replace the built-in :func:`bz2.open` function | ||
in read mode that only returns an unpicklable file object. | ||
This function returns a BZ2Picklable object when given the "rb" or "r" | ||
reading mode, or a BZ2Picklable object wrapped in a TextIOPicklable class | ||
with the "rt" reading mode. | ||
It can be used as a context manager, and replace the built-in | ||
:func:`bz2.open` function in read mode that only returns an | ||
unpicklable file object. | ||
|
||
Note | ||
---- | ||
|
@@ -415,7 +428,9 @@ def bz2_pickle_open(name, mode='rb'): | |
Parameters | ||
---------- | ||
name : str | ||
a filename given a text or byte string. | ||
either a text or byte string giving the name (and the path | ||
if the file isn't in the current working directory) of the file to | ||
be opened. | ||
mode: {'r', 'rt', 'rb'} (optional) | ||
'r': open for reading in binary mode; | ||
'rt': read in text mode; | ||
|
@@ -471,10 +486,12 @@ def gzip_pickle_open(name, mode='rb'): | |
"""Open a gzip-compressed file in binary or text mode | ||
with pickle function implemented. | ||
|
||
This function returns either GzipPicklable or TextIOPicklable wrapped | ||
GzipPicklable object given different reading mode. It can be used as a | ||
context manager, and replace the built-in :func:`gzip.open` function | ||
in read mode that only returns an unpicklable file object. | ||
This function returns a GzipPicklable object when given the "rb" or "r" | ||
reading mode, or a GzipPicklable object wrapped in a TextIOPicklable class | ||
with the "rt" reading mode. | ||
It can be used as a context manager, and replace the built-in | ||
:func:`gzip.open` function in read mode that only returns an | ||
unpicklable file object. | ||
|
||
Note | ||
---- | ||
|
@@ -483,7 +500,9 @@ def gzip_pickle_open(name, mode='rb'): | |
Parameters | ||
---------- | ||
name : str | ||
a filename given a text or byte string. | ||
either a text or byte string giving the name (and the path | ||
if the file isn't in the current working directory) of the file to | ||
be opened. | ||
mode: {'r', 'rt', 'rb'} (optional) | ||
'r': open for reading in binary mode; | ||
'rt': read in text mode; | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I do not particularly like this function. It is unclear from the name that this can only be used to open files for reading. You also implicitly assume we always want to pickle a file object when we open it for reading. I would much rather have an exception when we actually try to pickle the file.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So if we get IO classes that behave like the original ones except that they raise an error when you try to pickle with “w” but pickle fine with “r” then we still need our own
open()
function, right? Could we directly haveanyopen()
use these new classes? (Maybe you said this already somewhere...)There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not sure. But yeah only using anyopen uniformly in MDAnalysis sounds good.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We could mark the
pickle_open()
function and related functions as private for now, i.e.,_pickle_open()
,_bz2_pickle_open()
,_gsd_pickle_open()
etc. We then have the freedom to change implementation in a backward-incompatible fashion even after a 2.0 release, e.g., if we want to go back to the idea to having classes that accept r and w and only fail pickling at runtime.Or are ultimately ok with the design as it stands, @kain88-de ?