annotate win64-msvc/include/capnp/blob.h @ 74:2f2b27544483

Rebuild win32 Opus using mingw 5 rather than 7 to avoid runtime incompatibility
author Chris Cannam
date Wed, 30 Jan 2019 10:30:56 +0000
parents 0f2d93caa50c
children
rev   line source
Chris@63 1 // Copyright (c) 2013-2014 Sandstorm Development Group, Inc. and contributors
Chris@63 2 // Licensed under the MIT License:
Chris@63 3 //
Chris@63 4 // Permission is hereby granted, free of charge, to any person obtaining a copy
Chris@63 5 // of this software and associated documentation files (the "Software"), to deal
Chris@63 6 // in the Software without restriction, including without limitation the rights
Chris@63 7 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
Chris@63 8 // copies of the Software, and to permit persons to whom the Software is
Chris@63 9 // furnished to do so, subject to the following conditions:
Chris@63 10 //
Chris@63 11 // The above copyright notice and this permission notice shall be included in
Chris@63 12 // all copies or substantial portions of the Software.
Chris@63 13 //
Chris@63 14 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
Chris@63 15 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
Chris@63 16 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
Chris@63 17 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
Chris@63 18 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
Chris@63 19 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
Chris@63 20 // THE SOFTWARE.
Chris@63 21
Chris@63 22 #ifndef CAPNP_BLOB_H_
Chris@63 23 #define CAPNP_BLOB_H_
Chris@63 24
Chris@63 25 #if defined(__GNUC__) && !defined(CAPNP_HEADER_WARNINGS)
Chris@63 26 #pragma GCC system_header
Chris@63 27 #endif
Chris@63 28
Chris@63 29 #include <kj/common.h>
Chris@63 30 #include <kj/string.h>
Chris@63 31 #include "common.h"
Chris@63 32 #include <string.h>
Chris@63 33
Chris@63 34 namespace capnp {
Chris@63 35
Chris@63 36 struct Data {
Chris@63 37 Data() = delete;
Chris@63 38 class Reader;
Chris@63 39 class Builder;
Chris@63 40 class Pipeline {};
Chris@63 41 };
Chris@63 42
Chris@63 43 struct Text {
Chris@63 44 Text() = delete;
Chris@63 45 class Reader;
Chris@63 46 class Builder;
Chris@63 47 class Pipeline {};
Chris@63 48 };
Chris@63 49
Chris@63 50 class Data::Reader: public kj::ArrayPtr<const byte> {
Chris@63 51 // Points to a blob of bytes. The usual Reader rules apply -- Data::Reader behaves like a simple
Chris@63 52 // pointer which does not own its target, can be passed by value, etc.
Chris@63 53
Chris@63 54 public:
Chris@63 55 typedef Data Reads;
Chris@63 56
Chris@63 57 Reader() = default;
Chris@63 58 inline Reader(decltype(nullptr)): ArrayPtr<const byte>(nullptr) {}
Chris@63 59 inline Reader(const byte* value, size_t size): ArrayPtr<const byte>(value, size) {}
Chris@63 60 inline Reader(const kj::Array<const byte>& value): ArrayPtr<const byte>(value) {}
Chris@63 61 inline Reader(const ArrayPtr<const byte>& value): ArrayPtr<const byte>(value) {}
Chris@63 62 inline Reader(const kj::Array<byte>& value): ArrayPtr<const byte>(value) {}
Chris@63 63 inline Reader(const ArrayPtr<byte>& value): ArrayPtr<const byte>(value) {}
Chris@63 64 };
Chris@63 65
Chris@63 66 class Text::Reader: public kj::StringPtr {
Chris@63 67 // Like Data::Reader, but points at NUL-terminated UTF-8 text. The NUL terminator is not counted
Chris@63 68 // in the size but must be present immediately after the last byte.
Chris@63 69 //
Chris@63 70 // Text::Reader's interface contract is that its data MUST be NUL-terminated. The producer of
Chris@63 71 // the Text::Reader must guarantee this, so that the consumer need not check. The data SHOULD
Chris@63 72 // also be valid UTF-8, but this is NOT guaranteed -- the consumer must verify if it cares.
Chris@63 73
Chris@63 74 public:
Chris@63 75 typedef Text Reads;
Chris@63 76
Chris@63 77 Reader() = default;
Chris@63 78 inline Reader(decltype(nullptr)): StringPtr(nullptr) {}
Chris@63 79 inline Reader(const char* value): StringPtr(value) {}
Chris@63 80 inline Reader(const char* value, size_t size): StringPtr(value, size) {}
Chris@63 81 inline Reader(const kj::String& value): StringPtr(value) {}
Chris@63 82 inline Reader(const StringPtr& value): StringPtr(value) {}
Chris@63 83
Chris@63 84 #if KJ_COMPILER_SUPPORTS_STL_STRING_INTEROP
Chris@63 85 template <typename T, typename = decltype(kj::instance<T>().c_str())>
Chris@63 86 inline Reader(const T& t): StringPtr(t) {}
Chris@63 87 // Allow implicit conversion from any class that has a c_str() method (namely, std::string).
Chris@63 88 // We use a template trick to detect std::string in order to avoid including the header for
Chris@63 89 // those who don't want it.
Chris@63 90 #endif
Chris@63 91 };
Chris@63 92
Chris@63 93 class Data::Builder: public kj::ArrayPtr<byte> {
Chris@63 94 // Like Data::Reader except the pointers aren't const.
Chris@63 95
Chris@63 96 public:
Chris@63 97 typedef Data Builds;
Chris@63 98
Chris@63 99 Builder() = default;
Chris@63 100 inline Builder(decltype(nullptr)): ArrayPtr<byte>(nullptr) {}
Chris@63 101 inline Builder(byte* value, size_t size): ArrayPtr<byte>(value, size) {}
Chris@63 102 inline Builder(kj::Array<byte>& value): ArrayPtr<byte>(value) {}
Chris@63 103 inline Builder(ArrayPtr<byte> value): ArrayPtr<byte>(value) {}
Chris@63 104
Chris@63 105 inline Data::Reader asReader() const { return Data::Reader(*this); }
Chris@63 106 inline operator Reader() const { return asReader(); }
Chris@63 107 };
Chris@63 108
Chris@63 109 class Text::Builder: public kj::DisallowConstCopy {
Chris@63 110 // Basically identical to kj::StringPtr, except that the contents are non-const.
Chris@63 111
Chris@63 112 public:
Chris@63 113 inline Builder(): content(nulstr, 1) {}
Chris@63 114 inline Builder(decltype(nullptr)): content(nulstr, 1) {}
Chris@63 115 inline Builder(char* value): content(value, strlen(value) + 1) {}
Chris@63 116 inline Builder(char* value, size_t size): content(value, size + 1) {
Chris@63 117 KJ_IREQUIRE(value[size] == '\0', "StringPtr must be NUL-terminated.");
Chris@63 118 }
Chris@63 119
Chris@63 120 inline Reader asReader() const { return Reader(content.begin(), content.size() - 1); }
Chris@63 121 inline operator Reader() const { return asReader(); }
Chris@63 122
Chris@63 123 inline operator kj::ArrayPtr<char>();
Chris@63 124 inline kj::ArrayPtr<char> asArray();
Chris@63 125 inline operator kj::ArrayPtr<const char>() const;
Chris@63 126 inline kj::ArrayPtr<const char> asArray() const;
Chris@63 127 inline kj::ArrayPtr<byte> asBytes() { return asArray().asBytes(); }
Chris@63 128 inline kj::ArrayPtr<const byte> asBytes() const { return asArray().asBytes(); }
Chris@63 129 // Result does not include NUL terminator.
Chris@63 130
Chris@63 131 inline operator kj::StringPtr() const;
Chris@63 132 inline kj::StringPtr asString() const;
Chris@63 133
Chris@63 134 inline const char* cStr() const { return content.begin(); }
Chris@63 135 // Returns NUL-terminated string.
Chris@63 136
Chris@63 137 inline size_t size() const { return content.size() - 1; }
Chris@63 138 // Result does not include NUL terminator.
Chris@63 139
Chris@63 140 inline char operator[](size_t index) const { return content[index]; }
Chris@63 141 inline char& operator[](size_t index) { return content[index]; }
Chris@63 142
Chris@63 143 inline char* begin() { return content.begin(); }
Chris@63 144 inline char* end() { return content.end() - 1; }
Chris@63 145 inline const char* begin() const { return content.begin(); }
Chris@63 146 inline const char* end() const { return content.end() - 1; }
Chris@63 147
Chris@63 148 inline bool operator==(decltype(nullptr)) const { return content.size() <= 1; }
Chris@63 149 inline bool operator!=(decltype(nullptr)) const { return content.size() > 1; }
Chris@63 150
Chris@63 151 inline bool operator==(Builder other) const { return asString() == other.asString(); }
Chris@63 152 inline bool operator!=(Builder other) const { return asString() != other.asString(); }
Chris@63 153 inline bool operator< (Builder other) const { return asString() < other.asString(); }
Chris@63 154 inline bool operator> (Builder other) const { return asString() > other.asString(); }
Chris@63 155 inline bool operator<=(Builder other) const { return asString() <= other.asString(); }
Chris@63 156 inline bool operator>=(Builder other) const { return asString() >= other.asString(); }
Chris@63 157
Chris@63 158 inline kj::StringPtr slice(size_t start) const;
Chris@63 159 inline kj::ArrayPtr<const char> slice(size_t start, size_t end) const;
Chris@63 160 inline Builder slice(size_t start);
Chris@63 161 inline kj::ArrayPtr<char> slice(size_t start, size_t end);
Chris@63 162 // A string slice is only NUL-terminated if it is a suffix, so slice() has a one-parameter
Chris@63 163 // version that assumes end = size().
Chris@63 164
Chris@63 165 private:
Chris@63 166 inline explicit Builder(kj::ArrayPtr<char> content): content(content) {}
Chris@63 167
Chris@63 168 kj::ArrayPtr<char> content;
Chris@63 169
Chris@63 170 static char nulstr[1];
Chris@63 171 };
Chris@63 172
Chris@63 173 inline kj::StringPtr KJ_STRINGIFY(Text::Builder builder) {
Chris@63 174 return builder.asString();
Chris@63 175 }
Chris@63 176
Chris@63 177 inline bool operator==(const char* a, const Text::Builder& b) { return a == b.asString(); }
Chris@63 178 inline bool operator!=(const char* a, const Text::Builder& b) { return a != b.asString(); }
Chris@63 179
Chris@63 180 inline Text::Builder::operator kj::StringPtr() const {
Chris@63 181 return kj::StringPtr(content.begin(), content.size() - 1);
Chris@63 182 }
Chris@63 183
Chris@63 184 inline kj::StringPtr Text::Builder::asString() const {
Chris@63 185 return kj::StringPtr(content.begin(), content.size() - 1);
Chris@63 186 }
Chris@63 187
Chris@63 188 inline Text::Builder::operator kj::ArrayPtr<char>() {
Chris@63 189 return content.slice(0, content.size() - 1);
Chris@63 190 }
Chris@63 191
Chris@63 192 inline kj::ArrayPtr<char> Text::Builder::asArray() {
Chris@63 193 return content.slice(0, content.size() - 1);
Chris@63 194 }
Chris@63 195
Chris@63 196 inline Text::Builder::operator kj::ArrayPtr<const char>() const {
Chris@63 197 return content.slice(0, content.size() - 1);
Chris@63 198 }
Chris@63 199
Chris@63 200 inline kj::ArrayPtr<const char> Text::Builder::asArray() const {
Chris@63 201 return content.slice(0, content.size() - 1);
Chris@63 202 }
Chris@63 203
Chris@63 204 inline kj::StringPtr Text::Builder::slice(size_t start) const {
Chris@63 205 return asReader().slice(start);
Chris@63 206 }
Chris@63 207 inline kj::ArrayPtr<const char> Text::Builder::slice(size_t start, size_t end) const {
Chris@63 208 return content.slice(start, end);
Chris@63 209 }
Chris@63 210
Chris@63 211 inline Text::Builder Text::Builder::slice(size_t start) {
Chris@63 212 return Text::Builder(content.slice(start, content.size()));
Chris@63 213 }
Chris@63 214 inline kj::ArrayPtr<char> Text::Builder::slice(size_t start, size_t end) {
Chris@63 215 return content.slice(start, end);
Chris@63 216 }
Chris@63 217
Chris@63 218 } // namespace capnp
Chris@63 219
Chris@63 220 #endif // CAPNP_BLOB_H_