Split <ctype.h> header out of <cctype> On Tue, Oct 6, 2015 at 3:07 PM, Richard Smith <rich...@metafoo.co.uk> wrote:
> Next: factoring the definition of std::nullptr_t out into a separate file, > so that <cstddef> and <stddef.h> can both use it, without <stddef.h> > including <cstddef> and without <cstddef> providing a ::nullptr_t like > <stddef.h> does. > > On Tue, Oct 6, 2015 at 3:02 PM, Eric Fiselier <e...@efcs.ca> wrote: > >> LGTM. >> >> On Tue, Oct 6, 2015 at 3:58 PM, Richard Smith <rich...@metafoo.co.uk> >> wrote: >> > On Mon, Oct 5, 2015 at 7:10 PM, Eric Fiselier <e...@efcs.ca> wrote: >> >> >> >> EricWF added a comment. >> >> >> >> I think thing change will help us close a number out outstanding bugs. >> I >> >> don't have any fundamental objections to this approach. However the >> size of >> >> this patch scares me. I understand the changes are mostly mechanical >> but >> >> their size can hide things. For example has anybody noticed that your >> >> internal changes to `<deque>` are in this patch? It would be nice to >> break >> >> this down into more digestible pieces that could be quickly spot >> checked. >> > >> > >> > OK. First such patch is attached. It just removes the macro-capturing >> > wrapper functions. >> > >
diff --git include/cctype include/cctype index db16343..a68c2a0 100644 --- include/cctype +++ include/cctype @@ -37,10 +37,6 @@ int toupper(int c); #include <__config> #include <ctype.h> -#if defined(_LIBCPP_MSVCRT) -#include "support/win32/support.h" -#include "support/win32/locale_win32.h" -#endif // _LIBCPP_MSVCRT #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) #pragma GCC system_header @@ -48,33 +44,19 @@ int toupper(int c); _LIBCPP_BEGIN_NAMESPACE_STD -#undef isalnum using ::isalnum; -#undef isalpha using ::isalpha; -#undef isblank using ::isblank; -#undef iscntrl using ::iscntrl; -#undef isdigit using ::isdigit; -#undef isgraph using ::isgraph; -#undef islower using ::islower; -#undef isprint using ::isprint; -#undef ispunct using ::ispunct; -#undef isspace using ::isspace; -#undef isupper using ::isupper; -#undef isxdigit using ::isxdigit; -#undef tolower using ::tolower; -#undef toupper using ::toupper; _LIBCPP_END_NAMESPACE_STD diff --git include/ctype.h include/ctype.h new file mode 100644 index 0000000..63f0b29 --- /dev/null +++ include/ctype.h @@ -0,0 +1,68 @@ +// -*- C++ -*- +//===---------------------------- ctype.h ---------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is dual licensed under the MIT and the University of Illinois Open +// Source Licenses. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +#ifndef _LIBCPP_CTYPE_H +#define _LIBCPP_CTYPE_H + +/* + ctype.h synopsis + +int isalnum(int c); +int isalpha(int c); +int isblank(int c); // C99 +int iscntrl(int c); +int isdigit(int c); +int isgraph(int c); +int islower(int c); +int isprint(int c); +int ispunct(int c); +int isspace(int c); +int isupper(int c); +int isxdigit(int c); +int tolower(int c); +int toupper(int c); +*/ + +#include <__config> +#include_next <ctype.h> + +#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) +#pragma GCC system_header +#endif + +#ifdef __cplusplus + +#if defined(_LIBCPP_MSVCRT) +// We support including .h headers inside 'extern "C"' contexts, so switch +// back to C++ linkage before including these C++ headers. +extern "C++" { + #include "support/win32/support.h" + #include "support/win32/locale_win32.h" +} +#endif // _LIBCPP_MSVCRT + +#undef isalnum +#undef isalpha +#undef isblank +#undef iscntrl +#undef isdigit +#undef isgraph +#undef islower +#undef isprint +#undef ispunct +#undef isspace +#undef isupper +#undef isxdigit +#undef tolower +#undef toupper + +#endif + +#endif // _LIBCPP_CTYPE_H diff --git test/std/strings/c.strings/cctype.pass.cpp test/std/strings/c.strings/cctype.pass.cpp index 867338f..027fbcd 100644 --- test/std/strings/c.strings/cctype.pass.cpp +++ test/std/strings/c.strings/cctype.pass.cpp @@ -86,18 +86,18 @@ int main() static_assert((std::is_same<decltype(std::tolower(0)), int>::value), ""); static_assert((std::is_same<decltype(std::toupper(0)), int>::value), ""); - assert(isalnum('a')); - assert(isalpha('a')); - assert(isblank(' ')); - assert(!iscntrl(' ')); - assert(!isdigit('a')); - assert(isgraph('a')); - assert(islower('a')); - assert(isprint('a')); - assert(!ispunct('a')); - assert(!isspace('a')); - assert(!isupper('a')); - assert(isxdigit('a')); - assert(tolower('A') == 'a'); - assert(toupper('a') == 'A'); + assert(std::isalnum('a')); + assert(std::isalpha('a')); + assert(std::isblank(' ')); + assert(!std::iscntrl(' ')); + assert(!std::isdigit('a')); + assert(std::isgraph('a')); + assert(std::islower('a')); + assert(std::isprint('a')); + assert(!std::ispunct('a')); + assert(!std::isspace('a')); + assert(!std::isupper('a')); + assert(std::isxdigit('a')); + assert(std::tolower('A') == 'a'); + assert(std::toupper('a') == 'A'); }
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits