MAV'RIC
|
00001 /******************************************************************************* 00002 * Copyright (c) 2009-2016, MAV'RIC Development Team 00003 * All rights reserved. 00004 * 00005 * Redistribution and use in source and binary forms, with or without 00006 * modification, are permitted provided that the following conditions are met: 00007 * 00008 * 1. Redistributions of source code must retain the above copyright notice, 00009 * this list of conditions and the following disclaimer. 00010 * 00011 * 2. Redistributions in binary form must reproduce the above copyright notice, 00012 * this list of conditions and the following disclaimer in the documentation 00013 * and/or other materials provided with the distribution. 00014 * 00015 * 3. Neither the name of the copyright holder nor the names of its contributors 00016 * may be used to endorse or promote products derived from this software without 00017 * specific prior written permission. 00018 * 00019 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00020 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00021 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00022 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 00023 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00024 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00025 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00026 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00027 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00028 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00029 * POSSIBILITY OF SUCH DAMAGE. 00030 ******************************************************************************/ 00031 00032 /******************************************************************************* 00033 * \file console.hpp 00034 * 00035 * \author MAV'RIC Team 00036 * 00037 * \brief Write to any write-able module in human-readable format 00038 * You can use '<<' to print various data types in cout style: console << " hello " << endl; 00039 * To define '<<' operator for your own class, implement the follwing function 00040 * in the header of your class, outside of your class definition: 00041 * template<typename Writeable> 00042 * Console<Writeable>& operator<< (Console<Writeable>& console, YourClass& yourclass) 00043 * { 00044 * console.write(...); 00045 * return console; 00046 * } 00047 * 00048 ******************************************************************************/ 00049 00050 #ifndef CONSOLE_HPP_ 00051 #define CONSOLE_HPP_ 00052 00053 #include <cstdint> 00054 #include "util/string_util.hpp" 00055 00056 00060 template <typename Writeable> 00061 class Console 00062 { 00063 protected: 00064 Writeable& stream_; 00065 00066 public: 00070 Console(Writeable& stream); 00071 00072 00081 bool write(const uint8_t* data, uint32_t size); 00082 00090 bool write(const char* text); 00091 00099 bool writeln(const char* text); 00100 00101 00109 bool write(bool value); 00110 00111 00119 template<typename T> 00120 bool write(T number); 00121 00122 00130 bool write(float number, uint8_t after_digits = 3); 00131 bool write(double number, uint8_t after_digits = 3); 00132 00140 template <typename T> 00141 bool write_floating(T number, uint8_t after_digits = 3); 00142 00143 00149 void flush(); 00150 00156 void newline(); 00157 00158 00159 /* definition of ConsoleManipulator function pointer (used for "console << endl") */ 00160 typedef Console<Writeable>& (*ConsoleManipulator)(Console<Writeable>&); 00161 00162 00172 template<typename T> 00173 Console<Writeable>& operator<<(const T& data); 00174 00183 Console<Writeable>& operator<<(ConsoleManipulator manip); 00184 00185 Writeable* get_stream(); 00186 }; 00187 00196 template<typename Writeable> 00197 Console<Writeable>& endl(Console<Writeable>& console); 00198 00199 /* Template implementation file */ 00200 #include "console.hxx" 00201 00202 #endif /* CONSOLE_HPP_ */