See the Old README below for general usage.
- (!) Upgrading the configuration from older mimi versions
- Improvements from the original mimi
- Installation
- Old README
- Alternatives
TL;DR: configuration file is now called mimi.conf instead of mime.conf
Since XDG Base Directory specifications indicate $XDG_CONFIG_HOME/program/program.conf
,
in this fork I've renamed the configuration file's location from
mime.conf
to mimi.conf
($XDG_CONFIG_HOME
is usually ~/.config
, in case you didn't know).
See issue #3 for details; thanks to @vaygr for bringing up this issue.
I have added the following:
- support for custom
menu
programs in alternative todmenu
, by setting theMENU
andMENUARGS
configuration variable.MENU
has to be an executable, and also compatible withdmenu
's-p
flag; i.e. forrofi
useMENU: rofi -dmenu
. IfMENU
is not set ANDdmenu
is not available, a notification is sent to the user. - custom handling of
mailto
,spotify
andtg
(telegram) URI protocols via thex-scheme-handler
mimetype(!) - support for environmental variables (e.g.
$EDITOR
) - support for multiple arguments in
Exec
field of.desktop
files - support for symbolic links
- apps in your
$PATH
are now correctly listed when choosing an opener from${ MENU:-dmenu}
- fixed running in background for non-interactive mode
- prioritized the user's configuration for .desktop files
I have also collected a few commits from some other forks, which allow for shell interactive usage and handling of HTML urls' #section
suffixes.
If you think of something (i.e. a protocol) that mimi should be able to handle, feel free to open an issue!
I have also added a drop-in replacement for the xdg-email
script, part of the common xdg-utils
package, because some applications (such as chromium
) use it to handle the
mailto
protocol.
This script simply calls xdg-open
(aka mimi
) instead.
! This is a comment
TERM: st
! Default option
MENU: dmenu
# This is also a comment
audio/: mpv
video/: mpv
image/: sxiv
pdf: zathura
# Environmental variables also work
application/json: $TERMINAL -e $EDITOR
text/html: chromium
text/xml: chromium
application/xhtml_xml: chromium
x-scheme-handler/http: chromium
x-scheme-handler/https: chromium
x-scheme-handler/ftp: chromium
x-scheme-handler/about = chromium
x-scheme-handler/unknown = chromium
! vim: ft = xdefaults
- If your
TERM
variable is not executable (i.e. if it is set tost-256color
), you might want to setTERM: yourterminal
in yourmimi.conf
. - You can set
MENU
andMENUARGS
in order to use a dmenu alternative. For instance, to userofi
:
MENU: rofi
MENUARGS: -dmenu
- Note that
MENUARGS
can also be used to pass additional arguments todmenu
, but you will need to define theMENU
variable in order for these to be parsed. Additionally, ifMENUARGS
contains more than one argument, these should be separated by a colon:
. For instance:
MENU: dmenu
MENUARGS: -b:-i:-f
- Clone the repository:
git clone https://github.com/BachoSeven/mimi.git
- To replace the system's
xdg-open
andxdg-email
, just dosudo make install
.
You can find a handy package conflicting with xdg-utils
here.
Old README
mimi is an improved version of xdg-open. The original xdg-open works horribly without DE environment.
- you can define a list of 'how-to-open' in '~/.config/mimi/mimi.conf' (read below for format)
- or you are lazy, mimi will search a best-fit app using .desktop file. Best fit is defined as the first option sorted by mime order and then , if they have the same mime order, reverse sorted by generality
for example, the best-fit app says it can open 'text/html' in the very beginning of its mime definition. if two or more apps have the same priority, then we choose the app that can open the most number of file types.
for example, I want to define how to open 'text/html'. mimi will search in order like this
- 'txt' in your config
- in your config (i.e. http, ftp, magnet) ...etc.
- 'text/html' in your config
- 'text/' in your config
- 'text/html' in .desktop
- 'text/' in .desktop
- if mimi still cannot find anything, it will open dmenu and bug you.
note:
- sometimes, mimi is smart enough to figure out protocol based on mime-type when it searches for .desktop.
- sometimes, if an app requires a terminal to run (ncurses programs), mimi is able to find one terminal app in .desktop.
this is my own stuff
text/: xterm -e vim application/pdf: zathura video/: vlc image/: feh audio/: vlc application/x-tar: xterm -e 2a application/x-gzip: xterm -e 2a application/x-bzip2: xterm -e 2a application/x-rar: xterm -e 2a application/x-xz: xterm -e 2a application/zip: xterm -e 2a inode/directory: xterm -e ranger
it can be simplified by using:
rar: xterm -e 2a
but if you have time, using mime-type is more precise