// 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_