summaryrefslogtreecommitdiff
path: root/lisp
diff options
context:
space:
mode:
Diffstat (limited to 'lisp')
-rw-r--r--lisp/ChangeLog41
-rw-r--r--lisp/diff-mode.el3
-rw-r--r--lisp/files.el17
-rw-r--r--lisp/international/utf-7.el4
-rw-r--r--lisp/net/net-utils.el42
-rw-r--r--lisp/progmodes/cc-mode.el6
-rw-r--r--lisp/progmodes/gdb-ui.el48
-rw-r--r--lisp/textmodes/fill.el8
8 files changed, 108 insertions, 61 deletions
diff --git a/lisp/ChangeLog b/lisp/ChangeLog
index 6dc48287ab3..9b9b7eaee76 100644
--- a/lisp/ChangeLog
+++ b/lisp/ChangeLog
@@ -1,3 +1,44 @@
+2008-03-01 Stefan Monnier <monnier@iro.umontreal.ca>
+
+ * diff-mode.el (diff-sanity-check-hunk): Only accept an empty line if
+ we still expect more lines.
+
+2008-03-01 Stefan Monnier <monnier@iro.umontreal.ca>
+
+ * textmodes/fill.el (fill-comment-paragraph): Don't try to do
+ comment-paragraph filling if the commark doesn't match
+ comment-start-skip.
+
+2008-03-01 Daiki Ueno <ueno@unixuser.org>
+
+ * international/utf-7.el (utf-7-encode): Never skip the trailing - for
+ the `imap' variant.
+
+2008-03-01 Jason Rumney <jasonr@gnu.org>
+
+ * files.el (make-auto-save-file-name): Encode more characters in
+ non-file buffer names. Use url-encoding.
+
+2008-03-01 Juanma Barranquero <lekktu@gmail.com>
+
+ * net/net-utils.el (ftp-program): Fix typo in docstring.
+ (ifconfig-program-options, netstat-program-options)
+ (arp-program-options, route-program-options, nslookup-program-options)
+ (ftp-program-options, smbclient-program-options)
+ (dns-lookup-program-options, arp, route): Doc fixes.
+
+ * progmodes/gdb-ui.el (gdb-pc-address, gdb-source-file-list)
+ (gdb-cpp-define-alist-program, gdb-mouse-jump, gdb-get-buffer-create)
+ (gdb-set-gud-minor-mode-existing-buffers-1, gdb-debug-log):
+ Fix typos in docstrings.
+ (gdb-pending-triggers): Reflow docstring.
+ (gdb, gdb-init-1): Fix typos in docstrings of gud-def definitions.
+
+2008-03-01 Alan Mackenzie <acm@muc.de>
+
+ * progmodes/cc-mode.el (c-neutralize-syntax-in-CPP): Fix a bug on
+ typing "#" at EOB.
+
2008-03-01 Juanma Barranquero <lekktu@gmail.com>
* emulation/cua-base.el (cua-remap-control-z): Fix typo in docstring.
diff --git a/lisp/diff-mode.el b/lisp/diff-mode.el
index 8a3433537b0..afd9399d1e5 100644
--- a/lisp/diff-mode.el
+++ b/lisp/diff-mode.el
@@ -1363,7 +1363,8 @@ Only works for unified diffs."
(cond
((and diff-valid-unified-empty-line
;; Not just (eolp) so we don't infloop at eob.
- (eq (char-after) ?\n))
+ (eq (char-after) ?\n)
+ (> before 0) (> after 0))
(decf before) (decf after) t)
((and (zerop before) (zerop after)) nil)
((or (< before 0) (< after 0))
diff --git a/lisp/files.el b/lisp/files.el
index d1b8cd2f30e..740bba2764a 100644
--- a/lisp/files.el
+++ b/lisp/files.el
@@ -4656,15 +4656,18 @@ See also `auto-save-file-name-p'."
(let ((buffer-name (buffer-name))
(limit 0)
file-name)
- ;; Eliminate all slashes and backslashes by
- ;; replacing them with sequences that start with %.
- ;; Quote % also, to keep distinct names distinct.
- (while (string-match "[/\\%]" buffer-name limit)
+ ;; Restrict the characters used in the file name to those which
+ ;; are known to be safe on all filesystems, url-encoding the
+ ;; rest.
+ ;; We do this on all platforms, because even if we are not
+ ;; running on DOS/Windows, the current directory may be on a
+ ;; mounted VFAT filesystem, such as a USB memory stick.
+ (while (string-match "[^A-Za-z0-9-_.~#+]" buffer-name limit)
(let* ((character (aref buffer-name (match-beginning 0)))
(replacement
- (cond ((eq character ?%) "%%")
- ((eq character ?/) "%+")
- ((eq character ?\\) "%-"))))
+ ;; For multibyte characters, this will produce more than
+ ;; 2 hex digits, so is not true URL encoding.
+ (format "%%%02X" character)))
(setq buffer-name (replace-match replacement t t buffer-name))
(setq limit (1+ (match-end 0)))))
;; Generate the file name.
diff --git a/lisp/international/utf-7.el b/lisp/international/utf-7.el
index 77e2a18c684..e2fe6949cae 100644
--- a/lisp/international/utf-7.el
+++ b/lisp/international/utf-7.el
@@ -110,7 +110,9 @@ ESC and SKIP-CHARS are adjusted for the normal and IMAP versions."
;; consistent with iconv, at least regarding `='.
(skip-chars-forward "^= \t\n")
(delete-region (point) (point-max))))
- (unless (eobp)
+ ;; RFC2060 stipulates that all names MUST end in US-ASCII (i.e.
+ ;; a name that ends with a Unicode octet MUST end with a "-").
+ (if (or imap (not (eobp)))
(insert ?-)))))
nil))
diff --git a/lisp/net/net-utils.el b/lisp/net/net-utils.el
index 8492fa2912d..910dd322b6f 100644
--- a/lisp/net/net-utils.el
+++ b/lisp/net/net-utils.el
@@ -105,7 +105,7 @@ These options can be used to limit how many ICMP packets are emitted."
(list
(if (eq system-type 'windows-nt)
"/all" "-a"))
- "Options for `ifconfig-program'."
+ "Options for the ifconfig program."
:group 'net-utils
:type '(repeat string))
@@ -124,25 +124,25 @@ These options can be used to limit how many ICMP packets are emitted."
(define-obsolete-variable-alias 'ipconfig-program-options
'ifconfig-program-options "22.2")
-(defcustom netstat-program "netstat"
+(defcustom netstat-program "netstat"
"Program to print network statistics."
:group 'net-utils
:type 'string)
(defcustom netstat-program-options
(list "-a")
- "Options for netstat-program."
+ "Options for the netstat program."
:group 'net-utils
:type '(repeat string))
-(defcustom arp-program "arp"
+(defcustom arp-program "arp"
"Program to print IP to address translation tables."
:group 'net-utils
:type 'string)
(defcustom arp-program-options
(list "-a")
- "Options for arp-program."
+ "Options for the arp program."
:group 'net-utils
:type '(repeat string))
@@ -158,17 +158,17 @@ These options can be used to limit how many ICMP packets are emitted."
(if (eq system-type 'windows-nt)
(list "print")
(list "-r"))
- "Options for route-program."
+ "Options for the route program."
:group 'net-utils
:type '(repeat string))
-(defcustom nslookup-program "nslookup"
+(defcustom nslookup-program "nslookup"
"Program to interactively query DNS information."
:group 'net-utils
:type 'string)
-(defcustom nslookup-program-options nil
- "List of options to pass to the nslookup program."
+(defcustom nslookup-program-options nil
+ "Options for the nslookup program."
:group 'net-utils
:type '(repeat string))
@@ -180,18 +180,18 @@ This variable is only used if the variable
:group 'net-utils
:type 'regexp)
-(defcustom dig-program "dig"
+(defcustom dig-program "dig"
"Program to query DNS information."
:group 'net-utils
:type 'string)
(defcustom ftp-program "ftp"
- "Progam to run to do FTP transfers."
+ "Program to run to do FTP transfers."
:group 'net-utils
:type 'string)
(defcustom ftp-program-options nil
- "List of options to pass to the FTP program."
+ "Options for the ftp program."
:group 'net-utils
:type '(repeat string))
@@ -209,7 +209,7 @@ This variable is only used if the variable
:type 'string)
(defcustom smbclient-program-options nil
- "List of options to pass to the smbclient program."
+ "Options for the smbclient program."
:group 'net-utils
:type '(repeat string))
@@ -221,17 +221,15 @@ This variable is only used if the variable
:group 'net-utils
:type 'regexp)
-(defcustom dns-lookup-program "host"
+(defcustom dns-lookup-program "host"
"Program to interactively query DNS information."
:group 'net-utils
- :type 'string
- )
+ :type 'string)
-(defcustom dns-lookup-program-options nil
- "List of options to pass to the dns-lookup program."
+(defcustom dns-lookup-program-options nil
+ "Options for the dns-lookup program."
:group 'net-utils
- :type '(repeat string)
- )
+ :type '(repeat string))
;; Internal variables
(defvar network-connection-service nil)
@@ -397,7 +395,7 @@ If your system's ping continues until interrupted, you can try setting
;;;###autoload
(defun arp ()
- "Run the arp program."
+ "Run arp program."
(interactive)
(net-utils-run-program
"Arp"
@@ -407,7 +405,7 @@ If your system's ping continues until interrupted, you can try setting
;;;###autoload
(defun route ()
- "Run the route program."
+ "Run route program."
(interactive)
(net-utils-run-program
"Route"
diff --git a/lisp/progmodes/cc-mode.el b/lisp/progmodes/cc-mode.el
index 607ee54e30f..2d8e66ab3fc 100644
--- a/lisp/progmodes/cc-mode.el
+++ b/lisp/progmodes/cc-mode.el
@@ -848,13 +848,11 @@ Note that the style variables are always made local to the buffer."
(if (setq limits (c-literal-limits))
(goto-char (cdr limits)))
- (while (and (< (point) end)
- (search-forward-regexp c-anchored-cpp-prefix end t))
+ (while (search-forward-regexp c-anchored-cpp-prefix end t)
(when (c-beginning-of-macro) ; Guard against being in a string/comment.
(setq mbeg (point))
(c-end-of-macro) ; Do we need to go forward 1 char here? No!
- (c-neutralize-CPP-line mbeg (point)))
- (forward-char)))) ; We might still be in a comment - this is OK.
+ (c-neutralize-CPP-line mbeg (point)))))) ; We might still be in a comment - this is OK.
(defun c-before-change (beg end)
;; Function to be put on `before-change-function'. Primarily, this calls
diff --git a/lisp/progmodes/gdb-ui.el b/lisp/progmodes/gdb-ui.el
index 111f8903fd3..7cbea06889f 100644
--- a/lisp/progmodes/gdb-ui.el
+++ b/lisp/progmodes/gdb-ui.el
@@ -100,7 +100,7 @@
(defvar speedbar-initial-expansion-list-name)
(defvar gdb-pc-address nil "Initialization for Assembler buffer.
-Set to \"main\" at start if gdb-show-main is t.")
+Set to \"main\" at start if `gdb-show-main' is t.")
(defvar gdb-frame-address nil "Identity of frame for watch expression.")
(defvar gdb-previous-frame-address nil)
(defvar gdb-memory-address "main")
@@ -109,7 +109,7 @@ Set to \"main\" at start if gdb-show-main is t.")
(defvar gdb-frame-number nil)
(defvar gdb-current-language nil)
(defvar gdb-var-list nil
- "List of variables in watch window.
+ "List of variables in watch window.
Each element has the form (VARNUM EXPRESSION NUMCHILD TYPE VALUE STATUS FP)
where STATUS is nil (`unchanged'), `changed' or `out-of-scope', FP the frame
address for root variables.")
@@ -176,14 +176,13 @@ gdba (gdb-ui.el) uses all five values, gdbmi (gdb-mi.el) only two
"The most recent command item sent to gdb.")
(defvar gdb-pending-triggers '()
- "A list of trigger functions that have run later than their output
-handlers.")
+ "A list of trigger functions that have run later than their output handlers.")
(defvar gdb-first-post-prompt nil)
(defvar gdb-version nil)
(defvar gdb-locals-font-lock-keywords nil)
(defvar gdb-source-file-list nil
- "List of source files for the current executable")
+ "List of source files for the current executable.")
(defconst gdb-error-regexp "\\^error,msg=\"\\(.+\\)\"")
(defvar gdb-locals-font-lock-keywords-1
@@ -291,7 +290,7 @@ session."
(gud-def gud-break "break %f:%l" "\C-b" "Set breakpoint at current line.")
(gud-def gud-tbreak "tbreak %f:%l" "\C-t"
"Set temporary breakpoint at current line.")
- (gud-def gud-remove "clear %f:%l" "\C-d" "Remove breakpoint at current line")
+ (gud-def gud-remove "clear %f:%l" "\C-d" "Remove breakpoint at current line.")
(gud-def gud-step "step %p" "\C-s" "Step one source line with display.")
(gud-def gud-stepi "stepi %p" "\C-i" "Step one instruction with display.")
(gud-def gud-next "next %p" "\C-n" "Step one line (skip functions).")
@@ -338,10 +337,9 @@ session."
:version "22.1")
(defvar gdb-debug-log nil
- "List of commands sent to and replies received from GDB. Most
-recent commands are listed first. This list stores only the last
-'gdb-debug-log-max' values. This variable is used to debug
-GDB-UI.")
+ "List of commands sent to and replies received from GDB.
+Most recent commands are listed first. This list stores only the last
+`gdb-debug-log-max' values. This variable is used to debug GDB-UI.")
;;;###autoload
(defcustom gdb-enable-debug nil
@@ -354,7 +352,7 @@ GDB-UI.")
"Shell command for generating a list of defined macros in a source file.
This list is used to display the #define directive associated
with an identifier as a tooltip. It works in a debug session with
-GDB, when gud-tooltip-mode is t.
+GDB, when `gud-tooltip-mode' is t.
Set `gdb-cpp-define-alist-flags' for any include paths or
predefined macros."
@@ -555,7 +553,7 @@ otherwise do not."
"pp1 " (if (eq (buffer-local-value
'major-mode (window-buffer)) 'speedbar-mode)
(gdb-find-watch-expression) "%e")) arg)
- nil "Print the emacs s-expression.")
+ nil "Print the Emacs s-expression.")
(define-key gud-minor-mode-map [left-margin mouse-1]
'gdb-mouse-set-clear-breakpoint)
@@ -689,7 +687,7 @@ with mouse-1 (default bindings)."
"Set execution address/line.
The destination source line can be selected either by clicking with C-mouse-3
on the fringe/margin or dragging the arrow with C-mouse-1 (default bindings).
-Unlike gdb-mouse-until the destination address can be before the current
+Unlike `gdb-mouse-until' the destination address can be before the current
line, and no execution takes place."
(interactive "e")
(let ((start (event-start event))
@@ -827,7 +825,7 @@ With arg, enter name of variable to be watched in the minibuffer."
`(lambda () (gdb-var-list-children-handler ,varnum)))))
(defconst gdb-var-list-children-regexp
- "child={.*?name=\"\\(.*?\\)\",.*?exp=\"\\(.*?\\)\",.*?\
+ "child={.*?name=\"\\(.*?\\)\",.*?exp=\"\\(.*?\\)\",.*?\
numchild=\"\\(.*?\\)\"\\(}\\|,.*?\\(type=\"\\(.*?\\)\"\\)?.*?}\\)")
(defun gdb-var-list-children-handler (varnum)
@@ -1035,7 +1033,7 @@ The key should be one of the cars in `gdb-buffer-rules-assoc'."
(gdb-look-for-tagged-buffer key (buffer-list))))
(defun gdb-get-buffer-create (key)
- "Create a new gdb buffer of the type specified by KEY.
+ "Create a new gdb buffer of the type specified by KEY.
The key should be one of the cars in `gdb-buffer-rules-assoc'."
(or (gdb-get-buffer key)
(let* ((rules (assoc key gdb-buffer-rules-assoc))
@@ -1351,7 +1349,7 @@ happens to be in effect."
"An annotation handler for `prompt'.
This sends the next command (if any) to gdb."
(when gdb-first-prompt
- (gdb-force-mode-line-update
+ (gdb-force-mode-line-update
(propertize "initializing..." 'face font-lock-variable-name-face))
(gdb-init-1)
(setq gdb-first-prompt nil))
@@ -2283,7 +2281,7 @@ static char *magick[] = {
(kill-all-local-variables)
(setq major-mode 'gdb-frames-mode)
(setq mode-name "Frames")
- (setq gdb-stack-position nil)
+ (setq gdb-stack-position nil)
(add-to-list 'overlay-arrow-variable-list 'gdb-stack-position)
(setq truncate-lines t) ;; Make it easier to see overlay arrow.
(setq buffer-read-only t)
@@ -2612,10 +2610,10 @@ another GDB command e.g pwd, to see new frames")
(let ((map (make-sparse-keymap)))
(define-key map [header-line down-mouse-3] 'gdb-memory-format-menu-1)
map)
- "Keymap to select format in the header line.")
+ "Keymap to select format in the header line.")
(defvar gdb-memory-format-menu (make-sparse-keymap "Format")
- "Menu of display formats in the header line.")
+ "Menu of display formats in the header line.")
(define-key gdb-memory-format-menu [binary]
'(menu-item "Binary" gdb-memory-format-binary
@@ -2674,10 +2672,10 @@ another GDB command e.g pwd, to see new frames")
(let ((map (make-sparse-keymap)))
(define-key map [header-line down-mouse-3] 'gdb-memory-unit-menu-1)
map)
- "Keymap to select units in the header line.")
+ "Keymap to select units in the header line.")
(defvar gdb-memory-unit-menu (make-sparse-keymap "Unit")
- "Menu of units in the header line.")
+ "Menu of units in the header line.")
(define-key gdb-memory-unit-menu [giantwords]
'(menu-item "Giant words" gdb-memory-unit-giant
@@ -2840,7 +2838,7 @@ corresponding to the mode line clicked."
(beginning-of-line)
(gud-watch)))
map)
- "Keymap to create watch expression of a complex data type local variable.")
+ "Keymap to create watch expression of a complex data type local variable.")
(defconst gdb-struct-string
(concat (propertize "[struct/union]"
@@ -3489,7 +3487,7 @@ BUFFER nil or omitted means use the current buffer."
(defun gdb-set-gud-minor-mode-existing-buffers-1 ()
"Create list of source files for current GDB session.
-If buffers already exist for any of these files, gud-minor-mode
+If buffers already exist for any of these files, `gud-minor-mode'
is set in them."
(goto-char (point-min))
(while (re-search-forward gdb-source-file-regexp-1 nil t)
@@ -3700,7 +3698,7 @@ in_scope=\"\\(.*?\\)\".*?}")
(define-key map "\r" 'gud-watch)
(define-key map [mouse-2] 'gud-watch)
map)
- "Keymap to create watch expression of a complex data type local variable.")
+ "Keymap to create watch expression of a complex data type local variable.")
(defvar gdb-edit-locals-map-1
(let ((map (make-sparse-keymap)))
@@ -3708,7 +3706,7 @@ in_scope=\"\\(.*?\\)\".*?}")
(define-key map "\r" 'gdb-edit-locals-value)
(define-key map [mouse-2] 'gdb-edit-locals-value)
map)
- "Keymap to edit value of a simple data type local variable.")
+ "Keymap to edit value of a simple data type local variable.")
(defun gdb-edit-locals-value (&optional event)
"Assign a value to a variable displayed in the locals buffer."
diff --git a/lisp/textmodes/fill.el b/lisp/textmodes/fill.el
index 6fa26afa4f5..7f7a98e087a 100644
--- a/lisp/textmodes/fill.el
+++ b/lisp/textmodes/fill.el
@@ -855,7 +855,13 @@ can take care of filling. JUSTIFY is used as in `fill-paragraph'."
(goto-char comstart) (skip-chars-backward " \t")
(setq has-code-and-comment (not (bolp)))))
- (if (not comstart)
+ (if (not (and comstart
+ ;; Make sure the comment-start mark we found is accepted by
+ ;; comment-start-skip. If not, all bets are off, and
+ ;; we'd better not mess with it.
+ (string-match comment-start-skip
+ (buffer-substring comstart comin))))
+
;; Return nil, so the normal filling will take place.
nil