@kbd{M-x write-region} is the inverse of @kbd{M-x insert-file}; it
copies the contents of the region into the specified file. @kbd{M-x
append-to-file} adds the text of the region to the end of the
-specified file. @xref{Accumulating Text}. When called interactively,
-these commands print a message in the echo area giving the name
-of the file affected; if the variable @code{write-region-verbose} is
-non-nil the message also reports the number of characters written.
-The variable @code{write-region-inhibit-fsync} applies to
-these commands, as well as saving files; see @ref{Customize Save}.
+specified file. @xref{Accumulating Text}. The variable
+@code{write-region-inhibit-fsync} applies to these commands, as well
+as saving files; see @ref{Customize Save}.
@findex set-file-modes
@cindex file modes
\f
* Changes in Emacs 26.1
-+++
-** The functions write-region, append-to-file, and the like now also
-output the number of characters added in addition to the name of the
-file affected, if the new variable 'write-region-verbose' is non-nil.
-
** The variable 'emacs-version' no longer includes the build number.
This is now stored separately in a new variable, 'emacs-build-number'.
(if (or (eq visit t)
(eq visit nil)
(stringp visit))
- (message "Wrote `%s' (%d characters)" buffer-file-name
- (cond ((null start) (buffer-size))
- ((stringp start) (length start))
- (t (- end start)))))))
+ (message "Wrote %s" buffer-file-name))))
(put 'write-region 'epa-file 'epa-file-write-region)
(defun epa-file-select-keys ()
inhibit-file-name-handlers)
inhibit-file-name-handlers)))
(write-region start end filename t 'no-message)
- (message "Appended to `%s' (%d characters)" filename (- end start))))
+ (message "Appended to %s" filename)))
(defun mm-write-region (start end filename &optional append visit lockname
coding-system inhibit)
(and (or (eq visit t)
(eq visit nil)
(stringp visit))
- (message "Wrote `%s' (%d characters)" visit-file
- (cond ((null start) (buffer-size))
- ((stringp start) (length start))
- (t (- end start)))))
+ (message "Wrote %s" visit-file))
;; ensure `last-coding-system-used' has an appropriate value
(setq last-coding-system-used coding-system-used)
(set-buffer-modified-p nil)))
;; ensure `last-coding-system-used' has an appropriate value
(setq last-coding-system-used coding-system-used)
- (ange-ftp-message "Wrote `%s' (%d characters)" abbr
- (cond ((null start) (buffer-size))
- ((stringp start) (length start))
- (t (- end start))))
+ (ange-ftp-message "Wrote %s" abbr)
(ange-ftp-add-file-entry filename))
(ange-ftp-real-write-region start end filename append visit))))
(when (or (eq visit t) (stringp visit))
(set-visited-file-modtime))
- (tramp-handle-write-region-message v start end filename append visit)
-
(unless (equal curbuf (current-buffer))
(tramp-error
v 'file-error
(file-attributes filename))))
;; The end.
- (tramp-handle-write-region-message v start end filename append visit)
+ (when (or (eq visit t) (null visit) (stringp visit))
+ (tramp-message v 0 "Wrote %s" filename))
(run-hooks 'tramp-handle-write-region-hook)))
\f
;; Set the ownership.
(when need-chown
(tramp-set-file-uid-gid filename uid gid))
- (tramp-handle-write-region-message v start end filename append visit)
+ (when (or (eq visit t) (null visit) (stringp visit))
+ (tramp-message v 0 "Wrote %s" filename))
(run-hooks 'tramp-handle-write-region-hook)))))
(defvar tramp-vc-registered-file-names nil
v 'file-error
"Buffer has changed from `%s' to `%s'" curbuf (current-buffer)))
(when (eq visit t)
- (set-visited-file-modtime))
- (tramp-handle-write-region-message v start end filename append visit))))
+ (set-visited-file-modtime)))))
;; Internal file name functions.
(defvar tramp-handle-write-region-hook nil
"Normal hook to be run at the end of `tramp-*-handle-write-region'.")
-(defsubst tramp-handle-write-region-message
- (vec start end filename &optional append visit)
- "Message to be written for `tramp-*-handle-write-region'"
- ;; We shall also don't write when autosaving. How to check?
- (when (and (null noninteractive)
- (or (eq visit t) (null visit) (stringp visit)))
- (let ((nchars (cond ((null start) (buffer-size))
- ((stringp start) (length start))
- (t (- end start)))))
- (tramp-message
- vec 0 "%s `%s'%s"
- (cond
- ((numberp append) "Updated")
- (append "Added to")
- (t "Wrote"))
- filename
- (cond
- ((null (bound-and-true-p write-region-verbose)) "")
- ((= nchars 1) " (1 character)")
- (t (format " (%d characters)" nchars)))))))
-
(defun tramp-handle-directory-file-name (directory)
"Like `directory-file-name' for Tramp files."
;; If localname component of filename is "/", leave it unchanged.
}
if (!auto_saving && !noninteractive)
- {
- EMACS_INT nchars = (STRINGP (start) ? SCHARS (start)
- : XINT (end) - XINT (start));
- AUTO_STRING (format,
- (NUMBERP (append)
- ? (NILP (Vwrite_region_verbose)
- ? "Updated `%s'"
- : nchars == 1
- ? "Updated `%s' (1 character)"
- : "Updated `%s' (%d characters)")
- : ! NILP (append)
- ? (NILP (Vwrite_region_verbose)
- ? "Added to `%s'"
- : nchars == 1
- ? "Added to `%s' (1 character)"
- : "Added to `%s' (%d characters)")
- : (NILP (Vwrite_region_verbose)
- ? "Wrote `%s'"
- : nchars == 1
- ? "Wrote `%s' (1 character)"
- : "Wrote `%s' (%d characters)")));
- CALLN (Fmessage, format, visit_file, make_number (nchars));
- }
+ message_with_string ((NUMBERP (append)
+ ? "Updated %s"
+ : ! NILP (append)
+ ? "Added to %s"
+ : "Wrote %s"),
+ visit_file, 1);
+
return Qnil;
}
\f
that were already called. See also `write-region-annotate-functions'. */);
Vwrite_region_annotations_so_far = Qnil;
- DEFVAR_LISP ("write-region-verbose",
- Vwrite_region_verbose,
- doc: /* If non-nil, be more verbose when writing a region. */);
- Vwrite_region_verbose = Qnil;
-
DEFVAR_LISP ("inhibit-file-name-handlers", Vinhibit_file_name_handlers,
doc: /* A list of file name handlers that temporarily should not be used.
This applies only to the operation `inhibit-file-name-operation'. */);
(require 'dired)
(require 'ert)
-(require 'ert-x)
(require 'tramp)
(require 'vc)
(require 'vc-bzr)
(when (getenv "NIX_STORE")
(add-to-list 'tramp-remote-path 'tramp-own-remote-path))
-(defvar tramp--test-messages nil
- "Captured messages from *Messages* buffer.")
-
(defvar tramp--test-expensive-test
(null
(string-equal (getenv "SELECTOR") "(quote (not (tag :expensive-test)))"))
(skip-unless (tramp--test-enabled))
(dolist (quoted (if tramp--test-expensive-test '(nil t) '(nil)))
- (let* ((tmp-name (tramp--test-make-temp-name nil quoted))
- (text-quoting-style 'grave)
- (write-region-verbose
- (and (null noninteractive) (boundp 'write-region-verbose)))
- (tramp-message-show-message
- (or tramp-message-show-message write-region-verbose)))
+ (let ((tmp-name (tramp--test-make-temp-name nil quoted)))
(unwind-protect
- (ert-with-message-capture tramp--test-messages
- ;; Write buffer.
- (setq tramp--test-messages "")
+ (progn
(with-temp-buffer
(insert "foo")
(write-region nil nil tmp-name))
- (when write-region-verbose
- (should
- (string-match
- (format "Wrote `%s' (3 characters)" tmp-name)
- tramp--test-messages)))
(with-temp-buffer
(insert-file-contents tmp-name)
(should (string-equal (buffer-string) "foo")))
-
;; Append.
- (setq tramp--test-messages "")
(with-temp-buffer
(insert "bla")
(write-region nil nil tmp-name 'append))
- (when write-region-verbose
- (should
- (string-match
- (format "Added to `%s' (3 characters)" tmp-name)
- tramp--test-messages)))
(with-temp-buffer
(insert-file-contents tmp-name)
(should (string-equal (buffer-string) "foobla")))
-
- (setq tramp--test-messages "")
- (with-temp-buffer
- (insert "baz")
- (write-region nil nil tmp-name 3))
- (when write-region-verbose
- (should
- (string-match
- (format "Updated `%s' (3 characters)" tmp-name)
- tramp--test-messages)))
- (with-temp-buffer
- (insert-file-contents tmp-name)
- (should (string-equal (buffer-string) "foobaz")))
-
;; Write string.
- (setq tramp--test-messages "")
(write-region "foo" nil tmp-name)
- (when write-region-verbose
- (should
- (string-match
- (format "Wrote `%s' (3 characters)" tmp-name)
- tramp--test-messages)))
(with-temp-buffer
(insert-file-contents tmp-name)
(should (string-equal (buffer-string) "foo")))
-
;; Write partly.
- (setq tramp--test-messages "")
(with-temp-buffer
(insert "123456789")
(write-region 3 5 tmp-name))
- (when write-region-verbose
- (should
- (string-match
- (format "Wrote `%s' (2 characters)" tmp-name)
- tramp--test-messages)))
(with-temp-buffer
(insert-file-contents tmp-name)
(should (string-equal (buffer-string) "34"))))