blob: 38c4a17c94d3290dfcf9c4c413e3ede9b60f2c03 (
plain) (
tree)
|
|
# Tested with ranger 1.7.2
#
# This plugin creates a bunch of keybindings used to mount and unmount
# the devices using pmount(1).
#
# alt+m <letter> <digit>: mount /dev/sd<letter><digit>
# alt+m <uppercase letter> : mount /dev/sd<letter>
# alt+shift+m <letter> <digit>: unmount /dev/sd<letter><digit>
# alt+shift+m <uppercase letter> : unmount /dev/sd<letter>
# alt+shift+n : list the devices
from __future__ import (absolute_import, division, print_function)
import ranger.api
MOUNT_KEY = '<alt>m'
UMOUNT_KEY = '<alt>M'
LIST_MOUNTS_KEY = '<alt>N'
HOOK_INIT_OLD = ranger.api.hook_init
def hook_init(fm):
fm.execute_console("map {key} shell -p lsblk".format(key=LIST_MOUNTS_KEY))
for disk in "abcdefgh":
fm.execute_console("map {key}{0} chain shell pmount sd{1}; cd /media/sd{1}".format(
disk.upper(), disk, key=MOUNT_KEY))
fm.execute_console("map {key}{0} chain cd; chain shell pumount sd{1}".format(
disk.upper(), disk, key=UMOUNT_KEY))
for part in "123456789":
fm.execute_console(
"map {key}{0}{1} chain shell pmount sd{0}{1}; cd /media/sd{0}{1}".format(
disk, part, key=MOUNT_KEY)
)
fm.execute_console("map {key}{0}{1} chain cd; shell pumount sd{0}{1}".format(
disk, part, key=UMOUNT_KEY))
return HOOK_INIT_OLD(fm)
ranger.api.hook_init = hook_init
|