src/Format.h

Mon, 03 Mar 2014 17:02:38 +0200

author
Teemu Piippo <crimsondusk64@gmail.com>
date
Mon, 03 Mar 2014 17:02:38 +0200
changeset 117
cc1e14d55047
parent 115
9be16e1c1e44
permissions
-rw-r--r--

- reserved 'constexpr' as a keyword because I know I will need it someday

88
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
1 /*
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
2 Copyright 2012-2014 Santeri Piippo
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
3 All rights reserved.
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
4
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
5 Redistribution and use in source and binary forms, with or without
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
6 modification, are permitted provided that the following conditions
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
7 are met:
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
8
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
9 1. Redistributions of source code must retain the above copyright
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
10 notice, this list of conditions and the following disclaimer.
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
11 2. Redistributions in binary form must reproduce the above copyright
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
12 notice, this list of conditions and the following disclaimer in the
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
13 documentation and/or other materials provided with the distribution.
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
14 3. The name of the author may not be used to endorse or promote products
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
15 derived from this software without specific prior written permission.
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
16
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
17 THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
18 IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
19 OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
20 IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
21 INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
22 NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
23 DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
24 THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
25 (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
26 THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
27 */
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
28
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
29 #ifndef BOTC_FORMAT_H
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
30 #define BOTC_FORMAT_H
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
31
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
32 #include "String.h"
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
33 #include "Containers.h"
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
34
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
35 class FormatArgument
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
36 {
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
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
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
43
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
44 FormatArgument (void* a)
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
45 {
115
9be16e1c1e44 - reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents: 113
diff changeset
46 m_text.sprintf ("%p", a);
88
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
47 }
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
48
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
49 FormatArgument (const void* a)
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
50 {
115
9be16e1c1e44 - reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents: 113
diff changeset
51 m_text.sprintf ("%p", a);
88
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
52 }
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
53
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
54 template<class T> FormatArgument (const List<T>& list)
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
55 {
115
9be16e1c1e44 - reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents: 113
diff changeset
56 if (list.isEmpty())
88
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
57 {
115
9be16e1c1e44 - reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents: 113
diff changeset
58 m_text = "{}";
88
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
59 return;
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
60 }
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
61
115
9be16e1c1e44 - reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents: 113
diff changeset
62 m_text = "{ ";
88
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
63
115
9be16e1c1e44 - reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents: 113
diff changeset
64 for (const T& a : list)
88
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
65 {
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
66 if (&a != &list[0])
115
9be16e1c1e44 - reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents: 113
diff changeset
67 m_text += ", ";
88
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
68
115
9be16e1c1e44 - reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents: 113
diff changeset
69 m_text += FormatArgument (a).text();
88
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
70 }
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
71
115
9be16e1c1e44 - reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents: 113
diff changeset
72 m_text += " }";
88
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
73 }
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
74
115
9be16e1c1e44 - reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents: 113
diff changeset
75 inline const String& text() const
88
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
76 {
115
9be16e1c1e44 - reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents: 113
diff changeset
77 return m_text;
88
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
78 }
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
79
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
80 private:
115
9be16e1c1e44 - reformatting... again
Teemu Piippo <crimsondusk64@gmail.com>
parents: 113
diff changeset
81 String m_text;
88
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
82 };
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
83
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
84 #ifndef IN_IDE_PARSER
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
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
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
88 # else
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
89 # define devf(...)
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
90 # define dvalof( A )
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
91 # endif // DEBUG
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
92 #else
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
93 // print something in debug builds
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
94 void devf (void, ...);
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
95
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
96 // print the value of @a
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
97 void dvalof (void a);
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
98 #endif // IN_IDE_PARSER
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
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
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
231 #endif // BOTC_FORMAT_H

mercurial