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