From: Gerd Moellmann Date: Wed, 24 Nov 1999 14:59:03 +0000 (+0000) Subject: (sql-find-sqli-buffer): New function. X-Git-Tag: emacs-pretest-21.0.90~5990 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=46d94d0dfb254a2f663665a3d0d9f1fdc342ac40;p=emacs.git (sql-find-sqli-buffer): New function. (sql-set-sqli-buffer-generally): New function. (sql-set-sqli-buffer): Better checking of new-buffer. (sql-copy-column): Add comma after INTO clause, too. (sql-imenu-generic-expression): New, used to set imenu-generic-expression. (sql-mode): Use ?_ and ?. instead of 95 and 46 when setting font-lock-defaults' SYNTAX-ALIST. Set imenu-generic-expression, imenu-case-fold-search, and imenu-syntax-alist. (sql-interactive-mode): Use ?_ and ?. instead of 95 and 46 when setting font-lock-defaults' SYNTAX-ALIST. --- diff --git a/lisp/ChangeLog b/lisp/ChangeLog index fff915096b9..8fdf096a87b 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,23 @@ +1999-11-24 Alex Schroeder + + * sql.el (sql-find-sqli-buffer): New function. + (sql-set-sqli-buffer-generally): New function. + (sql-set-sqli-buffer): Better checking of new-buffer. + (sql-copy-column): Add comma after INTO clause, too. + +1999-11-24 Alex Schroeder + + * sql.el (sql-imenu-generic-expression): New, used to set + imenu-generic-expression. + + * sql.el (sql-mode): Use ?_ and ?. instead of 95 and 46 when + setting font-lock-defaults' SYNTAX-ALIST. Set + imenu-generic-expression, imenu-case-fold-search, and + imenu-syntax-alist. + + * sql.el (sql-interactive-mode): Use ?_ and ?. instead of 95 + and 46 when setting font-lock-defaults' SYNTAX-ALIST. + 1999-11-23 Andrew Innes * w32-win.el (w32-drag-n-drop): Load files in current window, if diff --git a/lisp/progmodes/sql.el b/lisp/progmodes/sql.el index f7defaf54e2..f3a1bb2a772 100644 --- a/lisp/progmodes/sql.el +++ b/lisp/progmodes/sql.el @@ -4,7 +4,7 @@ ;; Author: Alex Schroeder ;; Maintainer: Alex Schroeder -;; Version: 1.4.9 +;; Version: 1.4.10 ;; Keywords: comm languages processes ;; This file is part of GNU Emacs. @@ -721,6 +721,48 @@ function like this: (sql-get-login 'user 'password 'database)." (read-from-minibuffer "Database: " sql-database nil nil sql-database-history)))) +(defun sql-find-sqli-buffer () + "Return the current default SQLi buffer or nil. +In order to qualify, the SQLi buffer must be alive, +be in `sql-interactive-mode' and have a process." + (if (and (buffer-live-p (default-value 'sql-buffer)) + (get-buffer-process (default-value 'sql-buffer))) + sql-buffer + (save-excursion + (let ((buflist (buffer-list)) + (found)) + (while (not (or (null buflist) + found)) + (let ((candidate (car buflist))) + (set-buffer candidate) + (if (and (equal major-mode 'sql-interactive-mode) + (get-buffer-process candidate)) + (setq found candidate)) + (setq buflist (cdr buflist)))) + found)))) + +(defun sql-set-sqli-buffer-generally () + "Set SQLi buffer for all SQL buffers that have none. +This function checks all SQL buffers for their SQLi buffer. If their +SQLi buffer is nonexistent or has no process, it is set to the current +default SQLi buffer. The current default SQLi buffer is determined +using `sql-find-sqli-buffer'. If `sql-buffer' is set, +`sql-set-sqli-hook' is run." + (interactive) + (save-excursion + (let ((buflist (buffer-list)) + (default-sqli-buffer (sql-find-sqli-buffer))) + (setq-default sql-buffer default-sqli-buffer) + (while (not (null buflist)) + (let ((candidate (car buflist))) + (set-buffer candidate) + (if (and (equal major-mode 'sql-mode) + (not (buffer-live-p sql-buffer))) + (progn + (setq sql-buffer default-sqli-buffer) + (run-hooks 'sql-set-sqli-hook)))) + (setq buflist (cdr buflist)))))) + (defun sql-set-sqli-buffer () "Set the SQLi buffer SQL strings are sent to. @@ -734,11 +776,22 @@ If you call it from a SQL buffer, this sets the local copy of If you call it from anywhere else, it sets the global copy of `sql-buffer'." (interactive) - (let ((new-buffer (get-buffer (read-buffer "New SQLi buffer: " nil t)))) - (if new-buffer - (progn - (setq sql-buffer new-buffer) - (run-hooks 'sql-set-sqli-hook))))) + (let ((default-buffer (sql-find-sqli-buffer))) + (if (null default-buffer) + (error "There is no suitable SQLi buffer")) + (let ((new-buffer + (get-buffer + (read-buffer "New SQLi buffer: " default-buffer t)))) + (if (null (get-buffer-process new-buffer)) + (error "Buffer %s has no process" (buffer-name new-buffer))) + (if (null (save-excursion + (set-buffer new-buffer) + (equal major-mode 'sql-interactive-mode))) + (error "Buffer %s is no SQLi buffer" (buffer-name new-buffer))) + (if new-buffer + (progn + (setq sql-buffer new-buffer) + (run-hooks 'sql-set-sqli-hook)))))) (defun sql-show-sqli-buffer () "Show the name of current SQLi buffer. @@ -788,9 +841,9 @@ Inserts SELECT or commas if appropriate." ((save-excursion (beginning-of-line) (looking-at (concat comint-prompt-regexp "$"))) (insert "SELECT ")) - ;; else if appending to SELECT or ORDER BY, insert a comma + ;; else if appending to INTO .* (, SELECT or ORDER BY, insert a comma ((save-excursion - (re-search-backward "\\b\\(select\\|order by\\) .+" + (re-search-backward "\\b\\(\\(into\\s-+\\S-+\\s-+(\\)\\|select\\|order by\\) .+" (save-excursion (beginning-of-line) (point)) t)) (insert ", ")) ;; else insert a space