1
0
mirror of https://codeberg.org/cage/tinmop/ synced 2025-01-05 01:26:59 +01:00

- [gemini] improved tour-mode

the command accepts space separated list  of link index or link ranges
(e.g: "5-7 1 2").
This commit is contained in:
cage 2021-05-04 11:52:42 +02:00
parent 3136af5323
commit 37bab5740b
4 changed files with 75 additions and 12 deletions

View File

@ -681,6 +681,19 @@
:ipv4-address-p :ipv4-address-p
:ipv6-address-p)) :ipv6-address-p))
(defpackage :tour-mode-parser
(:use
:cl
:alexandria
:esrap
:cl-ppcre
:text-utils)
(:export
:range-from
:range-to
:range-p
:parse-tour-mode))
(defpackage :x509 (defpackage :x509
(:use (:use
:cl :cl

45
src/tour-mode-parser.lisp Normal file
View File

@ -0,0 +1,45 @@
;; tinmop: an humble gemini and pleroma client
;; Copyright (C) 2021 cage
;; This program 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.
;; This program 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 this program.
;; If not, see [[http://www.gnu.org/licenses/][http://www.gnu.org/licenses/]].
(in-package :tour-mode-parser)
(define-constant +-separator+ "/" :test #'string=)
(defrule digit (character-ranges (#\0 #\9))
(:text t))
(defrule range-delimter #\-)
(defrule list-delimiter #\Space)
(defrule number (and digit (* digit))
(:text t)
(:function parse-integer))
(defstruct range from to)
(defrule range (and number range-delimter number)
(:function (lambda (a) (make-range :from (first a) :to (third a)))))
(defrule tour-tail (? (and list-delimiter tour))
(:function rest))
(defrule tour (and (or range number) tour-tail)
(:function flatten))
(defun parse-tour-mode (data)
(parse 'tour data))

View File

@ -1868,24 +1868,28 @@ gemini://gemini.circumlunar.space/docs/companion/subscription.gmi
(defun tour-mode-on-input-completed-clsr (links) (defun tour-mode-on-input-completed-clsr (links)
(lambda (data) (lambda (data)
(when (string-not-empty-p data) (when (string-not-empty-p data)
(let ((words (split-words data))) (let ((parsed-tour (ignore-errors (tour-mode-parser:parse-tour-mode data))))
(if (> (length words) 1) (if (not parsed-tour)
(let ((indices-list (mapcar
#'num:safe-parse-number
(split-words data))))
(loop for index in indices-list when index do
(if (<= 0 index (length links))
(push (elt links index)
tour)
(notify (format nil (_ "Index ~a out of range") index)
:as-error t))))
(when-let ((scanner (create-scanner data))) (when-let ((scanner (create-scanner data)))
(loop for link in links do (loop for link in links do
(when (or (scan scanner (gemini-parser:name link)) (when (or (scan scanner (gemini-parser:name link))
(scan scanner (gemini-parser:target link))) (scan scanner (gemini-parser:target link)))
(pushnew link tour :test (lambda (a b) (pushnew link tour :test (lambda (a b)
(string= (gemini-parser:target a) (string= (gemini-parser:target a)
(gemini-parser:target b))))))))) (gemini-parser:target b)))))))
(let ((all-indices ()))
(loop for index in parsed-tour do
(if (tour-mode-parser:range-p index)
(let ((from (tour-mode-parser:range-from index))
(to (tour-mode-parser:range-to index)))
(loop for i from (min from to) to (max from to) do
(pushnew i all-indices :test #'=)))
(pushnew index all-indices :test #'=)))
(loop for index in (reverse all-indices) do
(if (<= 0 index (length links))
(push (elt links index) tour)
(notify (format nil (_ "Index ~a out of range") index)
:as-error t))))))
(info-message (_ "Tour saved"))))) (info-message (_ "Tour saved")))))
(defun tour-mode-link () (defun tour-mode-link ()

View File

@ -74,6 +74,7 @@
(:file "stack") (:file "stack")
(:file "uri-parser") (:file "uri-parser")
(:file "iri-parser") (:file "iri-parser")
(:file "tour-mode-parser")
(:file "x509-ffi") (:file "x509-ffi")
(:file "x509") (:file "x509")
(:file "api-pleroma-entities") (:file "api-pleroma-entities")