blob: 92838559e0aa33a55abb70a9968f6986cb1428a2 [file] [log] [blame]
Junxiao Shi38f4ce92016-08-04 10:01:52 +00001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Junxiao Shi1f481fa2017-01-26 15:14:43 +00003 * Copyright (c) 2014-2017, Regents of the University of California,
Junxiao Shi38f4ce92016-08-04 10:01:52 +00004 * Arizona Board of Regents,
5 * Colorado State University,
6 * University Pierre & Marie Curie, Sorbonne University,
7 * Washington University in St. Louis,
8 * Beijing Institute of Technology,
9 * The University of Memphis.
10 *
11 * This file is part of NFD (Named Data Networking Forwarding Daemon).
12 * See AUTHORS.md for complete list of NFD authors and contributors.
13 *
14 * NFD is free software: you can redistribute it and/or modify it under the terms
15 * of the GNU General Public License as published by the Free Software Foundation,
16 * either version 3 of the License, or (at your option) any later version.
17 *
18 * NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
19 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
20 * PURPOSE. See the GNU General Public License for more details.
21 *
22 * You should have received a copy of the GNU General Public License along with
23 * NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
24 */
25
Junxiao Shi331ade72016-08-19 14:07:19 +000026#ifndef NFD_TOOLS_NFDC_FORMAT_HELPERS_HPP
27#define NFD_TOOLS_NFDC_FORMAT_HELPERS_HPP
Junxiao Shi38f4ce92016-08-04 10:01:52 +000028
Junxiao Shi9f5b01d2016-08-05 03:54:28 +000029#include "core/common.hpp"
Junxiao Shi38f4ce92016-08-04 10:01:52 +000030
31namespace nfd {
32namespace tools {
Junxiao Shi331ade72016-08-19 14:07:19 +000033namespace nfdc {
Junxiao Shi38f4ce92016-08-04 10:01:52 +000034
35namespace xml {
36
37void
38printHeader(std::ostream& os);
39
40void
41printFooter(std::ostream& os);
42
43struct Text
44{
45 const std::string& s;
46};
47
48/** \brief print XML text with special character represented as predefined entities
49 */
50std::ostream&
51operator<<(std::ostream& os, const Text& text);
52
53std::string
54formatSeconds(time::seconds d);
55
56template<typename DURATION>
57std::string
58formatDuration(DURATION d)
59{
60 return formatSeconds(time::duration_cast<time::seconds>(d));
61}
62
63std::string
64formatTimestamp(time::system_clock::TimePoint t);
65
66} // namespace xml
67
68namespace text {
69
Junxiao Shi6c135622016-11-21 14:30:33 +000070/** \brief print a number of whitespaces
71 */
72struct Spaces
73{
74 int nSpaces; ///< number of spaces; print nothing if negative
75};
76
77std::ostream&
78operator<<(std::ostream& os, const Spaces& spaces);
79
Junxiao Shi38f4ce92016-08-04 10:01:52 +000080/** \brief print different string on first and subsequent usage
81 *
82 * \code
83 * Separator sep(",");
84 * for (int i = 1; i <= 3; ++i) {
85 * os << sep << i;
86 * }
87 * // prints: 1,2,3
88 * \endcode
89 */
Junxiao Shi1f481fa2017-01-26 15:14:43 +000090class Separator : noncopyable
Junxiao Shi38f4ce92016-08-04 10:01:52 +000091{
92public:
93 Separator(const std::string& first, const std::string& subsequent);
94
95 explicit
96 Separator(const std::string& subsequent);
97
Junxiao Shic143afe2016-09-20 13:04:51 +000098 int
99 getCount() const
100 {
101 return m_count;
102 }
103
Junxiao Shi38f4ce92016-08-04 10:01:52 +0000104private:
105 std::string m_first;
106 std::string m_subsequent;
107 int m_count;
108
109 friend std::ostream& operator<<(std::ostream& os, Separator& sep);
110};
111
112std::ostream&
113operator<<(std::ostream& os, Separator& sep);
114
Junxiao Shi1f481fa2017-01-26 15:14:43 +0000115/** \brief print attributes of an item
116 *
117 * \code
118 * ItemAttributes ia(wantMultiLine, 3);
119 * os << ia("id") << 500
120 * << ia("uri") << "udp4://192.0.2.1:6363"
121 * << ia.end();
122 *
123 * // prints in single-line style (wantMultiLine==false):
124 * // id=500 uri=udp4://192.0.2.1:6363 [no-newline]
125 *
126 * // prints in multi-line style (wantMultiLine==true):
127 * // id=500
128 * // uri=udp4://192.0.2.1:6363 [newline]
129 * \endcode
130 */
131class ItemAttributes : noncopyable
132{
133public:
134 /** \brief constructor
135 * \param wantMultiLine true to select multi-line style, false to use single-line style
136 * \param maxAttributeWidth maximum width of attribute names, for alignment in multi-line style
137 */
138 explicit
139 ItemAttributes(bool wantMultiLine = false, int maxAttributeWidth = 0);
140
141 struct Attribute
142 {
Junxiao Shi056815e2017-01-29 16:39:19 +0000143 ItemAttributes& ia;
Junxiao Shi1f481fa2017-01-26 15:14:43 +0000144 std::string attribute;
145 };
146
Junxiao Shi056815e2017-01-29 16:39:19 +0000147 /** \note Caller must ensure ItemAttributes object is alive until after all Attribute objects are
148 * destructed.
149 */
Junxiao Shi1f481fa2017-01-26 15:14:43 +0000150 Attribute
151 operator()(const std::string& attribute);
152
153 std::string
154 end() const;
155
156private:
157 bool m_wantMultiLine;
158 int m_maxAttributeWidth;
159 int m_count;
Junxiao Shi056815e2017-01-29 16:39:19 +0000160
161 friend std::ostream& operator<<(std::ostream& os, const ItemAttributes::Attribute& attr);
Junxiao Shi1f481fa2017-01-26 15:14:43 +0000162};
163
164std::ostream&
165operator<<(std::ostream& os, const ItemAttributes::Attribute& attr);
166
Junxiao Shi38f4ce92016-08-04 10:01:52 +0000167std::string
168formatSeconds(time::seconds d, bool isLong = false);
169
170template<typename DURATION>
171std::string
172formatDuration(DURATION d, bool isLong = false)
173{
174 return formatSeconds(time::duration_cast<time::seconds>(d), isLong);
175}
176
177std::string
178formatTimestamp(time::system_clock::TimePoint t);
179
180} // namespace text
181
Junxiao Shi331ade72016-08-19 14:07:19 +0000182} // namespace nfdc
Junxiao Shi38f4ce92016-08-04 10:01:52 +0000183} // namespace tools
184} // namespace nfd
185
Junxiao Shi331ade72016-08-19 14:07:19 +0000186#endif // NFD_TOOLS_NFDC_FORMAT_HELPERS_HPP