annotate irccdctl/alias.hpp @ 459:b347b10d24c1 release-2.1

Added tag 2.1.3 for changeset c3f46ad1ece6
author David Demelier <markand@malikania.fr>
date Fri, 28 Jul 2017 11:29:06 +0200
parents c6fbb6e0e06d
children a88796ed040a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
348
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
1 /*
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
2 * alias.hpp -- create irccdctl aliases
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
3 *
394
c6fbb6e0e06d Happy new year!
David Demelier <markand@malikania.fr>
parents: 374
diff changeset
4 * Copyright (c) 2013-2017 David Demelier <markand@malikania.fr>
348
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
5 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
6 * Permission to use, copy, modify, and/or distribute this software for any
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
7 * purpose with or without fee is hereby granted, provided that the above
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
8 * copyright notice and this permission notice appear in all copies.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
9 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
17 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
18
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
19 #ifndef IRCCD_ALIAS_HPP
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
20 #define IRCCD_ALIAS_HPP
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
21
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
22 /**
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
23 * \file alias.hpp
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
24 * \brief Create irccdctl aliases.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
25 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
26
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
27 #include <ostream>
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
28 #include <string>
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
29 #include <vector>
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
30
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
31 #include "sysconfig.hpp"
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
32
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
33 namespace irccd {
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
34
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
35 /**
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
36 * \brief Describe an alias argument.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
37 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
38 * When the user specify arguments, it can precise an applied argument or a
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
39 * placeholder that will be substituted during command line invocation.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
40 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
41 * Placeholders are placed using %n where n is an integer starting from 0.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
42 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
43 class AliasArg {
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
44 private:
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
45 std::string m_value;
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
46 bool m_isPlaceholder;
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
47
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
48 public:
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
49 /**
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
50 * Construct an argument.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
51 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
52 * \pre value must not be empty
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
53 * \param value the value
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
54 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
55 IRCCD_EXPORT AliasArg(std::string value);
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
56
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
57 /**
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
58 * Check if the argument is a placeholder.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
59 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
60 * \return true if the argument is a placeholder
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
61 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
62 inline bool isPlaceholder() const noexcept
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
63 {
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
64 return m_isPlaceholder;
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
65 }
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
66
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
67 /**
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
68 * Get the placeholder index (e.g %0 returns 0)
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
69 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
70 * \pre isPlaceholder() must return true
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
71 * \return the position
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
72 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
73 IRCCD_EXPORT unsigned index() const noexcept;
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
74
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
75 /**
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
76 * Get the real value.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
77 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
78 * \pre isPlaceholder() must return false
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
79 * \return the value
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
80 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
81 IRCCD_EXPORT const std::string &value() const noexcept;
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
82
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
83 /**
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
84 * Output the alias to the stream.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
85 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
86 * \param out the output stream
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
87 * \return out
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
88 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
89 IRCCD_EXPORT friend std::ostream &operator<<(std::ostream &out, const AliasArg &);
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
90 };
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
91
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
92 /**
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
93 * \brief Describe a user-provided alias command.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
94 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
95 * An alias command is just a command with a set of applied or placeholders
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
96 * arguments.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
97 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
98 class AliasCommand {
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
99 private:
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
100 std::string m_command;
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
101 std::vector<AliasArg> m_args;
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
102
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
103 public:
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
104 /**
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
105 * Create an alias command.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
106 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
107 * \param command the command
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
108 * \param args the arguments
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
109 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
110 inline AliasCommand(std::string command, std::vector<AliasArg> args = {}) noexcept
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
111 : m_command(std::move(command))
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
112 , m_args(std::move(args))
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
113 {
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
114 }
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
115
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
116 /**
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
117 * Get the command to execute.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
118 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
119 * \return the command name
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
120 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
121 inline const std::string &command() const noexcept
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
122 {
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
123 return m_command;
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
124 }
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
125
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
126 /**
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
127 * Get the arguments.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
128 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
129 * \return the arguments
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
130 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
131 inline const std::vector<AliasArg> &args() const noexcept
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
132 {
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
133 return m_args;
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
134 }
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
135 };
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
136
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
137 /**
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
138 * \brief A set of commands to execute with their arguments.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
139 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
140 * An alias is a composition of AliasCommand, typically, the user is able to set
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
141 * an alias that execute a list of specified commands in order they are defined.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
142 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
143 class Alias : public std::vector<AliasCommand> {
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
144 private:
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
145 std::string m_name;
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
146
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
147 public:
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
148 /**
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
149 * Create an alias.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
150 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
151 * \param name the alias name
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
152 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
153 inline Alias(std::string name) noexcept
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
154 : m_name(std::move(name))
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
155 {
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
156 }
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
157
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
158 /**
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
159 * Get the alias name.
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
160 *
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
161 * \return the name
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
162 */
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
163 inline const std::string &name() const noexcept
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
164 {
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
165 return m_name;
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
166 }
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
167 };
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
168
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
169 } // !irccd
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
170
24b1709093e7 Irccdctl: resurrect
David Demelier <markand@malikania.fr>
parents:
diff changeset
171 #endif // !IRCCD_ALIAS_HPP