X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/python-routefs.git/blobdiff_plain/52e4d12ce32bb9aa4a9366ca3f9f57e191e3edc6..837e818319e2394caf2dcab5e40b18dcad3c6f0b:/routefs/examples/pyhesiodfs.py diff --git a/routefs/examples/pyhesiodfs.py b/routefs/examples/pyhesiodfs.py index 92986a2..2a9bfb0 100755 --- a/routefs/examples/pyhesiodfs.py +++ b/routefs/examples/pyhesiodfs.py @@ -1,27 +1,31 @@ #!/usr/bin/python + import hesiod -import routefs from routes import Mapper +import routefs + + class PyHesiodFS(routefs.RouteFS): + controllers = ['getList', 'getReadme', 'getLocker'] def __init__(self, *args, **kwargs): super(PyHesiodFS, self).__init__(*args, **kwargs) self.fuse_args.add("allow_other", True) - + self.cache = {} - + def make_map(self): m = Mapper() m.connect('', controller='getList') m.connect('README.txt', controller='getReadme') m.connect(':action', controller='getLocker') return m - + def getLocker(self, action, **kwargs): if action in self.cache: return routefs.Symlink(self.cache[action]) - + try: filsys = hesiod.FilsysLookup(action).filsys[0] if filsys['type'] == 'AFS': @@ -29,10 +33,10 @@ class PyHesiodFS(routefs.RouteFS): return routefs.Symlink(self.cache[action]) except (TypeError, KeyError, IndexError): return - + def getList(self, **kwargs): return self.cache.keys() + ['README.txt'] - + def getReadme(self, **kwargs): return """ This is the pyHesiodFS FUSE automounter. To access a Hesiod filsys, @@ -42,5 +46,6 @@ If you're using the Finder, try pressing Cmd+Shift+G and then entering /mit/name """ + if __name__ == '__main__': routefs.main(PyHesiodFS)