From 38b581ae41c98f8aba7b188f8ec8c1ebcef164d3 Mon Sep 17 00:00:00 2001 From: DJ Delorie Date: Wed, 17 Apr 2002 01:03:04 +0000 Subject: [PATCH] merge from gcc --- include/ChangeLog | 5 +++++ include/xregex2.h | 14 ++++++++++---- 2 files changed, 15 insertions(+), 4 deletions(-) diff --git a/include/ChangeLog b/include/ChangeLog index 135105899f6..dd0a2302ae9 100644 --- a/include/ChangeLog +++ b/include/ChangeLog @@ -1,3 +1,8 @@ +2002-04-16 David S. Miller + + * xregex2.h (__restrict_arr): Define to __restrict on GCC + 3.1 and later. Do not redefine. + 2002-04-01 Phil Edwards * dyn-string.h: Also allow IN_GLIBCPP_V3 to redefine names. diff --git a/include/xregex2.h b/include/xregex2.h index b9c2d97cce1..2991daf9bcf 100644 --- a/include/xregex2.h +++ b/include/xregex2.h @@ -529,10 +529,16 @@ extern int re_exec _RE_ARGS ((const char *)); # endif # endif #endif -/* For now unconditionally define __restrict_arr to expand to nothing. - Ideally we would have a test for the compiler which allows defining - it to restrict. */ -#define __restrict_arr + +/* GCC 3.1 and later support declaring arrays as non-overlapping + using the syntax array_name[restrict] */ +#ifndef __restrict_arr +# if ! (3 < __GNUC__ || (3 == __GNUC__ && 1 <= __GNUC_MINOR__)) || defined (__GNUG__) +# define __restrict_arr +# else +# define __restrict_arr __restrict +# endif +#endif /* POSIX compatibility. */ extern int regcomp _RE_ARGS ((regex_t *__restrict __preg, -- 2.30.2