Chromium Code Reviews| Index: mojo/common/logging.h |
| diff --git a/mojo/common/logging.h b/mojo/common/logging.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..6cb69c6fba1a96ac03574548cd19b4a948f5404e |
| --- /dev/null |
| +++ b/mojo/common/logging.h |
| @@ -0,0 +1,81 @@ |
| +// Copyright 2015 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_COMMON_LOGGING_H_ |
| +#define MOJO_COMMON_LOGGING_H_ |
| + |
| +#include <ostream> |
|
vardhan
2015/12/11 00:12:20
nit: blank line after this include
|
| +#include "mojo/public/cpp/bindings/array.h" |
| +#include "mojo/public/cpp/bindings/interface_ptr.h" |
| +#include "mojo/public/cpp/bindings/map.h" |
| + |
| +// Mojom Logging helpers. |
|
vardhan
2015/12/11 00:12:20
Probably "mojom debug string" is more clarifying;
|
| + |
| +namespace mojo { |
| + |
| +// Support output formatting of Mojo structs by value or by reference |
| +// assuming there exists an operator<< overload that accepts a const reference. |
| +template <typename T, typename = typename T::Data_> |
|
vardhan
2015/12/11 00:12:20
Hm, I was hoping you could use IsStructPtr<> in bi
|
| +auto operator<<(std::ostream& os, const T* value) -> decltype(os << *value) { |
|
vardhan
2015/12/11 00:12:20
What do you think about defining:
template <Mojom
|
| + return value ? os << *value : os << "null"; |
| +} |
| + |
| +template <typename T> |
| +std::ostream& operator<<(std::ostream& os, const mojo::StructPtr<T>& value) { |
| + return os << value.get(); |
| +} |
| + |
| +template <typename T> |
| +std::ostream& operator<<(std::ostream& os, |
| + const mojo::InlinedStructPtr<T>& value) { |
| + return os << value.get(); |
| +} |
| + |
| +template <typename T> |
| +std::ostream& operator<<(std::ostream& os, const mojo::InterfacePtr<T>& iface) { |
| + return os << "{impl=" << iface.get() << ", bound=" << iface.is_bound() << "}"; |
| +} |
| + |
| +template <typename T> |
| +std::ostream& operator<<(std::ostream& os, const mojo::Array<T>& array) { |
| + if (array) { |
| + os << "["; |
| + bool first = true; |
| + for (auto it = array.storage().cbegin(); it != array.storage().cend(); |
| + ++it) { |
| + if (first) |
| + first = false; |
| + else |
| + os << ", "; |
| + os << *it; |
| + } |
| + os << "]"; |
| + } else { |
| + os << "null"; |
| + } |
| + return os; |
| +} |
| + |
| +template <typename Key, typename Value> |
| +std::ostream& operator<<(std::ostream& os, const mojo::Map<Key, Value>& map) { |
| + if (map) { |
| + os << "["; |
| + bool first = true; |
| + for (auto it = map.cbegin(); it != map.cend(); ++it) { |
| + if (first) |
| + first = false; |
| + else |
| + os << ", "; |
| + os << "{" << it.GetKey() << ": " << it.GetValue() << "}"; |
| + } |
| + os << "]"; |
| + } else { |
| + os << "null"; |
| + } |
| + return os; |
| +} |
| + |
| +} // namespace mojo |
| + |
| +#endif // MOJO_COMMON_LOGGING_H_ |