Mon, 03 Mar 2014 17:02:38 +0200
- reserved 'constexpr' as a keyword because I know I will need it someday
88 | 1 | /* |
2 | Copyright 2012-2014 Santeri Piippo | |
3 | All rights reserved. | |
4 | ||
5 | Redistribution and use in source and binary forms, with or without | |
6 | modification, are permitted provided that the following conditions | |
7 | are met: | |
8 | ||
9 | 1. Redistributions of source code must retain the above copyright | |
10 | notice, this list of conditions and the following disclaimer. | |
11 | 2. Redistributions in binary form must reproduce the above copyright | |
12 | notice, this list of conditions and the following disclaimer in the | |
13 | documentation and/or other materials provided with the distribution. | |
14 | 3. The name of the author may not be used to endorse or promote products | |
15 | derived from this software without specific prior written permission. | |
16 | ||
17 | THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR | |
18 | IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | |
19 | OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. | |
20 | IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, | |
21 | INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT | |
22 | NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | |
23 | DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | |
24 | THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | |
25 | (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | |
26 | THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
27 | */ | |
28 | ||
29 | #ifndef BOTC_FORMAT_H | |
30 | #define BOTC_FORMAT_H | |
31 | ||
32 | #include "String.h" | |
33 | #include "Containers.h" | |
34 | ||
35 | class FormatArgument | |
36 | { | |
37 | public: | |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
38 | FormatArgument (const String& a) : m_text (a) {} |
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
39 | FormatArgument (char a) : m_text (a) {} |
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
40 | FormatArgument (int a) : m_text (String::fromNumber (a)) {} |
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
41 | FormatArgument (long a) : m_text (String::fromNumber (a)) {} |
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
42 | FormatArgument (const char* a) : m_text (a) {} |
88 | 43 | |
44 | FormatArgument (void* a) | |
45 | { | |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
46 | m_text.sprintf ("%p", a); |
88 | 47 | } |
48 | ||
49 | FormatArgument (const void* a) | |
50 | { | |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
51 | m_text.sprintf ("%p", a); |
88 | 52 | } |
53 | ||
54 | template<class T> FormatArgument (const List<T>& list) | |
55 | { | |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
56 | if (list.isEmpty()) |
88 | 57 | { |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
58 | m_text = "{}"; |
88 | 59 | return; |
60 | } | |
61 | ||
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
62 | m_text = "{ "; |
88 | 63 | |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
64 | for (const T& a : list) |
88 | 65 | { |
66 | if (&a != &list[0]) | |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
67 | m_text += ", "; |
88 | 68 | |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
69 | m_text += FormatArgument (a).text(); |
88 | 70 | } |
71 | ||
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
72 | m_text += " }"; |
88 | 73 | } |
74 | ||
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
75 | inline const String& text() const |
88 | 76 | { |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
77 | return m_text; |
88 | 78 | } |
79 | ||
80 | private: | |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
81 | String m_text; |
88 | 82 | }; |
83 | ||
84 | #ifndef IN_IDE_PARSER | |
85 | # ifdef DEBUG | |
110
7a7a53f1d51b
- extended refactor to EToken (now TokenType)
Teemu Piippo <crimsondusk64@gmail.com>
parents:
88
diff
changeset
|
86 | # define devf(...) PrintTo (stderr, __VA_ARGS__) |
7a7a53f1d51b
- extended refactor to EToken (now TokenType)
Teemu Piippo <crimsondusk64@gmail.com>
parents:
88
diff
changeset
|
87 | # define dvalof( A ) PrintTo (stderr, "value of '%1' = %2\n", #A, A) |
88 | 88 | # else |
89 | # define devf(...) | |
90 | # define dvalof( A ) | |
91 | # endif // DEBUG | |
92 | #else | |
93 | // print something in debug builds | |
94 | void devf (void, ...); | |
95 | ||
96 | // print the value of @a | |
97 | void dvalof (void a); | |
98 | #endif // IN_IDE_PARSER | |
99 | ||
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
100 | |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
101 | /** |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
102 | * Formats the given string with the given args. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
103 | * |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
104 | * @param fmtstr Formatter string to process. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
105 | * @param args Args to format with the string. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
106 | * @see format() |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
107 | */ |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
108 | String formatArgs (const String& fmtstr, const std::vector<String>& args); |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
109 | |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
110 | /** |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
111 | * Expands the given arguments into a vector of strings. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
112 | * |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
113 | * @param data Where to insert the strings. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
114 | * @param arg First argument to process |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
115 | * @param rest... Rest of the arguments. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
116 | */ |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
117 | template<typename T, typename... RestTypes> |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
118 | void expandFormatArguments (std::vector<String>& data, const T& arg, const RestTypes& ... rest) |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
119 | { |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
120 | data.push_back (FormatArgument (arg).text()); |
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
121 | expandFormatArguments (data, rest...); |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
122 | } |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
123 | |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
124 | /** |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
125 | * This is an overload of @c ExpandFormatArguments for end-of-args support. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
126 | */ |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
127 | static void expandFormatArguments (std::vector<String>& data) __attribute__ ( (unused)); |
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
128 | static void expandFormatArguments (std::vector<String>& data) |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
129 | { |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
130 | (void) data; |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
131 | } |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
132 | |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
133 | /** |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
134 | * Formats the given formatter string and args and returns the string. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
135 | * This is essentially a modernized sprintf. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
136 | * |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
137 | * Args in the format string take the form %n where n is a digit. The argument |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
138 | * will be expanded to the nth argument passed. This is essentially Qt's |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
139 | * QString::arg() syntax. Note: %0 is invalid. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
140 | * |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
141 | * Arguments can be passed a modifier which takes the form of a character |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
142 | * just before the digit. Currently supported modifiers are s, d and x. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
143 | * |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
144 | * - s: The argument will expand into "s" if it would've not expanded into "1" |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
145 | * otherwise. If it would have expanded into "1" it will expand into an |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
146 | * empty string. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
147 | * |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
148 | * - d: The argument expands into the numeric form of the first character of |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
149 | * its previous expansion. Use this to get numeric forms of @c char |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
150 | * arguments. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
151 | * |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
152 | * - x: The numeric argument will be represented in hexadecimal notation. This |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
153 | * will work if the argument is a string representing a number. If the |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
154 | * argument did not expand into a number in the first place, 0 is used |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
155 | * (and 0x0 is printed). |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
156 | * |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
157 | * @param fmtstr Formatter string to process |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
158 | * @param raw_args Arguments for the formatter string. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
159 | * @return the formatted string. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
160 | * @see Print |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
161 | * @see PrintTo |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
162 | */ |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
163 | template<typename... argtypes> |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
164 | String format (const String& fmtstr, const argtypes&... raw_args) |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
165 | { |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
166 | std::vector<String> args; |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
167 | expandFormatArguments (args, raw_args...); |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
168 | assert (args.size() == sizeof... (raw_args)); |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
169 | return formatArgs (fmtstr, args); |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
170 | } |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
171 | |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
172 | /** |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
173 | * This is an overload of @c format where no arguments are supplied. |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
174 | * @return the formatter string as-is. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
175 | */ |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
176 | static String format (const String& fmtstr) __attribute__ ( (unused)); |
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
177 | static String format (const String& fmtstr) |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
178 | { |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
179 | return fmtstr; |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
180 | } |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
181 | |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
182 | /** |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
183 | * Processes the given formatter string using @c format and prints it to the |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
184 | * specified file pointer. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
185 | * |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
186 | * @param fp File pointer to print the formatted string to |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
187 | * @param fmtstr Formatter string for @c format |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
188 | * @param args Arguments for @c fmtstr |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
189 | */ |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
190 | template<typename... argtypes> |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
191 | void printTo (FILE* fp, const String& fmtstr, const argtypes&... args) |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
192 | { |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
193 | fprintf (fp, "%s", format (fmtstr, args...).c_str()); |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
194 | } |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
195 | |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
196 | /** |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
197 | * Processes the given formatter string using @c format and prints the result to |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
198 | * @c stdout. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
199 | * |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
200 | * @param fmtstr Formatter string for @c format |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
201 | * @param args Arguments for @c fmtstr |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
202 | */ |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
203 | template<typename... argtypes> |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
204 | void print (const String& fmtstr, const argtypes&... args) |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
205 | { |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
206 | printTo (stdout, fmtstr, args...); |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
207 | } |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
208 | |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
209 | /** |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
210 | * Throws an std::runtime_error with the processed formatted string. The program |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
211 | * execution terminates after a call to this function as the exception is first |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
212 | * caught in @c main which prints the error to stderr and then exits. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
213 | * |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
214 | * @param fmtstr The formatter string of the error. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
215 | * @param args The args to the formatter string. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
216 | * @see Format |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
217 | */ |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
218 | template<typename... argtypes> |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
219 | void error (const String& fmtstr, const argtypes&... args) |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
220 | { |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
221 | error (format (fmtstr, args...)); |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
222 | } |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
223 | |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
224 | /** |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
225 | * An overload of @c Error with no string formatting in between. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
226 | * |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
227 | * @param msg The error message. |
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
228 | */ |
115
9be16e1c1e44
- reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents:
113
diff
changeset
|
229 | void error (String msg); |
113
4d4c43eca4d7
- now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents:
110
diff
changeset
|
230 | |
88 | 231 | #endif // BOTC_FORMAT_H |