src/Format.h

Wed, 26 Feb 2014 07:36:14 +0200

author
Teemu Piippo <crimsondusk64@gmail.com>
date
Wed, 26 Feb 2014 07:36:14 +0200
changeset 113
4d4c43eca4d7
parent 110
7a7a53f1d51b
child 115
9be16e1c1e44
permissions
-rw-r--r--

- now uses a variadic template formatter instead of a macro

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:
113
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
38 FormatArgument (const String& a) : mText (a) {}
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
39 FormatArgument (char a) : mText (a) {}
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
40 FormatArgument (int a) : mText (String::FromNumber (a)) {}
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
41 FormatArgument (long a) : mText (String::FromNumber (a)) {}
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
42 FormatArgument (const char* a) : mText (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 {
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
46 mText.SPrintf ("%p", a);
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 {
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
51 mText.SPrintf ("%p", a);
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 {
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
56 if (list.IsEmpty())
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
57 {
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
58 mText = "{}";
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
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
62 mText = "{ ";
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
63
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
64 for (const T & a : list)
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])
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
67 mText += ", ";
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
68
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
69 mText += FormatArgument (a).AsString();
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
70 }
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
71
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
72 mText += " }";
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
73 }
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
74
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
75 inline const String& AsString() const
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
76 {
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
77 return mText;
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:
5def6ff8b466 - reformatting
Teemu Piippo <crimsondusk64@gmail.com>
parents:
diff changeset
81 String mText;
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 */
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
108 String FormatArgs (const String& fmtstr, const std::vector<String>& args);
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>
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
118 void ExpandFormatArguments (std::vector<String>& data, const T& arg, const RestTypes& ... rest)
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
119 {
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
120 data.push_back (FormatArgument (arg).AsString());
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
121 ExpandFormatArguments (data, rest...);
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 */
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
127 static void ExpandFormatArguments (std::vector<String>& data) __attribute__ ( (unused));
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
128 static void ExpandFormatArguments (std::vector<String>& data)
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>
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
164 String Format (const String& fmtstr, const argtypes&... raw_args)
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;
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
167 ExpandFormatArguments (args, raw_args...);
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));
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
169 return FormatArgs (fmtstr, args);
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 /**
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
173 * This is an overload of @c Format where no arguments are supplied.
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 */
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
176 static String Format (const String& fmtstr) __attribute__ ( (unused));
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
177 static String Format (const String& fmtstr)
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 /**
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
183 * Processes the given formatter string using @c Format and prints it to the
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
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
187 * @param fmtstr Formatter string for @c Format
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>
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
191 void PrintTo (FILE* fp, const String& fmtstr, const argtypes&... args)
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
192 {
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
193 fprintf (fp, "%s", Format (fmtstr, args...).c_str());
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 /**
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
197 * Processes the given formatter string using @c Format and prints the result to
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 *
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
200 * @param fmtstr Formatter string for @c Format
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>
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
204 void Print (const String& fmtstr, const argtypes&... args)
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
205 {
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
206 PrintTo (stdout, fmtstr, args...);
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>
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
219 void Error (const String& fmtstr, const argtypes&... args)
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
220 {
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
221 Error (Format (fmtstr, args...));
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 */
4d4c43eca4d7 - now uses a variadic template formatter instead of a macro
Teemu Piippo <crimsondusk64@gmail.com>
parents: 110
diff changeset
229 void Error (String msg);
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