cmd_about.cpp revision 1.1 1 1.1 jmmv // Copyright 2010 Google Inc.
2 1.1 jmmv // All rights reserved.
3 1.1 jmmv //
4 1.1 jmmv // Redistribution and use in source and binary forms, with or without
5 1.1 jmmv // modification, are permitted provided that the following conditions are
6 1.1 jmmv // met:
7 1.1 jmmv //
8 1.1 jmmv // * Redistributions of source code must retain the above copyright
9 1.1 jmmv // notice, this list of conditions and the following disclaimer.
10 1.1 jmmv // * Redistributions in binary form must reproduce the above copyright
11 1.1 jmmv // notice, this list of conditions and the following disclaimer in the
12 1.1 jmmv // documentation and/or other materials provided with the distribution.
13 1.1 jmmv // * Neither the name of Google Inc. nor the names of its contributors
14 1.1 jmmv // may be used to endorse or promote products derived from this software
15 1.1 jmmv // without specific prior written permission.
16 1.1 jmmv //
17 1.1 jmmv // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18 1.1 jmmv // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19 1.1 jmmv // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20 1.1 jmmv // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21 1.1 jmmv // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22 1.1 jmmv // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23 1.1 jmmv // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 1.1 jmmv // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 1.1 jmmv // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 1.1 jmmv // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27 1.1 jmmv // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 1.1 jmmv
29 1.1 jmmv #include "cli/cmd_about.hpp"
30 1.1 jmmv
31 1.1 jmmv #include <cstdlib>
32 1.1 jmmv #include <fstream>
33 1.1 jmmv #include <utility>
34 1.1 jmmv #include <vector>
35 1.1 jmmv
36 1.1 jmmv #include "cli/common.ipp"
37 1.1 jmmv #include "utils/cmdline/exceptions.hpp"
38 1.1 jmmv #include "utils/cmdline/parser.ipp"
39 1.1 jmmv #include "utils/cmdline/ui.hpp"
40 1.1 jmmv #include "utils/defs.hpp"
41 1.1 jmmv #include "utils/env.hpp"
42 1.1 jmmv #include "utils/format/macros.hpp"
43 1.1 jmmv #include "utils/fs/path.hpp"
44 1.1 jmmv #include "utils/sanity.hpp"
45 1.1 jmmv
46 1.1 jmmv #if defined(HAVE_CONFIG_H)
47 1.1 jmmv # include "config.h"
48 1.1 jmmv #endif
49 1.1 jmmv
50 1.1 jmmv namespace cmdline = utils::cmdline;
51 1.1 jmmv namespace config = utils::config;
52 1.1 jmmv namespace fs = utils::fs;
53 1.1 jmmv
54 1.1 jmmv using cli::cmd_about;
55 1.1 jmmv
56 1.1 jmmv
57 1.1 jmmv namespace {
58 1.1 jmmv
59 1.1 jmmv
60 1.1 jmmv /// Print the contents of a document.
61 1.1 jmmv ///
62 1.1 jmmv /// If the file cannot be opened for whatever reason, an error message is
63 1.1 jmmv /// printed to the output of the program instead of the contents of the file.
64 1.1 jmmv ///
65 1.1 jmmv /// \param ui Object to interact with the I/O of the program.
66 1.1 jmmv /// \param file The file to print.
67 1.1 jmmv ///
68 1.1 jmmv /// \return True if the file was printed, false otherwise.
69 1.1 jmmv static bool
70 1.1 jmmv cat_file(cmdline::ui* ui, const fs::path& file)
71 1.1 jmmv {
72 1.1 jmmv std::ifstream input(file.c_str());
73 1.1 jmmv if (!input) {
74 1.1 jmmv ui->err(F("Failed to open %s") % file);
75 1.1 jmmv return false;
76 1.1 jmmv }
77 1.1 jmmv
78 1.1 jmmv std::string line;
79 1.1 jmmv while (std::getline(input, line).good())
80 1.1 jmmv ui->out(line);
81 1.1 jmmv input.close();
82 1.1 jmmv return true;
83 1.1 jmmv }
84 1.1 jmmv
85 1.1 jmmv
86 1.1 jmmv } // anonymous namespace
87 1.1 jmmv
88 1.1 jmmv
89 1.1 jmmv /// Default constructor for cmd_about.
90 1.1 jmmv cmd_about::cmd_about(void) : cli_command(
91 1.1 jmmv "about", "[authors|license|version]", 0, 1,
92 1.1 jmmv "Shows general program information")
93 1.1 jmmv {
94 1.1 jmmv }
95 1.1 jmmv
96 1.1 jmmv
97 1.1 jmmv /// Entry point for the "about" subcommand.
98 1.1 jmmv ///
99 1.1 jmmv /// \param ui Object to interact with the I/O of the program.
100 1.1 jmmv /// \param cmdline Representation of the command line to the subcommand.
101 1.1 jmmv /// \param unused_user_config The runtime configuration of the program.
102 1.1 jmmv ///
103 1.1 jmmv /// \return 0 if everything is OK, 1 if any of the necessary documents cannot be
104 1.1 jmmv /// opened.
105 1.1 jmmv int
106 1.1 jmmv cmd_about::run(cmdline::ui* ui, const cmdline::parsed_cmdline& cmdline,
107 1.1 jmmv const config::tree& UTILS_UNUSED_PARAM(user_config))
108 1.1 jmmv {
109 1.1 jmmv const fs::path docdir(utils::getenv_with_default(
110 1.1 jmmv "KYUA_DOCDIR", KYUA_DOCDIR));
111 1.1 jmmv
112 1.1 jmmv bool success = true;
113 1.1 jmmv
114 1.1 jmmv if (cmdline.arguments().empty()) {
115 1.1 jmmv ui->out(PACKAGE " (" PACKAGE_NAME ") " PACKAGE_VERSION);
116 1.1 jmmv ui->out("");
117 1.1 jmmv ui->out("License terms:");
118 1.1 jmmv ui->out("");
119 1.1 jmmv success &= cat_file(ui, docdir / "COPYING");
120 1.1 jmmv ui->out("");
121 1.1 jmmv ui->out("Brought to you by:");
122 1.1 jmmv ui->out("");
123 1.1 jmmv success &= cat_file(ui, docdir / "AUTHORS");
124 1.1 jmmv ui->out("");
125 1.1 jmmv ui->out(F("Homepage: %s") % PACKAGE_URL);
126 1.1 jmmv } else {
127 1.1 jmmv const std::string& topic = cmdline.arguments()[0];
128 1.1 jmmv
129 1.1 jmmv if (topic == "authors") {
130 1.1 jmmv success &= cat_file(ui, docdir / "AUTHORS");
131 1.1 jmmv } else if (topic == "license") {
132 1.1 jmmv success &= cat_file(ui, docdir / "COPYING");
133 1.1 jmmv } else if (topic == "version") {
134 1.1 jmmv ui->out(PACKAGE " (" PACKAGE_NAME ") " PACKAGE_VERSION);
135 1.1 jmmv } else {
136 1.1 jmmv throw cmdline::usage_error(F("Invalid about topic '%s'") % topic);
137 1.1 jmmv }
138 1.1 jmmv }
139 1.1 jmmv
140 1.1 jmmv return success ? EXIT_SUCCESS : EXIT_FAILURE;
141 1.1 jmmv }
142