summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStefan Monnier <monnier@iro.umontreal.ca>2008-03-07 15:42:30 +0000
committerStefan Monnier <monnier@iro.umontreal.ca>2008-03-07 15:42:30 +0000
commit3efaadb7b2c3e5c4e7e48622b1def6e2872cf866 (patch)
tree0c6739cb0771dd0329b8d79848457619732b3bc1
parentc80b160d0722ae1ee0fc5e09e829c16fc2f4aaa3 (diff)
downloademacs-3efaadb7b2c3e5c4e7e48622b1def6e2872cf866.tar.gz
(Fsubstitute_in_file_name): Fix up computation of maximum
size of resulting string.
-rw-r--r--src/ChangeLog5
-rw-r--r--src/fileio.c4
2 files changed, 7 insertions, 2 deletions
diff --git a/src/ChangeLog b/src/ChangeLog
index 0ddc633e61f..b2310ae76c2 100644
--- a/src/ChangeLog
+++ b/src/ChangeLog
@@ -1,3 +1,8 @@
+2008-03-07 Stefan Monnier <monnier@iro.umontreal.ca>
+
+ * fileio.c (Fsubstitute_in_file_name): Fix up computation of maximum
+ size of resulting string.
+
2008-03-05 Jason Rumney <jasonr@gnu.org>
* dispnew.c (adjust_glyph_matrix): Initialize window_height.
diff --git a/src/fileio.c b/src/fileio.c
index c5bff5b8153..769a719191e 100644
--- a/src/fileio.c
+++ b/src/fileio.c
@@ -2226,8 +2226,8 @@ duplicates what `expand-file-name' does. */)
/* Get variable value */
o = (unsigned char *) egetenv (target);
if (o)
- {
- total += strlen (o);
+ { /* Eight-bit chars occupy upto 2 bytes in multibyte. */
+ total += strlen (o) * (STRING_MULTIBYTE (filename) ? 2 : 1);
substituted = 1;
}
else if (*p == '}')