projects
/
arvados.git
/ blobdiff
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
6260: most golint suggestions are addressed.
[arvados.git]
/
services
/
fuse
/
arvados_fuse
/
fusefile.py
diff --git
a/services/fuse/arvados_fuse/fusefile.py
b/services/fuse/arvados_fuse/fusefile.py
index efe31c387c09432f3905144c19b5417161d6a1a7..4d472cff1cca38380d80afa63b9783027ad1db30 100644
(file)
--- a/
services/fuse/arvados_fuse/fusefile.py
+++ b/
services/fuse/arvados_fuse/fusefile.py
@@
-1,6
+1,7
@@
import logging
import re
import json
import logging
import re
import json
+import llfuse
from fresh import FreshBase, convertTime
from fresh import FreshBase, convertTime
@@
-18,32
+19,55
@@
class File(FreshBase):
def size(self):
return 0
def size(self):
return 0
- def readfrom(self, off, size):
+ def readfrom(self, off, size
, num_retries=0
):
return ''
return ''
+ def writeto(self, off, size, num_retries=0):
+ raise Exception("Not writable")
+
def mtime(self):
return self._mtime
def clear(self, force=False):
return True
def mtime(self):
return self._mtime
def clear(self, force=False):
return True
+ def writable(self):
+ return False
+
+ def flush(self):
+ pass
-class StreamReaderFile(File):
- """Wraps a StreamFileReader as a file."""
- def __init__(self, parent_inode, reader, _mtime):
- super(StreamReaderFile, self).__init__(parent_inode, _mtime)
- self.reader = reader
+class FuseArvadosFile(File):
+ """Wraps a ArvadosFile."""
+
+ def __init__(self, parent_inode, arvfile, _mtime):
+ super(FuseArvadosFile, self).__init__(parent_inode, _mtime)
+ self.arvfile = arvfile
def size(self):
def size(self):
- return self.reader.size()
+ with llfuse.lock_released:
+ return self.arvfile.size()
+
+ def readfrom(self, off, size, num_retries=0):
+ with llfuse.lock_released:
+ return self.arvfile.readfrom(off, size, num_retries, exact=True)
- def readfrom(self, off, size):
- return self.reader.readfrom(off, size)
+ def writeto(self, off, buf, num_retries=0):
+ with llfuse.lock_released:
+ return self.arvfile.writeto(off, buf, num_retries)
def stale(self):
return False
def stale(self):
return False
+ def writable(self):
+ return self.arvfile.writable()
+
+ def flush(self):
+ with llfuse.lock_released:
+ if self.writable():
+ self.arvfile.parent.root_collection().save()
+
class StringFile(File):
"""Wrap a simple string as a file"""
class StringFile(File):
"""Wrap a simple string as a file"""
@@
-54,7
+78,7
@@
class StringFile(File):
def size(self):
return len(self.contents)
def size(self):
return len(self.contents)
- def readfrom(self, off, size):
+ def readfrom(self, off, size
, num_retries=0
):
return self.contents[off:(off+size)]
return self.contents[off:(off+size)]
@@
-63,9
+87,15
@@
class ObjectFile(StringFile):
def __init__(self, parent_inode, obj):
super(ObjectFile, self).__init__(parent_inode, "", 0)
def __init__(self, parent_inode, obj):
super(ObjectFile, self).__init__(parent_inode, "", 0)
- self.uuid = obj['uuid']
+ self.
object_
uuid = obj['uuid']
self.update(obj)
self.update(obj)
- def update(self, obj):
+ def uuid(self):
+ return self.object_uuid
+
+ def update(self, obj=None):
self._mtime = convertTime(obj['modified_at']) if 'modified_at' in obj else 0
self.contents = json.dumps(obj, indent=4, sort_keys=True) + "\n"
self._mtime = convertTime(obj['modified_at']) if 'modified_at' in obj else 0
self.contents = json.dumps(obj, indent=4, sort_keys=True) + "\n"
+
+ def persisted(self):
+ return True