all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
* [patch] vc-annotate-toggle-annotation-visibility, almost
@ 2007-11-04  1:29 Thien-Thi Nguyen
  2007-11-04  3:13 ` Stefan Monnier
  0 siblings, 1 reply; 3+ messages in thread
From: Thien-Thi Nguyen @ 2007-11-04  1:29 UTC (permalink / raw)
  To: emacs-devel

"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))

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2007-11-04  9:43 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-11-04  1:29 [patch] vc-annotate-toggle-annotation-visibility, almost Thien-Thi Nguyen
2007-11-04  3:13 ` Stefan Monnier
2007-11-04  9:43   ` Thien-Thi Nguyen

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.