all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Thien-Thi Nguyen <ttn@gnuvola.org>
To: emacs-devel@gnu.org
Subject: [patch] vc-annotate-toggle-annotation-visibility, almost
Date: Sun, 04 Nov 2007 02:29:15 +0100	[thread overview]
Message-ID: <87zlxu4x3o.fsf@ambire.localdomain> (raw)

"almost" because i don't see any change w/ `redisplay'
in `vc-annotate-toggle-annotation-visibility'; use of
`force-mode-line-update' is suboptimal.  still investigating.

  * vc.el (vc-annotate-toggle-annotation-visibility): New command.
  (vc-annotate-mode-map): Bind "V" to new command.
  (vc-annotate-mode): Clear buffer-invisibility-spec.
  (vc-annotate-get-time-set-line-props): New func.
  (vc-annotate-display-autoscale, vc-annotate-difference): Use it.
  ("VC Annotate Display Menu"): Add entry for new command.

comments?

thi

__________________________________________________________
*** vc.el	30 Oct 2007 12:43:34 -0000	1.477
--- vc.el	4 Nov 2007 01:17:53 -0000
***************
*** 774,779 ****
--- 774,780 ----
      (define-key m "N" 'vc-annotate-next-revision)
      (define-key m "P" 'vc-annotate-prev-revision)
      (define-key m "W" 'vc-annotate-working-revision)
+     (define-key m "V" 'vc-annotate-toggle-annotation-visibility)
      m)
    "Local keymap used for VC-Annotate mode.")
  
***************
*** 3132,3142 ****
--- 3133,3158 ----
  You can use the mode-specific menu to alter the time-span of the used
  colors.  See variable `vc-annotate-menu-elements' for customizing the
  menu items."
+   (setq buffer-invisibility-spec nil)
    (set (make-local-variable 'truncate-lines) t)
    (set (make-local-variable 'font-lock-defaults)
         '(vc-annotate-font-lock-keywords t))
    (view-mode 1))
  
+ (defun vc-annotate-toggle-annotation-visibility ()
+   "Toggle whether or not the annotation is visible."
+   (interactive)
+   (funcall (if (memq 'vc-annotate-annotation buffer-invisibility-spec)
+                'remove-from-invisibility-spec
+              'add-to-invisibility-spec)
+            'vc-annotate-annotation)
+   (when (get-text-property (point) 'invisible)
+     (goto-char (next-single-property-change (point) 'invisible)))
+   ;; FIXME: `redisplay' is ineffectual. --ttn
+   ;; (let ((redisplay-dont-pause t))
+   ;;   (redisplay t))
+   (force-mode-line-update t))
+ 
  (defun vc-annotate-display-default (ratio)
    "Display the output of \\[vc-annotate] using the default color range.
  The color range is given by `vc-annotate-color-map', scaled by RATIO.
***************
*** 3151,3156 ****
--- 3167,3179 ----
    ;; Since entries should be sorted, we can just use the last one.
    (caar (last color-map)))
  
+ (defun vc-annotate-get-time-set-line-props ()
+   (let ((bol (point))
+         (date (vc-call-backend vc-annotate-backend 'annotate-time))
+         (inhibit-read-only t))
+     (put-text-property bol (point) 'invisible 'vc-annotate-annotation)
+     date))
+ 
  (defun vc-annotate-display-autoscale (&optional full)
    "Highlight the output of \\[vc-annotate] using an autoscaled color map.
  Autoscaling means that the map is scaled from the current time to the
***************
*** 3166,3172 ****
      (save-excursion
        (goto-char (point-min))
        (while (not (eobp))
!         (when (setq date (vc-call-backend vc-annotate-backend 'annotate-time))
            (if (> date newest)
                (setq newest date))
            (if (< date oldest)
--- 3189,3195 ----
      (save-excursion
        (goto-char (point-min))
        (while (not (eobp))
!         (when (setq date (vc-annotate-get-time-set-line-props))
            (if (> date newest)
                (setq newest date))
            (if (< date oldest)
***************
*** 3214,3219 ****
--- 3237,3243 ----
       :style toggle :selected
       (eq vc-annotate-display-mode 'fullscale)]
      "--"
+     ["Toggle annotation visibility" vc-annotate-toggle-annotation-visibility]
      ["Annotate previous revision" vc-annotate-prev-revision]
      ["Annotate next revision" vc-annotate-next-revision]
      ["Annotate revision at line" vc-annotate-revision-at-line]
***************
*** 3478,3484 ****
  This calls the backend function annotate-time, and returns the
  difference in days between the time returned and the current time,
  or OFFSET if present."
!    (let ((next-time (vc-call-backend vc-annotate-backend 'annotate-time)))
       (if next-time
  	 (- (or offset
  		(vc-call-backend vc-annotate-backend 'annotate-current-time))
--- 3502,3508 ----
  This calls the backend function annotate-time, and returns the
  difference in days between the time returned and the current time,
  or OFFSET if present."
!    (let ((next-time (vc-annotate-get-time-set-line-props)))
       (if next-time
  	 (- (or offset
  		(vc-call-backend vc-annotate-backend 'annotate-current-time))

             reply	other threads:[~2007-11-04  1:29 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2007-11-04  1:29 Thien-Thi Nguyen [this message]
2007-11-04  3:13 ` [patch] vc-annotate-toggle-annotation-visibility, almost Stefan Monnier
2007-11-04  9:43   ` Thien-Thi Nguyen

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=87zlxu4x3o.fsf@ambire.localdomain \
    --to=ttn@gnuvola.org \
    --cc=emacs-devel@gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this external index

	https://git.savannah.gnu.org/cgit/emacs.git
	https://git.savannah.gnu.org/cgit/emacs/org-mode.git

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.