mirror of
git://git.sv.gnu.org/emacs.git
synced 2025-12-06 06:20:55 -08:00
Update from gnulib
This incorporates: 2019-12-23 mktime, nstrftime: tweak division performance 2019-12-22 count-leading-zeros: assume 'long long' 2019-12-22 count-one-bits: assume 'long long' 2019-12-22 count-trailing-zeros: assume 'long long' 2019-12-12 inttypes-incomplete: assume 'long long' 2019-12-22 malloca: assume 'long long' 2019-12-22 stdint: assume 'long long' 2019-12-22 strtoll, strtoimax, strtoumax: assume 'long long' 2019-12-22 prefer lib_SOURCES to unconditional AC_LIBOBJ 2019-12-19 nstrftime: avoid a shadowing warning 2019-12-18 improve port of AC_C_RESTRICT to Oracle C++ 2019-12-12 stdalign: port to xlclang 16.01 2019-12-11 stddef, unistd: fix compilation error in C++ mode on MSVC 2019-12-08 fix compilation errors in C++ mode on Haiku 2019-12-08 fix compilation errors in 32-bit C++ mode on HP-UX 11/ia64 2019-12-08 fix compilation error in C++ mode on OpenBSD * build-aux/config.guess, doc/misc/texinfo.tex: * lib/count-leading-zeros.h, lib/count-one-bits.h: * lib/count-trailing-zeros.h, lib/inttypes.in.h, lib/malloca.h: * lib/mktime.c, lib/nstrftime.c, lib/signal.in.h, lib/stdalign.in.h: * lib/stddef.in.h, lib/stdint.in.h, lib/stdio.in.h, lib/stdlib.in.h: * lib/strtoimax.c, lib/unistd.in.h, m4/gnulib-common.m4: * m4/inttypes.m4, m4/largefile.m4, m4/malloca.m4, m4/strtoimax.m4: * m4/strtoll.m4: Copy from Gnulib. Also, change copyright notices in some other Gnulib-copied files to exactly match Gnulib, as Gnulib updated them in a trivially different way. * lib/gnulib.mk.in, m4/gnulib-comp.m4: Regenerate.
This commit is contained in:
parent
c6fb86b40b
commit
64d1b9fd8a
85 changed files with 217 additions and 258 deletions
|
|
@ -113,7 +113,7 @@ extern char *tzname[];
|
|||
#define SHR(a, b) \
|
||||
(-1 >> 1 == -1 \
|
||||
? (a) >> (b) \
|
||||
: (a) / (1 << (b)) - ((a) % (1 << (b)) < 0))
|
||||
: ((a) + ((a) < 0)) / (1 << (b)) - ((a) < 0))
|
||||
|
||||
#define TM_YEAR_BASE 1900
|
||||
|
||||
|
|
@ -348,8 +348,8 @@ tm_diff (const struct tm *a, const struct tm *b)
|
|||
but it's OK to assume that A and B are close to each other. */
|
||||
int a4 = SHR (a->tm_year, 2) + SHR (TM_YEAR_BASE, 2) - ! (a->tm_year & 3);
|
||||
int b4 = SHR (b->tm_year, 2) + SHR (TM_YEAR_BASE, 2) - ! (b->tm_year & 3);
|
||||
int a100 = a4 / 25 - (a4 % 25 < 0);
|
||||
int b100 = b4 / 25 - (b4 % 25 < 0);
|
||||
int a100 = (a4 + (a4 < 0)) / 25 - (a4 < 0);
|
||||
int b100 = (b4 + (b4 < 0)) / 25 - (b4 < 0);
|
||||
int a400 = SHR (a100, 2);
|
||||
int b400 = SHR (b100, 2);
|
||||
int intervening_leap_days = (a4 - b4) - (a100 - b100) + (a400 - b400);
|
||||
|
|
@ -927,9 +927,11 @@ __strftime_internal (STREAM_OR_CHAR_T *s, STRFTIME_ARG (size_t maxsize)
|
|||
}
|
||||
|
||||
{
|
||||
int century = tp->tm_year / 100 + TM_YEAR_BASE / 100;
|
||||
century -= tp->tm_year % 100 < 0 && 0 < century;
|
||||
DO_YEARISH (2, tp->tm_year < - TM_YEAR_BASE, century);
|
||||
bool negative_year = tp->tm_year < - TM_YEAR_BASE;
|
||||
bool zero_thru_1899 = !negative_year & (tp->tm_year < 0);
|
||||
int century = ((tp->tm_year - 99 * zero_thru_1899) / 100
|
||||
+ TM_YEAR_BASE / 100);
|
||||
DO_YEARISH (2, negative_year, century);
|
||||
}
|
||||
|
||||
case L_('x'):
|
||||
|
|
@ -1138,8 +1140,8 @@ __strftime_internal (STREAM_OR_CHAR_T *s, STRFTIME_ARG (size_t maxsize)
|
|||
int ndigs = ns_digits;
|
||||
while (width < ndigs || (1 < ndigs && n % 10 == 0))
|
||||
ndigs--, n /= 10;
|
||||
for (int i = ndigs; 0 < i; i--)
|
||||
buf[i - 1] = n % 10 + L_('0'), n /= 10;
|
||||
for (int j = ndigs; 0 < j; j--)
|
||||
buf[j - 1] = n % 10 + L_('0'), n /= 10;
|
||||
if (!pad)
|
||||
pad = L_('0');
|
||||
width_cpy (0, ndigs, buf);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue