tags. From commented-out advice in semantic/senator.el.
+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.
;; [(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:
;; 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)
(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")))))
(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)))