FreeBSD Manual Pages
ticc_prettyprint(1) General Commands Manual ticc_prettyprint(1) NAME ticc_prettyprint - format C++ containers SYNOPSIS #include ticcutils/PrettyPrint.h using namespace TiCC; DESCRIPTION TiCC Pretty Print provides some C++ templates to output C++ containers in an orderly fashion. It's not rocket science, nor complete. But for instance for debugging it is convenient to be able to output containers a bit readable. To get usefull output, a well defined output operator is required for the elements in the container too. TiCC output operators are currenly defined for: set<T> list<T> vector<T> map<S,T> map<S,T,U> multimap<S,T> To get usefull output, it is needed that an output operator is defined for the elements S and T in the container too. EXAMPLES Example 1 #include <vector> #include <string> #include <iostream> #include "ticcutils/PrettyPrint.h" using namespace std; using namespace TiCC; int main(){ vector<string> vec; vec.push_back("one"); vec.push_back("two"); vec.push_back("three"); cout << vec << endl; } The output of this simple program will be: [one,two,three] Example 2 #include <vector> #include <string> #include <iostream> #include "ticcutils/PrettyPrint.h" using namespace std; using namespace TiCC; class myClass { friend ostream& operator<< (ostream&, const myClass& ); public: myClass( int i, const string& s ): _i(i),_s(s){} private: int _i; string _s; }; ostream& operator<< (ostream& os, const myClass& mc ){ os << "Myclass(" << mc._i << "," << mc._s << ")"; return os; } int main(){ vector<myClass> vec; vec.push_back( myClass(1,"one") ); vec.push_back( myClass(2,"two") ); vec.push_back( myClass(3,"three") ); cout << vec << endl; } The output of this example program will be: [Myclass(1,one),Myclass(2,two),Myclass(3,three)] Example 3 #include <vector> #include <string> #include <iostream> #include "ticcutils/PrettyPrint.h" using namespace std; using namespace TiCC; class myClass { friend ostream& operator<< (ostream&, const myClass& ); public: myClass( int i, const string& s ): _i(i),_s(s){} private: int _i; string _s; }; ostream& operator<< (ostream& os, const myClass& mc ){ os << "Myclass(" << mc._i << "," << mc._s << ")"; return os; } int main(){ vector<*myClass> vec; vec.push_back( new myClass(1,"one") ); vec.push_back( new myClass(2,"two") ); vec.push_back( new myClass(3,"three") ); cout << vec << endl; } The output of this program will be: [0x2363040,0x23630b0,0x2363060] Or something similar. Why is this so? Well, we didn't provide an output operator for myClass pointers! To fix this we have to change de definition of the output operator for myClass or just add a second definition, e.g. add: friend ostream& operator<< (ostream&, const myClass* ); to myClass, and also add: ostream& operator<< (ostream& os, const myClass *mc ){ if ( mc ) os << *mc; else os << "zero pointer"; return os; } The output now indeed is what we expected: [Myclass(1,one),Myclass(2,two),Myclass(3,three)] AUTHORS Ko van der Sloot Timbl@uvt.nl 2012 August 21 ticc_prettyprint(1)
NAME | SYNOPSIS | DESCRIPTION | EXAMPLES | AUTHORS
Want to link to this manual page? Use this URL:
<https://man.freebsd.org/cgi/man.cgi?query=ticc_prettyprint&sektion=1&manpath=FreeBSD+Ports+14.3.quarterly>
