Mercurial > emacs
view lisp/progmodes/cap-words.el @ 110309:14a601b405fc
SQL Mode, Version 2.6
* progmodes/sql.el: Version 2.6
(sql-dialect): Synonym for "sql-product".
(sql-find-sqli-buffer, sql-set-sqli-buffer-generally)
(sql-set-sqli-buffer, sql-show-sqli-buffer, sql-interactive-mode):
Set "sql-buffer" to buffer name not buffer object so multiple sql
interactive buffers work properly. Reverts misguided changes in
earlier work.
(sql-comint): Make sure different buffer name is used if "*SQL*"
buffer is for a different product.
(sql-make-alternate-buffer-name): Fix bug with "sql-database"
login param.
(sql-oracle, sql-sybase, sql-informix, sql-sqlite, sql-mysql)
(sql-solid, sql-ingres, sql-ms, sql-postgres, sql-interbase)
(sql-db2, sql-linter, sql-product-interactive, sql-rename-buffer):
Accept new buffer name or prompt for one.
(sql-port): Default to zero.
(sql-comint-mysql): Handle "sql-port" as a numeric.
(sql-port-history): Delete unused variable.
(sql-get-login): Default "sql-port" to a number.
(sql-product-alist): Correct Postgres prompt and terminator
regexp.
(sql-sqlite-program): Dynamically detect presence of "sqlite" or
"sqlite3" executables.
(sql-sqlite-login-params): Add "*.sqlite[23]?" database name
pattern.
(sql-buffer-live-p): New function.
(sql-mode-menu, sql-send-string): Use it.
(sql-mode-oracle-font-lock-keywords): Improve SQL*Plus REMARK
syntax pattern.
(sql-mode-postgres-font-lock-keywords): Support Postgres V9.
(sql-mode-sqlite-font-lock-keywords): Hilight sqlite commands.
author | Michael Mauger <mmaug@yahoo.com> |
---|---|
date | Fri, 10 Sep 2010 23:17:02 -0400 |
parents | 1d1d5d9bd884 |
children | 376148b31b5e |
line wrap: on
line source
;;; cap-words.el --- minor mode for motion in CapitalizedWordIdentifiers ;; Copyright (C) 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 ;; Free Software Foundation, Inc. ;; Author: Dave Love <fx@gnu.org> ;; Keywords: languages ;; This file is part of GNU Emacs. ;; GNU Emacs 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 3 of the License, or ;; (at your option) any later version. ;; GNU Emacs 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. If not, see <http://www.gnu.org/licenses/>. ;;; 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-find-word-boundary (pos limit) "Function for use in `find-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-find-word-boundary-function-table (let ((tab (make-char-table nil))) (set-char-table-range tab t #'capitalized-find-word-boundary) tab) "Assigned to `find-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 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 language 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 'find-word-boundary-function-table) capitalized-find-word-boundary-function-table)) (provide 'cap-words) ;; arch-tag: 46513b64-fe5a-4c0b-902c-ed235c22975f ;;; cap-words.el ends here