X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/python-routefs.git/blobdiff_plain/dc42e1c9590fe239e37f2218d115a4ea810f9882..1ca21d260eed935ea49c846dfd9ce217d8685778:/routefs/__init__.py diff --git a/routefs/__init__.py b/routefs/__init__.py index bd7fa7b..c3b0357 100644 --- a/routefs/__init__.py +++ b/routefs/__init__.py @@ -86,6 +86,8 @@ class RouteFS(fuse.Fuse): return NoEntry() controller = match.pop('controller') result = getattr(self, controller)(**match) + if result is None: + return NoEntry() if type(result) is str: result = File(result) if type(result) is list: @@ -113,37 +115,33 @@ class RouteFS(fuse.Fuse): If the path specified is a file, return the requested portion of the file """ - obj = self._get_file(path) - if type(obj) is NoEntry: - return -errno.ENOENT - elif type(obj) in (Directory, Symlink): - return -errno.EINVAL - else: - return obj[offset:offset + length] + return self._get_file(path).read(length, offset) def readlink(self, path): """ If the path specified is a symlink, return the target """ - obj = self._get_file(path) - if obj is None: - return -errno.ENOENT - elif type(obj) is not Symlink: - return -errno.EINVAL - else: - return obj + return self._get_file(path).readlink() class TreeKey(object): def getattr(self): return -errno.EINVAL def readdir(self, offset): return -errno.EINVAL + def read(self, length, offset): + return -errno.EINVAL + def readlink(self): + return -errno.EINVAL class NoEntry(TreeKey): def getattr(self): return -errno.ENOENT def readdir(self, offset): return -errno.ENOENT + def read(self, length, offset): + return -errno.ENOENT + def readlink(self): + return -errno.ENOENT class TreeEntry(TreeKey): default_mode = 0444 @@ -189,6 +187,9 @@ class Symlink(TreeEntry, str): st.st_size = len(self) return st + def readlink(self): + return self + class File(TreeEntry, str): """ A dummy class representing something that should be a file @@ -202,6 +203,9 @@ class File(TreeEntry, str): st.st_size = len(self) return st + def read(self, length, offset): + return self[offset:offset + length] + def main(cls): """ A convenience function for initializing a RouteFS filesystem