about summary refs log tree commit diff stats
path: root/examples/plugin_avfs.py
diff options
context:
space:
mode:
authorXunius <xugzhi1987@gmail.com>2018-05-15 07:31:07 +0800
committerGitHub <noreply@github.com>2018-05-15 07:31:07 +0800
commitb1aaad4f986cb686b55e784baa812bd7a16b9b24 (patch)
treed479d0e78defba8240a2cfe83740feef617df1db /examples/plugin_avfs.py
parent7baa70ec2032e328439c286d0e671ef56be22e59 (diff)
parent42c0d2a65b2b370ac20838aa4507a263cdec24b6 (diff)
downloadranger-b1aaad4f986cb686b55e784baa812bd7a16b9b24.tar.gz
Merge branch 'master' into flagt
Diffstat (limited to 'examples/plugin_avfs.py')
-rw-r--r--examples/plugin_avfs.py33
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)