X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/python-routefs.git/blobdiff_plain/84dc76ae031c95272512d37269e8a98f629487a4..f2e13ce53aa1209779400a61c7779b87b280f7f8:/routefs/__init__.py diff --git a/routefs/__init__.py b/routefs/__init__.py index 871774e..5137256 100644 --- a/routefs/__init__.py +++ b/routefs/__init__.py @@ -15,7 +15,6 @@ import fuse import routes import errno import stat -from dictfs import DictFS fuse.fuse_python_api = (0, 2) @@ -87,6 +86,10 @@ class RouteFS(fuse.Fuse): return controller = match.pop('controller') result = getattr(self, controller)(**match) + if type(result) is str: + result = File(result) + if type(result) is list: + result = Directory(result) return result def readdir(self, path, offset): @@ -114,14 +117,14 @@ class RouteFS(fuse.Fuse): st = RouteStat() if type(obj) is Directory: - st.st_mode = stat.S_IFDIR | 0755 + st.st_mode = stat.S_IFDIR | obj.mode st.st_nlink = 2 elif type(obj) is Symlink: - st.st_mode = stat.S_IFLNK | 0777 + st.st_mode = stat.S_IFLNK | obj.mode st.st_nlink = 1 st.st_size = len(obj) else: - st.st_mode = stat.S_IFREG | 0444 + st.st_mode = stat.S_IFREG | obj.mode st.st_nlink = 1 st.st_size = len(obj) @@ -150,18 +153,38 @@ class RouteFS(fuse.Fuse): else: return obj -class Directory(list): +class TreeEntry(object): + default_mode = 0444 + + def __new__(cls, contents, mode=None): + return super(TreeEntry, cls).__new__(cls, contents) + + def __init__(self, contents, mode=None): + if mode is None: + self.mode = self.default_mode + else: + self.mode = mode + + super(TreeEntry, self).__init__(contents) + +class Directory(TreeEntry, list): """ A dummy class representing a filesystem entry that should be a directory """ - pass + default_mode = 0555 -class Symlink(str): +class Symlink(TreeEntry, str): """ A dummy class representing something that should be a symlink """ - pass + default_mode = 0777 + +class File(TreeEntry, str): + """ + A dummy class representing something that should be a file + """ + default_mode = 0444 def main(cls): """ @@ -173,4 +196,6 @@ def main(cls): server.parse(errex=1) server.main() -__all__ = ['RouteFS', 'DictFS', 'Symlink', 'Directory', 'main'] +from dictfs import DictFS + +__all__ = ['RouteFS', 'DictFS', 'Symlink', 'Directory', 'File', 'main']