]> git.eshelyaron.com Git - emacs.git/commitdiff
* thingatpt.el: Add support for email addresses (`email').
authorKarl Fogel <kfogel@red-bean.com>
Sat, 16 Jun 2007 01:03:35 +0000 (01:03 +0000)
committerKarl Fogel <kfogel@red-bean.com>
Sat, 16 Jun 2007 01:03:35 +0000 (01:03 +0000)
  (thing-at-point, bounds-of-thing-at-point): Document `email' support.
  (thing-at-point-email-regexp): New variable.
  (`email'): Put `bounds-of-thing-at-point' and `thing-at-point'
  properties on this symbol, with lambda forms for values.

lisp/ChangeLog
lisp/thingatpt.el

index c93f195d087a86960f719afe5617c136bf390df2..ec8ca907eebc144f3b64e3ae984cf96631ebc7b6 100644 (file)
@@ -1,3 +1,11 @@
+2007-06-15  Karl Fogel  <kfogel@red-bean.com>
+
+       * thingatpt.el: Add support for email addresses (`email').
+       (thing-at-point, bounds-of-thing-at-point): Document `email' support.
+       (thing-at-point-email-regexp): New variable.
+       (`email'): Put `bounds-of-thing-at-point' and `thing-at-point'
+       properties on this symbol, with lambda forms for values.
+       
 2007-06-15  Masatake YAMATO  <jet@gyve.org>
 
        * vc-bzr.el (vc-bzr-root): Cache the output of shell command
index fd387a22c0f2bbb93cd5b3daaf06346d2bf05e50..0d57091fb0925d59d201a535fe7a8f8b9285617c 100644 (file)
@@ -67,7 +67,7 @@
   "Determine the start and end buffer locations for the THING at point.
 THING is a symbol which specifies the kind of syntactic entity you want.
 Possibilities include `symbol', `list', `sexp', `defun', `filename', `url',
-`word', `sentence', `whitespace', `line', `page' and others.
+`email', `word', `sentence', `whitespace', `line', `page' and others.
 
 See the file `thingatpt.el' for documentation on how to define
 a symbol as a valid THING.
@@ -124,7 +124,7 @@ of the textual entity that was found."
   "Return the THING at point.
 THING is a symbol which specifies the kind of syntactic entity you want.
 Possibilities include `symbol', `list', `sexp', `defun', `filename', `url',
-`word', `sentence', `whitespace', `line', `page' and others.
+`email', `word', `sentence', `whitespace', `line', `page' and others.
 
 See the file `thingatpt.el' for documentation on how to define
 a symbol as a valid THING."
@@ -340,6 +340,33 @@ point."
              (goto-char (car bounds))
            (error "No URL here")))))
 
+;;   Email addresses
+(defvar thing-at-point-email-regexp
+  "<?[-+_.~a-zA-Z][-+_.~:a-zA-Z0-9]+@[-.a-zA-Z0-9]+>?"
+  "A regular expression probably matching an email address.
+This does not match the real name portion, only the address, optionally
+with angle brackets.")
+
+;; Haven't set 'forward-op on 'email nor defined 'forward-email' because
+;; not sure they're actually needed, and URL seems to skip them too.
+;; Note that (end-of-thing 'email) and (beginning-of-thing 'email)
+;; work automagically, though.
+
+(put 'email 'bounds-of-thing-at-point
+     (lambda ()
+       (let ((thing (thing-at-point-looking-at thing-at-point-email-regexp)))
+         (if thing
+             (let ((beginning (match-beginning 0))
+                   (end (match-end 0)))
+               (cons beginning end))))))
+
+(put 'email 'thing-at-point
+     (lambda ()
+       (let ((boundary-pair (bounds-of-thing-at-point 'email)))
+         (if boundary-pair
+             (buffer-substring-no-properties
+              (car boundary-pair) (cdr boundary-pair))))))
+
 ;;  Whitespace
 
 (defun forward-whitespace (arg)