X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/python-routefs.git/blobdiff_plain/1a73a7a8555da25ee7c7a36496a389928e379002..refs/heads/dev:/routefs/__init__.py diff --git a/routefs/__init__.py b/routefs/__init__.py index 162601e..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: @@ -119,13 +121,7 @@ class RouteFS(fuse.Fuse): """ 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): @@ -134,6 +130,8 @@ class TreeKey(object): return -errno.EINVAL def read(self, length, offset): return -errno.EINVAL + def readlink(self): + return -errno.EINVAL class NoEntry(TreeKey): def getattr(self): @@ -142,6 +140,8 @@ class NoEntry(TreeKey): return -errno.ENOENT def read(self, length, offset): return -errno.ENOENT + def readlink(self): + return -errno.ENOENT class TreeEntry(TreeKey): default_mode = 0444 @@ -187,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