;; emms-streams.el -- A collection of online streaming audio -*- lexical-binding: t; -*- ;; Copyright (C) 2019 Free Software Foundation, Inc. ;; Authors: Yoni Rabkin ;; This file is part of EMMS. ;; EMMS is free software; you can redistribute it and/or modify it ;; under the terms of the GNU General Public License as published by ;; the Free Software Foundation; either version 3 of the License, or ;; (at your option) any later version. ;; EMMS is distributed in the hope that it will be useful, but WITHOUT ;; ANY WARRANTY; without even the implied warranty of MERCHANTABILITY ;; or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public ;; License for more details. ;; You should have received a copy of the GNU General Public License ;; along with EMMS; if not, write to the Free Software Foundation, ;; Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. ;;; Commentary: ;; 2019-11-05 - This is a complete re-write of the emms-streams.el, ;; using a different approach. ;; This includes the built-in list of streams which come with Emms by ;; default. Emms has no affiliation of any kind with the streaming ;; audio stations listed below, nor is this an endorsement of these ;; stations. Instead, this is a collection of stations submitted to ;; the project over the years by people who enjoy Emms. We hope you ;; will enjoy them too. ;;; Code: (require 'emms) (require 'emms-source-playlist) (require 'emms-playlist-mode) ;;; ------------------------------------------------------------------ ;;; definitions ;;; ------------------------------------------------------------------ (defvar emms-streams-buffer-name "Emms Streams" "Name for creating a streams buffer.") (defvar emms-streams-built-in-disclaimer ";; This includes the built-in list of streams which come with Emms by ;; default. Emms has no affiliation of any kind with the streaming ;; audio stations listed below, nor is this an endorsement of these ;; stations. Instead, this is a collection of stations submitted to ;; the project over the years by people who enjoy Emms. We hope you ;; will enjoy them too." "Explaining the relationship between Emms and these streams.") (defvar emms-streams-built-in-list '((*track* (type . streamlist) (name . "http://www.somafm.com/beatblender.pls") (metadata "SomaFM: Beatblender" "http://www.somafm.com/beatblender.pls" 1 streamlist)) (*track* (type . streamlist) (name . "http://www.somafm.com/secretagent.pls") (metadata "SomaFM: Secret Agent" "http://www.somafm.com/secretagent.pls" 1 streamlist)) (*track* (type . streamlist) (name . "http://www.somafm.com/groovesalad.pls") (metadata "SomaFM: Groove Salad" "http://www.somafm.com/groovesalad.pls" 1 streamlist)) (*track* (type . streamlist) (name . "http://www.somafm.com/dronezone.pls") (metadata "SomaFM: Drone Zone" "http://www.somafm.com/dronezone.pls" 1 streamlist)) (*track* (type . streamlist) (name . "http://www.somafm.com/tagstrance.pls") (metadata "SomaFM: Tag's Trance" "http://www.somafm.com/tagstrance.pls" 1 streamlist)) (*track* (type . streamlist) (name . "http://www.somafm.com/indiepop.pls") (metadata "SomaFM: Indie Pop Rocks" "http://www.somafm.com/indiepop.pls" 1 streamlist)) (*track* (type . streamlist) (name . "http://www.somafm.com/doomed.pls") (metadata "SomaFM: Doomed" "http://www.somafm.com/doomed.pls" 1 streamlist)) (*track* (type . url) (name . "http://listen.radionomy.com:80/-PHILOSOMATIKAPROGRESSIVE-") (metadata "P H I L O S O M A T I K A - Progressive Psytrance" "http://listen.radionomy.com:80/-PHILOSOMATIKAPROGRESSIVE-" 1 url)) (*track* (type . streamlist) (name . "http://www.bassdrive.com/BassDrive.m3u") (metadata "Drum and Bass Radio, BassDrive" "http://www.bassdrive.com/BassDrive.m3u" 1 streamlist)) (*track* (type . streamlist) (name . "http://www.ibiblio.org/wcpe/wcpe.pls") (metadata "WCPE, Classical Music" "http://www.ibiblio.org/wcpe/wcpe.pls" 1 streamlist)) (*track* (type . streamlist) (name . "http://stream.nute.net/kohina/stream.ogg.m3u") (metadata "Kohina - Old school game and demo music" "http://stream.nute.net/kohina/stream.ogg.m3u" 1 streamlist)) (*track* (type . streamlist) (name . "http://privat.is-by.us:8000/necta192.mp3.m3u") (metadata "Nectarine, Demoscene Radio, DE Continuum's relay 192 mp3" "http://privat.is-by.us:8000/necta192.mp3.m3u" 1 streamlist)) (*track* (type . streamlist) (name . "http://nectarine.from-de.com/necta192.m3u") (metadata "Nectarine, Demoscene Radio, DE stream (High Bitrate)" "http://nectarine.from-de.com/necta192.m3u" 1 streamlist)) (*track* (type . streamlist) (name . "http://www.wfmu.org/wfmu.pls") (metadata "WFMU, Freeform radio" "http://www.wfmu.org/wfmu.pls" 1 streamlist)) (*track* (type . streamlist) (name . "http://wfmu.org/wfmu_rock.pls") (metadata "WFMU, Rock'n'Soul Ichiban!" "http://www.wfmu.org/wfmu.pls" 1 streamlist)) (*track* (type . streamlist) (name . "http://wfmu.org/wfmu_drummer.pls") (metadata "WFMU, Give the Drummer Radio" "http://www.wfmu.org/wfmu.pls" 1 streamlist)) (*track* (type . streamlist) (name . "http://wfmu.org/wfmu_sheena.pls") (metadata "WFMU, Sheena's Jungle Room" "http://www.wfmu.org/wfmu.pls" 1 streamlist)) (*track* (type . streamlist) (name . "http://nyc01.egihosting.com:6232/listen.pls") (metadata "WBCR-LP - Berkshire Community Radio" "http://nyc01.egihosting.com:6232/listen.pls" 1 streamlist)) (*track* (type . streamlist) (name . "http://199.244.85.125:8000/wxhq1") (metadata "WXHQ-LP - Newport Radio" "http://199.244.85.125:8000/wxhq1" 1 streamlist)))) (defcustom emms-streams-file (concat (file-name-as-directory emms-directory) "streams.emms") "A file used to store the built-in streams." :group 'emms :type 'file) ;;; ------------------------------------------------------------------ ;;; private functions ;;; ------------------------------------------------------------------ (defun emms-streams-install-file (file) "Install FILE, containing streams." (when (not (file-directory-p (file-name-directory emms-streams-file))) (make-directory (file-name-directory emms-streams-file))) (if (or (not (file-exists-p file)) (and (file-exists-p file) (y-or-n-p (format "overwrite existing %s?" file)))) (progn (message "writing %s" file) (with-temp-buffer (insert emms-source-playlist-native-header-line) (insert (format "\n%s\n\n" emms-streams-built-in-disclaimer)) (insert (concat "(" (mapconcat #'(lambda (e) (format "%S" e)) emms-streams-built-in-list "\n") ")")) (write-region (point-min) (point-max) file)) (message "writing %s... done" file)) (message "aborting"))) ;;; ------------------------------------------------------------------ ;;; interface ;;; ------------------------------------------------------------------ (defun emms-streams-install () (interactive) "Install the built-in streams file." (emms-streams-install-file emms-streams-file)) (defun emms-streams () (interactive) "Create or switch to the built-in streaming audio playlist." (when (and (not (file-exists-p emms-streams-file)) (y-or-n-p "Emms' built-in streams file hasn't been installed yet. Install it now?")) (emms-streams-install)) (let ((buf (get-buffer emms-streams-buffer-name))) (when (not buf) (with-current-buffer (get-buffer-create emms-streams-buffer-name) (setq buf (current-buffer)) (emms-playlist-mode) (setq emms-playlist-buffer-p t) (emms-playlist-set-playlist-buffer (current-buffer)) (emms-add-native-playlist emms-streams-file))) (switch-to-buffer buf))) (provide 'emms-streams) ;;; emms-streams.el ends here