Gamedev Framework (gf)  0.6.0
A C++11 framework for 2D games
StringUtils.h
1 /*
2  * Gamedev Framework (gf)
3  * Copyright (C) 2016-2017 Julien Bernard
4  *
5  * This software is provided 'as-is', without any express or implied
6  * warranty. In no event will the authors be held liable for any damages
7  * arising from the use of this software.
8  *
9  * Permission is granted to anyone to use this software for any purpose,
10  * including commercial applications, and to alter it and redistribute it
11  * freely, subject to the following restrictions:
12  *
13  * 1. The origin of this software must not be misrepresented; you must not
14  * claim that you wrote the original software. If you use this software
15  * in a product, an acknowledgment in the product documentation would be
16  * appreciated but is not required.
17  * 2. Altered source versions must be plainly marked as such, and must not be
18  * misrepresented as being the original software.
19  * 3. This notice may not be removed or altered from any source distribution.
20  */
21 #ifndef GF_STRING_UTILS_H
22 #define GF_STRING_UTILS_H
23 
24 #include <cstdarg>
25 
26 #include <vector>
27 #include <string>
28 
29 #include "Portability.h"
30 #include "StringRef.h"
31 
32 namespace gf {
33 #ifndef DOXYGEN_SHOULD_SKIP_THIS
34 inline namespace v1 {
35 #endif
36 
37  /**
38  * @ingroup core
39  * @brief Create a string representation of a floating point number
40  *
41  * It is based on [Python niceNum](https://mail.python.org/pipermail/python-list/1999-October/005748.html).
42  *
43  * @param num The number to display
44  * @param precision The precision to use for display
45  * @returns A string representing the number
46  */
47  GF_API std::string niceNum(float num, float precision);
48 
49  /**
50  * @ingroup core
51  * @brief Compute a UTF-32 string from a UTF-8 string
52  *
53  * @param str A UTF-8 string
54  * @returns The corresponding UTF-32 string
55  */
56  GF_API std::u32string computeUnicodeString(StringRef str);
57 
58  /**
59  * @ingroup core
60  * @brief Format a string like printf
61  *
62  * @param fmt The [format string](http://en.cppreference.com/w/cpp/io/c/fprintf)
63  */
64  GF_API std::string formatString(const char *fmt, ...) GF_FORMAT(1, 2);
65 
66  /**
67  * @ingroup core
68  * @brief Format a string like vprintf
69  *
70  * @param fmt The [format string](http://en.cppreference.com/w/cpp/io/c/fprintf)
71  * @param ap The arguments of the format string
72  */
73  GF_API std::string formatString(const char *fmt, va_list ap);
74 
75 
76  /**
77  * @ingroup core
78  */
80 
82 
83 #ifndef DOXYGEN_SHOULD_SKIP_THIS
84 }
85 #endif
86 }
87 
88 #endif // GF_STRING_UTILS_H
std::string formatString(const char *fmt,...)
Format a string like printf.
The namespace for gf classes.
Definition: Action.h:34
std::string niceNum(float num, float precision)
Create a string representation of a floating point number.
std::vector< std::u32string > splitInWords(const std::u32string &str)
A constant reference to a string and its size.
Definition: StringRef.h:41
std::u32string computeUnicodeString(StringRef str)
Compute a UTF-32 string from a UTF-8 string.
std::vector< std::u32string > splitInParagraphs(const std::u32string &str)
#define GF_API
Definition: Portability.h:35
std::string formatString(const char *fmt, va_list ap)
Format a string like vprintf.
#define GF_FORMAT(X, Y)
Definition: Portability.h:42