"Default full name.")
(defcustom lirc-user-name "plugd"
"Default user name.")
-(defcustom lirc-host "irc.libera.chat"
+(defcustom lirc-host "localhost"
"Default server.")
(defcustom lirc-port 6667
"Default port.")
(with-current-buffer "*lirc*"
(set-marker-insertion-type lirc-prompt-marker nil)
(set-marker-insertion-type lirc-input-marker t)
- (let ((inhibit-read-only t))
- (delete-region lirc-prompt-marker lirc-input-marker))
(save-excursion
- (goto-char lirc-prompt-marker)
(let ((inhibit-read-only t))
+ (delete-region lirc-prompt-marker lirc-input-marker)
+ (goto-char lirc-prompt-marker)
(insert
(propertize (if lirc-current-channel
lirc-current-channel
(propertize lirc-prompt-string
'face 'lirc-prompt
'read-only t
- 'rear-nonsticky t))))
- (set-marker-insertion-type lirc-input-marker nil)))
+ 'rear-nonsticky t)))))
+ (set-marker-insertion-type lirc-input-marker nil))
(defvar lirc-prompt-marker nil
"Marker for prompt position in LIRC buffer.")
(defun lirc-eval-msg-string (string)
(let* ((msg (lirc-string->msg string)))
- (cond
- ((equal (lirc-msg-cmd msg) "PING")
+ (pcase (lirc-msg-cmd msg)
+ ("PING"
(lirc-send-msg
(lirc-msg nil nil "PONG" (lirc-msg-params msg))))
- ((string-match (rx (= 3 digit)) (lirc-msg-cmd msg))
- (lirc-display-string (string-join (cdr (lirc-msg-params msg)) " ")))
- (t
+ ;; ((rx (= 3 digit))
+ ;; (lirc-display-string (string-join (cdr (lirc-msg-params msg)) " ")))
+ ((and "JOIN" (let (rx (: (literal lirc-nick) "!" (* anychar))) (lirc-msg-src msg)))
+ (let ((channel (car (lirc-msg-params msg))))
+ (setq lirc-current-channel channel)
+ (add-to-list 'lirc-channel-list channel)
+ (lirc-render-prompt)))
+ (_
(lirc-display-string (lirc-msg->string msg))))))