blob: ff04e1f8b2bad7a715aeaa1dedbd31f1571e9319 [file] [log] [blame]
Junxiao Shi38f4ce92016-08-04 10:01:52 +00001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
3 * Copyright (c) 2014-2016, Regents of the University of California,
4 * 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
26#include "status-report.hpp"
27#include "format-helpers.hpp"
28
29namespace nfd {
30namespace tools {
31namespace nfd_status {
32
33uint32_t
34StatusReport::collect(Face& face, KeyChain& keyChain, Validator& validator, const CommandOptions& options)
35{
36 Controller controller(face, keyChain, validator);
37 uint32_t errorCode = 0;
38
39 for (size_t i = 0; i < sections.size(); ++i) {
40 Module& module = *sections[i];
41 module.fetchStatus(
42 controller,
43 [] {},
44 [i, &errorCode] (uint32_t code, const std::string& reason) {
45 errorCode = i * 1000000 + code;
46 },
47 options);
48 }
49
50 this->processEvents(face);
51 return errorCode;
52}
53
54void
55StatusReport::processEvents(Face& face)
56{
57 face.processEvents();
58}
59
60void
61StatusReport::formatXml(std::ostream& os) const
62{
63 xml::printHeader(os);
64 for (const unique_ptr<Module>& module : sections) {
65 module->formatStatusXml(os);
66 }
67 xml::printFooter(os);
68}
69
70void
71StatusReport::formatText(std::ostream& os) const
72{
73 for (const unique_ptr<Module>& module : sections) {
74 module->formatStatusText(os);
75 }
76}
77
78} // namespace nfd_status
79} // namespace tools
80} // namespace nfd