/* 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
using StartStopType = Gio::Drive::StartStopType;
namespace Gio
{
void
Drive::eject(
const SlotAsyncReady& slot, const Glib::RefPtr& cancellable, Mount::UnmountFlags flags)
{
// Create a copy of the slot.
// A pointer to it will be passed through the callback's data parameter
// and deleted in the callback.
auto slot_copy = new SlotAsyncReady(slot);
g_drive_eject_with_operation(gobj(), static_cast(flags),
nullptr, // mount_operation
Glib::unwrap(cancellable), &SignalProxy_async_callback, slot_copy);
}
void
Drive::eject(const SlotAsyncReady& slot, Mount::UnmountFlags flags)
{
// Create a copy of the slot.
// A pointer to it will be passed through the callback's data parameter
// and deleted in the callback.
auto slot_copy = new SlotAsyncReady(slot);
g_drive_eject_with_operation(gobj(), static_cast(flags),
nullptr, // mount_operation
nullptr, // cancellable
&SignalProxy_async_callback, slot_copy);
}
void
Drive::eject(const Glib::RefPtr& mount_operation, const SlotAsyncReady& slot,
const Glib::RefPtr& cancellable, Mount::UnmountFlags flags)
{
// Create a copy of the slot.
// A pointer to it will be passed through the callback's data parameter
// and deleted in the callback.
auto slot_copy = new SlotAsyncReady(slot);
g_drive_eject_with_operation(gobj(), static_cast(flags),
Glib::unwrap(mount_operation), Glib::unwrap(cancellable), &SignalProxy_async_callback,
slot_copy);
}
void
Drive::eject(const Glib::RefPtr& mount_operation, const SlotAsyncReady& slot,
Mount::UnmountFlags flags)
{
// Create a copy of the slot.
// A pointer to it will be passed through the callback's data parameter
// and deleted in the callback.
auto slot_copy = new SlotAsyncReady(slot);
g_drive_eject_with_operation(gobj(), static_cast(flags),
Glib::unwrap(mount_operation),
nullptr, // cancellable
&SignalProxy_async_callback, slot_copy);
}
void
Drive::eject(const Glib::RefPtr& mount_operation, Mount::UnmountFlags flags)
{
g_drive_eject_with_operation(gobj(), static_cast(flags),
Glib::unwrap(mount_operation),
nullptr, // cancellable
nullptr, // callback
nullptr); // user_data
}
void
Drive::eject(Mount::UnmountFlags flags)
{
g_drive_eject_with_operation(gobj(), static_cast(flags),
nullptr, // mount_operation
nullptr, // cancellable
nullptr, // callback
nullptr); // user_data
}
void
Drive::poll_for_media(const SlotAsyncReady& slot, const Glib::RefPtr& cancellable)
{
// Create a copy of the slot.
// A pointer to it will be passed through the callback's data parameter
// and deleted in the callback.
auto slot_copy = new SlotAsyncReady(slot);
g_drive_poll_for_media(gobj(), Glib::unwrap(cancellable), &SignalProxy_async_callback, slot_copy);
}
void
Drive::poll_for_media(const SlotAsyncReady& slot)
{
// Create a copy of the slot.
// A pointer to it will be passed through the callback's data parameter
// and deleted in the callback.
auto slot_copy = new SlotAsyncReady(slot);
g_drive_poll_for_media(gobj(),
nullptr, // cancellable
&SignalProxy_async_callback, slot_copy);
}
void
Drive::poll_for_media()
{
g_drive_poll_for_media(gobj(),
nullptr, // cancellable
nullptr, nullptr);
}
void
Drive::stop(const Glib::RefPtr& mount_operation,
const Glib::RefPtr& cancellable, const SlotAsyncReady& slot, Mount::UnmountFlags flags)
{
// Create a copy of the slot.
// A pointer to it will be passed through the callback's data parameter
// and deleted in the callback.
auto slot_copy = new SlotAsyncReady(slot);
g_drive_stop(gobj(), static_cast(flags), Glib::unwrap(mount_operation),
Glib::unwrap(cancellable), &SignalProxy_async_callback, slot_copy);
}
void
Drive::stop(const Glib::RefPtr& mount_operation, const SlotAsyncReady& slot,
Mount::UnmountFlags flags)
{
// Create a copy of the slot.
// A pointer to it will be passed through the callback's data parameter
// and deleted in the callback.
auto slot_copy = new SlotAsyncReady(slot);
g_drive_stop(gobj(), static_cast(flags), Glib::unwrap(mount_operation),
nullptr, &SignalProxy_async_callback, slot_copy);
}
void
Drive::start(const Glib::RefPtr& mount_operation,
const Glib::RefPtr& cancellable, const SlotAsyncReady& slot, StartFlags flags)
{
// Create a copy of the slot.
// A pointer to it will be passed through the callback's data parameter
// and deleted in the callback.
auto slot_copy = new SlotAsyncReady(slot);
g_drive_start(gobj(), static_cast(flags), Glib::unwrap(mount_operation),
Glib::unwrap(cancellable), &SignalProxy_async_callback, slot_copy);
}
void
Drive::start(const Glib::RefPtr& mount_operation, const SlotAsyncReady& slot,
StartFlags flags)
{
// Create a copy of the slot.
// A pointer to it will be passed through the callback's data parameter
// and deleted in the callback.
auto slot_copy = new SlotAsyncReady(slot);
g_drive_start(gobj(), static_cast(flags), Glib::unwrap(mount_operation),
nullptr, &SignalProxy_async_callback, slot_copy);
}
} // namespace Gio