# vim: filetype=cfg
# _ __ _
# _ __(_)/ _| | ___
# | '__| | |_| |/ _ \
# | | | | _| | __/
# |_| |_|_| |_|\___|
#
# ~/.config/ranger/rifle.conf
# This is the configuration file of "rifle", ranger's file executor/opener.
# Each line consists of conditions and a command. For each line the conditions
# are checked and if they are met, the respective command is run.
#
# Syntax:
# <condition1> , <condition2> , ... = command
#
# The command can contain these environment variables:
# $1-$9 | The n-th selected file
# $@ | All selected files
#
# If you use the special command "ask", rifle will ask you what program to run.
#
# Prefixing a condition with "!" will negate its result.
# These conditions are currently supported:
# match <regexp> | The regexp matches $1
# ext <regexp> | The regexp matches the extension of $1
# mime <regexp> | The regexp matches the mime type of $1
# name <regexp> | The regexp matches the basename of $1
# path <regexp> | The regexp matches the absolute path of $1
# has <program> | The program is installed (i.e. located in $PATH)
# env <variable> | The environment variable "variable" is non-empty
# file | $1 is a file
# directory | $1 is a directory
# number <n> | change the number of this command to n
# terminal | stdin, stderr and stdout are connected to a terminal
# X | $DISPLAY is not empty (i.e. Xorg runs)
#
# There are also pseudo-conditions which have a "side effect":
# flag <flags> | Change how the program is run. See below.
# label <label> | Assign a label or name to the command so it can
# | be started with :open_with <label> in ranger
# | or `rifle -p <label>` in the standalone executable.
# else | Always true.
#
# Flags are single characters which slightly transform the command:
# f | Fork the program, make it run in the background.
# | New command = setsid $command >& /dev/null &
# r | Execute the command with root permissions
# | New command = sudo $command
# t | Run the program in a new terminal. If $TERMCMD is not defined,
# | rifle will attempt to extract it from $TERM.
# | New command = $TERMCMD -e $command
# Note: The "New command" serves only as an illustration, the exact
# implementation may differ.
# Note: When using rifle in ranger, there is an additional flag "c" for
# only running the current file even if you have marked multiple files.
# # --- Websites --- # #
ext x?html? = ${VISUAL:-$EDITOR} -- "$1"
#ext x?html?, has surf, X, flag f = surf -md -- "$@"
#ext x?html?, has firefox, X, flag f = firefox -- "$@"
#ext x?html?, has qutebrowser, X, flag f = qutebrowser -- "$@"
#ext x?html?, has chromium, X, flag f = chromium -- "$@"
#ext x?html?, has links, terminal = links "$@"
#ext x?html?, has w3m, terminal = w3m "$@"
# # --- Audio Video --- # #
mime ^audio, has mpv, X, flag t = mpv -- "$@"
mime ^video|audio, has mpv, X, flag f = mpv -- "$@"
mime ^video|audio, has mpv, X, flag f = mpv --fs -- "$@"
mime ^video|audio, has mpv, X, flag f = mpv --loop -- "$@"
mime ^audio|ogg$, terminal, has mpv = mpv --no-audio-display -- "$@"
mime ^audio|ogg$, terminal, has mpv = mpv -- "$@"
mime ^video, terminal, !X, has mpv = mpv -- "$@"
# # --- Documents --- # #
mime ^text, label editor, flag t = $EDITOR -- "$@"
!mime ^text, label editor, ext xml|json|csv|tex|py|pl|rb|js|sh|php|conf, flag t = $EDITOR -- "$@"
ext pdf|epub|djvu|cbr|cbz|ps, X, flag f = $READER -- "$@"
ext sc|csv|sxc|xlsx?|xlt|xlw|gnm|gnumeric, flag t = sc-im -- "$@"
ext pptx?|od[dfgpst]|doc|docx|docx?|sxc|xlsx?|xlt|xlw|gnm|gnumeric, has libreoffice, X, flag f = libreoffice "$@"
# # --- Images --- # #
mime ^image/gif, has sxiv, X, flag f = sxiv -a -- "$@"
mime ^image/gif, has mpv, X, flag f = mpv --loop -- "$@"
mime ^image, has sxiv, X, flag f = sxiv -a -- "$@"
mime ^image, has feh, X, flag f = feh --scale-down --auto-zoom --image-bg black -- "$@"
ext xcf, X, flag f = gimp -- "$@"
# # --- Archives --- # #
ext 7z|ace|ar|arc|bz2?|cab|cpio|cpt|deb|dgc|dmg|gz, has aunpack = aunpack -- "$@"
ext iso|jar|msi|pkg|rar|shar|tar|tgz|xar|xpi|xz|zip, has aunpack = aunpack -- "$@"
ext jar = java -jar "$@"
ext gpg = gpg "$@"
# Define the editor for non-text files + pager as last action
!mime ^text, !ext xml|json|csv|tex|py|pl|rb|js|sh|php = ask
label editor, !mime ^text, !ext xml|json|csv|tex|py|pl|rb|js|sh|php, flag t = $EDITOR -- "$@"