# HG changeset patch # User Glenn Morris # Date 1192305645 0 # Node ID b5a52e129c973cf272e86526fe010fbd7d6b2959 # Parent f38764fb0146c4d4bfec7b19caaa754cc238f266 John W. Eaton (octave-looking-at-kw) (octave-re-search-forward-kw, octave-re-search-backward-kw): New functions. (octave-in-defun-p, calculate-octave-indent) (octave-blink-matching-block-open, octave-beginning-of-defun) (octave-auto-fill): Use octave-looking-at-kw instead of looking-at, to search for regexps that contain case-sensitive keywords. (octave-beginning-of-defun): Likewise, for octave-re-search-backward-kw. (octave-scan-blocks): Likewise, for octave-re-search-forward-kw. diff -r f38764fb0146 -r b5a52e129c97 lisp/progmodes/octave-mod.el --- a/lisp/progmodes/octave-mod.el Sat Oct 13 14:10:21 2007 +0000 +++ b/lisp/progmodes/octave-mod.el Sat Oct 13 20:00:45 2007 +0000 @@ -598,13 +598,25 @@ (error nil)) (< pos (point))))) +(defun octave-looking-at-kw (regexp) + (let ((case-fold-search nil)) + (looking-at regexp))) + +(defun octave-re-search-forward-kw (regexp) + (let ((case-fold-search nil)) + (re-search-forward regexp nil 'move inc))) + +(defun octave-re-search-backward-kw (regexp) + (let ((case-fold-search nil)) + (re-search-backward regexp nil 'move inc))) + (defun octave-in-defun-p () "Return t if point is inside an Octave function declaration. The function is taken to start at the `f' of `function' and to end after the end keyword." (let ((pos (point))) (save-excursion - (or (and (looking-at "\\") + (or (and (octave-looking-at-kw "\\") (octave-not-in-string-or-comment-p)) (and (octave-beginning-of-defun) (condition-case nil @@ -675,14 +687,14 @@ (while (< (point) eol) (if (octave-not-in-string-or-comment-p) (cond - ((looking-at "\\") + ((octave-looking-at-kw "\\") (setq icol (+ icol (* 2 octave-block-offset)))) - ((looking-at octave-block-begin-regexp) + ((octave-looking-at-kw octave-block-begin-regexp) (setq icol (+ icol octave-block-offset))) - ((looking-at octave-block-else-regexp) + ((octave-looking-at-kw octave-block-else-regexp) (if (= bot (point)) (setq icol (+ icol octave-block-offset)))) - ((looking-at octave-block-end-regexp) + ((octave-looking-at-kw octave-block-end-regexp) (if (not (= bot (point))) (setq icol (- icol (octave-block-end-offset))))))) @@ -692,10 +704,10 @@ (save-excursion (back-to-indentation) (cond - ((and (looking-at octave-block-else-regexp) + ((and (octave-looking-at-kw octave-block-else-regexp) (octave-not-in-string-or-comment-p)) (setq icol (- icol octave-block-offset))) - ((and (looking-at octave-block-end-regexp) + ((and (octave-looking-at-kw octave-block-end-regexp) (octave-not-in-string-or-comment-p)) (setq icol (- icol (octave-block-end-offset)))) ((or (looking-at "\\s<\\s<\\s<\\S<") @@ -871,8 +883,8 @@ (save-excursion (while (/= count 0) (catch 'foo - (while (or (re-search-forward - octave-block-begin-or-end-regexp nil 'move inc) + (while (or (octave-re-search-forward-kw + octave-block-begin-or-end-regexp) (if (/= depth 0) (error "Unbalanced block"))) (if (octave-not-in-string-or-comment-p) @@ -991,7 +1003,7 @@ (looking-at "\\>") (save-excursion (skip-syntax-backward "w") - (looking-at octave-block-else-or-end-regexp))) + (octave-looking-at-kw octave-block-else-or-end-regexp))) (save-excursion (cond ((match-end 1) @@ -1038,11 +1050,11 @@ (inc (if (> arg 0) 1 -1)) (found)) (and (not (eobp)) - (not (and (> arg 0) (looking-at "\\"))) + (not (and (> arg 0) (octave-looking-at-kw "\\"))) (skip-syntax-forward "w")) (while (and (/= arg 0) (setq found - (re-search-backward "\\" nil 'move inc))) + (octave-re-search-backward-kw "\\"))) (if (octave-not-in-string-or-comment-p) (setq arg (- arg inc)))) (if found @@ -1095,7 +1107,7 @@ (save-excursion (beginning-of-line) (and auto-fill-inhibit-regexp - (looking-at auto-fill-inhibit-regexp)))) + (octave-looking-at-kw auto-fill-inhibit-regexp)))) nil ; Can't do anything (if (and (not (octave-in-comment-p)) (> (current-column) fc))