diff options
author | Miles Bader <miles@gnu.org> | 2006-03-28 23:08:20 +0000 |
---|---|---|
committer | Miles Bader <miles@gnu.org> | 2006-03-28 23:08:20 +0000 |
commit | 1ef7e5599f5aa981399221e657ff34e80cc2c1a3 (patch) | |
tree | 539ff4cf9ea84af29a4e8628d049f3a4253a51f4 /src/editfns.c | |
parent | 33bd75ec5fb277e58731c8cbbb942cba4d9a9f19 (diff) | |
parent | 29314e0fd78063d663bd272787d0ea81cc61e38e (diff) | |
download | emacs-1ef7e5599f5aa981399221e657ff34e80cc2c1a3.tar.gz emacs-1ef7e5599f5aa981399221e657ff34e80cc2c1a3.tar.bz2 emacs-1ef7e5599f5aa981399221e657ff34e80cc2c1a3.zip |
Revision: emacs@sv.gnu.org/emacs--unicode--0--patch-49
Merge from emacs--devo--0
Patches applied:
* emacs--devo--0 (patch 164-184)
- Update from CVS
- Merge from gnus--rel--5.10
- Update from CVS: man/mh-e.texi (Folders): Various edits.
- Update from erc--emacs--0
* gnus--rel--5.10 (patch 62-70)
- Merge from emacs--devo--0
- Update from CVS
Diffstat (limited to 'src/editfns.c')
-rw-r--r-- | src/editfns.c | 32 |
1 files changed, 24 insertions, 8 deletions
diff --git a/src/editfns.c b/src/editfns.c index 7c2c2a8edd0..59401fdfecd 100644 --- a/src/editfns.c +++ b/src/editfns.c @@ -72,6 +72,8 @@ Boston, MA 02110-1301, USA. */ extern char **environ; #endif +#define TM_YEAR_BASE 1900 + extern size_t emacs_strftimeu P_ ((char *, size_t, const char *, const struct tm *, int)); static int tm_diff P_ ((struct tm *, struct tm *)); @@ -719,7 +721,7 @@ Field boundaries are not noticed if `inhibit-field-text-motion' is non-nil. */) int orig_point = 0; int fwd; Lisp_Object prev_old, prev_new; - + if (NILP (new_pos)) /* Use the current point, and afterwards, set it. */ { @@ -734,7 +736,7 @@ Field boundaries are not noticed if `inhibit-field-text-motion' is non-nil. */) prev_old = make_number (XFASTINT (old_pos) - 1); prev_new = make_number (XFASTINT (new_pos) - 1); - + if (NILP (Vinhibit_field_text_motion) && !EQ (new_pos, old_pos) && (!NILP (Fget_char_property (new_pos, Qfield, Qnil)) @@ -1720,7 +1722,9 @@ DOW and ZONE.) */) XSETFASTINT (list_args[2], decoded_time->tm_hour); XSETFASTINT (list_args[3], decoded_time->tm_mday); XSETFASTINT (list_args[4], decoded_time->tm_mon + 1); - XSETINT (list_args[5], decoded_time->tm_year + 1900); + /* On 64-bit machines an int is narrower than EMACS_INT, thus the + cast below avoids overflow in int arithmetics. */ + XSETINT (list_args[5], TM_YEAR_BASE + (EMACS_INT) decoded_time->tm_year); XSETFASTINT (list_args[6], decoded_time->tm_wday); list_args[7] = (decoded_time->tm_isdst)? Qt : Qnil; @@ -1776,7 +1780,7 @@ usage: (encode-time SECOND MINUTE HOUR DAY MONTH YEAR &optional ZONE) */) tm.tm_hour = XINT (args[2]); tm.tm_mday = XINT (args[3]); tm.tm_mon = XINT (args[4]) - 1; - tm.tm_year = XINT (args[5]) - 1900; + tm.tm_year = XINT (args[5]) - TM_YEAR_BASE; tm.tm_isdst = -1; if (CONSP (zone)) @@ -1842,11 +1846,25 @@ but this is considered obsolete. */) { time_t value; char buf[30]; + struct tm *tm; register char *tem; if (! lisp_time_argument (specified_time, &value, NULL)) - value = -1; - tem = (char *) ctime (&value); + error ("Invalid time specification"); + /* Do not use ctime, since it has undefined behavior with + out-of-range time stamps. This avoids a core dump triggered by + (current-time-string '(2814749767106 0)) on 64-bit Solaris 8. See + <http://www.opengroup.org/austin/mailarchives/ag/msg09294.html> + for more details about this portability problem. */ + tm = localtime (&value); + /* Checking for out-of-range time stamps avoids buffer overruns that + cause core dump on some systems (e.g., 64-bit Solaris), and also + preserves the historic behavior of always returning a fixed-size + 24-character string. */ + if (! (tm && -999 - TM_YEAR_BASE <= tm->tm_year + && tm->tm_year <= 9999 - TM_YEAR_BASE)) + error ("Specified time is not representable"); + tem = asctime (tm); strncpy (buf, tem, 24); buf[24] = 0; @@ -1854,8 +1872,6 @@ but this is considered obsolete. */) return build_string (buf); } -#define TM_YEAR_BASE 1900 - /* Yield A - B, measured in seconds. This function is copied from the GNU C Library. */ static int |