std_cstring.h revision 132720
1// -*- C++ -*- forwarding header. 2 3// Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002 4// Free Software Foundation, Inc. 5// 6// This file is part of the GNU ISO C++ Library. This library is free 7// software; you can redistribute it and/or modify it under the 8// terms of the GNU General Public License as published by the 9// Free Software Foundation; either version 2, or (at your option) 10// any later version. 11 12// This library is distributed in the hope that it will be useful, 13// but WITHOUT ANY WARRANTY; without even the implied warranty of 14// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 15// GNU General Public License for more details. 16 17// You should have received a copy of the GNU General Public License along 18// with this library; see the file COPYING. If not, write to the Free 19// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, 20// USA. 21 22// As a special exception, you may use this file as part of a free software 23// library without restriction. Specifically, if other files instantiate 24// templates or use macros or inline functions from this file, or you compile 25// this file and link it with other files to produce an executable, this 26// file does not by itself cause the resulting executable to be covered by 27// the GNU General Public License. This exception does not however 28// invalidate any other reasons why the executable file might be covered by 29// the GNU General Public License. 30 31// 32// ISO C++ 14882: 20.4.6 C library 33// 34 35/** @file cstring 36 * This is a Standard C++ Library file. You should @c #include this file 37 * in your programs, rather than any of the "*.h" implementation files. 38 * 39 * This is the C++ version of the Standard C Library header @c string.h, 40 * and its contents are (mostly) the same as that header, but are all 41 * contained in the namespace @c std. 42 */ 43 44#ifndef _GLIBCXX_CSTRING 45#define _GLIBCXX_CSTRING 1 46 47#pragma GCC system_header 48 49#include <cstddef> 50 51#include <string.h> 52 53// Get rid of those macros defined in <string.h> in lieu of real functions. 54#undef memcpy 55#undef memmove 56#undef strcpy 57#undef strncpy 58#undef strcat 59#undef strncat 60#undef memcmp 61#undef strcmp 62#undef strcoll 63#undef strncmp 64#undef strxfrm 65#undef memchr 66#undef strchr 67#undef strcspn 68#undef strpbrk 69#undef strrchr 70#undef strspn 71#undef strstr 72#undef strtok 73#undef memset 74#undef strerror 75#undef strlen 76 77namespace std 78{ 79 using ::memcpy; 80 using ::memmove; 81 using ::strcpy; 82 using ::strncpy; 83 using ::strcat; 84 using ::strncat; 85 using ::memcmp; 86 using ::strcmp; 87 using ::strcoll; 88 using ::strncmp; 89 using ::strxfrm; 90 using ::strcspn; 91 using ::strspn; 92 using ::strtok; 93 using ::memset; 94 using ::strerror; 95 using ::strlen; 96 97 using ::memchr; 98 99 inline void* 100 memchr(void* __p, int __c, size_t __n) 101 { return memchr(const_cast<const void*>(__p), __c, __n); } 102 103 using ::strchr; 104 105 inline char* 106 strchr(char* __s1, int __n) 107 { return __builtin_strchr(const_cast<const char*>(__s1), __n); } 108 109 using ::strpbrk; 110 111 inline char* 112 strpbrk(char* __s1, const char* __s2) 113 { return __builtin_strpbrk(const_cast<const char*>(__s1), __s2); } 114 115 using ::strrchr; 116 117 inline char* 118 strrchr(char* __s1, int __n) 119 { return __builtin_strrchr(const_cast<const char*>(__s1), __n); } 120 121 using ::strstr; 122 123 inline char* 124 strstr(char* __s1, const char* __s2) 125 { return __builtin_strstr(const_cast<const char*>(__s1), __s2); } 126} 127 128#endif 129