mirror of
https://gitee.com/TarsCloud/TarsCpp.git
synced 2025-01-05 17:42:24 +08:00
372 lines
9.8 KiB
C++
Executable File
372 lines
9.8 KiB
C++
Executable File
/**
|
|
* Tencent is pleased to support the open source community by making Tars available.
|
|
*
|
|
* Copyright (C) 2016THL A29 Limited, a Tencent company. All rights reserved.
|
|
*
|
|
* Licensed under the BSD 3-Clause License (the "License"); you may not use this file except
|
|
* in compliance with the License. You may obtain a copy of the License at
|
|
*
|
|
* https://opensource.org/licenses/BSD-3-Clause
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software distributed
|
|
* under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
|
|
* CONDITIONS OF ANY KIND, either express or implied. See the License for the
|
|
* specific language governing permissions and limitations under the License.
|
|
*/
|
|
|
|
#ifndef __TARS_DISPLAYER_H__
|
|
#define __TARS_DISPLAYER_H__
|
|
|
|
//#include <netinet/in.h>
|
|
#include <iostream>
|
|
#include <cassert>
|
|
#include <vector>
|
|
#include <map>
|
|
#include <string>
|
|
#include <stdexcept>
|
|
#include <stdint.h>
|
|
#include <string.h>
|
|
#include <limits.h>
|
|
|
|
//支持iphone
|
|
#ifdef __APPLE__
|
|
#include "TarsType.h"
|
|
#else
|
|
#include "tup/TarsType.h"
|
|
#endif
|
|
|
|
namespace tars
|
|
{
|
|
//////////////////////////////////////////////////////////////////////
|
|
/// 用于输出
|
|
class TarsDisplayer
|
|
{
|
|
std::ostream& _os;
|
|
int _level;
|
|
|
|
void ps(const char * fieldName)
|
|
{
|
|
for(int i = 0; i < _level; ++i)
|
|
_os << '\t';
|
|
if(fieldName != NULL)
|
|
_os << fieldName << ": ";
|
|
}
|
|
public:
|
|
explicit TarsDisplayer(std::ostream& os, int level = 0)
|
|
: _os(os)
|
|
, _level(level)
|
|
{}
|
|
|
|
TarsDisplayer& display(Bool b, const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
_os << (b ? 'T' : 'F') << std::endl;
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& display(Char n, const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
_os << n << std::endl;
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& display(UInt8 n, const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
_os << n << std::endl;
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& display(Short n, const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
_os << n << std::endl;
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& display(UInt16 n, const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
_os << n << std::endl;
|
|
return *this;
|
|
}
|
|
|
|
|
|
TarsDisplayer& display(Int32 n, const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
_os << n << std::endl;
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& display(UInt32 n, const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
_os << n << std::endl;
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& display(Int64 n, const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
_os << n << std::endl;
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& display(Float n, const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
_os << n << std::endl;
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& display(Double n, const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
_os << n << std::endl;
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& display(const std::string& s, const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
_os << s << std::endl;
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& display(const char *s, const size_t len, const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
for(unsigned i=0;i< len; i++) {
|
|
_os << s[i];
|
|
}
|
|
_os<<std::endl;
|
|
return *this;
|
|
}
|
|
|
|
template <typename K, typename V, typename Cmp, typename Alloc >
|
|
TarsDisplayer& display(const std::map<K, V, Cmp, Alloc>& m, const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
if(m.empty()){
|
|
_os << m.size() << ", {}" << std::endl;
|
|
return *this;
|
|
}
|
|
_os << m.size() << ", {" << std::endl;
|
|
TarsDisplayer jd1(_os, _level + 1);
|
|
TarsDisplayer jd(_os, _level + 2);
|
|
typedef typename std::map<K, V, Cmp, Alloc>::const_iterator IT;
|
|
IT f = m.begin(), l = m.end();
|
|
for(; f != l; ++f){
|
|
jd1.display('(', NULL);
|
|
jd.display(f->first, NULL);
|
|
jd.display(f->second, NULL);
|
|
jd1.display(')', NULL);
|
|
}
|
|
display('}', NULL);
|
|
return *this;
|
|
}
|
|
|
|
template < typename T, typename Alloc >
|
|
TarsDisplayer& display(const std::vector<T, Alloc>& v, const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
if(v.empty()){
|
|
_os << v.size() << ", []" << std::endl;
|
|
return *this;
|
|
}
|
|
_os << v.size() << ", [" << std::endl;
|
|
TarsDisplayer jd(_os, _level + 1);
|
|
typedef typename std::vector<T, Alloc>::const_iterator IT;
|
|
IT f = v.begin(), l = v.end();
|
|
for(; f != l; ++f)
|
|
jd.display(*f, NULL);
|
|
display(']', NULL);
|
|
return *this;
|
|
}
|
|
|
|
template < typename T >
|
|
TarsDisplayer& display(const T * v, const size_t len ,const char * fieldName)
|
|
{
|
|
ps(fieldName);
|
|
if(len == 0){
|
|
_os << len << ", []" << std::endl;
|
|
return *this;
|
|
}
|
|
_os << len << ", [" << std::endl;
|
|
TarsDisplayer jd(_os, _level + 1);
|
|
for(size_t i=0; i< len; ++i)
|
|
jd.display(v[i], NULL);
|
|
display(']', NULL);
|
|
return *this;
|
|
}
|
|
|
|
template < typename T >
|
|
TarsDisplayer& display(const T& v, const char * fieldName, typename detail::disable_if<detail::is_convertible<T*, TarsStructBase*>, void ***>::type dummy = 0)
|
|
{
|
|
return display((Int32) v, fieldName);
|
|
}
|
|
|
|
template < typename T >
|
|
TarsDisplayer& display(const T& v, const char * fieldName, typename detail::enable_if<detail::is_convertible<T*, TarsStructBase*>, void ***>::type dummy = 0)
|
|
{
|
|
display('{', fieldName);
|
|
v.display(_os, _level + 1);
|
|
display('}', NULL);
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& displaySimple(Bool b, bool bSep)
|
|
{
|
|
_os << (b ? 'T' : 'F') << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& displaySimple(Char n, bool bSep)
|
|
{
|
|
_os << n << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& displaySimple(UInt8 n, bool bSep)
|
|
{
|
|
_os << n << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& displaySimple(Short n, bool bSep)
|
|
{
|
|
_os << n << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& displaySimple(UInt16 n, bool bSep)
|
|
{
|
|
_os << n << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& displaySimple(Int32 n, bool bSep)
|
|
{
|
|
_os << n << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& displaySimple(UInt32 n, bool bSep)
|
|
{
|
|
_os << n << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& displaySimple(Int64 n, bool bSep)
|
|
{
|
|
_os << n << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& displaySimple(Float n, bool bSep)
|
|
{
|
|
_os << n << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& displaySimple(Double n, bool bSep)
|
|
{
|
|
_os << n << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& displaySimple(const std::string& n, bool bSep)
|
|
{
|
|
_os << n << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
TarsDisplayer& displaySimple(const char * n, const size_t len, bool bSep)
|
|
{
|
|
for(unsigned i=0;i< len; i++) {
|
|
_os << n[i] ;
|
|
}
|
|
_os<<(bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
template <typename K, typename V, typename Cmp, typename Alloc >
|
|
TarsDisplayer& displaySimple(const std::map<K, V, Cmp, Alloc>& m, bool bSep)
|
|
{
|
|
if(m.empty()){
|
|
_os << m.size() << "{}";
|
|
return *this;
|
|
}
|
|
_os << m.size() << "{";
|
|
TarsDisplayer jd1(_os, _level + 1);
|
|
TarsDisplayer jd(_os, _level + 2);
|
|
typedef typename std::map<K, V, Cmp, Alloc>::const_iterator IT;
|
|
IT f = m.begin(), l = m.end();
|
|
for(; f != l; ++f){
|
|
if(f != m.begin()) _os << ',';
|
|
jd.displaySimple(f->first, true);
|
|
jd.displaySimple(f->second, false);
|
|
}
|
|
_os << '}' << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
template < typename T, typename Alloc >
|
|
TarsDisplayer& displaySimple(const std::vector<T, Alloc>& v, bool bSep)
|
|
{
|
|
if(v.empty()){
|
|
_os << v.size() << "{}";
|
|
return *this;
|
|
}
|
|
_os << v.size() << '{';
|
|
TarsDisplayer jd(_os, _level + 1);
|
|
typedef typename std::vector<T, Alloc>::const_iterator IT;
|
|
IT f = v.begin(), l = v.end();
|
|
for(; f != l; ++f)
|
|
{
|
|
if(f != v.begin()) _os << "|";
|
|
jd.displaySimple(*f, false);
|
|
}
|
|
_os << '}' << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
template < typename T>
|
|
TarsDisplayer& displaySimple(const T* v, const size_t len, bool bSep)
|
|
{
|
|
if(len == 0){
|
|
_os << len << "{}";
|
|
return *this;
|
|
}
|
|
_os << len << '{';
|
|
TarsDisplayer jd(_os, _level + 1);
|
|
for(size_t i=0; i <len ; ++i)
|
|
{
|
|
if(i != 0) _os << "|";
|
|
jd.displaySimple(v[i], false);
|
|
}
|
|
_os << '}' << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
|
|
template < typename T >
|
|
TarsDisplayer& displaySimple(const T& v, bool bSep, typename detail::disable_if<detail::is_convertible<T*, TarsStructBase*>, void ***>::type dummy = 0)
|
|
{
|
|
return displaySimple((Int32) v, bSep);
|
|
}
|
|
|
|
template < typename T >
|
|
TarsDisplayer& displaySimple(const T& v, bool bSep, typename detail::enable_if<detail::is_convertible<T*, TarsStructBase*>, void ***>::type dummy = 0)
|
|
{
|
|
_os << "{";
|
|
v.displaySimple(_os, _level + 1);
|
|
_os << "}" << (bSep ? "|" : "");
|
|
return *this;
|
|
}
|
|
};
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
}
|
|
#endif
|