use gio_sys;
use glib;
use glib::object::IsA;
use glib::translate::*;
use glib::GString;
use glib_sys;
use gobject_sys;
use std;
use std::boxed::Box as Box_;
use std::fmt;
use std::mem;
use std::pin::Pin;
use std::ptr;
use AppInfo;
use Cancellable;
use DriveStartFlags;
use FileCopyFlags;
use FileCreateFlags;
use FileEnumerator;
use FileIOStream;
use FileInfo;
use FileInputStream;
use FileMeasureFlags;
use FileMonitor;
use FileMonitorFlags;
use FileOutputStream;
use FileQueryInfoFlags;
use FileType;
use Mount;
use MountMountFlags;
use MountOperation;
use MountUnmountFlags;
glib_wrapper! {
pub struct File(Interface<gio_sys::GFile>);
match fn {
get_type => || gio_sys::g_file_get_type(),
}
}
impl File {
pub fn new_for_commandline_arg<P: AsRef<std::ffi::OsStr>>(arg: P) -> File {
unsafe {
from_glib_full(gio_sys::g_file_new_for_commandline_arg(
arg.as_ref().to_glib_none().0,
))
}
}
pub fn new_for_commandline_arg_and_cwd<P: AsRef<std::ffi::OsStr>, Q: AsRef<std::path::Path>>(
arg: P,
cwd: Q,
) -> File {
unsafe {
from_glib_full(gio_sys::g_file_new_for_commandline_arg_and_cwd(
arg.as_ref().to_glib_none().0,
cwd.as_ref().to_glib_none().0,
))
}
}
pub fn new_for_path<P: AsRef<std::path::Path>>(path: P) -> File {
unsafe { from_glib_full(gio_sys::g_file_new_for_path(path.as_ref().to_glib_none().0)) }
}
pub fn new_for_uri(uri: &str) -> File {
unsafe { from_glib_full(gio_sys::g_file_new_for_uri(uri.to_glib_none().0)) }
}
pub fn new_tmp<P: AsRef<std::path::Path>>(
tmpl: P,
) -> Result<(File, FileIOStream), glib::Error> {
unsafe {
let mut iostream = ptr::null_mut();
let mut error = ptr::null_mut();
let ret =
gio_sys::g_file_new_tmp(tmpl.as_ref().to_glib_none().0, &mut iostream, &mut error);
if error.is_null() {
Ok((from_glib_full(ret), from_glib_full(iostream)))
} else {
Err(from_glib_full(error))
}
}
}
pub fn parse_name(parse_name: &str) -> Option<File> {
unsafe { from_glib_full(gio_sys::g_file_parse_name(parse_name.to_glib_none().0)) }
}
}
unsafe impl Send for File {}
unsafe impl Sync for File {}
pub const NONE_FILE: Option<&File> = None;
pub trait FileExt: 'static {
fn append_to<P: IsA<Cancellable>>(
&self,
flags: FileCreateFlags,
cancellable: Option<&P>,
) -> Result<FileOutputStream, glib::Error>;
fn append_to_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileOutputStream, glib::Error>) + Send + 'static,
>(
&self,
flags: FileCreateFlags,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
fn append_to_async_future(
&self,
flags: FileCreateFlags,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileOutputStream, glib::Error>> + 'static>>;
fn copy<P: IsA<File>, Q: IsA<Cancellable>>(
&self,
destination: &P,
flags: FileCopyFlags,
cancellable: Option<&Q>,
progress_callback: Option<&mut dyn (FnMut(i64, i64))>,
) -> Result<(), glib::Error>;
fn copy_attributes<P: IsA<File>, Q: IsA<Cancellable>>(
&self,
destination: &P,
flags: FileCopyFlags,
cancellable: Option<&Q>,
) -> Result<(), glib::Error>;
fn create<P: IsA<Cancellable>>(
&self,
flags: FileCreateFlags,
cancellable: Option<&P>,
) -> Result<FileOutputStream, glib::Error>;
fn create_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileOutputStream, glib::Error>) + Send + 'static,
>(
&self,
flags: FileCreateFlags,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
fn create_async_future(
&self,
flags: FileCreateFlags,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileOutputStream, glib::Error>> + 'static>>;
fn create_readwrite<P: IsA<Cancellable>>(
&self,
flags: FileCreateFlags,
cancellable: Option<&P>,
) -> Result<FileIOStream, glib::Error>;
fn create_readwrite_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileIOStream, glib::Error>) + Send + 'static,
>(
&self,
flags: FileCreateFlags,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
fn create_readwrite_async_future(
&self,
flags: FileCreateFlags,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileIOStream, glib::Error>> + 'static>>;
fn delete<P: IsA<Cancellable>>(&self, cancellable: Option<&P>) -> Result<(), glib::Error>;
fn delete_async<P: IsA<Cancellable>, Q: FnOnce(Result<(), glib::Error>) + Send + 'static>(
&self,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
fn delete_async_future(
&self,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>>;
fn dup(&self) -> Option<File>;
fn eject_mountable_with_operation<
P: IsA<MountOperation>,
Q: IsA<Cancellable>,
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
&self,
flags: MountUnmountFlags,
mount_operation: Option<&P>,
cancellable: Option<&Q>,
callback: R,
);
fn eject_mountable_with_operation_future<P: IsA<MountOperation> + Clone + 'static>(
&self,
flags: MountUnmountFlags,
mount_operation: Option<&P>,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>>;
fn enumerate_children<P: IsA<Cancellable>>(
&self,
attributes: &str,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<FileEnumerator, glib::Error>;
fn equal<P: IsA<File>>(&self, file2: &P) -> bool;
fn find_enclosing_mount<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<Mount, glib::Error>;
fn get_basename(&self) -> Option<std::path::PathBuf>;
fn get_child<P: AsRef<std::path::Path>>(&self, name: P) -> Option<File>;
fn get_child_for_display_name(&self, display_name: &str) -> Result<File, glib::Error>;
fn get_parent(&self) -> Option<File>;
fn get_parse_name(&self) -> Option<GString>;
fn get_path(&self) -> Option<std::path::PathBuf>;
fn get_relative_path<P: IsA<File>>(&self, descendant: &P) -> Option<std::path::PathBuf>;
fn get_uri(&self) -> GString;
fn get_uri_scheme(&self) -> GString;
fn has_parent<P: IsA<File>>(&self, parent: Option<&P>) -> bool;
fn has_prefix<P: IsA<File>>(&self, prefix: &P) -> bool;
fn has_uri_scheme(&self, uri_scheme: &str) -> bool;
fn is_native(&self) -> bool;
#[cfg(any(feature = "v2_56", feature = "dox"))]
fn load_bytes<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<(glib::Bytes, Option<GString>), glib::Error>;
#[cfg(any(feature = "v2_56", feature = "dox"))]
fn load_bytes_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<(glib::Bytes, GString), glib::Error>) + Send + 'static,
>(
&self,
cancellable: Option<&P>,
callback: Q,
);
#[cfg(any(feature = "v2_56", feature = "dox"))]
fn load_bytes_async_future(
&self,
) -> Pin<
Box_<
dyn std::future::Future<Output = Result<(glib::Bytes, GString), glib::Error>> + 'static,
>,
>;
fn load_contents<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<(Vec<u8>, GString), glib::Error>;
fn load_contents_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<(Vec<u8>, GString), glib::Error>) + Send + 'static,
>(
&self,
cancellable: Option<&P>,
callback: Q,
);
fn load_contents_async_future(
&self,
) -> Pin<
Box_<dyn std::future::Future<Output = Result<(Vec<u8>, GString), glib::Error>> + 'static>,
>;
fn make_directory<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<(), glib::Error>;
fn make_directory_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
&self,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
fn make_directory_async_future(
&self,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>>;
fn make_directory_with_parents<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<(), glib::Error>;
fn make_symbolic_link<P: AsRef<std::path::Path>, Q: IsA<Cancellable>>(
&self,
symlink_value: P,
cancellable: Option<&Q>,
) -> Result<(), glib::Error>;
fn measure_disk_usage<P: IsA<Cancellable>>(
&self,
flags: FileMeasureFlags,
cancellable: Option<&P>,
progress_callback: Option<Box_<dyn Fn(bool, u64, u64, u64) + 'static>>,
) -> Result<(u64, u64, u64), glib::Error>;
fn monitor<P: IsA<Cancellable>>(
&self,
flags: FileMonitorFlags,
cancellable: Option<&P>,
) -> Result<FileMonitor, glib::Error>;
fn monitor_directory<P: IsA<Cancellable>>(
&self,
flags: FileMonitorFlags,
cancellable: Option<&P>,
) -> Result<FileMonitor, glib::Error>;
fn monitor_file<P: IsA<Cancellable>>(
&self,
flags: FileMonitorFlags,
cancellable: Option<&P>,
) -> Result<FileMonitor, glib::Error>;
fn mount_enclosing_volume<
P: IsA<MountOperation>,
Q: IsA<Cancellable>,
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
&self,
flags: MountMountFlags,
mount_operation: Option<&P>,
cancellable: Option<&Q>,
callback: R,
);
fn mount_enclosing_volume_future<P: IsA<MountOperation> + Clone + 'static>(
&self,
flags: MountMountFlags,
mount_operation: Option<&P>,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>>;
fn mount_mountable<
P: IsA<MountOperation>,
Q: IsA<Cancellable>,
R: FnOnce(Result<File, glib::Error>) + Send + 'static,
>(
&self,
flags: MountMountFlags,
mount_operation: Option<&P>,
cancellable: Option<&Q>,
callback: R,
);
fn mount_mountable_future<P: IsA<MountOperation> + Clone + 'static>(
&self,
flags: MountMountFlags,
mount_operation: Option<&P>,
) -> Pin<Box_<dyn std::future::Future<Output = Result<File, glib::Error>> + 'static>>;
fn move_<P: IsA<File>, Q: IsA<Cancellable>>(
&self,
destination: &P,
flags: FileCopyFlags,
cancellable: Option<&Q>,
progress_callback: Option<&mut dyn (FnMut(i64, i64))>,
) -> Result<(), glib::Error>;
fn open_readwrite<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<FileIOStream, glib::Error>;
fn open_readwrite_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileIOStream, glib::Error>) + Send + 'static,
>(
&self,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
fn open_readwrite_async_future(
&self,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileIOStream, glib::Error>> + 'static>>;
#[cfg(any(feature = "v2_56", feature = "dox"))]
fn peek_path(&self) -> Option<std::path::PathBuf>;
fn poll_mountable<P: IsA<Cancellable>, Q: FnOnce(Result<(), glib::Error>) + Send + 'static>(
&self,
cancellable: Option<&P>,
callback: Q,
);
fn poll_mountable_future(
&self,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>>;
fn query_default_handler<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<AppInfo, glib::Error>;
#[cfg(any(feature = "v2_60", feature = "dox"))]
fn query_default_handler_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<AppInfo, glib::Error>) + Send + 'static,
>(
&self,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
#[cfg(any(feature = "v2_60", feature = "dox"))]
fn query_default_handler_async_future(
&self,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<AppInfo, glib::Error>> + 'static>>;
fn query_exists<P: IsA<Cancellable>>(&self, cancellable: Option<&P>) -> bool;
fn query_file_type<P: IsA<Cancellable>>(
&self,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> FileType;
fn query_filesystem_info<P: IsA<Cancellable>>(
&self,
attributes: &str,
cancellable: Option<&P>,
) -> Result<FileInfo, glib::Error>;
fn query_filesystem_info_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileInfo, glib::Error>) + Send + 'static,
>(
&self,
attributes: &str,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
fn query_filesystem_info_async_future(
&self,
attributes: &str,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileInfo, glib::Error>> + 'static>>;
fn query_info<P: IsA<Cancellable>>(
&self,
attributes: &str,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<FileInfo, glib::Error>;
fn query_info_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileInfo, glib::Error>) + Send + 'static,
>(
&self,
attributes: &str,
flags: FileQueryInfoFlags,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
fn query_info_async_future(
&self,
attributes: &str,
flags: FileQueryInfoFlags,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileInfo, glib::Error>> + 'static>>;
fn read<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<FileInputStream, glib::Error>;
fn read_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileInputStream, glib::Error>) + Send + 'static,
>(
&self,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
fn read_async_future(
&self,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileInputStream, glib::Error>> + 'static>>;
fn replace<P: IsA<Cancellable>>(
&self,
etag: Option<&str>,
make_backup: bool,
flags: FileCreateFlags,
cancellable: Option<&P>,
) -> Result<FileOutputStream, glib::Error>;
fn replace_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileOutputStream, glib::Error>) + Send + 'static,
>(
&self,
etag: Option<&str>,
make_backup: bool,
flags: FileCreateFlags,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
fn replace_async_future(
&self,
etag: Option<&str>,
make_backup: bool,
flags: FileCreateFlags,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileOutputStream, glib::Error>> + 'static>>;
fn replace_contents<P: IsA<Cancellable>>(
&self,
contents: &[u8],
etag: Option<&str>,
make_backup: bool,
flags: FileCreateFlags,
cancellable: Option<&P>,
) -> Result<GString, glib::Error>;
fn replace_readwrite<P: IsA<Cancellable>>(
&self,
etag: Option<&str>,
make_backup: bool,
flags: FileCreateFlags,
cancellable: Option<&P>,
) -> Result<FileIOStream, glib::Error>;
fn replace_readwrite_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileIOStream, glib::Error>) + Send + 'static,
>(
&self,
etag: Option<&str>,
make_backup: bool,
flags: FileCreateFlags,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
fn replace_readwrite_async_future(
&self,
etag: Option<&str>,
make_backup: bool,
flags: FileCreateFlags,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileIOStream, glib::Error>> + 'static>>;
fn resolve_relative_path<P: AsRef<std::path::Path>>(&self, relative_path: P) -> Option<File>;
fn set_attribute_byte_string<P: IsA<Cancellable>>(
&self,
attribute: &str,
value: &str,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<(), glib::Error>;
fn set_attribute_int32<P: IsA<Cancellable>>(
&self,
attribute: &str,
value: i32,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<(), glib::Error>;
fn set_attribute_int64<P: IsA<Cancellable>>(
&self,
attribute: &str,
value: i64,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<(), glib::Error>;
fn set_attribute_string<P: IsA<Cancellable>>(
&self,
attribute: &str,
value: &str,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<(), glib::Error>;
fn set_attribute_uint32<P: IsA<Cancellable>>(
&self,
attribute: &str,
value: u32,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<(), glib::Error>;
fn set_attribute_uint64<P: IsA<Cancellable>>(
&self,
attribute: &str,
value: u64,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<(), glib::Error>;
fn set_attributes_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileInfo, glib::Error>) + Send + 'static,
>(
&self,
info: &FileInfo,
flags: FileQueryInfoFlags,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
fn set_attributes_async_future(
&self,
info: &FileInfo,
flags: FileQueryInfoFlags,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileInfo, glib::Error>> + 'static>>;
fn set_attributes_from_info<P: IsA<Cancellable>>(
&self,
info: &FileInfo,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<(), glib::Error>;
fn set_display_name<P: IsA<Cancellable>>(
&self,
display_name: &str,
cancellable: Option<&P>,
) -> Result<File, glib::Error>;
fn set_display_name_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<File, glib::Error>) + Send + 'static,
>(
&self,
display_name: &str,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
fn set_display_name_async_future(
&self,
display_name: &str,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<File, glib::Error>> + 'static>>;
fn start_mountable<
P: IsA<MountOperation>,
Q: IsA<Cancellable>,
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
&self,
flags: DriveStartFlags,
start_operation: Option<&P>,
cancellable: Option<&Q>,
callback: R,
);
fn start_mountable_future<P: IsA<MountOperation> + Clone + 'static>(
&self,
flags: DriveStartFlags,
start_operation: Option<&P>,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>>;
fn stop_mountable<
P: IsA<MountOperation>,
Q: IsA<Cancellable>,
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
&self,
flags: MountUnmountFlags,
mount_operation: Option<&P>,
cancellable: Option<&Q>,
callback: R,
);
fn stop_mountable_future<P: IsA<MountOperation> + Clone + 'static>(
&self,
flags: MountUnmountFlags,
mount_operation: Option<&P>,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>>;
fn supports_thread_contexts(&self) -> bool;
fn trash<P: IsA<Cancellable>>(&self, cancellable: Option<&P>) -> Result<(), glib::Error>;
fn trash_async<P: IsA<Cancellable>, Q: FnOnce(Result<(), glib::Error>) + Send + 'static>(
&self,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
);
fn trash_async_future(
&self,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>>;
fn unmount_mountable_with_operation<
P: IsA<MountOperation>,
Q: IsA<Cancellable>,
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
&self,
flags: MountUnmountFlags,
mount_operation: Option<&P>,
cancellable: Option<&Q>,
callback: R,
);
fn unmount_mountable_with_operation_future<P: IsA<MountOperation> + Clone + 'static>(
&self,
flags: MountUnmountFlags,
mount_operation: Option<&P>,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>>;
}
impl<O: IsA<File>> FileExt for O {
fn append_to<P: IsA<Cancellable>>(
&self,
flags: FileCreateFlags,
cancellable: Option<&P>,
) -> Result<FileOutputStream, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_append_to(
self.as_ref().to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn append_to_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileOutputStream, glib::Error>) + Send + 'static,
>(
&self,
flags: FileCreateFlags,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn append_to_async_trampoline<
Q: FnOnce(Result<FileOutputStream, glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_append_to_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = append_to_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_append_to_async(
self.as_ref().to_glib_none().0,
flags.to_glib(),
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn append_to_async_future(
&self,
flags: FileCreateFlags,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileOutputStream, glib::Error>> + 'static>>
{
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.append_to_async(flags, io_priority, Some(&cancellable), move |res| {
send.resolve(res);
});
cancellable
}))
}
fn copy<P: IsA<File>, Q: IsA<Cancellable>>(
&self,
destination: &P,
flags: FileCopyFlags,
cancellable: Option<&Q>,
progress_callback: Option<&mut dyn (FnMut(i64, i64))>,
) -> Result<(), glib::Error> {
let progress_callback_data: Option<&mut dyn (FnMut(i64, i64))> = progress_callback;
unsafe extern "C" fn progress_callback_func<P: IsA<File>, Q: IsA<Cancellable>>(
current_num_bytes: i64,
total_num_bytes: i64,
user_data: glib_sys::gpointer,
) {
let callback: *mut Option<&mut dyn (FnMut(i64, i64))> =
user_data as *const _ as usize as *mut Option<&mut dyn (FnMut(i64, i64))>;
if let Some(ref mut callback) = *callback {
callback(current_num_bytes, total_num_bytes)
} else {
panic!("cannot get closure...")
};
}
let progress_callback = if progress_callback_data.is_some() {
Some(progress_callback_func::<P, Q> as _)
} else {
None
};
let super_callback0: &Option<&mut dyn (FnMut(i64, i64))> = &progress_callback_data;
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_copy(
self.as_ref().to_glib_none().0,
destination.as_ref().to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
progress_callback,
super_callback0 as *const _ as usize as *mut _,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn copy_attributes<P: IsA<File>, Q: IsA<Cancellable>>(
&self,
destination: &P,
flags: FileCopyFlags,
cancellable: Option<&Q>,
) -> Result<(), glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_copy_attributes(
self.as_ref().to_glib_none().0,
destination.as_ref().to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn create<P: IsA<Cancellable>>(
&self,
flags: FileCreateFlags,
cancellable: Option<&P>,
) -> Result<FileOutputStream, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_create(
self.as_ref().to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn create_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileOutputStream, glib::Error>) + Send + 'static,
>(
&self,
flags: FileCreateFlags,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn create_async_trampoline<
Q: FnOnce(Result<FileOutputStream, glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_create_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = create_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_create_async(
self.as_ref().to_glib_none().0,
flags.to_glib(),
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn create_async_future(
&self,
flags: FileCreateFlags,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileOutputStream, glib::Error>> + 'static>>
{
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.create_async(flags, io_priority, Some(&cancellable), move |res| {
send.resolve(res);
});
cancellable
}))
}
fn create_readwrite<P: IsA<Cancellable>>(
&self,
flags: FileCreateFlags,
cancellable: Option<&P>,
) -> Result<FileIOStream, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_create_readwrite(
self.as_ref().to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn create_readwrite_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileIOStream, glib::Error>) + Send + 'static,
>(
&self,
flags: FileCreateFlags,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn create_readwrite_async_trampoline<
Q: FnOnce(Result<FileIOStream, glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let ret =
gio_sys::g_file_create_readwrite_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = create_readwrite_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_create_readwrite_async(
self.as_ref().to_glib_none().0,
flags.to_glib(),
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn create_readwrite_async_future(
&self,
flags: FileCreateFlags,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileIOStream, glib::Error>> + 'static>>
{
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.create_readwrite_async(flags, io_priority, Some(&cancellable), move |res| {
send.resolve(res);
});
cancellable
}))
}
fn delete<P: IsA<Cancellable>>(&self, cancellable: Option<&P>) -> Result<(), glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_delete(
self.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn delete_async<P: IsA<Cancellable>, Q: FnOnce(Result<(), glib::Error>) + Send + 'static>(
&self,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn delete_async_trampoline<
Q: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_delete_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = delete_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_delete_async(
self.as_ref().to_glib_none().0,
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn delete_async_future(
&self,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>> {
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.delete_async(io_priority, Some(&cancellable), move |res| {
send.resolve(res);
});
cancellable
}))
}
fn dup(&self) -> Option<File> {
unsafe { from_glib_full(gio_sys::g_file_dup(self.as_ref().to_glib_none().0)) }
}
fn eject_mountable_with_operation<
P: IsA<MountOperation>,
Q: IsA<Cancellable>,
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
&self,
flags: MountUnmountFlags,
mount_operation: Option<&P>,
cancellable: Option<&Q>,
callback: R,
) {
let user_data: Box_<R> = Box_::new(callback);
unsafe extern "C" fn eject_mountable_with_operation_trampoline<
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_eject_mountable_with_operation_finish(
_source_object as *mut _,
res,
&mut error,
);
let result = if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
};
let callback: Box_<R> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = eject_mountable_with_operation_trampoline::<R>;
unsafe {
gio_sys::g_file_eject_mountable_with_operation(
self.as_ref().to_glib_none().0,
flags.to_glib(),
mount_operation.map(|p| p.as_ref()).to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn eject_mountable_with_operation_future<P: IsA<MountOperation> + Clone + 'static>(
&self,
flags: MountUnmountFlags,
mount_operation: Option<&P>,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>> {
let mount_operation = mount_operation.map(ToOwned::to_owned);
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.eject_mountable_with_operation(
flags,
mount_operation.as_ref().map(::std::borrow::Borrow::borrow),
Some(&cancellable),
move |res| {
send.resolve(res);
},
);
cancellable
}))
}
fn enumerate_children<P: IsA<Cancellable>>(
&self,
attributes: &str,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<FileEnumerator, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_enumerate_children(
self.as_ref().to_glib_none().0,
attributes.to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn equal<P: IsA<File>>(&self, file2: &P) -> bool {
unsafe {
from_glib(gio_sys::g_file_equal(
self.as_ref().to_glib_none().0,
file2.as_ref().to_glib_none().0,
))
}
}
fn find_enclosing_mount<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<Mount, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_find_enclosing_mount(
self.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn get_basename(&self) -> Option<std::path::PathBuf> {
unsafe { from_glib_full(gio_sys::g_file_get_basename(self.as_ref().to_glib_none().0)) }
}
fn get_child<P: AsRef<std::path::Path>>(&self, name: P) -> Option<File> {
unsafe {
from_glib_full(gio_sys::g_file_get_child(
self.as_ref().to_glib_none().0,
name.as_ref().to_glib_none().0,
))
}
}
fn get_child_for_display_name(&self, display_name: &str) -> Result<File, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_get_child_for_display_name(
self.as_ref().to_glib_none().0,
display_name.to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn get_parent(&self) -> Option<File> {
unsafe { from_glib_full(gio_sys::g_file_get_parent(self.as_ref().to_glib_none().0)) }
}
fn get_parse_name(&self) -> Option<GString> {
unsafe {
from_glib_full(gio_sys::g_file_get_parse_name(
self.as_ref().to_glib_none().0,
))
}
}
fn get_path(&self) -> Option<std::path::PathBuf> {
unsafe { from_glib_full(gio_sys::g_file_get_path(self.as_ref().to_glib_none().0)) }
}
fn get_relative_path<P: IsA<File>>(&self, descendant: &P) -> Option<std::path::PathBuf> {
unsafe {
from_glib_full(gio_sys::g_file_get_relative_path(
self.as_ref().to_glib_none().0,
descendant.as_ref().to_glib_none().0,
))
}
}
fn get_uri(&self) -> GString {
unsafe { from_glib_full(gio_sys::g_file_get_uri(self.as_ref().to_glib_none().0)) }
}
fn get_uri_scheme(&self) -> GString {
unsafe {
from_glib_full(gio_sys::g_file_get_uri_scheme(
self.as_ref().to_glib_none().0,
))
}
}
fn has_parent<P: IsA<File>>(&self, parent: Option<&P>) -> bool {
unsafe {
from_glib(gio_sys::g_file_has_parent(
self.as_ref().to_glib_none().0,
parent.map(|p| p.as_ref()).to_glib_none().0,
))
}
}
fn has_prefix<P: IsA<File>>(&self, prefix: &P) -> bool {
unsafe {
from_glib(gio_sys::g_file_has_prefix(
self.as_ref().to_glib_none().0,
prefix.as_ref().to_glib_none().0,
))
}
}
fn has_uri_scheme(&self, uri_scheme: &str) -> bool {
unsafe {
from_glib(gio_sys::g_file_has_uri_scheme(
self.as_ref().to_glib_none().0,
uri_scheme.to_glib_none().0,
))
}
}
fn is_native(&self) -> bool {
unsafe { from_glib(gio_sys::g_file_is_native(self.as_ref().to_glib_none().0)) }
}
#[cfg(any(feature = "v2_56", feature = "dox"))]
fn load_bytes<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<(glib::Bytes, Option<GString>), glib::Error> {
unsafe {
let mut etag_out = ptr::null_mut();
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_load_bytes(
self.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut etag_out,
&mut error,
);
if error.is_null() {
Ok((from_glib_full(ret), from_glib_full(etag_out)))
} else {
Err(from_glib_full(error))
}
}
}
#[cfg(any(feature = "v2_56", feature = "dox"))]
fn load_bytes_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<(glib::Bytes, GString), glib::Error>) + Send + 'static,
>(
&self,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn load_bytes_async_trampoline<
Q: FnOnce(Result<(glib::Bytes, GString), glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let mut etag_out = ptr::null_mut();
let ret = gio_sys::g_file_load_bytes_finish(
_source_object as *mut _,
res,
&mut etag_out,
&mut error,
);
let result = if error.is_null() {
Ok((from_glib_full(ret), from_glib_full(etag_out)))
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = load_bytes_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_load_bytes_async(
self.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
#[cfg(any(feature = "v2_56", feature = "dox"))]
fn load_bytes_async_future(
&self,
) -> Pin<
Box_<
dyn std::future::Future<Output = Result<(glib::Bytes, GString), glib::Error>> + 'static,
>,
> {
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.load_bytes_async(Some(&cancellable), move |res| {
send.resolve(res);
});
cancellable
}))
}
fn load_contents<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<(Vec<u8>, GString), glib::Error> {
unsafe {
let mut contents = ptr::null_mut();
let mut length = mem::MaybeUninit::uninit();
let mut etag_out = ptr::null_mut();
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_load_contents(
self.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut contents,
length.as_mut_ptr(),
&mut etag_out,
&mut error,
);
if error.is_null() {
Ok((
FromGlibContainer::from_glib_full_num(contents, length.assume_init() as usize),
from_glib_full(etag_out),
))
} else {
Err(from_glib_full(error))
}
}
}
fn load_contents_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<(Vec<u8>, GString), glib::Error>) + Send + 'static,
>(
&self,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn load_contents_async_trampoline<
Q: FnOnce(Result<(Vec<u8>, GString), glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let mut contents = ptr::null_mut();
let mut length = mem::MaybeUninit::uninit();
let mut etag_out = ptr::null_mut();
let _ = gio_sys::g_file_load_contents_finish(
_source_object as *mut _,
res,
&mut contents,
length.as_mut_ptr(),
&mut etag_out,
&mut error,
);
let result = if error.is_null() {
Ok((
FromGlibContainer::from_glib_full_num(contents, length.assume_init() as usize),
from_glib_full(etag_out),
))
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = load_contents_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_load_contents_async(
self.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn load_contents_async_future(
&self,
) -> Pin<
Box_<dyn std::future::Future<Output = Result<(Vec<u8>, GString), glib::Error>> + 'static>,
> {
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.load_contents_async(Some(&cancellable), move |res| {
send.resolve(res);
});
cancellable
}))
}
fn make_directory<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<(), glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_make_directory(
self.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn make_directory_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
&self,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn make_directory_async_trampoline<
Q: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let _ =
gio_sys::g_file_make_directory_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = make_directory_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_make_directory_async(
self.as_ref().to_glib_none().0,
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn make_directory_async_future(
&self,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>> {
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.make_directory_async(io_priority, Some(&cancellable), move |res| {
send.resolve(res);
});
cancellable
}))
}
fn make_directory_with_parents<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<(), glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_make_directory_with_parents(
self.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn make_symbolic_link<P: AsRef<std::path::Path>, Q: IsA<Cancellable>>(
&self,
symlink_value: P,
cancellable: Option<&Q>,
) -> Result<(), glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_make_symbolic_link(
self.as_ref().to_glib_none().0,
symlink_value.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn measure_disk_usage<P: IsA<Cancellable>>(
&self,
flags: FileMeasureFlags,
cancellable: Option<&P>,
progress_callback: Option<Box_<dyn Fn(bool, u64, u64, u64) + 'static>>,
) -> Result<(u64, u64, u64), glib::Error> {
let progress_callback_data: Box_<Option<Box_<dyn Fn(bool, u64, u64, u64) + 'static>>> =
Box_::new(progress_callback);
unsafe extern "C" fn progress_callback_func<P: IsA<Cancellable>>(
reporting: glib_sys::gboolean,
current_size: u64,
num_dirs: u64,
num_files: u64,
user_data: glib_sys::gpointer,
) {
let reporting = from_glib(reporting);
let callback: &Option<Box_<dyn Fn(bool, u64, u64, u64) + 'static>> =
&*(user_data as *mut _);
if let Some(ref callback) = *callback {
callback(reporting, current_size, num_dirs, num_files)
} else {
panic!("cannot get closure...")
};
}
let progress_callback = if progress_callback_data.is_some() {
Some(progress_callback_func::<P> as _)
} else {
None
};
let super_callback0: Box_<Option<Box_<dyn Fn(bool, u64, u64, u64) + 'static>>> =
progress_callback_data;
unsafe {
let mut disk_usage = mem::MaybeUninit::uninit();
let mut num_dirs = mem::MaybeUninit::uninit();
let mut num_files = mem::MaybeUninit::uninit();
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_measure_disk_usage(
self.as_ref().to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
progress_callback,
Box_::into_raw(super_callback0) as *mut _,
disk_usage.as_mut_ptr(),
num_dirs.as_mut_ptr(),
num_files.as_mut_ptr(),
&mut error,
);
let disk_usage = disk_usage.assume_init();
let num_dirs = num_dirs.assume_init();
let num_files = num_files.assume_init();
if error.is_null() {
Ok((disk_usage, num_dirs, num_files))
} else {
Err(from_glib_full(error))
}
}
}
fn monitor<P: IsA<Cancellable>>(
&self,
flags: FileMonitorFlags,
cancellable: Option<&P>,
) -> Result<FileMonitor, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_monitor(
self.as_ref().to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn monitor_directory<P: IsA<Cancellable>>(
&self,
flags: FileMonitorFlags,
cancellable: Option<&P>,
) -> Result<FileMonitor, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_monitor_directory(
self.as_ref().to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn monitor_file<P: IsA<Cancellable>>(
&self,
flags: FileMonitorFlags,
cancellable: Option<&P>,
) -> Result<FileMonitor, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_monitor_file(
self.as_ref().to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn mount_enclosing_volume<
P: IsA<MountOperation>,
Q: IsA<Cancellable>,
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
&self,
flags: MountMountFlags,
mount_operation: Option<&P>,
cancellable: Option<&Q>,
callback: R,
) {
let user_data: Box_<R> = Box_::new(callback);
unsafe extern "C" fn mount_enclosing_volume_trampoline<
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_mount_enclosing_volume_finish(
_source_object as *mut _,
res,
&mut error,
);
let result = if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
};
let callback: Box_<R> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = mount_enclosing_volume_trampoline::<R>;
unsafe {
gio_sys::g_file_mount_enclosing_volume(
self.as_ref().to_glib_none().0,
flags.to_glib(),
mount_operation.map(|p| p.as_ref()).to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn mount_enclosing_volume_future<P: IsA<MountOperation> + Clone + 'static>(
&self,
flags: MountMountFlags,
mount_operation: Option<&P>,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>> {
let mount_operation = mount_operation.map(ToOwned::to_owned);
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.mount_enclosing_volume(
flags,
mount_operation.as_ref().map(::std::borrow::Borrow::borrow),
Some(&cancellable),
move |res| {
send.resolve(res);
},
);
cancellable
}))
}
fn mount_mountable<
P: IsA<MountOperation>,
Q: IsA<Cancellable>,
R: FnOnce(Result<File, glib::Error>) + Send + 'static,
>(
&self,
flags: MountMountFlags,
mount_operation: Option<&P>,
cancellable: Option<&Q>,
callback: R,
) {
let user_data: Box_<R> = Box_::new(callback);
unsafe extern "C" fn mount_mountable_trampoline<
R: FnOnce(Result<File, glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let ret =
gio_sys::g_file_mount_mountable_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
};
let callback: Box_<R> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = mount_mountable_trampoline::<R>;
unsafe {
gio_sys::g_file_mount_mountable(
self.as_ref().to_glib_none().0,
flags.to_glib(),
mount_operation.map(|p| p.as_ref()).to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn mount_mountable_future<P: IsA<MountOperation> + Clone + 'static>(
&self,
flags: MountMountFlags,
mount_operation: Option<&P>,
) -> Pin<Box_<dyn std::future::Future<Output = Result<File, glib::Error>> + 'static>> {
let mount_operation = mount_operation.map(ToOwned::to_owned);
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.mount_mountable(
flags,
mount_operation.as_ref().map(::std::borrow::Borrow::borrow),
Some(&cancellable),
move |res| {
send.resolve(res);
},
);
cancellable
}))
}
fn move_<P: IsA<File>, Q: IsA<Cancellable>>(
&self,
destination: &P,
flags: FileCopyFlags,
cancellable: Option<&Q>,
progress_callback: Option<&mut dyn (FnMut(i64, i64))>,
) -> Result<(), glib::Error> {
let progress_callback_data: Option<&mut dyn (FnMut(i64, i64))> = progress_callback;
unsafe extern "C" fn progress_callback_func<P: IsA<File>, Q: IsA<Cancellable>>(
current_num_bytes: i64,
total_num_bytes: i64,
user_data: glib_sys::gpointer,
) {
let callback: *mut Option<&mut dyn (FnMut(i64, i64))> =
user_data as *const _ as usize as *mut Option<&mut dyn (FnMut(i64, i64))>;
if let Some(ref mut callback) = *callback {
callback(current_num_bytes, total_num_bytes)
} else {
panic!("cannot get closure...")
};
}
let progress_callback = if progress_callback_data.is_some() {
Some(progress_callback_func::<P, Q> as _)
} else {
None
};
let super_callback0: &Option<&mut dyn (FnMut(i64, i64))> = &progress_callback_data;
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_move(
self.as_ref().to_glib_none().0,
destination.as_ref().to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
progress_callback,
super_callback0 as *const _ as usize as *mut _,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn open_readwrite<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<FileIOStream, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_open_readwrite(
self.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn open_readwrite_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileIOStream, glib::Error>) + Send + 'static,
>(
&self,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn open_readwrite_async_trampoline<
Q: FnOnce(Result<FileIOStream, glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let ret =
gio_sys::g_file_open_readwrite_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = open_readwrite_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_open_readwrite_async(
self.as_ref().to_glib_none().0,
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn open_readwrite_async_future(
&self,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileIOStream, glib::Error>> + 'static>>
{
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.open_readwrite_async(io_priority, Some(&cancellable), move |res| {
send.resolve(res);
});
cancellable
}))
}
#[cfg(any(feature = "v2_56", feature = "dox"))]
fn peek_path(&self) -> Option<std::path::PathBuf> {
unsafe { from_glib_none(gio_sys::g_file_peek_path(self.as_ref().to_glib_none().0)) }
}
fn poll_mountable<P: IsA<Cancellable>, Q: FnOnce(Result<(), glib::Error>) + Send + 'static>(
&self,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn poll_mountable_trampoline<
Q: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let _ =
gio_sys::g_file_poll_mountable_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = poll_mountable_trampoline::<Q>;
unsafe {
gio_sys::g_file_poll_mountable(
self.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn poll_mountable_future(
&self,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>> {
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.poll_mountable(Some(&cancellable), move |res| {
send.resolve(res);
});
cancellable
}))
}
fn query_default_handler<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<AppInfo, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_query_default_handler(
self.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
#[cfg(any(feature = "v2_60", feature = "dox"))]
fn query_default_handler_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<AppInfo, glib::Error>) + Send + 'static,
>(
&self,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn query_default_handler_async_trampoline<
Q: FnOnce(Result<AppInfo, glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_query_default_handler_finish(
_source_object as *mut _,
res,
&mut error,
);
let result = if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = query_default_handler_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_query_default_handler_async(
self.as_ref().to_glib_none().0,
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
#[cfg(any(feature = "v2_60", feature = "dox"))]
fn query_default_handler_async_future(
&self,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<AppInfo, glib::Error>> + 'static>> {
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.query_default_handler_async(io_priority, Some(&cancellable), move |res| {
send.resolve(res);
});
cancellable
}))
}
fn query_exists<P: IsA<Cancellable>>(&self, cancellable: Option<&P>) -> bool {
unsafe {
from_glib(gio_sys::g_file_query_exists(
self.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
))
}
}
fn query_file_type<P: IsA<Cancellable>>(
&self,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> FileType {
unsafe {
from_glib(gio_sys::g_file_query_file_type(
self.as_ref().to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
))
}
}
fn query_filesystem_info<P: IsA<Cancellable>>(
&self,
attributes: &str,
cancellable: Option<&P>,
) -> Result<FileInfo, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_query_filesystem_info(
self.as_ref().to_glib_none().0,
attributes.to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn query_filesystem_info_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileInfo, glib::Error>) + Send + 'static,
>(
&self,
attributes: &str,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn query_filesystem_info_async_trampoline<
Q: FnOnce(Result<FileInfo, glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_query_filesystem_info_finish(
_source_object as *mut _,
res,
&mut error,
);
let result = if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = query_filesystem_info_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_query_filesystem_info_async(
self.as_ref().to_glib_none().0,
attributes.to_glib_none().0,
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn query_filesystem_info_async_future(
&self,
attributes: &str,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileInfo, glib::Error>> + 'static>> {
let attributes = String::from(attributes);
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.query_filesystem_info_async(
&attributes,
io_priority,
Some(&cancellable),
move |res| {
send.resolve(res);
},
);
cancellable
}))
}
fn query_info<P: IsA<Cancellable>>(
&self,
attributes: &str,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<FileInfo, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_query_info(
self.as_ref().to_glib_none().0,
attributes.to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn query_info_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileInfo, glib::Error>) + Send + 'static,
>(
&self,
attributes: &str,
flags: FileQueryInfoFlags,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn query_info_async_trampoline<
Q: FnOnce(Result<FileInfo, glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_query_info_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = query_info_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_query_info_async(
self.as_ref().to_glib_none().0,
attributes.to_glib_none().0,
flags.to_glib(),
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn query_info_async_future(
&self,
attributes: &str,
flags: FileQueryInfoFlags,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileInfo, glib::Error>> + 'static>> {
let attributes = String::from(attributes);
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.query_info_async(
&attributes,
flags,
io_priority,
Some(&cancellable),
move |res| {
send.resolve(res);
},
);
cancellable
}))
}
fn read<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>,
) -> Result<FileInputStream, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_read(
self.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn read_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileInputStream, glib::Error>) + Send + 'static,
>(
&self,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn read_async_trampoline<
Q: FnOnce(Result<FileInputStream, glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_read_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = read_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_read_async(
self.as_ref().to_glib_none().0,
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn read_async_future(
&self,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileInputStream, glib::Error>> + 'static>>
{
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.read_async(io_priority, Some(&cancellable), move |res| {
send.resolve(res);
});
cancellable
}))
}
fn replace<P: IsA<Cancellable>>(
&self,
etag: Option<&str>,
make_backup: bool,
flags: FileCreateFlags,
cancellable: Option<&P>,
) -> Result<FileOutputStream, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_replace(
self.as_ref().to_glib_none().0,
etag.to_glib_none().0,
make_backup.to_glib(),
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn replace_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileOutputStream, glib::Error>) + Send + 'static,
>(
&self,
etag: Option<&str>,
make_backup: bool,
flags: FileCreateFlags,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn replace_async_trampoline<
Q: FnOnce(Result<FileOutputStream, glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_replace_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = replace_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_replace_async(
self.as_ref().to_glib_none().0,
etag.to_glib_none().0,
make_backup.to_glib(),
flags.to_glib(),
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn replace_async_future(
&self,
etag: Option<&str>,
make_backup: bool,
flags: FileCreateFlags,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileOutputStream, glib::Error>> + 'static>>
{
let etag = etag.map(ToOwned::to_owned);
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.replace_async(
etag.as_ref().map(::std::borrow::Borrow::borrow),
make_backup,
flags,
io_priority,
Some(&cancellable),
move |res| {
send.resolve(res);
},
);
cancellable
}))
}
fn replace_contents<P: IsA<Cancellable>>(
&self,
contents: &[u8],
etag: Option<&str>,
make_backup: bool,
flags: FileCreateFlags,
cancellable: Option<&P>,
) -> Result<GString, glib::Error> {
let length = contents.len() as usize;
unsafe {
let mut new_etag = ptr::null_mut();
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_replace_contents(
self.as_ref().to_glib_none().0,
contents.to_glib_none().0,
length,
etag.to_glib_none().0,
make_backup.to_glib(),
flags.to_glib(),
&mut new_etag,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(new_etag))
} else {
Err(from_glib_full(error))
}
}
}
fn replace_readwrite<P: IsA<Cancellable>>(
&self,
etag: Option<&str>,
make_backup: bool,
flags: FileCreateFlags,
cancellable: Option<&P>,
) -> Result<FileIOStream, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_replace_readwrite(
self.as_ref().to_glib_none().0,
etag.to_glib_none().0,
make_backup.to_glib(),
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn replace_readwrite_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileIOStream, glib::Error>) + Send + 'static,
>(
&self,
etag: Option<&str>,
make_backup: bool,
flags: FileCreateFlags,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn replace_readwrite_async_trampoline<
Q: FnOnce(Result<FileIOStream, glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let ret =
gio_sys::g_file_replace_readwrite_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = replace_readwrite_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_replace_readwrite_async(
self.as_ref().to_glib_none().0,
etag.to_glib_none().0,
make_backup.to_glib(),
flags.to_glib(),
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn replace_readwrite_async_future(
&self,
etag: Option<&str>,
make_backup: bool,
flags: FileCreateFlags,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileIOStream, glib::Error>> + 'static>>
{
let etag = etag.map(ToOwned::to_owned);
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.replace_readwrite_async(
etag.as_ref().map(::std::borrow::Borrow::borrow),
make_backup,
flags,
io_priority,
Some(&cancellable),
move |res| {
send.resolve(res);
},
);
cancellable
}))
}
fn resolve_relative_path<P: AsRef<std::path::Path>>(&self, relative_path: P) -> Option<File> {
unsafe {
from_glib_full(gio_sys::g_file_resolve_relative_path(
self.as_ref().to_glib_none().0,
relative_path.as_ref().to_glib_none().0,
))
}
}
fn set_attribute_byte_string<P: IsA<Cancellable>>(
&self,
attribute: &str,
value: &str,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<(), glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_set_attribute_byte_string(
self.as_ref().to_glib_none().0,
attribute.to_glib_none().0,
value.to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn set_attribute_int32<P: IsA<Cancellable>>(
&self,
attribute: &str,
value: i32,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<(), glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_set_attribute_int32(
self.as_ref().to_glib_none().0,
attribute.to_glib_none().0,
value,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn set_attribute_int64<P: IsA<Cancellable>>(
&self,
attribute: &str,
value: i64,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<(), glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_set_attribute_int64(
self.as_ref().to_glib_none().0,
attribute.to_glib_none().0,
value,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn set_attribute_string<P: IsA<Cancellable>>(
&self,
attribute: &str,
value: &str,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<(), glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_set_attribute_string(
self.as_ref().to_glib_none().0,
attribute.to_glib_none().0,
value.to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn set_attribute_uint32<P: IsA<Cancellable>>(
&self,
attribute: &str,
value: u32,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<(), glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_set_attribute_uint32(
self.as_ref().to_glib_none().0,
attribute.to_glib_none().0,
value,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn set_attribute_uint64<P: IsA<Cancellable>>(
&self,
attribute: &str,
value: u64,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<(), glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_set_attribute_uint64(
self.as_ref().to_glib_none().0,
attribute.to_glib_none().0,
value,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn set_attributes_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<FileInfo, glib::Error>) + Send + 'static,
>(
&self,
info: &FileInfo,
flags: FileQueryInfoFlags,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn set_attributes_async_trampoline<
Q: FnOnce(Result<FileInfo, glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let mut info = ptr::null_mut();
let _ = gio_sys::g_file_set_attributes_finish(
_source_object as *mut _,
res,
&mut info,
&mut error,
);
let result = if error.is_null() {
Ok(from_glib_full(info))
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = set_attributes_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_set_attributes_async(
self.as_ref().to_glib_none().0,
info.to_glib_none().0,
flags.to_glib(),
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn set_attributes_async_future(
&self,
info: &FileInfo,
flags: FileQueryInfoFlags,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<FileInfo, glib::Error>> + 'static>> {
let info = info.clone();
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.set_attributes_async(&info, flags, io_priority, Some(&cancellable), move |res| {
send.resolve(res);
});
cancellable
}))
}
fn set_attributes_from_info<P: IsA<Cancellable>>(
&self,
info: &FileInfo,
flags: FileQueryInfoFlags,
cancellable: Option<&P>,
) -> Result<(), glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_set_attributes_from_info(
self.as_ref().to_glib_none().0,
info.to_glib_none().0,
flags.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn set_display_name<P: IsA<Cancellable>>(
&self,
display_name: &str,
cancellable: Option<&P>,
) -> Result<File, glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let ret = gio_sys::g_file_set_display_name(
self.as_ref().to_glib_none().0,
display_name.to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
}
}
}
fn set_display_name_async<
P: IsA<Cancellable>,
Q: FnOnce(Result<File, glib::Error>) + Send + 'static,
>(
&self,
display_name: &str,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn set_display_name_async_trampoline<
Q: FnOnce(Result<File, glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let ret =
gio_sys::g_file_set_display_name_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(from_glib_full(ret))
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = set_display_name_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_set_display_name_async(
self.as_ref().to_glib_none().0,
display_name.to_glib_none().0,
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn set_display_name_async_future(
&self,
display_name: &str,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<File, glib::Error>> + 'static>> {
let display_name = String::from(display_name);
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.set_display_name_async(
&display_name,
io_priority,
Some(&cancellable),
move |res| {
send.resolve(res);
},
);
cancellable
}))
}
fn start_mountable<
P: IsA<MountOperation>,
Q: IsA<Cancellable>,
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
&self,
flags: DriveStartFlags,
start_operation: Option<&P>,
cancellable: Option<&Q>,
callback: R,
) {
let user_data: Box_<R> = Box_::new(callback);
unsafe extern "C" fn start_mountable_trampoline<
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let _ =
gio_sys::g_file_start_mountable_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
};
let callback: Box_<R> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = start_mountable_trampoline::<R>;
unsafe {
gio_sys::g_file_start_mountable(
self.as_ref().to_glib_none().0,
flags.to_glib(),
start_operation.map(|p| p.as_ref()).to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn start_mountable_future<P: IsA<MountOperation> + Clone + 'static>(
&self,
flags: DriveStartFlags,
start_operation: Option<&P>,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>> {
let start_operation = start_operation.map(ToOwned::to_owned);
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.start_mountable(
flags,
start_operation.as_ref().map(::std::borrow::Borrow::borrow),
Some(&cancellable),
move |res| {
send.resolve(res);
},
);
cancellable
}))
}
fn stop_mountable<
P: IsA<MountOperation>,
Q: IsA<Cancellable>,
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
&self,
flags: MountUnmountFlags,
mount_operation: Option<&P>,
cancellable: Option<&Q>,
callback: R,
) {
let user_data: Box_<R> = Box_::new(callback);
unsafe extern "C" fn stop_mountable_trampoline<
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let _ =
gio_sys::g_file_stop_mountable_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
};
let callback: Box_<R> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = stop_mountable_trampoline::<R>;
unsafe {
gio_sys::g_file_stop_mountable(
self.as_ref().to_glib_none().0,
flags.to_glib(),
mount_operation.map(|p| p.as_ref()).to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn stop_mountable_future<P: IsA<MountOperation> + Clone + 'static>(
&self,
flags: MountUnmountFlags,
mount_operation: Option<&P>,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>> {
let mount_operation = mount_operation.map(ToOwned::to_owned);
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.stop_mountable(
flags,
mount_operation.as_ref().map(::std::borrow::Borrow::borrow),
Some(&cancellable),
move |res| {
send.resolve(res);
},
);
cancellable
}))
}
fn supports_thread_contexts(&self) -> bool {
unsafe {
from_glib(gio_sys::g_file_supports_thread_contexts(
self.as_ref().to_glib_none().0,
))
}
}
fn trash<P: IsA<Cancellable>>(&self, cancellable: Option<&P>) -> Result<(), glib::Error> {
unsafe {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_trash(
self.as_ref().to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
&mut error,
);
if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
}
}
}
fn trash_async<P: IsA<Cancellable>, Q: FnOnce(Result<(), glib::Error>) + Send + 'static>(
&self,
io_priority: glib::Priority,
cancellable: Option<&P>,
callback: Q,
) {
let user_data: Box_<Q> = Box_::new(callback);
unsafe extern "C" fn trash_async_trampoline<
Q: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_trash_finish(_source_object as *mut _, res, &mut error);
let result = if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
};
let callback: Box_<Q> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = trash_async_trampoline::<Q>;
unsafe {
gio_sys::g_file_trash_async(
self.as_ref().to_glib_none().0,
io_priority.to_glib(),
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn trash_async_future(
&self,
io_priority: glib::Priority,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>> {
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.trash_async(io_priority, Some(&cancellable), move |res| {
send.resolve(res);
});
cancellable
}))
}
fn unmount_mountable_with_operation<
P: IsA<MountOperation>,
Q: IsA<Cancellable>,
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
&self,
flags: MountUnmountFlags,
mount_operation: Option<&P>,
cancellable: Option<&Q>,
callback: R,
) {
let user_data: Box_<R> = Box_::new(callback);
unsafe extern "C" fn unmount_mountable_with_operation_trampoline<
R: FnOnce(Result<(), glib::Error>) + Send + 'static,
>(
_source_object: *mut gobject_sys::GObject,
res: *mut gio_sys::GAsyncResult,
user_data: glib_sys::gpointer,
) {
let mut error = ptr::null_mut();
let _ = gio_sys::g_file_unmount_mountable_with_operation_finish(
_source_object as *mut _,
res,
&mut error,
);
let result = if error.is_null() {
Ok(())
} else {
Err(from_glib_full(error))
};
let callback: Box_<R> = Box_::from_raw(user_data as *mut _);
callback(result);
}
let callback = unmount_mountable_with_operation_trampoline::<R>;
unsafe {
gio_sys::g_file_unmount_mountable_with_operation(
self.as_ref().to_glib_none().0,
flags.to_glib(),
mount_operation.map(|p| p.as_ref()).to_glib_none().0,
cancellable.map(|p| p.as_ref()).to_glib_none().0,
Some(callback),
Box_::into_raw(user_data) as *mut _,
);
}
}
fn unmount_mountable_with_operation_future<P: IsA<MountOperation> + Clone + 'static>(
&self,
flags: MountUnmountFlags,
mount_operation: Option<&P>,
) -> Pin<Box_<dyn std::future::Future<Output = Result<(), glib::Error>> + 'static>> {
let mount_operation = mount_operation.map(ToOwned::to_owned);
Box_::pin(crate::GioFuture::new(self, move |obj, send| {
let cancellable = Cancellable::new();
obj.unmount_mountable_with_operation(
flags,
mount_operation.as_ref().map(::std::borrow::Borrow::borrow),
Some(&cancellable),
move |res| {
send.resolve(res);
},
);
cancellable
}))
}
}
impl fmt::Display for File {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "File")
}
}