aboutsummaryrefslogtreecommitdiffstats
path: root/lisp/progmodes
diff options
context:
space:
mode:
Diffstat (limited to 'lisp/progmodes')
-rw-r--r--lisp/progmodes/cap-words.el94
-rw-r--r--lisp/progmodes/perl-mode.el2
-rw-r--r--lisp/progmodes/sh-script.el2
3 files changed, 96 insertions, 2 deletions
diff --git a/lisp/progmodes/cap-words.el b/lisp/progmodes/cap-words.el
new file mode 100644
index 0000000000..36a2ba0ad5
--- /dev/null
+++ b/lisp/progmodes/cap-words.el
@@ -0,0 +1,94 @@
+;;; cap-words.el --- minor mode for motion in CapsitalizedWordIdentifiers
+
+;; Copyright (C) 2002 Free Software Foundation, Inc.
+
+;; Author: Dave Love <[email protected]>
+;; Keywords: languages
+
+;; This file is free software; you can redistribute it and/or modify
+;; it under the terms of the GNU General Public License as published by
+;; the Free Software Foundation; either version 2, or (at your option)
+;; any later version.
+
+;; This file is distributed in the hope that it will be useful,
+;; but WITHOUT ANY WARRANTY; without even the implied warranty of
+;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+;; GNU General Public License for more details.
+
+;; You should have received a copy of the GNU General Public License
+;; along with GNU Emacs; see the file COPYING. If not, write to
+;; the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+;; Boston, MA 02111-1307, USA.
+
+;;; Commentary:
+
+;; Provides Capitalized Words minor mode for word movement in
+;; identifiers CapitalizedLikeThis.
+
+;; Note that the same effect could be obtained by frobbing the
+;; category of upper case characters to produce word boundaries, but
+;; the necessary processing isn't done for ASCII characters.
+
+;; Fixme: This doesn't work properly for mouse double clicks.
+
+;;; Code:
+
+(defun capitalized-next-word-boundary (pos limit)
+ "Function for use in `next-word-boundary-function-table'.
+Looks for word boundaries before capitals."
+ (save-excursion
+ (goto-char pos)
+ (let (case-fold-search)
+ (if (<= pos limit)
+ ;; Fixme: Are these regexps the best?
+ (or (and (re-search-forward "\\=.\\w*[[:upper:]]"
+ limit t)
+ (progn (backward-char)
+ t))
+ (re-search-forward "\\>" limit t))
+ (or (re-search-backward "[[:upper:]]\\w*\\=" limit t)
+ (re-search-backward "\\<" limit t))))
+ (point)))
+
+(defconst capitalized-next-word-boundary-function-table
+ (let ((tab (make-char-table nil)))
+ (set-char-table-range tab t #'capitalized-next-word-boundary)
+ tab)
+ "Assigned to `next-word-boundary-function-table' in Capitalized Words mode.")
+
+;;;###autoload
+(define-minor-mode capitalized-words-mode
+ "Toggle Capitalized- Words mode.
+
+In this minor mode, a word boundary occurs immediately before an
+uppercase letter in a symbol. This is in addition to all the normal
+boundaries given by the syntax and category tables. There is no
+restriction to ASCII.
+
+E.g. the beginning of words in the following identifier are as marked:
+
+ capitalizedWorDD
+ ^ ^ ^^
+
+Note that these word boundaries only apply for word motion and
+marking commands such as \\[forward-word]. This mode does not affect word
+boundaries in found by regexp matching (`\\>', `\\w' &c).
+
+This style of identifiers is common in environments like Java ones,
+where underscores aren't trendy enough. Capitalization rules are
+sometimes part of the language, e.g. Haskell, which may thus encourage
+such a style. It is appropriate to add `capitalized-words-mode' to
+the mode hook for programming langauge modes in which you encounter
+variables like this, e.g. `java-mode-hook'. It's unlikely to cause
+trouble if such identifiers aren't used.
+
+See also `glasses-mode' and `studlify-word'.
+Obsoletes `c-forward-into-nomenclature'."
+ nil " Caps" nil :group 'programming
+ (set (make-local-variable 'next-word-boundary-function-table)
+ capitalized-next-word-boundary-function-table))
+
+(provide 'cap-words)
+
+;;; arch-tag: 46513b64-fe5a-4c0b-902c-ed235c22975f
+;;; cap-words.el ends here
diff --git a/lisp/progmodes/perl-mode.el b/lisp/progmodes/perl-mode.el
index 6fcd16e97c..0febea4450 100644
--- a/lisp/progmodes/perl-mode.el
+++ b/lisp/progmodes/perl-mode.el
@@ -296,7 +296,7 @@ The expansion is entirely correct because it uses the C preprocessor."
((not char)
;; Comment or docstring.
(if (nth 7 state) font-lock-doc-face font-lock-comment-face))
- ((and (char-valid-p char) (eq (char-syntax (nth 3 state)) ?\"))
+ ((and (characterp char) (eq (char-syntax (nth 3 state)) ?\"))
;; Normal string.
font-lock-string-face)
((eq (nth 3 state) ?\n)
diff --git a/lisp/progmodes/sh-script.el b/lisp/progmodes/sh-script.el
index 1e21d10cdc..d08af6e853 100644
--- a/lisp/progmodes/sh-script.el
+++ b/lisp/progmodes/sh-script.el
@@ -954,7 +954,7 @@ be indented (i.e. a <<- was used rather than just <<)."
(defun sh-font-lock-syntactic-face-function (state)
(if (nth 3 state)
- (if (char-valid-p (nth 3 state))
+ (if (characterp (nth 3 state))
font-lock-string-face
sh-heredoc-face)
font-lock-comment-face))