1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
|
{-# LANGUAGE QuasiQuotes #-}
module Ppr006 where
commands :: [Command]
commands = [
command "help" "display a list of all commands, and their current keybindings" $ do
macroGuesses <- Macro.guessCommands commandNames <$> getMacros
addTab (Other "Help") (makeHelpWidget commands macroGuesses) AutoClose
, command "log" "show the error log" $ do
messages <- gets logMessages
let widget = ListWidget.moveLast (ListWidget.new $ reverse messages)
addTab (Other "Log") (AnyWidget . LogWidget $ widget) AutoClose
, command "map" "display a list of all commands that are currently bound to keys" $ do
showMappings
, command "map" "display the command that is currently bound to the key {name}" $ do
showMapping
, command "map" [help|
Bind the command {expansion} to the key {name}. The same command may
be bound to different keys.
|] $ do
addMapping
, command "unmap" "remove the binding currently bound to the key {name}" $ do
\(MacroName m) -> removeMacro m
, command "mapclear" "" $ do
clearMacros
, command "exit" "exit vimus" $ do
eval "quit"
, command "quit" "exit vimus" $ do
liftIO exitSuccess :: Vimus ()
, command "close" "close the current window (not all windows can be closed)" $ do
void closeTab
, command "source" "read the file {path} and interprets all lines found there as if they were entered as commands." $ do
\(Path p) -> liftIO (expandHome p) >>= either printError source_
, command "runtime" "" $
\(Path p) -> liftIO (getDataFileName p) >>= source_
, command "color" "define the fore- and background color for a thing on the screen." $ do
\color fg bg -> liftIO (defineColor color fg bg) :: Vimus ()
, command "repeat" "set the playlist option *repeat*. When *repeat* is set, the playlist will start over when the last song has finished playing." $ do
MPD.repeat True :: Vimus ()
, command "norepeat" "Unset the playlist option *repeat*." $ do
MPD.repeat False :: Vimus ()
, command "consume" "set the playlist option *consume*. When *consume* is set, songs that have finished playing are automatically removed from the playlist." $ do
MPD.consume True :: Vimus ()
, command "noconsume" "Unset the playlist option *consume*." $ do
MPD.consume False :: Vimus ()
, command "random" "set the playlist option *random*. When *random* is set, songs in the playlist are played in random order." $ do
MPD.random True :: Vimus ()
, command "norandom" "Unset the playlist option *random*." $ do
MPD.random False :: Vimus ()
, command "single" "Set the playlist option *single*. When *single* is set, playback does not advance automatically to the next item in the playlist. Combine with *repeat* to repeatedly play the same song." $ do
MPD.single True :: Vimus ()
, command "nosingle" "Unset the playlist option *single*." $ do
MPD.single False :: Vimus ()
, command "autotitle" "Set the *autotitle* option. When *autotitle* is set, the console window title is automatically set to the currently playing song." $ do
setAutoTitle True
, command "noautotitle" "Unset the *autotitle* option." $ do
setAutoTitle False
, command "volume" "[+-] set volume to or adjust by [+-] num" $ do
volume :: Volume -> Vimus ()
, command "toggle-repeat" "Toggle the *repeat* option." $ do
MPD.status >>= MPD.repeat . not . MPD.stRepeat :: Vimus ()
, command "toggle-consume" "Toggle the *consume* option." $ do
MPD.status >>= MPD.consume . not . MPD.stConsume :: Vimus ()
, command "toggle-random" "Toggle the *random* option." $ do
MPD.status >>= MPD.random . not . MPD.stRandom :: Vimus ()
, command "toggle-single" "Toggle the *single* option." $ do
MPD.status >>= MPD.single . not . MPD.stSingle :: Vimus ()
, command "set-library-path" "While MPD knows where your songs are stored, vimus doesn't. If you want to use the *%* feature of the command :! you need to tell vimus where your songs are stored." $ do
\(Path p) -> setLibraryPath p
, command "next" "stop playing the current song, and starts the next one" $ do
MPD.next :: Vimus ()
, command "previous" "stop playing the current song, and starts the previous one" $ do
MPD.previous :: Vimus ()
, command "toggle" "toggle between play and pause" $ do
MPDE.toggle :: Vimus ()
, command "stop" "stop playback" $ do
MPD.stop :: Vimus ()
, command "update" "tell MPD to update the music database. You must update your database when you add or delete files in your music directory, or when you edit the metadata of a song. MPD will only rescan a file already in the database if its modification time has changed." $ do
void (MPD.update Nothing) :: Vimus ()
, command "rescan" "" $ do
void (MPD.rescan Nothing) :: Vimus ()
, command "clear" "delete all songs from the playlist" $ do
MPD.clear :: Vimus ()
, command "search-next" "jump to the next occurrence of the search string in the current window"
searchNext
, command "search-prev" "jump to the previous occurrence of the search string in the current window"
searchPrev
, command "window-library" "open the *Library* window" $
selectTab Library
, command "window-playlist" "open the *Playlist* window" $
selectTab Playlist
, command "window-search" "open the *SearchResult* window" $
selectTab SearchResult
, command "window-browser" "open the *Browser* window" $
selectTab Browser
, command "window-next" "open the window to the right of the current one"
nextTab
, command "window-prev" "open the window to the left of the current one"
previousTab
, command "!" "execute {cmd} on the system shell. See chapter \"Using an external tag editor\" for an example."
runShellCommand
, command "seek" "jump to the given position in the current song"
seek
, command "visual" "start visual selection" $
sendEventCurrent EvVisual
, command "novisual" "cancel visual selection" $
sendEventCurrent EvNoVisual
-- Remove current song from playlist
, command "remove" "remove the song under the cursor from the playlist" $
sendEventCurrent EvRemove
, command "paste" "add the last deleted song after the selected song in the playlist" $
sendEventCurrent EvPaste
, command "paste-prev" "" $
sendEventCurrent EvPastePrevious
, command "copy" "" $
sendEventCurrent EvCopy
, command "shuffle" "shuffle the current playlist" $ do
MPD.shuffle Nothing :: Vimus ()
, command "add" "append selected songs to the end of the playlist" $ do
sendEventCurrent EvAdd
-- insert a song right after the current song
, command "insert" [help|
inserts a song to the playlist. The song is inserted after the currently
playing song.
|] $ do
st <- MPD.status
case MPD.stSongPos st of
Just n -> do
-- there is a current song, insert after
sendEventCurrent (EvInsert (n + 1))
_ -> do
-- there is no current song, just add
sendEventCurrent EvAdd
-- Playlist: play selected song
-- Library: add song to playlist and play it
-- Browse: either add song to playlist and play it, or :move-in
, command "default-action" [help|
depending on the item under the cursor, somthing different happens:
- *Playlist* start playing the song under the cursor
- *Library* append the song under the cursor to the playlist and start playing it
- *Browser* on a song: append the song to the playlist and play it. On a directory: go down to that directory.
|] $ do
sendEventCurrent EvDefaultAction
, command "add-album" "add all songs of the album of the selected song to the playlist" $ do
songs <- fromCurrent MPD.Album [MPD.Disc, MPD.Track]
maybe (printError "Song has no album metadata!") (MPDE.addMany "" . map MPD.sgFilePath) songs
, command "add-artist" "add all songs of the artist of the selected song to the playlist" $ do
songs <- fromCurrent MPD.Artist [MPD.Date, MPD.Album, MPD.Disc, MPD.Track]
maybe (printError "Song has no artist metadata!") (MPDE.addMany "" . map MPD.sgFilePath) songs
-- movement
, command "move-up" "move the cursor one line up" $
sendEventCurrent EvMoveUp
, command "move-down" "move the cursor one line down" $
sendEventCurrent EvMoveDown
, command "move-album-prev" "move the cursor up to the first song of an album" $
sendEventCurrent EvMoveAlbumPrev
, command "move-album-next" "move the cursor down to the first song of an album" $
sendEventCurrent EvMoveAlbumNext
, command "move-in" "go down one level the directory hierarchy in the *Browser* window" $
sendEventCurrent EvMoveIn
, command "move-out" "go up one level in the directory hierarchy in the *Browser* window" $
sendEventCurrent EvMoveOut
, command "move-first" "go to the first line in the current window" $
sendEventCurrent EvMoveFirst
, command "move-last" "go to the last line in the current window" $
sendEventCurrent EvMoveLast
, command "scroll-up" "scroll the contents of the current window up one line" $
sendEventCurrent (EvScroll (-1))
, command "scroll-down" "scroll the contents of the current window down one line" $
sendEventCurrent (EvScroll 1)
, command "scroll-page-up" "scroll the contents of the current window up one page" $
pageScroll >>= sendEventCurrent . EvScroll . negate
, command "scroll-half-page-up" "scroll the contents of the current window up one half page" $
pageScroll >>= sendEventCurrent . EvScroll . negate . (`div` 2)
, command "scroll-page-down" "scroll the contents of the current window down one page" $
pageScroll >>= sendEventCurrent . EvScroll
, command "scroll-half-page-down" "scroll the contents of the current window down one half page" $
pageScroll >>= sendEventCurrent . EvScroll . (`div` 2)
, command "song-format" "set song rendering format" $
sendEvent . EvChangeSongFormat
]
|