File: bm-sync.el

package info (click to toggle)
bm-el 201905-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye, sid
  • size: 204 kB
  • sloc: lisp: 1,519; sh: 12; makefile: 2
file content (75 lines) | stat: -rw-r--r-- 2,361 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
;;; bm-sync.el --- Synchronize bm.el bookmarks with standard Emacs bookmarks

;; Copyright (C) 2016  Jo Odland

;; Author: Jo Odland <jo.odland(at)gmail.com>
;; Keywords: bookmark
;; URL: https://github.com/joodland/bm


;; This file is *NOT* part of GNU Emacs.

;; 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 2, 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 GNU Emacs; see the file COPYING. If not, write to the
;; Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.


;;; Description:
;;
;; Create/remove a standard Emacs bookmark every time you toggle a
;; bm.el bookmark. This code is experimental.
;;
;; This code is related to a GitHub issue,
;; https://github.com/joodland/bm/issues/18

;;; Installation:
;;
;;   To use bm-sync.el, put it in your load-path and add the following
;;   to your .emacs. It also requires bm.el to be present.
;;
;;   (require 'bm-sync)
;;


;;; Code:
;;
(require 'bm)


(defun bm-bookmark-add--sync (&optional annotation time temporary-bookmark)
  "Add a standard Emacs bookmarks when setting a bm-bookmark."
  ;; create a unique name for the bookmark
  (let ((name (concat (buffer-name)
                      " l:" (int-to-string
                             (count-lines (point-min) (point))))))
    ;; store the bookmark name as an annotation
    (bm-bookmark-annotate (bm-bookmark-at (point)) name)
    (bookmark-set name)))

(advice-add 'bm-bookmark-add :after #'bm-bookmark-add--sync)


(defun bm-bookmark-remove--sync (&optional bookmark)
  "Remove a standard Emacs bookmarks when setting a bm-bookmark."
  (if (null bookmark)
      (setq bookmark (bm-bookmark-at (point))))

  (if (bm-bookmarkp bookmark)
      ;; delete bookmark by name (from annotation)
      (bookmark-delete (overlay-get bookmark 'annotation))))

(advice-add 'bm-bookmark-remove :before #'bm-bookmark-remove--sync)


(provide 'bm-sync)
;;; bm-sync.el ends here