/* -*- c++ -*- */ /* * Copyright (C) 2010 The Android Open Source Project * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. */ #ifndef ANDROID_ASTL_CHAR_TRAITS_H__ #define ANDROID_ASTL_CHAR_TRAITS_H__ #include <ios_pos_types.h> // For streampos #include <cstdio> // For EOF #include <cstring> // For memcmp, memchr, strlen namespace std { /** * char_traits defines the basic types and constants (eof) used in * string and stream as well as basic char manipulations. * Android's support only char. The state_type is missing because we * don't support multibyte strings. */ template<class _CharT> struct char_traits { // Empty on purpose. You should use char_traits<char> only. }; template<> struct char_traits<char> { typedef char char_type; typedef int int_type; typedef streampos pos_type; typedef streamoff off_type; static void assign(char& lhs, const char& rhs) { lhs = rhs; } static bool eq(const char& lhs, const char& rhs) { return lhs == rhs; } static bool lt(const char& lhs, const char& rhs) { return lhs < rhs; } static int compare(const char* lhs, const char* rhs, size_t n) { return std::memcmp(lhs, rhs, n); } static size_t length(const char* str) { return std::strlen(str); } static const char* find(const char* str, size_t n, const char& c) { return static_cast<const char*>(std::memchr(str, c, n)); } static char* move(char* lhs, const char* rhs, size_t n) { return static_cast<char*>(std::memmove(lhs, rhs, n)); } static char* copy(char* lhs, const char* rhs, size_t n) { return static_cast<char*>(std::memcpy(lhs, rhs, n)); } // Fill 'lhs' with 'n' occurences of 'c' static char* assign(char* lhs, size_t n, char c) { return static_cast<char*>(std::memset(lhs, c, n)); } static char to_char(const int_type& c) { return static_cast<char>(c); } static int_type to_int_type(const char& c) { return static_cast<int_type>(static_cast<unsigned char>(c)); } static bool eq_int_type(const int_type& lhs, const int_type& rhs) { return lhs == rhs; } static int_type eof() { return static_cast<int_type>(EOF); } static int_type not_eof(const int_type& c) { return (c == eof()) ? 0 : c; } }; } // namespace std #endif