-
Notifications
You must be signed in to change notification settings - Fork 0
/
pyfile.py
107 lines (72 loc) · 2.75 KB
/
pyfile.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
class IOInterface(object):
"""This is the interface mutagen expects from custom file-like
objects.
For loading read(), tell() and seek() have to be implemented. "name"
is optional.
For saving/deleting write(), flush() and truncate() have to be
implemented in addition. fileno() is optional.
"""
# For loading
def tell(self):
"""Returns he current offset as int. Always >= 0.
Raises IOError in case fetching the position is for some reason
not possible.
"""
raise NotImplementedError
def read(self, size=-1):
"""Returns 'size' amount of bytes or less if there is no more data.
If no size is given all data is returned. size can be >= 0.
Raises IOError in case reading failed while data was available.
"""
raise NotImplementedError
def seek(self, offset, whence=0):
"""Move to a new offset either relative or absolute. whence=0 is
absolute, whence=1 is relative, whence=2 is relative to the end.
Any relative or absolute seek operation which would result in a
negative position is undefined and that case can be ignored
in the implementation.
Any seek operation which moves the position after the stream
should succeed. tell() should report that position and read()
should return an empty bytes object.
Returns Nothing.
Raise IOError in case the seek operation asn't possible.
"""
raise NotImplementedError
# For loading, but optional
@property
def name(self):
"""Should return text. For example the file name.
If not available the attribute can be missing or can return
an empty string.
Will be used for error messages and type detection.
"""
raise NotImplementedError
# For writing
def write(self, data):
"""Write data to the file.
Returns Nothing.
Raises IOError
"""
raise NotImplementedError
def truncate(self, size=None):
"""Truncate to the current position or size if size is given.
The current position or given size will never be larger than the
file size.
This has to flush write buffers in case writing is buffered.
Returns Nothing.
Raises IOError.
"""
raise NotImplementedError
def flush(self):
"""Flush the write buffer.
Returns Nothing.
Raises IOError.
"""
raise NotImplementedError
# For writing, but optional
def fileno(self):
"""Returns the file descriptor (int) or raises IOError
if there is none.
Will be used for low level operations if available.
"""
raise NotImplementedError