/* -*- 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_OSTREAM__ #define ANDROID_ASTL_OSTREAM__ #include <ios_base.h> #include <basic_ios.h> #include <ios_pos_types.h> #include <char_traits.h> namespace std { /** * Basic implementation of ostream. The STL standard defines a * basic_ostream template that gets specialized for char and * wchar. Since Android supports only char, we don't use a template * here. */ class streambuf; class ostream: public basic_ios { public: typedef char char_type; typedef char_traits<char_type>::int_type int_type; typedef char_traits<char_type>::pos_type pos_type; typedef char_traits<char_type>::off_type off_type; protected: ostream(); public: explicit ostream(streambuf *sb) { this->init(sb); } virtual ~ostream(); // Synchronize the stream buffer. ostream& flush(); // Formatted output. /** * Interface for manipulators (e.g std::endl, std::hex in * expression like "std::cout << std::endl"). See iomanip header. */ ostream& operator<<(ostream& (*manip)(ostream&)) { return manip(*this); } ostream& operator<<(ios_base& (*manip)(ios_base&)) { manip(*this); return *this; } ostream& operator<<(unsigned long int val); ostream& operator<<(long int val); ostream& operator<<(unsigned int val); ostream& operator<<(int val); ostream& operator<<(unsigned long long int val); ostream& operator<<(long long int val); ostream& operator<<(double val); ostream& operator<<(float val); ostream& operator<<(char_type c); ostream& operator<<(const char_type *str); ostream& operator<<(bool val); // '(nil)' if p == 0 ostream& operator<<(const void *p); // This is non standard, used by string. ostream& write_formatted(const char_type *str, streamsize num); // Unformatted output. ostream& put(char_type c); ostream& write(const char_type *str, streamsize num); }; /** * Flushes the output stream. */ inline ostream& flush(ostream& os) { return os.flush(); } /** * Write a newline and flush the stream. */ inline ostream& endl(ostream& os) { return flush(os.put('\n')); } /** * Write a null character into the output sequence. */ inline ostream& ends(ostream& os) { return os.put(char()); } } // namespace std #endif