# -*- mode: conf -*-
##############################################################################
## This is the example configuration file. Copy it to $HOME/.ncmpcpp/config ##
## or $XDG_CONFIG_HOME/ncmpcpp/config and set up your preferences.          ##
##############################################################################
#
##### directories ######
ncmpcpp_directory = ~/.config/ncmpcpp
lyrics_directory = ~/.lyrics

##### MPD #####
mpd_host = localhost
mpd_port = 6600
mpd_music_dir = ~/Music
mpd_connection_timeout = 5
mpd_crossfade_time = 0

##### music visualizer #####
visualizer_fifo_path = /tmp/mpd.fifo
visualizer_output_name = "my_fifo"
visualizer_in_stereo = yes
visualizer_sync_interval = 30
visualizer_type = "spectrum" ## Available values: spectrum, wave, wave_filled, ellipse.
visualizer_look = "+|"
visualizer_color = blue, cyan, green, yellow, magenta, red

##### system encoding #####
system_encoding = "UTF-8"

##### delays #####
#playlist_disable_highlight_delay = 5
#message_delay_time = 5

##### song format #####
##
## For a song format you can use:
##
## %l - length
## %f - filename
## %D - directory
## %a - artist
## %A - album artist
## %t - title
## %b - album
## %y - date
## %n - track number (01/12 -> 01)
## %N - full track info (01/12 -> 01/12)
## %g - genre
## %c - composer
## %p - performer
## %d - disc
## %C - comment
## %P - priority
## $R - begin right alignment
##
## If you  want to make sure  that a part of  the format is displayed  only when
## certain tags are present, you can archieve it by grouping them with brackets,
## e.g. '{%a  - %t}'  will be  evaluated to 'ARTIST  - TITLE'  if both  tags are
## present or '' otherwise. It is also possible to define a list of alternatives
## by providing  several groups and  separating them with '|',  e.g. '{%t}|{%f}'
## will be evaluated to 'TITLE' or 'FILENAME' if the former is not present.
##
## Note: If  you want  to set limit  on maximal  length of a  tag, just  put the
## appropriate number  between % and  character that  defines tag type,  e.g. to
## make album take max. 20 terminal cells, use '%20b'.
##
## In  addition, formats  support markers  used  for text  attributes. They  are
## followed by character '$'. After that you can put:
##
## - 0 - default window color (discards all other colors)
## - 1 - black
## - 2 - red
## - 3 - green
## - 4 - yellow
## - 5 - blue
## - 6 - magenta
## - 7 - cyan
## - 8 - white
## - 9 - end of current color
## - b - bold text
## - u - underline text
## - r - reverse colors
## - a - use alternative character set
##
## If you don't  want to use a  non-color attribute anymore, just  put it again,
## but this time insert character '/'  between '$' and attribute character, e.g.
## {$b%t$/b}|{$r%f$/r} will display  bolded title tag or  filename with reversed
## colors.
##
## If you want to use 256 colors and/or background colors in formats (the naming
## scheme is described below in section about color definitions), it can be done
## with  the  syntax  $(COLOR), e.g.  to  set  the  artist  tag to  one  of  the
## non-standard colors  and make it  have yellow  background, you need  to write
## $(197_yellow)%a$(end). Note  that for standard colors  this is interchangable
## with attributes listed above.
##
## Note: colors can be nested.
##
#
song_list_format = (6)[]{} (23)[red]{a} (26)[yellow]{t|f} (40)[green]{b} (4)[blue]{l}
#song_status_format = {{%a{ "%b"{ (%y)}} - }{%t}}|{%f}
#song_library_format = {%n - }{%t}|{%f}
#alternative_header_first_line_format = $b$1$aqqu$/a$9 {%t}|{%f} $1$atqq$/a$9$/b
#alternative_header_second_line_format = {{$4$b%a$/b$9}{ - $7%b$9}{ ($4%y$9)}}|{%D}
#current_item_prefix = $(yellow)$r
#current_item_suffix = $/r$(end)
#current_item_inactive_column_prefix = $(white)$r
#current_item_inactive_column_suffix = $/r$(end)
now_playing_prefix = $b
now_playing_suffix = $8$/b
#browser_playlist_prefix = "$2playlist$9 "
#selected_item_prefix = $6
#selected_item_suffix = $9
#modified_item_prefix = $3> $9
#song_window_title_format = {%a - }{%t}|{%f}

