Gamedev Framework (gf)  0.3.0
A C++11 framework for 2D games
StringRef.h
1 /*
2  * Gamedev Framework (gf)
3  * Copyright (C) 2016 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_REF_H
22 #define GF_STRING_REF_H
23 
24 #include <cstring>
25 #include <string>
26 
27 namespace gf {
28 #ifndef DOXYGEN_SHOULD_SKIP_THIS
29 inline namespace v1 {
30 #endif
31 
32  /**
33  * @ingroup core
34  * @brief A constant reference to a string and its size
35  *
36  * This class stores a pointer to a string and its size. It can be built
37  * from various inputs: `std::string`, C string.
38  *
39  * @sa ArrayRef
40  */
41  class StringRef {
42  public:
43  /**
44  * @brief Default constructor
45  *
46  * Data is `nullptr` and size is 0.
47  */
48  constexpr StringRef()
49  : m_data(nullptr)
50  , m_size(0)
51  {
52 
53  }
54 
55  /**
56  * @brief Constructor from a pointer and a size
57  *
58  * @param str A pointer to a string
59  * @param size The size of the string
60  */
61  constexpr StringRef(const char *str, std::size_t size)
62  : m_data(str)
63  , m_size(size)
64  {
65 
66  }
67 
68  /**
69  * @brief Constructor from a null-terminated string
70  *
71  * The size is computed with `std::strlen`.
72  *
73  * @param str A null-terminated string
74  */
75  StringRef(const char *str)
76  : m_data(str)
77  , m_size(std::strlen(str))
78  {
79 
80  }
81 
82  /**
83  * @brief Constructor from a `std::string`
84  *
85  * @param str A C++ string
86  */
87  StringRef(const std::string& str)
88  : m_data(str.data())
89  , m_size(str.size())
90  {
91 
92  }
93 
94  /**
95  * @brief Get a pointer to the string
96  *
97  * @returns A pointer to the beginning of the string
98  */
99  constexpr const char *getData() const {
100  return m_data;
101  }
102 
103  /**
104  * @brief Get the size of the string
105  *
106  * @returns The size of the string
107  */
108  constexpr std::size_t getSize() const {
109  return m_size;
110  }
111 
112  private:
113  const char *m_data;
114  std::size_t m_size;
115  };
116 
117 
118 #ifndef DOXYGEN_SHOULD_SKIP_THIS
119 }
120 #endif
121 }
122 
123 #endif // GF_STRING_REF_H
constexpr StringRef()
Default constructor.
Definition: StringRef.h:48
StringRef(const std::string &str)
Constructor from a std::string
Definition: StringRef.h:87
constexpr std::size_t getSize() const
Get the size of the string.
Definition: StringRef.h:108
Definition: Action.h:34
A constant reference to a string and its size.
Definition: StringRef.h:41
constexpr const char * getData() const
Get a pointer to the string.
Definition: StringRef.h:99
StringRef(const char *str)
Constructor from a null-terminated string.
Definition: StringRef.h:75
constexpr StringRef(const char *str, std::size_t size)
Constructor from a pointer and a size.
Definition: StringRef.h:61