blob: 8d611992c444c749f46edd6fc312918401cd2b0c (
plain)
| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
 | // Scintilla source code edit control
/** @file UniqueString.h
 ** Define UniqueString, a unique_ptr based string type for storage in containers
 ** and an allocator for UniqueString.
 ** Define UniqueStringSet which holds a set of strings, used to avoid holding many copies
 ** of font names.
 **/
// Copyright 2017 by Neil Hodgson <neilh@scintilla.org>
// The License.txt file describes the conditions under which this software may be distributed.
#ifndef UNIQUESTRING_H
#define UNIQUESTRING_H
namespace Scintilla::Internal {
constexpr bool IsNullOrEmpty(const char *text) noexcept {
	return text == nullptr || *text == '\0';
}
using UniqueString = std::unique_ptr<const char[]>;
/// Equivalent to strdup but produces a std::unique_ptr<const char[]> allocation to go
/// into collections.
UniqueString UniqueStringCopy(const char *text);
// A set of strings that always returns the same pointer for each string.
class UniqueStringSet {
private:
	std::vector<UniqueString> strings;
public:
	UniqueStringSet();
	// UniqueStringSet objects can not be copied.
	UniqueStringSet(const UniqueStringSet &) = delete;
	UniqueStringSet &operator=(const UniqueStringSet &) = delete;
	// UniqueStringSet objects can be moved.
	UniqueStringSet(UniqueStringSet &&) = default;
	UniqueStringSet &operator=(UniqueStringSet &&) = default;
	~UniqueStringSet() noexcept;
	void Clear() noexcept;
	const char *Save(const char *text);
};
}
#endif
 |