##
## Note: Below  variables are used for  sorting songs in browser.  The sort mode
## determines how songs are  sorted, and can be used in  combination with a sort
## format   to  specify   a  custom   sorting  format.   Available  values   for
## browser_sort_mode are "name", "mtime", "format" and "noop".
##
#
#browser_sort_mode = name
#browser_sort_format = {%a - }{%t}|{%f} {(%l)}

##### columns settings #####
##
## syntax of song columns list format is "column column etc."
##
## - syntax for each column is:
##
## (width of the column)[color of the column]{displayed tag}
##
## Note: Width is by default in %, if  you want a column to have fixed size, add
## 'f' after the value, e.g. (10)[white]{a} will  be the column that take 10% of
## screen  (so the  real  width  will depend  on  actual  screen size),  whereas
## (10f)[white]{a} will  take 10 terminal cells,  no matter how wide  the screen
## is.
##
## - color is optional (if you want the default one, leave the field empty).
##
## Note:  You can  give a  column additional  attributes by  putting appropriate
## character after displayed tag character. Available attributes are:
##
## - r - column will be right aligned
## - E - if tag is empty, empty tag marker won't be displayed
##
## You can also:
##
## - give a  column custom name by  putting it after attributes,  separated with
##   character ':', e.g.  {lr:Length} gives you right aligned  column of lengths
##   named "Length".
##
## - define sequence of  tags, that have to be displayed  in case predecessor is
##   empty in a  way similar to the  one in classic song format,  i.e. using '|'
##   character, e.g.  {a|c|p:Owner} creates column  named "Owner" that  tries to
##   display artist tag and then composer and performer if previous ones are not
##   available.
##
song_columns_list_format = (6)[]{} (23)[red]{a} (26)[yellow]{t|f} (40)[green]{b} (4)[blue]{l}

##### various settings #####

##
## Note: Custom command that will be executed each time song changes. Useful for
## notifications etc.
##
#execute_on_song_change = "~/.ncmpcpp/art.sh"
#song_list_format = "                       $2%t $R$5%a "

##
## Note: Custom  command that will be  executed each time player  state changes.
## The environment variable MPD_PLAYER_STATE is set to the current state (either
## unknown, play, pause, or stop) for its duration.
##
#execute_on_player_state_change = ""
#playlist_show_mpd_host = no
#playlist_show_remaining_time = no
playlist_shorten_total_times = yes
#playlist_separate_albums = no

##
## Note: Possible display modes: classic, columns.
##
playlist_display_mode = columns
browser_display_mode = "columns"
search_engine_display_mode = "columns"
playlist_editor_display_mode = "columns"
#discard_colors_if_item_is_selected = yes
#show_duplicate_tags = yes
#incremental_seeking = yes
#seek_time = 1
#volume_change_step = 2
autocenter_mode = yes
centered_cursor = yes

##
## Note: You  can specify third  character which will  be used to  build 'empty'
## part of progressbar.
##
progressbar_look = "─> "
#default_place_to_search_in = database ## Available values: database, playlist.
#user_interface = classic ## Available values: classic, alternative.
#data_fetching_delay = yes
#media_library_primary_tag = artist ## Available values: artist, album_artist, date, genre, composer, performer.
#media_library_albums_split_by_date = yes
#default_find_mode = wrapped ## Available values: wrapped, normal.
#default_tag_editor_pattern = %n - %t
header_visibility = no
statusbar_visibility = no
titles_visibility = no
#header_text_scrolling = yes
#cyclic_scrolling = no
#lines_scrolled = 2
#lyrics_fetchers = lyricwiki, azlyrics, genius, sing365, lyricsmania, metrolyrics, justsomelyrics, jahlyrics, plyrics, tekstowo, internet
#follow_now_playing_lyrics = no
#fetch_lyrics_for_current_song_in_background = no
#store_lyrics_in_song_dir = no
#generate_win32_compatible_filenames = yes
allow_for_physical_item_deletion = yes

##
## Note: If you set this variable, ncmpcpp  will try to get info from last.fm in
## language you set and if it fails,  it will fall back to english. Otherwise it
## will use english the first time.
##
## Note: Language has to be expressed as an ISO 639 alpha-2 code.
##
lastfm_preferred_language = en
space_add_mode = add_remove
#show_hidden_files_in_local_browser = no

