aboutsummaryrefslogtreecommitdiff
path: root/lisp/mastodon-tl.el
diff options
context:
space:
mode:
Diffstat (limited to 'lisp/mastodon-tl.el')
-rw-r--r--lisp/mastodon-tl.el56
1 files changed, 28 insertions, 28 deletions
diff --git a/lisp/mastodon-tl.el b/lisp/mastodon-tl.el
index 2f879de..124d635 100644
--- a/lisp/mastodon-tl.el
+++ b/lisp/mastodon-tl.el
@@ -67,6 +67,7 @@
(autoload 'mastodon-profile--lookup-account-in-status "mastodon-profile")
(autoload 'mastodon-profile--make-author-buffer "mastodon-profile")
(autoload 'mastodon-profile--my-profile "mastodon-profile")
+(autoload 'mastodon-profile--profile-json "mastodon-profile")
(autoload 'mastodon-profile--search-account-by-handle "mastodon-profile")
(autoload 'mastodon-profile--toot-json "mastodon-profile")
(autoload 'mastodon-profile--view-author-profile "mastodon-profile")
@@ -273,7 +274,7 @@ This also skips tab items in invisible text, i.e. hidden spoiler text."
(if (null next-range)
(message "Nothing else here.")
(goto-char (car next-range))
- (message "%s" (get-text-property (point) 'help-echo)))))
+ (message "%s" (mastodon-tl--property 'help-echo :no-move)))))
(defun mastodon-tl--previous-tab-item ()
"Move to the previous interesting item.
@@ -293,7 +294,7 @@ text, i.e. hidden spoiler text."
(if (null next-range)
(message "Nothing else before this.")
(goto-char (car next-range))
- (message "%s" (get-text-property (point) 'help-echo)))))
+ (message "%s" (mastodon-tl--property 'help-echo :no-move)))))
(defun mastodon-tl--goto-toot-pos (find-pos refresh &optional pos)
"Search for toot with FIND-POS.
@@ -400,12 +401,12 @@ Optionally load TAG timeline directly."
Do so if type of status at poins is not follow_request/follow."
(let ((type (alist-get
'type
- (get-text-property (point) 'toot-json)))
- (echo (get-text-property (point) 'help-echo)))
+ (mastodon-tl--property 'toot-json :no-move)))
+ (echo (mastodon-tl--property 'help-echo :no-move)))
(when echo ; not for followers/following in profile
(unless (or (string= type "follow_request")
(string= type "follow")) ; no counts for these
- (message "%s" (get-text-property (point) 'help-echo))))))
+ (message "%s" (mastodon-tl--property 'help-echo :no-move))))))
(defun mastodon-tl--byline-author (toot &optional avatar)
"Propertize author of TOOT.
@@ -1311,11 +1312,11 @@ in which case play first video or gif from current toot."
;; point in byline:
url
;; point in toot:
- (get-text-property (point) 'image-url)))
+ (mastodon-tl--property 'image-url :no-move)))
(type (or ;; in byline:
type
;; point in toot:
- (mastodon-tl--property 'mastodon-media-type))))
+ (mastodon-tl--property 'mastodon-media-type :no-move))))
(if url
(if (or (equal type "gifv")
(equal type "video"))
@@ -1594,15 +1595,18 @@ Return value from boosted content if available."
(t2 (replace-regexp-in-string "<\/?span>" "" t1)))
(replace-regexp-in-string "<span class=\"h-card\">" "" t2)))
-(defun mastodon-tl--property (prop &optional backward)
+(defun mastodon-tl--property (prop &optional no-move backward)
"Get property PROP for toot at point.
-Move forward (down) the timeline unless BACKWARD is non-nil."
- (or (get-text-property (point) prop)
- (save-excursion
- (if backward
- (mastodon-tl--goto-prev-toot)
- (mastodon-tl--goto-next-toot))
- (get-text-property (point) prop))))
+Move forward (down) the timeline unless NO-MOVE is non-nil.
+BACKWARD means move backward (up) the timeline."
+ (if no-move
+ (get-text-property (point) prop)
+ (or (get-text-property (point) prop)
+ (save-excursion
+ (if backward
+ (mastodon-tl--goto-prev-toot)
+ (mastodon-tl--goto-next-toot))
+ (get-text-property (point) prop)))))
(defun mastodon-tl--newest-id ()
"Return toot-id from the top of the buffer."
@@ -1672,12 +1676,9 @@ view all branches of a thread."
(defun mastodon-tl--thread (&optional id)
"Open thread buffer for toot at point or with ID."
- ;; NB: this is called by `mastodon-url-lookup', which means it must work
- ;; without `mastodon-tl--buffer-spec' being set!
- ;; so avoid calls to `mastodon-tl--property' and friends
(interactive)
- (let* ((id (or id (get-text-property (point) 'base-toot-id)))
- (type (mastodon-tl--field 'type (get-text-property (point) 'toot-json))))
+ (let* ((id (or id (mastodon-tl--property 'base-toot-id :no-move)))
+ (type (mastodon-tl--field 'type (mastodon-tl--property 'toot-json :no-move))))
(if (or (string= type "follow_request")
(string= type "follow")) ; no can thread these
(error "No thread")
@@ -1912,14 +1913,13 @@ LANGS is the accumulated array param alist if we re-run recursively."
;; fetch 'toot-json:
(mastodon-tl--buffer-type-eq 'profile-followers)
(mastodon-tl--buffer-type-eq 'profile-following))
- (list (alist-get 'acct (get-text-property (point) 'toot-json))))
- ;; profile view, no toots, point on profile note, ie. 'profile-json:
+ (list (alist-get 'acct
+ (mastodon-tl--property 'toot-json :no-move))))
+ ;; profile view, no toots
;; needed for e.g. gup.pe groups which show no toots publically:
- ((and (mastodon-tl--profile-buffer-p)
- (get-text-property (point) 'profile-json))
- (list (alist-get 'acct (get-text-property (point) 'profile-json))))
- ;; avoid tl--property here because it calls next-toot
- ;; which breaks non-toot buffers like foll reqs etc.:
+ ((mastodon-tl--profile-buffer-p)
+ (list (alist-get 'acct
+ (mastodon-profile--profile-json))))
(t
(mastodon-profile--extract-users-handles
(mastodon-profile--toot-json))))))
@@ -1961,7 +1961,7 @@ LANGS is an array parameters alist of languages to filer user's posts by."
;; if profile view, use 'profile-json as status:
(if (mastodon-tl--profile-buffer-p)
(mastodon-profile--lookup-account-in-status
- user-handle (get-text-property (point) 'profile-json))
+ user-handle (mastodon-profile--profile-json))
;; if muting/blocking, we select from handles in current status
(mastodon-profile--lookup-account-in-status
user-handle (mastodon-profile--toot-json)))))