There are no reviews yet. Be the first to send feedback to the community and the maintainers!
Bongo is a flexible and usable media player for GNU Emacs. If you store your music collection locally and use structured file names, then Bongo is a great way for you to play music from within Emacs. Bongo can be installed through MELPA using `M-x package-install'. Getting Started =============== Though Bongo has certain preferences about how you name the files in your music collection (see below), you should be able to get started right away by runing `M-x bongo RET' and following the instructions. Before getting your hands dirty, you might want to skim through the customization group for Bongo (`M-x customize-group RET bongo RET'). It might be fun to browse through all of it, but at the moment the most important option is `bongo-enabled-backends', which determines what external programs Bongo will use to play media. Bongo will try to find a reasonable set of default backends by looking for the programs `vlc', `mpg123', `ogg123', `speexdec', `timidity', `mikmod' and `afplay'. (If you install one of these programs now, you will have to restart Emacs for Bongo to pick it up automatically.) If you want to use another program for media playback, you can easily define your own backend. Basic play/pause functionality works with any backend, whereas other features like seeking require custom code. (The default pause functionality is implemented using `SIGSTOP'.) Your Music Collection ===================== For the best Bongo user experience, your music collection should have hierarchical file names. That is, they should be named according to one of the following templates: Artist - 2014 - Album - 01 - Title.mp3 Artist - 2014 - Album - Title.mp3 Artist - Album - 01 - Title.mp3 Artist - Album - Title.mp3 Artist - Title.mp3 Title.mp3 So any reasonable combination of artist, year, album, index and title in the right order (less specific to more specific) should be okay. Embedding the metadata in the file name is simple and robust and also speeds up the process of fetching it. You don't have to use ` - ' as the separator, but you can't use `/' and have your files in nested directories. The information actually needs to be stored in the basename of each file. Many people use tags (e.g., ID3v2 tags or Ogg tags) for their metadata and don't care about file names. Luckily, Bongo comes with a tool called `tree-from-tags.rb`, which can be used to create a hierarchy of nicely-named symlinks into your tagged media collection. The tool depends on [ruby-taglib](https://robinst.github.io/taglib-ruby/) for extracting tag data from files make sure you have it installed before running the tool. Run ``` shell ruby tree-from-tags.rb --help ``` for more details. Basic Commands ============== To start Bongo, run `M-x bongo RET'. To insert a file or a whole directory of files, type `i'. Then hit `RET' to play one of them. To see a list of available commands, run `M-x describe-mode RET'. Here are some common ones for your convenience: `i' Insert a track (or a directory tree full of tracks). `RET' Start playing the track at point (and then continue). `SPC' Pause playback (if supported by the backend). `C-c C-s' Stop playback (or start, if already stopped). `C-c C-n' Start playing the next track. `C-c C-r' Start playing a random track. `s' Seek backward or forward (if supported by the backend). `l' Move point to the current track and recenter. `q' Quit Bongo (bury Bongo buffers and delete windows). `c' Copy the track or section under point. `k' Kill the track or section under point. `C-w' Kill all tracks and sections in the region. `y' Reinsert the last copied or killed stuff. `I u' Insert a URI (can be used to play podcasts and radio). `I TAB' List other kinds of tracks that can be inserted. `2 C-c C-n' Skip the next track and start playing the one after that. `3 C-c C-s' Stop playback after the next three tracks finish playing. `3 RET' Start playing the track under point, and continue playing tracks, but stop after playing the third track. `C-u C-c C-s' Stop playback after each track finishes playing (this is good when playing movies, for example). `C-u C-u C-c C-s' Stop playback after the track at point finishes playing. `C-u C-c C-n' Play the next track after each track finishes playing (this undoes the effect of `C-u C-c C-s'). `C-u C-c C-r' Play tracks in random order. Here are some commands that are nice if you use library buffers: `h' Switch from playlist to library (or vice versa). `C-u h' Switch from playlist to library (or vice versa), leaving the original buffer visible in another window. `e' Append the track under point or the region (if active) to the end of the playlist buffer. `3 e' Append the track at point and the two after that to the end of the playlist buffer. `E' Insert the track under point or the region (if active) into the playlist buffer, directly below the track that's currently playing. `C-x C-s' Save the current buffer (library buffers are stored using the `.bongo-library' file extension). Finally, since you've read this far, here are a few bonus commands: `d' Open a Dired buffer containing the track under point. `r' Rename the file corresponding to the track under point. `v' Change audio volume (requires the `volume-el' package).
semver-howto
Simple guide to using semantic versioningzenburn-el
The zenburn color theme for GNU Emacsvolume.el
Tweak your loudness with GNU Emacs ("the best Emacs package ever")goplayer
Modern, open-source video player written in ActionScript 3blossom
Quick-start, state-of-the-art web development with Haml, Sass, Compass and CoffeeScriptasspec
BDD framework for AS3payex-ruby
PayEx SOAP API glue for Rubynode-regexp-quote
RegExp.quote = require("regexp-quote")asautotest
An indispensable tool for non-IDE ActionScript developmentsquirrel
fcshd
Usable CLI frontend to Adobe’s Flex compilerFunction.prototype.bind
How I invented Function.prototype.bindds-multisig-ui
Simple web-based UI for interacting with DSEasyMultisig instanceshyphen-ruby
Dehyphenate identifiers in Ruby codeds-auth-ui
rack-normalize-domain
Rack middleware that redirects www.example.com to example.comaslayout
Simple layout framework for Actionscript 3campfire-say
Say something on Campfirestdio.as
Lets your Flash/Flex apps read from stdin, write to stdout/stderr, access command-line arguments, run shell commands, etc.flexc
Usable CLI frontend to Adobe’s Flex compilercis
knock.as
Lightweight ActionScript 3 testingflower
heroku-buildpack-git
Heroku buildpack for vendoring Gitjsonrpc2
JSON-RPC 2.0 clientclean-wikipedia-css
The CSS code hotlinked into Wikipedia by Deuglify.mesass-extractor
flex-compiler
Node.js wrapper for the Adobe Flex compiler shell (fcsh)find-grid
node-main
fswatch
Watch for file system changes—for use in shell scripts.jams
JAMS is a minimal JSON alternativesiss
flex-testing-harness
dgeth
Go Ethereum Docker wrapper — run geth(1) without installing Gofruitysnake
Buggy game written in QBasic 4.5 (lots of purples, yellows and oranges)twerfect
Google Chrome extension to highlight perfect-140 tweets on twitter.commotherfuckingwebsite
My take on motherfuckingwebsite.combardock
Dock a dock bar (e.g., a doc bar) to your source codemasktags
Love Open Source and this site? Check out how you can help us