| // Copyright (c) 2012 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 DBUS_OBJECT_PATH_H_ |
| #define DBUS_OBJECT_PATH_H_ |
| |
| #include <iosfwd> |
| #include <string> |
| |
| #include "dbus/dbus_export.h" |
| |
| namespace dbus { |
| |
| // ObjectPath is a type used to distinguish D-Bus object paths from simple |
| // strings, especially since normal practice is that these should be only |
| // initialized from static constants or obtained from remote objects and no |
| // assumptions about their value made. |
| class CHROME_DBUS_EXPORT ObjectPath { |
| public: |
| // Permit initialization without a value for passing to |
| // dbus::MessageReader::PopObjectPath to fill in and from std::string |
| // objects. |
| // |
| // The compiler synthesised copy constructor and assignment operator are |
| // sufficient for our needs, as is implicit initialization of a std::string |
| // from a string constant. |
| ObjectPath() {} |
| explicit ObjectPath(const std::string& value) : value_(value) {} |
| |
| // Retrieves value as a std::string. |
| const std::string& value() const { return value_; } |
| |
| // Returns true if the value is a valid object path. |
| bool IsValid() const; |
| |
| // Permit sufficient comparison to allow an ObjectPath to be used as a |
| // key in a std::map. |
| bool operator<(const ObjectPath&) const; |
| |
| // Permit testing for equality, required for mocks to work and useful for |
| // observers. |
| bool operator==(const ObjectPath&) const; |
| bool operator!=(const ObjectPath&) const; |
| |
| private: |
| std::string value_; |
| }; |
| |
| // This is required by gtest to print a readable output on test failures. |
| CHROME_DBUS_EXPORT void PrintTo(const ObjectPath& path, std::ostream* out); |
| |
| } // namespace dbus |
| |
| #endif // DBUS_OBJECT_PATH_H_ |