aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKarl Fogel2007-06-16 01:03:35 +0000
committerKarl Fogel2007-06-16 01:03:35 +0000
commitbaef4cbec38e736b3dfd05aec00b783112103c5f (patch)
treef655412aa79bea305b5d69ab3fb1222da3e189bc
parentb32ce4c33acdac8d1fef85f9cd5ec4de3aa4e0fe (diff)
downloademacs-baef4cbec38e736b3dfd05aec00b783112103c5f.tar.gz
emacs-baef4cbec38e736b3dfd05aec00b783112103c5f.zip
* 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.
-rw-r--r--lisp/ChangeLog8
-rw-r--r--lisp/thingatpt.el31
2 files changed, 37 insertions, 2 deletions
diff --git a/lisp/ChangeLog b/lisp/ChangeLog
index c93f195d087..ec8ca907eeb 100644
--- a/lisp/ChangeLog
+++ b/lisp/ChangeLog
@@ -1,3 +1,11 @@
12007-06-15 Karl Fogel <kfogel@red-bean.com>
2
3 * thingatpt.el: Add support for email addresses (`email').
4 (thing-at-point, bounds-of-thing-at-point): Document `email' support.
5 (thing-at-point-email-regexp): New variable.
6 (`email'): Put `bounds-of-thing-at-point' and `thing-at-point'
7 properties on this symbol, with lambda forms for values.
8
12007-06-15 Masatake YAMATO <jet@gyve.org> 92007-06-15 Masatake YAMATO <jet@gyve.org>
2 10
3 * vc-bzr.el (vc-bzr-root): Cache the output of shell command 11 * vc-bzr.el (vc-bzr-root): Cache the output of shell command
diff --git a/lisp/thingatpt.el b/lisp/thingatpt.el
index fd387a22c0f..0d57091fb09 100644
--- a/lisp/thingatpt.el
+++ b/lisp/thingatpt.el
@@ -67,7 +67,7 @@
67 "Determine the start and end buffer locations for the THING at point. 67 "Determine the start and end buffer locations for the THING at point.
68THING is a symbol which specifies the kind of syntactic entity you want. 68THING is a symbol which specifies the kind of syntactic entity you want.
69Possibilities include `symbol', `list', `sexp', `defun', `filename', `url', 69Possibilities include `symbol', `list', `sexp', `defun', `filename', `url',
70`word', `sentence', `whitespace', `line', `page' and others. 70`email', `word', `sentence', `whitespace', `line', `page' and others.
71 71
72See the file `thingatpt.el' for documentation on how to define 72See the file `thingatpt.el' for documentation on how to define
73a symbol as a valid THING. 73a symbol as a valid THING.
@@ -124,7 +124,7 @@ of the textual entity that was found."
124 "Return the THING at point. 124 "Return the THING at point.
125THING is a symbol which specifies the kind of syntactic entity you want. 125THING is a symbol which specifies the kind of syntactic entity you want.
126Possibilities include `symbol', `list', `sexp', `defun', `filename', `url', 126Possibilities include `symbol', `list', `sexp', `defun', `filename', `url',
127`word', `sentence', `whitespace', `line', `page' and others. 127`email', `word', `sentence', `whitespace', `line', `page' and others.
128 128
129See the file `thingatpt.el' for documentation on how to define 129See the file `thingatpt.el' for documentation on how to define
130a symbol as a valid THING." 130a symbol as a valid THING."
@@ -340,6 +340,33 @@ point."
340 (goto-char (car bounds)) 340 (goto-char (car bounds))
341 (error "No URL here"))))) 341 (error "No URL here")))))
342 342
343;; Email addresses
344(defvar thing-at-point-email-regexp
345 "<?[-+_.~a-zA-Z][-+_.~:a-zA-Z0-9]+@[-.a-zA-Z0-9]+>?"
346 "A regular expression probably matching an email address.
347This does not match the real name portion, only the address, optionally
348with angle brackets.")
349
350;; Haven't set 'forward-op on 'email nor defined 'forward-email' because
351;; not sure they're actually needed, and URL seems to skip them too.
352;; Note that (end-of-thing 'email) and (beginning-of-thing 'email)
353;; work automagically, though.
354
355(put 'email 'bounds-of-thing-at-point
356 (lambda ()
357 (let ((thing (thing-at-point-looking-at thing-at-point-email-regexp)))
358 (if thing
359 (let ((beginning (match-beginning 0))
360 (end (match-end 0)))
361 (cons beginning end))))))
362
363(put 'email 'thing-at-point
364 (lambda ()
365 (let ((boundary-pair (bounds-of-thing-at-point 'email)))
366 (if boundary-pair
367 (buffer-substring-no-properties
368 (car boundary-pair) (cdr boundary-pair))))))
369
343;; Whitespace 370;; Whitespace
344 371
345(defun forward-whitespace (arg) 372(defun forward-whitespace (arg)