]> git.eshelyaron.com Git - emacs.git/commitdiff
* register.el (jump-to-register, insert-register): Handle Semantic
authorChong Yidong <cyd@stupidchicken.com>
Sun, 15 Nov 2009 23:54:21 +0000 (23:54 +0000)
committerChong Yidong <cyd@stupidchicken.com>
Sun, 15 Nov 2009 23:54:21 +0000 (23:54 +0000)
tags.  From commented-out advice in semantic/senator.el.

lisp/ChangeLog
lisp/cedet/semantic/senator.el
lisp/register.el

index 876e48db9fd640019c86e4f13272497daf72c4cd..6dac08e6c56acf6007b05dd56c16d1ed2cad2aad 100644 (file)
@@ -1,3 +1,8 @@
+2009-11-15  Chong Yidong  <cyd@stupidchicken.com>
+
+       * register.el (jump-to-register, insert-register): Handle Semantic
+       tags.  From commented-out advice in semantic/senator.el.
+
 2009-11-15  Dan Nicolaescu  <dann@ics.uci.edu>
 
        * vc.el (vc-log-show-limit): New variable.
index 522b655c2084587f465e410e98409bd41c174fe1..d9dda2499576d3262c045da65944f2da266ae5c1 100644 (file)
@@ -857,26 +857,6 @@ Use a senator search function when semantic isearch mode is enabled."
 ;;   [(control ?,)]
 ;;   'senator-isearch-toggle-semantic-mode)
 
-;; (defadvice insert-register (around senator activate)
-;;   "Insert contents of register REGISTER as a tag.
-;; If senator is not active, use the original mechanism."
-;;   (let ((val (get-register (ad-get-arg 0))))
-;;     (if (and senator-minor-mode (interactive-p)
-;;              (semantic-foreign-tag-p val))
-;;         (semantic-insert-foreign-tag val)
-;;       ad-do-it)))
-
-;; (defadvice jump-to-register (around senator activate)
-;;   "Insert contents of register REGISTER as a tag.
-;; If senator is not active, use the original mechanism."
-;;   (let ((val (get-register (ad-get-arg 0))))
-;;     (if (and senator-minor-mode (interactive-p)
-;;              (semantic-foreign-tag-p val))
-;;         (progn
-;;           (switch-to-buffer (semantic-tag-buffer val))
-;;           (goto-char (semantic-tag-start val)))
-;;       ad-do-it)))
-
 (provide 'semantic/senator)
 
 ;; Local variables:
index 4144bba7d0b877ac2ecf037fc91791d96ee48646..2800fd96ee37b0728fd0e4914299403f509bd5ad 100644 (file)
 ;; pieces of buffer state to named variables.  The entry points are
 ;; documented in the Emacs user's manual.
 
+(declare-function semantic-insert-foreign-tag "semantic/tag" (foreign-tag))
+(declare-function semantic-tag-buffer "semantic/tag" (tag))
+(declare-function semantic-tag-start "semantic/tag" (tag))
+
 ;;; Global key bindings
 
 (define-key ctl-x-r-map "\C-@" 'point-to-register)
@@ -135,6 +139,11 @@ delete any existing frames that the frame configuration doesn't mention.
          (error "Register access aborted"))
       (find-file (nth 1 val))
       (goto-char (nth 2 val)))
+     ((and (fboundp 'semantic-foreign-tag-p)
+          semantic-mode
+          (semantic-foreign-tag-p val))
+      (switch-to-buffer (semantic-tag-buffer val))
+      (goto-char (semantic-tag-start val)))
      (t
       (error "Register doesn't contain a buffer position or configuration")))))
 
@@ -284,6 +293,10 @@ Interactively, second arg is non-nil if prefix arg is supplied."
       (princ val (current-buffer)))
      ((and (markerp val) (marker-position val))
       (princ (marker-position val) (current-buffer)))
+     ((and (fboundp 'semantic-foreign-tag-p)
+          semantic-mode
+          (semantic-foreign-tag-p val))
+      (semantic-insert-foreign-tag val))
      (t
       (error "Register does not contain text"))))
   (if (not arg) (exchange-point-and-mark)))