MAV'RIC
/home/travis/build/lis-epfl/MAVRIC_Library/hal/common/console.hpp
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_ */
 All Classes Files Functions Variables Typedefs Enumerations Enumerator Friends Defines