1 # ===================================================================
2 # This file contains the default startup commands for ranger.
3 # To change them, it is recommended to create the file
4 # ~/.config/ranger/rc.conf and add your custom commands there.
6 # If you copy this whole file there, you may want to set the environment
7 # variable RANGER_LOAD_DEFAULT_RC to FALSE to avoid loading it twice.
9 # The purpose of this file is mainly to define keybindings and settings.
10 # For running more complex python code, please create a plugin in "plugins/" or
11 # a command in "commands.py".
13 # Each line is a command that will be run before the user interface
14 # is initialized. As a result, you can not use commands which rely
15 # on the UI such as :delete or :mark.
16 # ===================================================================
18 # ===================================================================
20 # ===================================================================
22 # How many columns are there, and what are their relative widths?
23 #set column_ratios 1,3,4
25 # Which files should be hidden? (regular expression)
26 set hidden_filter ^\.|^lost\+found$
28 # Show hidden files? You can toggle this by typing 'zh'
29 #set show_hidden false
31 # Ask for a confirmation when running the "delete" command?
32 # Valid values are "always" (default), "never", "multiple"
33 # With "multiple", ranger will ask only if you delete multiple files at once.
34 set confirm_on_delete multiple
36 # Which script is used to generate file previews?
37 # ranger ships with scope.sh, a script that calls external programs (see
38 # README for dependencies) to preview images, archives, etc.
39 set preview_script ~/.config/ranger/scope.sh
41 # Use the external preview script or display simple plain text previews?
42 set use_preview_script true
44 # Open all images in this directory when running certain image viewers
45 # like feh or sxiv? You can still open selected files by marking them.
46 set open_all_images true
48 # Be aware of version control systems and display information.
51 # State of the three backends git, hg, bzr. The possible states are
52 # disabled, local (only show local info), enabled (show local and remote
54 #set vcs_backend_git enabled
55 #set vcs_backend_hg disabled
56 #set vcs_backend_bzr disabled
58 # Preview images in full color with the external command "w3mimgpreview"?
59 # This requires the console web browser "w3m" and a supported terminal.
60 # It has been successfully tested with "xterm" and "urxvt" without tmux.
61 # Does not work in urxvt with 32bit colordepth, tradeoff between preview
63 set preview_images true
65 # Use a unicode "..." character to mark cut-off filenames?
66 set unicode_ellipsis true
68 # Show dotfiles in the bookmark preview box?
69 #set show_hidden_bookmarks true
71 # Which colorscheme to use? These colorschemes are available by default:
72 # default, jungle, snow
73 set colorscheme custom
75 # Preview files on the rightmost column?
76 # And collapse (shrink) the last column if there is nothing to preview?
77 #set preview_files true
78 #set preview_directories true
79 #set collapse_preview true
81 # Save the console history on exit?
82 #set save_console_history true
84 # Draw the status bar on top of the browser window (default: bottom)
85 #set status_bar_on_top false
87 # Draw a progress bar in the status bar which displays the average state of all
88 # currently running tasks which support progress bars?
89 #set draw_progress_bar_in_status_bar true
91 # Draw borders around columns?
94 # Display the directory name in tabs?
95 set dirname_in_tabs true
97 # Enable the mouse support?
98 #set mouse_enabled true
100 # Display the file size in the main column or status bar?
101 #set display_size_in_main_column true
102 #set display_size_in_status_bar true
104 # Display files tags in all columns or only in main column?
105 #set display_tags_in_all_columns true
107 # Set a title for the window?
108 set update_title true
110 # Set the title to "ranger" in the tmux program?
111 #set update_tmux_title false
113 # Shorten the title if it gets long? The number defines how many
114 # directories are displayed at once, 0 turns off this feature.
117 # Abbreviate $HOME with ~ in the titlebar (first line) of ranger?
118 set tilde_in_titlebar true
120 # How many directory-changes or console-commands should be kept in history?
121 set max_history_size 2000
122 set max_console_history_size 5000
124 # Try to keep so much space between the top/bottom border when scrolling:
127 # Flush the input after each key hit? (Noticable when ranger lags)
130 # Padding on the right when there's no preview?
131 # This allows you to click into the space to run the file.
132 set padding_right false
134 # Save bookmarks (used with mX and `X) instantly?
135 # This helps to synchronize bookmarks between multiple ranger
136 # instances but leads to *slight* performance loss.
137 # When false, bookmarks are saved when ranger is exited.
138 #set autosave_bookmarks true
140 # You can display the "real" cumulative size of directories by using the
141 # command :get_cumulative_size or typing "dc". The size is expensive to
142 # calculate and will not be updated automatically. You can choose
143 # to update it automatically though by turning on this option:
144 #set autoupdate_cumulative_size false
146 # Turning this on makes sense for screen readers:
147 #set show_cursor false
149 # One of: size, basename, mtime, type
152 # Additional sorting options
153 #set sort_reverse false
154 #set sort_case_insensitive true
155 set sort_directories_first false
157 # Enable this if key combinations with the Alt Key don't work for you.
158 # (Especially on xterm)
159 #set xterm_alt_key false
161 # ===================================================================
163 # ===================================================================
164 # You can set local options that only affect a single directory.
167 setlocal path=~/downloads sort mtime
169 # ===================================================================
170 # == Command Aliases in the Console
171 # ===================================================================
179 #alias filter scout -prt
180 #alias find scout -aet
181 #alias mark scout -mr
182 #alias unmark scout -Mr
183 #alias search scout -rs
184 #alias search_inc scout -rts
185 #alias travel scout -aefiklst
187 # ===================================================================
188 # == Define keys for the browser
189 # ===================================================================
198 #map <C-l> redraw_window
200 #map <esc> change_mode normal
211 #map @ console -p6 shell %%s
212 #map # console shell -p
214 #map r chain draw_possible_programs; console open_with
221 #map "<any> tag_toggle tag=%any
222 #map <Space> mark_files toggle=True
223 #map v mark_files all=True toggle=True
224 #map uv mark_files all=True val=False
225 #map V toggle_visual_mode
226 #map uV toggle_visual_mode reverse=True
228 # For the nostalgics: Midnight Commander bindings
230 #map <F3> display_file
234 #map <F7> console mkdir
235 #map <F8> console delete
238 # In case you work on a keyboard with dvorak layout
240 #map <DOWN> move down=1
241 #map <LEFT> move left=1
242 #map <RIGHT> move right=1
243 #map <HOME> move to=0
244 #map <END> move to=-1
245 #map <PAGEDOWN> move down=1 pages=True
246 #map <PAGEUP> move up=1 pages=True
247 #map <CR> move right=1
248 #map <DELETE> console delete
249 #map <INSERT> console touch
258 #copymap <PAGEDOWN> <C-F>
259 #copymap <PAGEUP> <C-B>
261 #map J move down=0.5 pages=True
262 #map K move up=0.5 pages=True
270 #map [ move_parent -1
285 #map gR eval fm.cd(ranger.RANGERDIR)
287 #map g? cd /usr/share/doc/ranger
291 #map du shell -p du --max-depth=1 -h --apparent-size
292 #map dU shell -p du --max-depth=1 -h --apparent-size | sort -rh
293 #map yp shell -d echo -n %d/%f | xsel -i
294 #map yd shell -d echo -n %d | xsel -i
295 #map yn shell -d echo -n %f | xsel -i
297 # Filesystem Operations
300 #map cw console rename
301 #map A eval fm.open_console('rename ' + fm.thisfile.basename)
302 #map I eval fm.open_console('rename ' + fm.thisfile.basename, position=7)
305 #map po paste overwrite=True
306 #map pl paste_symlink relative=False
307 #map pL paste_symlink relative=True
308 #map phl paste_hardlink
309 #map pht paste_hardlinked_subtree
314 #map dr cut mode=remove
318 #map ya copy mode=add
319 #map yr copy mode=remove
321 # Temporary workarounds
322 #map dgg eval fm.cut(dirarg=dict(to=0), narg=quantifier)
323 #map dG eval fm.cut(dirarg=dict(to=-1), narg=quantifier)
324 #map dj eval fm.cut(dirarg=dict(down=1), narg=quantifier)
325 #map dk eval fm.cut(dirarg=dict(up=1), narg=quantifier)
326 #map ygg eval fm.copy(dirarg=dict(to=0), narg=quantifier)
327 #map yG eval fm.copy(dirarg=dict(to=-1), narg=quantifier)
328 #map yj eval fm.copy(dirarg=dict(down=1), narg=quantifier)
329 #map yk eval fm.copy(dirarg=dict(up=1), narg=quantifier)
332 #map / console search
334 #map N search_next forward=False
335 #map ct search_next order=tag
336 #map cs search_next order=size
337 #map ci search_next order=mimetype
338 #map cc search_next order=ctime
339 #map cm search_next order=mtime
340 #map ca search_next order=atime
345 #map <TAB> tab_move 1
346 #map <S-TAB> tab_move -1
347 #map <A-Right> tab_move 1
348 #map <A-Left> tab_move -1
365 #map or toggle_option sort_reverse
366 #map os chain set sort=size; set sort_reverse=False
367 #map ob chain set sort=basename; set sort_reverse=False
368 #map on chain set sort=natural; set sort_reverse=False
369 #map om chain set sort=mtime; set sort_reverse=False
370 #map oc chain set sort=ctime; set sort_reverse=False
371 #map oa chain set sort=atime; set sort_reverse=False
372 #map ot chain set sort=type; set sort_reverse=False
374 #map oS chain set sort=size; set sort_reverse=True
375 #map oB chain set sort=basename; set sort_reverse=True
376 #map oN chain set sort=natural; set sort_reverse=True
377 #map oM chain set sort=mtime; set sort_reverse=True
378 #map oC chain set sort=ctime; set sort_reverse=True
379 #map oA chain set sort=atime; set sort_reverse=True
380 #map oT chain set sort=type; set sort_reverse=True
382 #map dc get_cumulative_size
385 #map zc toggle_option collapse_preview
386 #map zd toggle_option sort_directories_first
387 #map zh toggle_option show_hidden
388 #map <C-h> toggle_option show_hidden
389 #map zi toggle_option flushinput
390 #map zm toggle_option mouse_enabled
391 #map zp toggle_option preview_files
392 #map zP toggle_option preview_directories
393 #map zs toggle_option sort_case_insensitive
394 #map zu toggle_option autoupdate_cumulative_size
395 #map zv toggle_option use_preview_script
396 #map zf console filter
399 #map `<any> enter_bookmark %any
400 #map '<any> enter_bookmark %any
401 #map m<any> set_bookmark %any
402 #map um<any> unset_bookmark %any
404 #map m<bg> draw_bookmarks
405 #copymap m<bg> um<bg> `<bg> '<bg>
407 # Generate all the chmod bindings with some python help:
408 #eval for arg in "rwxXst": cmd("map +u{0} shell -d chmod u+{0} %s".format(arg))
409 #eval for arg in "rwxXst": cmd("map +g{0} shell -d chmod g+{0} %s".format(arg))
410 #eval for arg in "rwxXst": cmd("map +o{0} shell -d chmod o+{0} %s".format(arg))
411 #eval for arg in "rwxXst": cmd("map +a{0} shell -d chmod a+{0} %s".format(arg))
412 #eval for arg in "rwxXst": cmd("map +{0} shell -d chmod u+{0} %s".format(arg))
414 #eval for arg in "rwxXst": cmd("map -u{0} shell -d chmod u-{0} %s".format(arg))
415 #eval for arg in "rwxXst": cmd("map -g{0} shell -d chmod g-{0} %s".format(arg))
416 #eval for arg in "rwxXst": cmd("map -o{0} shell -d chmod o-{0} %s".format(arg))
417 #eval for arg in "rwxXst": cmd("map -a{0} shell -d chmod a-{0} %s".format(arg))
418 #eval for arg in "rwxXst": cmd("map -{0} shell -d chmod u-{0} %s".format(arg))
420 # ===================================================================
421 # == Define keys for the console
422 # ===================================================================
423 # Note: Unmapped keys are passed directly to the console.
426 #cmap <tab> eval fm.ui.console.tab()
427 #cmap <s-tab> eval fm.ui.console.tab(-1)
428 #cmap <ESC> eval fm.ui.console.close()
429 #cmap <CR> eval fm.ui.console.execute()
430 #cmap <C-l> redraw_window
432 #copycmap <ESC> <C-c>
436 #cmap <up> eval fm.ui.console.history_move(-1)
437 #cmap <down> eval fm.ui.console.history_move(1)
438 #cmap <left> eval fm.ui.console.move(left=1)
439 #cmap <right> eval fm.ui.console.move(right=1)
440 #cmap <home> eval fm.ui.console.move(right=0, absolute=True)
441 #cmap <end> eval fm.ui.console.move(right=-1, absolute=True)
444 #cmap <backspace> eval fm.ui.console.delete(-1)
445 #cmap <delete> eval fm.ui.console.delete(0)
446 #cmap <C-w> eval fm.ui.console.delete_word()
447 #cmap <C-k> eval fm.ui.console.delete_rest(1)
448 #cmap <C-u> eval fm.ui.console.delete_rest(-1)
449 #cmap <C-y> eval fm.ui.console.paste()
451 # And of course the emacs way
453 #copycmap <down> <C-n>
454 #copycmap <left> <C-b>
455 #copycmap <right> <C-f>
456 #copycmap <home> <C-a>
457 #copycmap <end> <C-e>
458 #copycmap <delete> <C-d>
459 #copycmap <backspace> <C-h>
461 # Note: There are multiple ways to express backspaces. <backspace> (code 263)
462 # and <backspace2> (code 127). To be sure, use both.
463 #copycmap <backspace> <backspace2>
465 # This special expression allows typing in numerals:
466 #cmap <allow_quantifiers> false
468 # ===================================================================
469 # == Pager Keybindings
470 # ===================================================================
473 #pmap <down> pager_move down=1
474 #pmap <up> pager_move up=1
475 #pmap <left> pager_move left=4
476 #pmap <right> pager_move right=4
477 #pmap <home> pager_move to=0
478 #pmap <end> pager_move to=-1
479 #pmap <pagedown> pager_move down=1.0 pages=True
480 #pmap <pageup> pager_move up=1.0 pages=True
481 #pmap <C-d> pager_move down=0.5 pages=True
482 #pmap <C-u> pager_move up=0.5 pages=True
484 #copypmap <UP> k <C-p>
485 #copypmap <DOWN> j <C-n> <CR>
492 #copypmap <PAGEDOWN> n f <C-F> <Space>
493 #copypmap <PAGEUP> p b <C-B>
496 #pmap <ESC> pager_close
497 #copypmap <ESC> q Q i <F3>
500 # ===================================================================
501 # == Taskview Keybindings
502 # ===================================================================
505 #tmap <up> taskview_move up=1
506 #tmap <down> taskview_move down=1
507 #tmap <home> taskview_move to=0
508 #tmap <end> taskview_move to=-1
509 #tmap <pagedown> taskview_move down=1.0 pages=True
510 #tmap <pageup> taskview_move up=1.0 pages=True
511 #tmap <C-d> taskview_move down=0.5 pages=True
512 #tmap <C-u> taskview_move up=0.5 pages=True
514 #copytmap <UP> k <C-p>
515 #copytmap <DOWN> j <C-n> <CR>
519 #copytmap <PAGEDOWN> n f <C-F> <Space>
520 #copytmap <PAGEUP> p b <C-B>
522 # Changing priority and deleting tasks
523 #tmap J eval -q fm.ui.taskview.task_move(-1)
524 #tmap K eval -q fm.ui.taskview.task_move(0)
525 #tmap dd eval -q fm.ui.taskview.task_remove()
526 #tmap <pagedown> eval -q fm.ui.taskview.task_move(-1)
527 #tmap <pageup> eval -q fm.ui.taskview.task_move(0)
528 #tmap <delete> eval -q fm.ui.taskview.task_remove()
531 #tmap <ESC> taskview_close
532 #copytmap <ESC> q Q w <C-c>