// Copyright 2016 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef MOJO_PUBLIC_CPP_BINDINGS_STRING_TRAITS_STRING_PIECE_H_
#define MOJO_PUBLIC_CPP_BINDINGS_STRING_TRAITS_STRING_PIECE_H_
#include "base/strings/string_piece.h"
#include "mojo/public/cpp/bindings/string_traits.h"
namespace mojo {
template <>
struct StringTraits<base::StringPiece> {
static bool IsNull(const base::StringPiece& input) {
// base::StringPiece is always converted to non-null mojom string. We could
// have let StringPiece containing a null data pointer map to null mojom
// string, but StringPiece::empty() returns true in this case. It seems
// confusing to mix the concept of empty and null strings, especially
// because they mean different things in mojom.
return false;
}
static void SetToNull(base::StringPiece* output) {
// Convert null to an "empty" base::StringPiece.
output->set(nullptr, 0);
}
static size_t GetSize(const base::StringPiece& input) { return input.size(); }
static const char* GetData(const base::StringPiece& input) {
return input.data();
}
static bool Read(StringDataView input, base::StringPiece* output) {
output->set(input.storage(), input.size());
return true;
}
};
} // namespace mojo
#endif // MOJO_PUBLIC_CPP_BINDINGS_STRING_TRAITS_STRING_PIECE_H_