summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThanos Apollo <[email protected]>2023-10-17 09:34:40 +0300
committerThanos Apollo <[email protected]>2023-10-17 09:34:40 +0300
commitf0dfd5508df5d33cbbc801a6e5a56b73b5aa3d7d (patch)
tree4244d6bbe7e8fb2eaa59a559311242bfe9c4d21b
parent0a2719e72a8bb09d104044f0cf0c9ebf9485647b (diff)
parent1b4a3c46643cf08cf867d632078eaff446f2dd0c (diff)
Merge version 2.0.7 branch to 'master'
- Add yeetube-replay (replay entry stored in yeetube-history) - Fix title issues & separate unicode character replacements into yeetube--title-replacements - Improve messages, for future debugging & aesthetics - Redo storing of content info and retrieval, using keywords This version marks yeetube.el in maintenance mode. I have no further plans for further feature additions. However, feel free to discuss with me any changes you'd like to see.
-rw-r--r--README.md5
-rw-r--r--yeetube-buffer.el30
-rw-r--r--yeetube-mpv.el9
-rw-r--r--yeetube.el96
4 files changed, 99 insertions, 41 deletions
diff --git a/README.md b/README.md
index 04ad99e..1b564de 100644
--- a/README.md
+++ b/README.md
@@ -1,3 +1,4 @@
+[![self-host-badge](https://img.shields.io/badge/Repository-Self_hosted-black?logo=git&logoColor=red)](https://git.thanosapollo.com/yeetube/about)
[![MELPA](https://melpa.org/packages/yeetube-badge.svg)](https://melpa.org/#/yeetube)
# Yeetube | Emacs' Youtube Front End
@@ -10,7 +11,7 @@ displayed in a proced-like buffer.
Package functionality includes:
-- Search Youtube for query
+- Query YouTube
- Play video url *by default using mpv*
- Bookmark/Save video url
- Download video *using yt-dlp*
@@ -61,7 +62,7 @@ $ sudo apt install mpv yt-dlp
## Configuration
### Media Player
-By default `yeetube-player` is set to `yeetube-mpv-play-url`, you can
+By default `yeetube-player` is set to `yeetube-mpv-play`, you can
use [mpv.el](https://github.com/kljohann/mpv.el),
[GNU/Emms](https://www.gnu.org/software/emms/) or other similar
packages like so:
diff --git a/yeetube-buffer.el b/yeetube-buffer.el
index 565d192..119c07f 100644
--- a/yeetube-buffer.el
+++ b/yeetube-buffer.el
@@ -75,22 +75,6 @@ Emojis cause formatting issues, this should be off by default."
(equal (aref char-script-table c) 'emoji))
str))
-;; Usually titles from youtube get messed up,
-;; This should fix some of the common issues.
-(defun yeetube-buffer-fix-title (title)
- "Adjust TITLE."
- (let ((replacements '(("&amp;" . "&")
- ("&quot;" . "\"")
- ("&#39;" . "'")
- ("u0026" . "&")
- ("\\\\" . ""))))
- (mapc (lambda (replacement)
- (setf title (replace-regexp-in-string (car replacement) (cdr replacement) title)))
- replacements)
- (if yeetube-buffer-display-emojis
- title
- (yeetube-buffer-strip-emojis title))))
-
(defun yeetube-buffer-fix-view-count (view-count)
"Fix VIEW-COUNT display issues."
(replace-regexp-in-string "[^0-9]" "" view-count))
@@ -183,12 +167,14 @@ Emojis cause formatting issues, this should be off by default."
(defun yeetube-buffer-insert-content (content)
"Insert formatted CONTENT."
(insert
- (concat (yeetube-buffer--format-title (yeetube-buffer-fix-title (car content)))
- (yeetube-buffer--format-view-count (yeetube-buffer-view-count-add-commas
- (yeetube-buffer-fix-view-count (nth 2 content))))
- (yeetube-buffer--format-video-duration (nth 3 content))
- (yeetube-buffer--format-channel (nth 4 content))
- "\n")))
+ (concat
+ (yeetube-buffer--format-title (cl-getf content :title))
+ (yeetube-buffer--format-view-count (yeetube-buffer-view-count-add-commas
+ (yeetube-buffer-fix-view-count
+ (cl-getf content :view-count))))
+ (yeetube-buffer--format-video-duration (cl-getf content :duration))
+ (yeetube-buffer--format-channel (cl-getf content :channel))
+ "\n")))
;;;###autoload
(defun yeetube-buffer-create (query content buffer-mode)
diff --git a/yeetube-mpv.el b/yeetube-mpv.el
index 6c59552..22c78ae 100644
--- a/yeetube-mpv.el
+++ b/yeetube-mpv.el
@@ -50,11 +50,14 @@
(start-process-shell-command
"yeetube" nil command))))
-(defun yeetube-mpv-play-url (url)
- "Start yeetube process to play URL using mpv."
+(defun yeetube-mpv-play (input)
+ "Start yeetube process to play INPUT using mpv.
+
+This function is not specific to just playing urls. Feel free to use
+to play local files."
(yeetube-mpv-process
(concat yeetube-mpv-path " "
- (shell-quote-argument url)
+ (shell-quote-argument input)
(when yeetube-mpv-disable-video " --no-video")))
(message "yeetube: starting mpv process"))
diff --git a/yeetube.el b/yeetube.el
index 3b41587..7edfcd8 100644
--- a/yeetube.el
+++ b/yeetube.el
@@ -5,7 +5,7 @@
;; Author: Thanos Apollo <[email protected]>
;; Keywords: extensions youtube videos
;; URL: https://git.thanosapollo.com/yeetube
-;; Version: 2.0.6
+;; Version: 2.0.7
;; Package-Requires: ((emacs "27.2"))
@@ -30,7 +30,7 @@
;;
;; Basic functionality includes:
;;
-;; - Search Youtube for query
+;; - Query YouTube
;; - Play video url by default using mpv
;; - Bookmark/Save video url
;; - Download video using yt-dlp
@@ -53,7 +53,7 @@
:type 'natnump
:group 'yeetube)
-(defcustom yeetube-player #'yeetube-mpv-play-url
+(defcustom yeetube-player #'yeetube-mpv-play
"Select media player function."
:type 'function
:group 'yeetube)
@@ -87,21 +87,59 @@ Example Usage:
(defvar yeetube-saved-videos nil
"Saved/bookmarked video urls.")
-(defvar yeetube-last-played nil
- "Last played url.")
+(defvar yeetube-history nil
+ "Stored urls & titles of recently played content.")
+
+(defvar yeetube-url "https://youtube.com/watch?v="
+ "URL used to play videos from.
+
+You can change the value to an invidious instance.")
+
+(defun yeetube-get (keyword)
+ "Retrieve KEYWORD value for entry at point.
+
+Retrieve keyword value for entry at point, from `yeetube-content', in
+*yeetube* buffer.
+
+Keywords:
+- :title
+- :videoid
+- :view-count
+- :duration
+- :channel"
+ (unless (keywordp keyword)
+ (error "Value `%s' is not a keyword" keyword))
+ (let ((video-info
+ (cl-getf (nth (- (line-number-at-pos) 1) (reverse yeetube-content)) keyword)))
+ video-info))
-;; TODO: Rewrite without hardcoding youtube.com
(defun yeetube-get-url ()
- "Get url for subject in *yeetube* buffer at point."
- (let ((video-url (concat "https://youtube.com/watch?v="
- (cadr (nth (- (line-number-at-pos) 1) (reverse yeetube-content))))))
+ "Get video url."
+ (let ((video-url (concat yeetube-url (yeetube-get :videoid))))
video-url))
;;;###autoload
(defun yeetube-play ()
"Play video at point in *yeetube* buffer."
(interactive)
- (funcall yeetube-player (yeetube-get-url)))
+ (let ((video-url (yeetube-get-url))
+ (video-title (yeetube-get :title)))
+ (funcall yeetube-player video-url)
+ (push (list :url video-url :title video-title) yeetube-history)
+ (message "Playing: %s" video-title)))
+
+;;;###autoload
+(defun yeetube-replay ()
+ "Select entry from history to replay.
+
+Select entry title from yeetube-history and play corresponding URL."
+ (interactive)
+ (let* ((titles (mapcar (lambda (entry) (cl-getf entry :title)) yeetube-history))
+ (selected (completing-read "Replay: " titles))
+ (selected-entry (cl-find-if (lambda (entry) (string= selected (cl-getf entry :title))) yeetube-history))
+ (url (cl-getf selected-entry :url)))
+ (funcall yeetube-player url)
+ (message "Replaying: %s" selected)))
(defun yeetube-load-saved-videos ()
"Load saved videos."
@@ -123,13 +161,16 @@ Example Usage:
(url (yeetube-get-url)))
(push (cons name url) yeetube-saved-videos)))
+;; We could use keywords here, but it would break users saved videos
+;; from previous versions.
;;;###autoload
(defun yeetube-play-saved-video ()
"Select & Play a saved video."
(interactive)
(yeetube-load-saved-videos)
(let ((video (completing-read "Select video: " yeetube-saved-videos nil t)))
- (funcall yeetube-player (cdr (assoc video yeetube-saved-videos)))))
+ (funcall yeetube-player (cdr (assoc video yeetube-saved-videos)))
+ (message "Playing: %s" (car (assoc video yeetube-saved-videos)))))
;;;###autoload
(defun yeetube-remove-saved-video ()
@@ -198,6 +239,25 @@ then for item."
(search-forward query nil t)
(search-forward "text" nil t))
+(defvar yeetube--title-replacements
+ '(("&amp;" . "&")
+ ("&quot;" . "\"")
+ ("&#39;" . "'")
+ ("u0026" . "&")
+ ("\\\\" . ""))
+ "Unicode character replacements.")
+
+;; Usually titles from youtube get messed up,
+;; This should fix some of the common issues.
+(defun yeetube---fix-title (title)
+ "Adjust TITLE."
+ (mapc (lambda (replacement)
+ (setf title (replace-regexp-in-string (car replacement) (cdr replacement) title)))
+ yeetube--title-replacements)
+ (if yeetube-buffer-display-emojis
+ title
+ (yeetube-buffer-strip-emojis title)))
+
(defun yeetube-get-content ()
"Get content from youtube."
(setf yeetube-content nil)
@@ -207,7 +267,8 @@ then for item."
(let ((videoid (buffer-substring (+ (point) 3) (- (search-forward ",") 2))))
(unless (member videoid (car yeetube-content))
(yeetube-get-item "title") ;; Video Title
- (let ((title (buffer-substring (+ (point) 3) (- (search-forward ",\"") 5))))
+ (let ((title (yeetube---fix-title
+ (buffer-substring (+ (point) 3) (- (search-forward ",\"") 5)))))
(unless (member title (car yeetube-content))
(yeetube-get-item "viewcounttext") ;; View Count
(let ((view-count (buffer-substring (+ (point) 3) (- (search-forward " ") 0))))
@@ -216,7 +277,11 @@ then for item."
(yeetube-get-item "longbylinetext") ;; Channel Name
(let ((channel (buffer-substring (+ (point) 3) (- (search-forward ",") 2))))
(push
- `(,title ,videoid ,view-count ,video-duration ,channel)
+ (list :title title
+ :videoid videoid
+ :view-count view-count
+ :duration video-duration
+ :channel channel)
yeetube-content))))))))))
(add-variable-watcher 'yeetube-saved-videos #'yeetube-update-saved-videos-list)
@@ -277,7 +342,8 @@ Optional values:
(when (string-prefix-p "http" url)
(let ((default-directory yeetube-download-directory))
(yeetube-download--ytdlp url nil yeetube-download-audio-format)
- (message "Downloading %s " url)))))
+ (message "Downloading: '%s' at '%s'"
+ (yeetube-get :title) yeetube-download-directory)))))
;; TODO: Add option to use ffmpeg
;;;###autoload
@@ -303,6 +369,7 @@ prompt blank to keep the default name."
;; Yeetube Mode
(defvar yeetube-mode-map (make-sparse-keymap))
(define-key yeetube-mode-map (kbd "RET") #'yeetube-play)
+(define-key yeetube-mode-map (kbd "M-RET") #'yeetube-search)
(define-key yeetube-mode-map (kbd "b") #'yeetube-browse-url)
(define-key yeetube-mode-map (kbd "d") #'yeetube-download-video)
(define-key yeetube-mode-map (kbd "D") #'yeetube-download-change-directory)
@@ -312,6 +379,7 @@ prompt blank to keep the default name."
(define-key yeetube-mode-map (kbd "s") #'yeetube-save-video)
(define-key yeetube-mode-map (kbd "P") #'yeetube-play-saved-video)
(define-key yeetube-mode-map (kbd "q") #'quit-window)
+(define-key yeetube-mode-map (kbd "r") #'yeetube-replay)
(define-derived-mode yeetube-mode special-mode "Yeetube"
"Yeetube mode."