X-Git-Url: http://christophe.rhodes.io/gitweb/?p=iplayer-el.git;a=blobdiff_plain;f=iplayer.el;h=6c4352021471045b4a493591bd23ed3d17f01a08;hp=3ef51900c5f4cefdae65c338f9f50cd28a96957d;hb=9ada771e3df04aa49f295d46e75ba8d2e8012444;hpb=bc288412803d415779da5df3fd5feec3051e1918 diff --git a/iplayer.el b/iplayer.el index 3ef5190..6c43520 100644 --- a/iplayer.el +++ b/iplayer.el @@ -166,6 +166,8 @@ ("2" . "BBC Two") ("3" . "BBC Three") ("4" . "BBC Four") + ("8" . "CBBC") + ("9" . "CBeebies") ("!" . "BBC Radio 1") ("\"" . "BBC Radio 2") @@ -224,17 +226,20 @@ The presets are defined in the variable `iplayer-presets'." (state (process-get process 'iplayer-state)) (progress (process-get process 'iplayer-progress))) (with-current-buffer (get-buffer-create "*iplayer-progress*") - (goto-char (point-min)) - (let ((found (re-search-forward (format "^%s:" id) nil 'end))) - (unless found - (unless (= (point) (progn (forward-line 0) (point))) - (goto-char (point-max)) - (newline))) - (forward-line 0) - (let ((beg (point))) - (end-of-line) - (delete-region beg (point))) - (insert (format "%s: %s %s%%" id state progress)))))) + (special-mode) + (save-excursion + (goto-char (point-min)) + (let ((found (re-search-forward (format "^%s:" id) nil 'end)) + (inhibit-read-only t)) + (unless found + (unless (= (point) (progn (forward-line 0) (point))) + (goto-char (point-max)) + (newline))) + (forward-line 0) + (let ((beg (point))) + (end-of-line) + (delete-region beg (point))) + (insert (format "%s: %s %s%%" id state progress))))))) (defun iplayer-download-process-filter (process string) (catch 'no-progress