summaryrefslogtreecommitdiff
path: root/toot/emojis.scm
diff options
context:
space:
mode:
authorMasaya Tojo <masaya@tojo.tokyo>2020-07-17 08:36:07 +0900
committerMasaya Tojo <masaya@tojo.tokyo>2020-07-17 08:57:50 +0900
commit81db0eb7de821aadbfe5392a02a6b1b3468aafdd (patch)
treebeebac16a3e46af26033e703eba5965f85d074d8 /toot/emojis.scm
parent661e5392c647812df711363cea7431a772dcbbed (diff)
toot: Split into modules.
Diffstat (limited to 'toot/emojis.scm')
-rw-r--r--toot/emojis.scm55
1 files changed, 55 insertions, 0 deletions
diff --git a/toot/emojis.scm b/toot/emojis.scm
new file mode 100644
index 0000000..9252911
--- /dev/null
+++ b/toot/emojis.scm
@@ -0,0 +1,55 @@
+;;; Toot --- Mastodon client.
+;;; Copyright © 2020 Masaya Tojo <masaya@tojo.tokyo>
+;;;
+;;; This file is part of Toot.
+;;;
+;;; Toot 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.
+;;;
+;;; Toot 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 Toot. If not, see <http://www.gnu.org/licenses/>.
+
+(define-module (toot emojis)
+ #:use-module (srfi srfi-9)
+ #:use-module (srfi srfi-9 gnu)
+ #:use-module (srfi srfi-1)
+ #:use-module (ice-9 regex)
+ #:export (emoji-from-json
+ emoji?
+ emoji-static-url
+ emoji-shortcode
+ emoji-visible-in-picker?
+ emojis->regexp
+ emoji-find))
+
+(define-record-type <emoji>
+ (emoji-from-json json)
+ emoji?
+ (json emoji-json))
+
+(define (emoji-static-url emoji)
+ (assoc-ref (emoji-json emoji) "static_url"))
+
+(define (emoji-shortcode emoji)
+ (assoc-ref (emoji-json emoji) "shortcode"))
+
+(define (emoji-visible-in-picker? emoji)
+ (assoc-ref (emoji-json emoji) "visible_in_picker"))
+
+(define (emojis->regexp emojis)
+ (string-append ":("
+ (string-join (map (compose regexp-quote emoji-shortcode)
+ emojis)
+ "|")
+ ":)"))
+
+(define (emoji-find emojis shortcode)
+ (find (lambda (emoji) (equal? shortcode (emoji-shortcode emoji)))
+ emojis))