// Generated by gmmproc 2.58.0 -- DO NOT MODIFY! #ifndef _GIOMM_DRIVE_H #define _GIOMM_DRIVE_H #include #include /* Copyright (C) 2007 The gtkmm Development Team * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library. If not, see . */ #include #include #include //#include //#include #ifndef DOXYGEN_SHOULD_SKIP_THIS typedef struct _GDriveIface GDriveIface; #endif /* DOXYGEN_SHOULD_SKIP_THIS */ #ifndef DOXYGEN_SHOULD_SKIP_THIS using GDrive = struct _GDrive; using GDriveClass = struct _GDriveClass; #endif /* DOXYGEN_SHOULD_SKIP_THIS */ #ifndef DOXYGEN_SHOULD_SKIP_THIS namespace Gio { class Drive_Class; } // namespace Gio #endif // DOXYGEN_SHOULD_SKIP_THIS namespace Gio { /** @addtogroup giommEnums giomm Enums and Flags */ /** * @var DriveStartFlags DRIVE_START_NONE * No flags set. * * @enum DriveStartFlags * * Flags used when starting a drive. * * @newin{2,22} * * @ingroup giommEnums * @par Bitwise operators: * %DriveStartFlags operator|(DriveStartFlags, DriveStartFlags)
* %DriveStartFlags operator&(DriveStartFlags, DriveStartFlags)
* %DriveStartFlags operator^(DriveStartFlags, DriveStartFlags)
* %DriveStartFlags operator~(DriveStartFlags)
* %DriveStartFlags& operator|=(DriveStartFlags&, DriveStartFlags)
* %DriveStartFlags& operator&=(DriveStartFlags&, DriveStartFlags)
* %DriveStartFlags& operator^=(DriveStartFlags&, DriveStartFlags)
*/ enum DriveStartFlags { DRIVE_START_NONE = 0x0 }; /** @ingroup giommEnums */ inline DriveStartFlags operator|(DriveStartFlags lhs, DriveStartFlags rhs) { return static_cast(static_cast(lhs) | static_cast(rhs)); } /** @ingroup giommEnums */ inline DriveStartFlags operator&(DriveStartFlags lhs, DriveStartFlags rhs) { return static_cast(static_cast(lhs) & static_cast(rhs)); } /** @ingroup giommEnums */ inline DriveStartFlags operator^(DriveStartFlags lhs, DriveStartFlags rhs) { return static_cast(static_cast(lhs) ^ static_cast(rhs)); } /** @ingroup giommEnums */ inline DriveStartFlags operator~(DriveStartFlags flags) { return static_cast(~static_cast(flags)); } /** @ingroup giommEnums */ inline DriveStartFlags& operator|=(DriveStartFlags& lhs, DriveStartFlags rhs) { return (lhs = static_cast(static_cast(lhs) | static_cast(rhs))); } /** @ingroup giommEnums */ inline DriveStartFlags& operator&=(DriveStartFlags& lhs, DriveStartFlags rhs) { return (lhs = static_cast(static_cast(lhs) & static_cast(rhs))); } /** @ingroup giommEnums */ inline DriveStartFlags& operator^=(DriveStartFlags& lhs, DriveStartFlags rhs) { return (lhs = static_cast(static_cast(lhs) ^ static_cast(rhs))); } } // namespace Gio #ifndef DOXYGEN_SHOULD_SKIP_THIS namespace Glib { template <> class Value : public Glib::Value_Flags { public: static GType value_type() G_GNUC_CONST; }; } // namespace Glib #endif /* DOXYGEN_SHOULD_SKIP_THIS */ namespace Gio { /** * @var DriveStartStopType DRIVE_START_STOP_TYPE_UNKNOWN * Unknown or drive doesn't support * start/stop. * * @var DriveStartStopType DRIVE_START_STOP_TYPE_SHUTDOWN * The stop method will physically * shut down the drive and e.g. power down the port the drive is * attached to. * * @var DriveStartStopType DRIVE_START_STOP_TYPE_NETWORK * The start/stop methods are used * for connecting/disconnect to the drive over the network. * * @var DriveStartStopType DRIVE_START_STOP_TYPE_MULTIDISK * The start/stop methods will * assemble/disassemble a virtual drive from several physical * drives. * * @var DriveStartStopType DRIVE_START_STOP_TYPE_PASSWORD * The start/stop methods will * unlock/lock the disk (for example using the ATA SECURITY * UNLOCK DEVICE command). * * @enum DriveStartStopType * * Enumeration describing how a drive can be started/stopped. * * @newin{2,22} * * @ingroup giommEnums */ enum DriveStartStopType { DRIVE_START_STOP_TYPE_UNKNOWN, DRIVE_START_STOP_TYPE_SHUTDOWN, DRIVE_START_STOP_TYPE_NETWORK, DRIVE_START_STOP_TYPE_MULTIDISK, DRIVE_START_STOP_TYPE_PASSWORD }; } // namespace Gio #ifndef DOXYGEN_SHOULD_SKIP_THIS namespace Glib { template <> class Value : public Glib::Value_Enum { public: static GType value_type() G_GNUC_CONST; }; } // namespace Glib #endif /* DOXYGEN_SHOULD_SKIP_THIS */ namespace Gio { /** Virtual File System drive management. * * This represent a piece of hardware connected to the machine. It's generally only created for removable hardware or hardware with removable media. * Gio::Drive is a container class for Gio::Volume objects that stem from the same piece of media. As such, Gio::Drive abstracts a drive with * (or without) removable media and provides operations for querying whether media is available, determing whether media change is automatically * detected and ejecting the media. * * If the Gio::Drive reports that media isn't automatically detected, one can poll for media; typically one should not do this periodically as a * poll for media operation is potententially expensive and may spin up the drive, creating noise. * * @newin{2,16} */ class Drive : public Glib::Interface { #ifndef DOXYGEN_SHOULD_SKIP_THIS public: using CppObjectType = Drive; using CppClassType = Drive_Class; using BaseObjectType = GDrive; using BaseClassType = GDriveIface; // noncopyable Drive(const Drive&) = delete; Drive& operator=(const Drive&) = delete; private: friend class Drive_Class; static CppClassType drive_class_; #endif /* DOXYGEN_SHOULD_SKIP_THIS */ protected: /** * You should derive from this class to use it. */ Drive(); #ifndef DOXYGEN_SHOULD_SKIP_THIS /** Called by constructors of derived classes. Provide the result of * the Class init() function to ensure that it is properly * initialized. * * @param interface_class The Class object for the derived type. */ explicit Drive(const Glib::Interface_Class& interface_class); public: // This is public so that C++ wrapper instances can be // created for C instances of unwrapped types. // For instance, if an unexpected C type implements the C interface. explicit Drive(GDrive* castitem); protected: #endif /* DOXYGEN_SHOULD_SKIP_THIS */ public: Drive(Drive&& src) noexcept; Drive& operator=(Drive&& src) noexcept; ~Drive() noexcept override; static void add_interface(GType gtype_implementer); /** Get the GType for this class, for use with the underlying GObject type system. */ static GType get_type() G_GNUC_CONST; #ifndef DOXYGEN_SHOULD_SKIP_THIS static GType get_base_type() G_GNUC_CONST; #endif ///Provides access to the underlying C GObject. GDrive* gobj() { return reinterpret_cast(gobject_); } ///Provides access to the underlying C GObject. const GDrive* gobj() const { return reinterpret_cast(gobject_); } private: public: /** Gets the name of @a drive. * * @return A string containing @a drive's name. The returned * string should be freed when no longer needed. */ Glib::ustring get_name() const; /** Gets the icon for @a drive. * * @return Icon for the @a drive. * Free the returned object with Glib::object_unref(). */ Glib::RefPtr get_icon(); /** Gets the icon for @a drive. * * @return Icon for the @a drive. * Free the returned object with Glib::object_unref(). */ Glib::RefPtr get_icon() const; /** Gets the icon for @a drive. * * @newin{2,34} * * @return Symbolic Icon for the @a drive. * Free the returned object with Glib::object_unref(). */ Glib::RefPtr get_symbolic_icon(); /** Gets the icon for @a drive. * * @newin{2,34} * * @return Symbolic Icon for the @a drive. * Free the returned object with Glib::object_unref(). */ Glib::RefPtr get_symbolic_icon() const; /** Check if @a drive has any mountable volumes. * * @return true if the @a drive contains volumes, false otherwise. */ bool has_volumes() const; /** Get a list of mountable volumes for @a drive. * * @return List containing any Volume objects on the given @a drive. */ Glib::ListHandle< Glib::RefPtr > get_volumes(); /** Checks if the @a drive supports removable media. * * @return true if @a drive supports removable media, false otherwise. */ bool is_media_removable() const; /** Checks if the Drive and/or its media is considered removable by the user. * See g_drive_is_media_removable(). * * @newin{2,50} * * @return true if @a drive and/or its media is considered removable, false otherwise. */ bool is_removable() const; /** Checks if the @a drive has media. Note that the OS may not be polling * the drive for media changes; see g_drive_is_media_check_automatic() * for more details. * * @return true if @a drive has media, false otherwise. */ bool has_media() const; /** Checks if @a drive is capabable of automatically detecting media changes. * * @return true if the @a drive is capabable of automatically detecting * media changes, false otherwise. */ bool is_media_check_automatic() const; /** Checks if a drive can be polled for media changes. * * @return true if the @a drive can be polled for media changes, * false otherwise. */ bool can_poll_for_media() const; /** Checks if a drive can be ejected. * * @return true if the @a drive can be ejected, false otherwise. */ bool can_eject() const; /** Ejects the drive. * @param slot A callback which will be called when the eject is completed or canceled. * @param flags Flags affecting the unmount if required for eject. * @param cancellable A cancellable object which can be used to cancel the eject. */ void eject(const SlotAsyncReady& slot, const Glib::RefPtr& cancellable, MountUnmountFlags flags = MOUNT_UNMOUNT_NONE); /** Ejects the drive. * @param slot A callback which will be called when the eject is completed. * @param flags Flags affecting the unmount if required for eject. */ void eject(const SlotAsyncReady& slot, MountUnmountFlags flags = MOUNT_UNMOUNT_NONE); void eject(const Glib::RefPtr& mount_operation, const SlotAsyncReady& slot, const Glib::RefPtr& cancellable, MountUnmountFlags flags = MOUNT_UNMOUNT_NONE); void eject(const Glib::RefPtr& mount_operation, const SlotAsyncReady& slot, MountUnmountFlags flags = MOUNT_UNMOUNT_NONE); /** Ejects the drive. * @param flags Flags affecting the unmount if required for eject. */ void eject(MountUnmountFlags flags = MOUNT_UNMOUNT_NONE); void eject(const Glib::RefPtr& mount_operation, MountUnmountFlags flags = MOUNT_UNMOUNT_NONE); // eject_finish() is deprecated in favor of eject_with_operation_finish(), and // since all of our eject() overloads are implemented by // eject_with_operation(), we implement the _finish() with // eject_with_operation_finish and ignore the deprecated one /** Finishes ejecting a drive. If any errors occurred during the operation, * @a error will be set to contain the errors and false will be returned. * * @newin{2,22} * * @param result A AsyncResult. * @return true if the drive was successfully ejected. false otherwise. * * @throws Glib::Error */ bool eject_finish(const Glib::RefPtr& result); /** Polls drive to see if media has been inserted or removed. * @param slot A callback which will be called when the poll is completed. * @param cancellable A cancellable object which can be used to cancel the operation. */ void poll_for_media(const SlotAsyncReady& slot, const Glib::RefPtr& cancellable); /** Polls drive to see if media has been inserted or removed. * @param slot A callback which will be called when the poll is completed. */ void poll_for_media(const SlotAsyncReady& slot); /** Polls drive to see if media has been inserted or removed. */ void poll_for_media(); /** Finishes an operation started with g_drive_poll_for_media() on a drive. * * @param result A AsyncResult. * @return true if the drive has been poll_for_mediaed successfully, * false otherwise. * * @throws Glib::Error */ bool poll_for_media_finish(const Glib::RefPtr& result); /** Gets the identifier of the given kind for @a drive. * * @param kind The kind of identifier to return. * @return A newly allocated string containing the * requested identfier, or nullptr if the Drive * doesn't have this kind of identifier. */ std::string get_identifier(const std::string& kind) const; /** Gets the kinds of identifiers that @a drive has. * Use g_drive_get_identifier() to obtain the identifiers * themselves. * * @return A nullptr-terminated * array of strings containing kinds of identifiers. */ Glib::StringArrayHandle enumerate_identifiers() const; /** @newin{2,22} */ void start(const Glib::RefPtr& mount_operation, const Glib::RefPtr& cancellable, const SlotAsyncReady& slot, DriveStartFlags flags = DRIVE_START_NONE); /** @newin{2,22} */ void start(const Glib::RefPtr& mount_operation, const SlotAsyncReady& slot, DriveStartFlags flags = DRIVE_START_NONE); /** Finishes starting a drive. * * @newin{2,22} * * @param result A AsyncResult. * @return true if the drive has been started successfully, * false otherwise. * * @throws Glib::Error */ bool start_finish(const Glib::RefPtr& result); /** @newin{2,22} */ bool can_start() const; /** @newin{2,22} */ bool can_start_degraded() const; /** @newin{2,22} */ void stop(const Glib::RefPtr& mount_operation, const Glib::RefPtr& cancellable, const SlotAsyncReady& slot, MountUnmountFlags flags = MOUNT_UNMOUNT_NONE); /** @newin{2,22} */ void stop(const Glib::RefPtr& mount_operation, const SlotAsyncReady& slot, MountUnmountFlags flags = MOUNT_UNMOUNT_NONE); /** Finishes stopping a drive. * * @newin{2,22} * * @param result A AsyncResult. * @return true if the drive has been stopped successfully, * false otherwise. * * @throws Glib::Error */ bool stop_finish(const Glib::RefPtr& result); /** @newin{2,22} */ bool can_stop() const; /** Gets a hint about how a drive can be started/stopped. * * @newin{2,22} * * @return A value from the DriveStartStopType enumeration. */ DriveStartStopType get_start_stop_type() const; /** Gets the sort key for @a drive, if any. * * @newin{2,32} * * @return Sorting key for @a drive or nullptr if no such key is available. */ Glib::ustring get_sort_key() const; /** @newin{2,20} * * @par Slot Prototype: * void on_my_%changed() * * Flags: Run Last * * Emitted when the drive's state has changed. */ Glib::SignalProxy< void > signal_changed(); /** @newin{2,20} * * @par Slot Prototype: * void on_my_%disconnected() * * Flags: Run Last * * This signal is emitted when the Drive have been * disconnected. If the recipient is holding references to the * object they should release them so the object can be * finalized. */ Glib::SignalProxy< void > signal_disconnected(); /** @newin{2,20} * * @par Slot Prototype: * void on_my_%eject_button() * * Flags: Run Last * * Emitted when the physical eject button (if any) of a drive has * been pressed. */ Glib::SignalProxy< void > signal_eject_button(); /** * @par Slot Prototype: * void on_my_%stop_button() * * Flags: Run Last * * Emitted when the physical stop button (if any) of a drive has * been pressed. * * @newin{2,22} */ Glib::SignalProxy< void > signal_stop_button(); //_WRAP_VFUNC(Glib::ustring get_name() const, get_name) //Careful of ref-counting: //_WRAP_VFUNC(Glib::RefPtr get_icon() const, get_icon) //_WRAP_VFUNC(bool has_volumes() const, has_volumes) public: public: //C++ methods used to invoke GTK+ virtual functions: protected: //GTK+ Virtual Functions (override these to change behaviour): //Default Signal Handlers:: }; } // namespace Gio namespace Glib { //Pre-declare this so we can use it in TypeTrait: Glib::RefPtr wrap(GDrive* object, bool take_copy); namespace Container_Helpers { /** This specialization of TypeTraits exists * because the default use of Glib::wrap(GObject*), * instead of a specific Glib::wrap(GSomeInterface*), * would not return a wrapper for an interface. */ template <> struct TypeTraits< Glib::RefPtr > { using CppType = Glib::RefPtr; using CType = GDrive*; using CTypeNonConst = GDrive*; static CType to_c_type (const CppType& item) { return Glib::unwrap (item); } static CppType to_cpp_type (const CType& item) { //Use a specific Glib::wrap() function, //because CType has the specific type (not just GObject): return Glib::wrap(item, true /* take_copy */); } static void release_c_type (CType item) { GLIBMM_DEBUG_UNREFERENCE(nullptr, item); g_object_unref(item); } }; } // Container_Helpers } // Glib namespace Glib { /** A Glib::wrap() method for this object. * * @param object The C instance. * @param take_copy False if the result should take ownership of the C instance. True if it should take a new copy or ref. * @result A C++ instance that wraps this C instance. * * @relates Gio::Drive */ Glib::RefPtr wrap(GDrive* object, bool take_copy = false); } // namespace Glib #endif /* _GIOMM_DRIVE_H */