diff options
author | Xunius <xugzhi1987@gmail.com> | 2018-05-15 07:31:07 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-05-15 07:31:07 +0800 |
commit | b1aaad4f986cb686b55e784baa812bd7a16b9b24 (patch) | |
tree | d479d0e78defba8240a2cfe83740feef617df1db /examples/plugin_avfs.py | |
parent | 7baa70ec2032e328439c286d0e671ef56be22e59 (diff) | |
parent | 42c0d2a65b2b370ac20838aa4507a263cdec24b6 (diff) | |
download | ranger-b1aaad4f986cb686b55e784baa812bd7a16b9b24.tar.gz |
Merge branch 'master' into flagt
Diffstat (limited to 'examples/plugin_avfs.py')
-rw-r--r-- | examples/plugin_avfs.py | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/examples/plugin_avfs.py b/examples/plugin_avfs.py new file mode 100644 index 00000000..07968a03 --- /dev/null +++ b/examples/plugin_avfs.py @@ -0,0 +1,33 @@ +# Tested with ranger 1.9.1 +# +# A very simple and possibly buggy support for AVFS +# (http://avf.sourceforge.net/), that allows ranger to handle +# archives. +# +# Run `:avfs' to browse the selected archive. + +from __future__ import (absolute_import, division, print_function) + +import os +import os.path + +from ranger.api.commands import Command + + +class avfs(Command): # pylint: disable=invalid-name + avfs_root = os.path.join(os.environ["HOME"], ".avfs") + avfs_suffix = "#" + + def execute(self): + if os.path.isdir(self.avfs_root): + archive_directory = "".join([ + self.avfs_root, + self.fm.thisfile.path, + self.avfs_suffix, + ]) + if os.path.isdir(archive_directory): + self.fm.cd(archive_directory) + else: + self.fm.notify("This file cannot be handled by avfs.", bad=True) + else: + self.fm.notify("Install `avfs' and run `mountavfs' first.", bad=True) |