##
## How shall screen switcher work?
##
## - "previous" - switch between the current and previous screen.
## - "screen1,...,screenN" - switch between given sequence of screens.
##
## Screens   available  for   use:  help,   playlist,  browser,   search_engine,
## media_library,  playlist_editor,  tag_editor,   outputs,  visualizer,  clock,
## lyrics, last_fm.
##
#screen_switcher_mode = playlist, browser

##
## Note: You can define startup screen by choosing screen from the list above.
##
#startup_screen = playlist

##
## Note: You  can define startup slave  screen by choosing screen  from the list
## above or an empty value for no slave screen.
##
#startup_slave_screen = ""
#startup_slave_screen_focus = no

##
## Default width of locked screen (in %).  Acceptable values are from 20 to 80.
##
locked_screen_width_part = 50
ask_for_locked_screen_width_part = yes
jump_to_now_playing_song_at_start = yes
ask_before_clearing_playlists = yes
clock_display_seconds = no
display_volume_level = yes
display_bitrate = no
display_remaining_time = yes

## Available values: none, basic, extended, perl.
regular_expressions = extended

##
## Note:  if below  is enabled,  ncmpcpp will  ignore leading  "The" word  while
## sorting items in browser, tags in media library, etc.
##
ignore_leading_the = yes

##
## Note: if below is enabled, ncmpcpp will ignore diacritics while searching and
## filtering lists.  This takes an  effect only if  boost was compiled  with ICU
## support.
##
ignore_diacritics = yes
#block_search_constraints_change_if_items_found = yes
mouse_support = no
#mouse_list_scroll_whole_page = yes
#empty_tag_marker = <empty>
tags_separator = " ; "
#tag_editor_extended_numeration = no
#media_library_sort_by_mtime = no
enable_window_title = yes

##
## Note: You can  choose default search mode for search  engine. Available modes
## are:
##
## - 1 - use mpd built-in searching (no regexes, pattern matching)
##
## - 2 - use  ncmpcpp searching (pattern matching with support  for regexes, but
##       if your mpd is on a remote machine, downloading big database to process
##       it can take a while
##
## - 3 - match only  exact values (this mode uses mpd  function for searching in
##       database and local one for searching in current playlist)
##
search_engine_default_search_mode = 1
external_editor = emacsclient -c
## Note: set to yes if external editor is a console application.
use_console_editor = yes

##### colors definitions #####
##
## It  is  possible  to  set  a  background  color  by  setting  a  color  value
## "<foreground>_<background>", e.g.  red_black will set foregound  color to red
## and background color to black.
##
## In addition, for terminals that support 256  colors it is possible to set one
## of them  by using  a number  in range [1,  256] instead  of color  name, e.g.
## numerical  value corresponding  to  red_black  is 2_1.  To  find  out if  the
## terminal supports  256 colors, run  ncmpcpp and check  out the bottom  of the
## help screen for list of available colors and their numerical values.
##
## What  is  more, there  are  two  special  values  for the  background  color:
## "transparent" and "current". The first  one explicitly sets the background to
## be  transparent,  while  the  second  one  allows  you  to  preserve  current
## background color  and change  only the foreground  one. It's  used implicitly
## when background color is not specified.
##
## Moreover,  it is  possible to  attach  format information  to selected  color
## variables by appending  to their end a  colon followed by one  or more format
## flags, e.g. black:b or red:ur. The following variables support this syntax:
## visualizer_color, color1, color2, empty_tag_color, volume_color,
## state_line_color, state_flags_color, progressbar_color,
## progressbar_elapsed_color, player_state_color, statusbar_time_color,
## alternative_ui_separator_color.
##
## Note: due  to technical limitations of  older ncurses version, if  256 colors
## are used there is  a possibility that you'll be able to  use only colors with
## transparent background.
colors_enabled = yes
#empty_tag_color = cyan
#header_window_color = default
volume_color = default
#state_line_color = default
#state_flags_color = default:b
#main_window_color = yellow
#color1 = white
#color2 = green
progressbar_color = "black"
progressbar_elapsed_color = "white"
statusbar_color = "white"
#statusbar_time_color = default:b
#player_state_color = default:b
#alternative_ui_separator_color = black:b
#window_border_color = green
#active_window_border = red