;;; Code:
+(require 'riece-identity)
+
(eval-when-compile
(autoload 'lsdb-maybe-load-hash-tables "lsdb")
+ (autoload 'lsdb-rebuild-secondary-hash-tables "lsdb")
(autoload 'lsdb-lookup-records "lsdb")
(autoload 'lsdb-puthash "lsdb")
(autoload 'lsdb-maphash "lsdb")
(autoload 'lsdb-gethash "lsdb")
- (autoload 'lsdb-display-records "lsdb"))
+ (autoload 'lsdb-display-records "lsdb")
+ (autoload 'lsdb-update-record "lsdb"))
(defvar riece-lsdb-cache nil)
+(defvar riece-lsdb-enabled nil)
+
+(defconst riece-lsdb-description
+ "Use LSDB (Lovely Sister Database)")
+
(defun riece-lsdb-update-cache (record)
(let ((irc (cdr (assq 'irc record))))
(while irc
(defun riece-lsdb-lookup-records (user)
(lsdb-maybe-load-hash-tables)
+ (unless riece-lsdb-cache
+ (lsdb-rebuild-secondary-hash-tables))
(let ((names (lsdb-gethash (riece-format-identity user t)
riece-lsdb-cache))
records)
(lsdb-display-records records)
(message "No entry for `%s'" (riece-format-identity user t)))))
+(defvar lsdb-hash-table)
(defun riece-lsdb-add-user (user full-name)
(interactive
(let ((completion-ignore-case t)
;; Remove all properties before adding entry.
(set-text-properties 0 (length irc) nil irc)
(unless (member irc old)
- (lsdb-update-record (list full-name)
+ (lsdb-update-record (list full-name
+ ;; LSDB does not allow empty 'net entry.
+ (or (nth 1 (assq 'net (lsdb-lookup-records
+ full-name)))
+ ""))
(list (cons 'irc (cons irc old)))))))
+(defvar riece-command-mode-map)
(defun riece-lsdb-insinuate ()
(require 'lsdb)
(add-to-list 'lsdb-secondary-hash-tables
(add-to-list 'lsdb-after-update-record-functions
'riece-lsdb-update-cache)
(add-to-list 'lsdb-after-delete-record-functions
- 'riece-lsdb-delete-cache)
+ 'riece-lsdb-delete-cache))
+
+(defun riece-lsdb-enable ()
(define-key riece-command-mode-map
"\C-c\C-ll" 'riece-lsdb-display-records)
(define-key riece-command-mode-map
- "\C-c\C-la" 'riece-lsdb-add-user))
+ "\C-c\C-la" 'riece-lsdb-add-user)
+ (setq riece-lsdb-enabled t))
+
+(defun riece-lsdb-disable ()
+ (define-key riece-command-mode-map
+ "\C-c\C-ll" nil)
+ (define-key riece-command-mode-map
+ "\C-c\C-la" nil)
+ (setq riece-lsdb-enabled nil))
(provide 'riece-lsdb)