aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorFederico Tedin2021-09-15 00:15:16 +0200
committerEli Zaretskii2021-09-18 09:36:26 +0300
commit4e21c5f451a18f96172e63dbe8a3ceef780758bb (patch)
treeeb8e8408ac1db13a0892eb20818189e3f3f086fd /src
parent62e870691d2192e7848e047734556dec21797a7b (diff)
downloademacs-4e21c5f451a18f96172e63dbe8a3ceef780758bb.tar.gz
emacs-4e21c5f451a18f96172e63dbe8a3ceef780758bb.zip
Check for null bytes in filenames in 'expand-file-name' (bug#49723)
* src/fileio.c (expand-file-name): Check for null bytes for both NAME and DEFAULT-DIRECTORY arguments. Also check for null bytes in buffer-local default-directory, assuming it is used. * src/coding.c (encode_file_name): Use CHECK_STRING_NULL_BYTES. * src/lisp.h (CHECK_STRING_NULL_BYTES): Add function for checking for null bytes in Lisp strings. * test/src/fileio-tests.el (fileio-test--expand-file-name-null-bytes): Add test for new changes to expand-file-name. * etc/NEWS: Announce changes.
Diffstat (limited to 'src')
-rw-r--r--src/coding.c3
-rw-r--r--src/fileio.c6
-rw-r--r--src/lisp.h7
3 files changed, 13 insertions, 3 deletions
diff --git a/src/coding.c b/src/coding.c
index d027c7d5399..7030a53869a 100644
--- a/src/coding.c
+++ b/src/coding.c
@@ -10430,8 +10430,7 @@ encode_file_name (Lisp_Object fname)
10430 cause subtle bugs because the system would silently use a 10430 cause subtle bugs because the system would silently use a
10431 different filename than expected. Perform this check after 10431 different filename than expected. Perform this check after
10432 encoding to not miss NUL bytes introduced through encoding. */ 10432 encoding to not miss NUL bytes introduced through encoding. */
10433 CHECK_TYPE (memchr (SSDATA (encoded), '\0', SBYTES (encoded)) == NULL, 10433 CHECK_STRING_NULL_BYTES (encoded);
10434 Qfilenamep, fname);
10435 return encoded; 10434 return encoded;
10436} 10435}
10437 10436
diff --git a/src/fileio.c b/src/fileio.c
index 0db8ed793b3..3c13d3fe416 100644
--- a/src/fileio.c
+++ b/src/fileio.c
@@ -945,6 +945,7 @@ the root directory. */)
945 USE_SAFE_ALLOCA; 945 USE_SAFE_ALLOCA;
946 946
947 CHECK_STRING (name); 947 CHECK_STRING (name);
948 CHECK_STRING_NULL_BYTES (name);
948 949
949 /* If the file name has special constructs in it, 950 /* If the file name has special constructs in it,
950 call the corresponding file name handler. */ 951 call the corresponding file name handler. */
@@ -993,7 +994,10 @@ the root directory. */)
993 if (STRINGP (dir)) 994 if (STRINGP (dir))
994 { 995 {
995 if (file_name_absolute_no_tilde_p (dir)) 996 if (file_name_absolute_no_tilde_p (dir))
996 default_directory = dir; 997 {
998 CHECK_STRING_NULL_BYTES (dir);
999 default_directory = dir;
1000 }
997 else 1001 else
998 { 1002 {
999 Lisp_Object absdir 1003 Lisp_Object absdir
diff --git a/src/lisp.h b/src/lisp.h
index 7bfc69b647b..9716b34baee 100644
--- a/src/lisp.h
+++ b/src/lisp.h
@@ -1615,6 +1615,13 @@ STRING_SET_CHARS (Lisp_Object string, ptrdiff_t newsize)
1615 XSTRING (string)->u.s.size = newsize; 1615 XSTRING (string)->u.s.size = newsize;
1616} 1616}
1617 1617
1618INLINE void
1619CHECK_STRING_NULL_BYTES (Lisp_Object string)
1620{
1621 CHECK_TYPE (memchr (SSDATA (string), '\0', SBYTES (string)) == NULL,
1622 Qfilenamep, string);
1623}
1624
1618/* A regular vector is just a header plus an array of Lisp_Objects. */ 1625/* A regular vector is just a header plus an array of Lisp_Objects. */
1619 1626
1620struct Lisp_Vector 1627struct Lisp_Vector