2010-07-07 19:55:12 +02:00
|
|
|
// stringdata.h
|
|
|
|
|
|
|
|
/* Copyright 2010 10gen Inc.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2010-07-18 21:04:01 +02:00
|
|
|
#ifndef BSON_STRINDATA_HEADER
|
|
|
|
#define BSON_STRINDATA_HEADER
|
2010-07-07 19:55:12 +02:00
|
|
|
|
|
|
|
#include <string>
|
|
|
|
#include <cstring>
|
|
|
|
|
|
|
|
namespace mongo {
|
|
|
|
|
|
|
|
using std::string;
|
|
|
|
|
2010-09-07 18:50:13 +02:00
|
|
|
// A StringData object wraps a 'const string&' or a 'const char*' without
|
|
|
|
// copying its contents. The most common usage is as a function argument that
|
|
|
|
// takes any of the two forms of strings above. Fundamentally, this class tries
|
|
|
|
// go around the fact that string literals in C++ are char[N]'s.
|
|
|
|
//
|
|
|
|
// Note that the object StringData wraps around must be alive while the StringDAta
|
|
|
|
// is.
|
|
|
|
|
2010-07-18 21:04:01 +02:00
|
|
|
class StringData {
|
|
|
|
public:
|
2010-09-07 18:50:13 +02:00
|
|
|
// Construct a StringData explicilty, for the case where the lenght of
|
|
|
|
// string is not known. 'c' must be a pointer to a null-terminated string.
|
2010-07-07 19:55:12 +02:00
|
|
|
StringData( const char* c )
|
2010-07-18 21:04:01 +02:00
|
|
|
: _data(c), _size((unsigned) strlen(c)) {}
|
2010-07-07 19:55:12 +02:00
|
|
|
|
2010-09-07 18:50:13 +02:00
|
|
|
// Construct a StringData explicitly, for the case where the length of the string
|
|
|
|
// is already known. 'c' must be a pointer to a null-terminated string, and strlenOfc
|
|
|
|
// must be the length that std::strlen(c) would return, a.k.a the index of the
|
|
|
|
// terminator in c.
|
|
|
|
StringData( const char* c, size_t strlenOfc )
|
|
|
|
: _data(c), _size((unsigned) strlenOfc) {}
|
|
|
|
|
|
|
|
// Construct a StringData explicitly, for the case of a std::string.
|
2010-07-07 19:55:12 +02:00
|
|
|
StringData( const string& s )
|
2010-07-18 21:04:01 +02:00
|
|
|
: _data(s.c_str()), _size((unsigned) s.size()) {}
|
2010-07-07 19:55:12 +02:00
|
|
|
|
2010-09-07 18:50:13 +02:00
|
|
|
// Construct a StringData explicitly, for the case of a literal whose size is
|
|
|
|
// known at compile time.
|
2010-07-07 20:53:12 +02:00
|
|
|
struct LiteralTag {};
|
2010-07-07 19:55:12 +02:00
|
|
|
template<size_t N>
|
2010-07-07 20:53:12 +02:00
|
|
|
StringData( const char (&val)[N], LiteralTag )
|
2010-07-18 21:04:01 +02:00
|
|
|
: _data(&val[0]), _size(N-1) {}
|
|
|
|
|
2010-09-07 18:50:13 +02:00
|
|
|
// accessors
|
2010-07-27 18:56:54 +02:00
|
|
|
|
2010-07-18 21:04:01 +02:00
|
|
|
const char* const data() const { return _data; }
|
|
|
|
const unsigned size() const { return _size; }
|
2010-07-07 19:55:12 +02:00
|
|
|
|
2010-07-18 21:04:01 +02:00
|
|
|
private:
|
2010-09-07 18:50:13 +02:00
|
|
|
// There are two assumptions we use bellow.
|
2010-07-18 21:04:01 +02:00
|
|
|
// '_data' *always* finishes with a null terminator
|
|
|
|
// 'size' does *not* account for the null terminator
|
2010-09-07 18:50:13 +02:00
|
|
|
// These assumptions may make it easier to minimize changes to existing code.
|
2010-07-18 21:04:01 +02:00
|
|
|
const char* const _data;
|
|
|
|
const unsigned _size;
|
2010-07-18 17:21:48 +02:00
|
|
|
};
|
|
|
|
|
2010-07-07 19:55:12 +02:00
|
|
|
} // namespace mongo
|
|
|
|
|
2010-07-18 21:04:01 +02:00
|
|
|
#endif // BSON_STRINGDATA_HEADER
|