summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAyke van Laethem <aykevanlaethem@gmail.com>2017-12-19 23:47:07 +0100
committerDamien George <damien.p.george@gmail.com>2018-01-31 17:33:07 +1100
commit7642785881550bd71815623c4f93e0516217429c (patch)
tree86c32f05a37566853d583498a66cc58acd500ed1
parentdf952633ef806d848ea75148a7be52e6a4e7f9fe (diff)
extmod/vfs_fat_file: Implement SEEK_CUR for non-zero offset.
CPython doesn't allow SEEK_CUR with non-zero offset for files in text mode, and uPy inherited this behaviour for both text and binary files. It makes sense to provide full support for SEEK_CUR of binary-mode files in uPy, and to do this in a minimal way means also allowing to use SEEK_CUR with non-zero offsets on text-mode files. That seems to be a fair compromise.
-rw-r--r--extmod/vfs_fat_file.c6
-rw-r--r--tests/extmod/vfs_fat_fileio1.py6
-rw-r--r--tests/extmod/vfs_fat_fileio1.py.exp2
3 files changed, 4 insertions, 10 deletions
diff --git a/extmod/vfs_fat_file.c b/extmod/vfs_fat_file.c
index 1fcbb253d..6154c8483 100644
--- a/extmod/vfs_fat_file.c
+++ b/extmod/vfs_fat_file.c
@@ -134,11 +134,7 @@ STATIC mp_uint_t file_obj_ioctl(mp_obj_t o_in, mp_uint_t request, uintptr_t arg,
break;
case 1: // SEEK_CUR
- if (s->offset != 0) {
- *errcode = MP_EOPNOTSUPP;
- return MP_STREAM_ERROR;
- }
- // no-operation
+ f_lseek(&self->fp, f_tell(&self->fp) + s->offset);
break;
case 2: // SEEK_END
diff --git a/tests/extmod/vfs_fat_fileio1.py b/tests/extmod/vfs_fat_fileio1.py
index d19df120b..8b9ff92eb 100644
--- a/tests/extmod/vfs_fat_fileio1.py
+++ b/tests/extmod/vfs_fat_fileio1.py
@@ -91,10 +91,8 @@ with open("foo_file.txt") as f2:
f2.seek(0, 1) # SEEK_CUR
print(f2.read(1))
- try:
- f2.seek(1, 1) # SEEK_END
- except OSError as e:
- print(e.args[0] == uerrno.EOPNOTSUPP)
+ f2.seek(2, 1) # SEEK_CUR
+ print(f2.read(1))
f2.seek(-2, 2) # SEEK_END
print(f2.read(1))
diff --git a/tests/extmod/vfs_fat_fileio1.py.exp b/tests/extmod/vfs_fat_fileio1.py.exp
index d777585cf..a66f07605 100644
--- a/tests/extmod/vfs_fat_fileio1.py.exp
+++ b/tests/extmod/vfs_fat_fileio1.py.exp
@@ -7,7 +7,7 @@ hello!world!
12
h
e
-True
+o
d
True
[('foo_dir', 16384, 0)]