blob: b365b6cf53a6601828f92bb80c2ae0be38f1afed (
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
#ifndef SLANG_STRING_UTIL_H
#define SLANG_STRING_UTIL_H
#include "slang-string.h"
#include "list.h"
#include <stdarg.h>
#include "../../slang-com-helper.h"
#include "../../slang-com-ptr.h"
namespace Slang {
/** A blob that uses a `String` for its storage.
*/
class StringBlob : public ISlangBlob, public RefObject
{
public:
// ISlangUnknown
SLANG_REF_OBJECT_IUNKNOWN_ALL
// ISlangBlob
SLANG_NO_THROW void const* SLANG_MCALL getBufferPointer() SLANG_OVERRIDE { return m_string.Buffer(); }
SLANG_NO_THROW size_t SLANG_MCALL getBufferSize() SLANG_OVERRIDE { return m_string.Length(); }
/// Get the contained string
SLANG_FORCE_INLINE const String& getString() const { return m_string; }
explicit StringBlob(String const& string)
: m_string(string)
{}
protected:
ISlangUnknown* getInterface(const Guid& guid);
String m_string;
};
struct StringUtil
{
/// Split in, by specified splitChar into slices out
/// Slices contents will directly address into in, so contents will only stay valid as long as in does.
static void split(const UnownedStringSlice& in, char splitChar, List<UnownedStringSlice>& slicesOut);
/// Appends formatted string with args into buf
static void append(const char* format, va_list args, StringBuilder& buf);
/// Appends the formatted string with specified trailing args
static void appendFormat(StringBuilder& buf, const char* format, ...);
/// Create a string from the format string applying args (like sprintf)
static String makeStringWithFormat(const char* format, ...);
/// Given a string held in a blob, returns as a String
/// Returns an empty string if blob is nullptr
static String getString(ISlangBlob* blob);
/// Create a blob from a string
static ComPtr<ISlangBlob> createStringBlob(const String& string);
};
} // namespace Slang
#endif // SLANG_STRING_UTIL_H
|