summary refs log tree commit diff stats
path: root/examples/plugin_avfs.py
diff options
context:
space:
mode:
authorWojciech Siewierski <wojciech.siewierski@onet.pl>2018-04-01 23:32:00 +0200
committerWojciech Siewierski <wojciech.siewierski@onet.pl>2018-04-01 23:57:27 +0200
commit00366b27e12023d31dc445660df05000cc47a114 (patch)
tree4b4d8f4bfeef7f44d191691166602f10d6f94679 /examples/plugin_avfs.py
parente09e2648752d24361e94d9bba66c5a1049fd2fb5 (diff)
downloadranger-00366b27e12023d31dc445660df05000cc47a114.tar.gz
examples: Add plugin_avfs.py, a simple AVFS integration
http://avf.sourceforge.net/
Diffstat (limited to 'examples/plugin_avfs.py')
-rw-r--r--examples/plugin_avfs.py31
1 files changed, 31 insertions, 0 deletions
diff --git a/examples/plugin_avfs.py b/examples/plugin_avfs.py
new file mode 100644
index 00000000..6910533c
--- /dev/null
+++ b/examples/plugin_avfs.py
@@ -0,0 +1,31 @@
+# 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)
+
+from ranger.api.commands import Command
+import os
+import os.path
+
+class avfs(Command):
+    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)