// Copyright 2012 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef DBUS_VALUES_UTIL_H_ #define DBUS_VALUES_UTIL_H_ #include <stdint.h> #include "dbus/dbus_export.h" namespace base { class Value; class ValueView; } namespace dbus { class MessageReader; class MessageWriter; // Pops a value from |reader| as a base::Value. // Returns base::Value() if an error occurs. // Note: Integer values larger than int32_t (including uint32_t) are converted // to double. Non-string dictionary keys are converted to strings. CHROME_DBUS_EXPORT base::Value PopDataAsValue(MessageReader* reader); // Appends a basic type value to |writer|. Basic types are BOOLEAN, INTEGER, // DOUBLE, and STRING. Use this function for values that are known to be basic // types and to handle basic type members of collections that should not // have type "a{sv}" or "av". Otherwise, use AppendValueData. CHROME_DBUS_EXPORT void AppendBasicTypeValueData(MessageWriter* writer, base::ValueView value); // Appends a basic type value to |writer| as a variant. Basic types are BOOLEAN, // INTEGER, DOUBLE, and STRING. Use this function for values that are known to // be basic types and to handle basic type members of collections that should // not have type "a{sv}" or "av". Otherwise, use AppendValueDataAsVariant. CHROME_DBUS_EXPORT void AppendBasicTypeValueDataAsVariant( MessageWriter* writer, base::ValueView value); // Appends a value to |writer|. Value can be a basic type, as well as a // collection type, such as dictionary or list. Collections will be recursively // written as variant containers, i.e. dictionaries will be written with type // a{sv} and lists with type av. Any sub-dictionaries or sub-lists will also // have these types. CHROME_DBUS_EXPORT void AppendValueData(MessageWriter* writer, base::ValueView value); // Appends a value to |writer| as a variant. Value can be a basic type, as well // as a collection type, such as dictionary or list. Collections will be // recursively written as variant containers, i.e. dictionaries will be written // with type a{sv} and lists with type av. Any sub-dictionaries or sub-lists // will also have these types. CHROME_DBUS_EXPORT void AppendValueDataAsVariant(MessageWriter* writer, base::ValueView value); } // namespace dbus #endif // DBUS_VALUES_UTIL_H_