2018-02-04 03:22:01 +01:00
|
|
|
// Matrix Construct
|
|
|
|
//
|
2018-01-11 06:30:31 +01:00
|
|
|
// Copyright (C) Matrix Construct Developers, Authors & Contributors
|
2018-02-04 03:22:01 +01:00
|
|
|
// Copyright (C) 2016-2018 Jason Volk <jason@zemos.net>
|
2018-01-11 06:30:31 +01:00
|
|
|
//
|
|
|
|
// Permission to use, copy, modify, and/or distribute this software for any
|
|
|
|
// purpose with or without fee is hereby granted, provided that the above
|
2018-02-04 03:22:01 +01:00
|
|
|
// copyright notice and this permission notice is present in all copies. The
|
|
|
|
// full license for this software is available in the LICENSE file.
|
2016-07-25 10:57:54 +02:00
|
|
|
|
|
|
|
#pragma once
|
2017-03-31 00:46:01 +02:00
|
|
|
#define HAVE_IRCD_FS_H
|
2016-07-25 10:57:54 +02:00
|
|
|
|
2018-12-30 00:27:58 +01:00
|
|
|
/// Local filesystem interface.
|
2017-10-12 02:43:11 +02:00
|
|
|
///
|
|
|
|
/// IRCd has wrapped operations for the local filesystem to maintain a
|
|
|
|
/// cross-platform implementation of asynchronous file IO in conjunction with
|
|
|
|
/// the ircd::ctx userspace context system. These operations will yield your
|
|
|
|
/// ircd::ctx when necessary to not block the event loop on the main thread
|
|
|
|
/// during IOs.
|
2018-12-30 00:27:58 +01:00
|
|
|
///
|
|
|
|
/// Paths are stored in the platform-specific format using plain old character
|
|
|
|
/// strings, which means you should never directly manipulate path strings to
|
|
|
|
/// maintain x-platformness; instead use the (or add more) tools provided by
|
|
|
|
/// this interface (see: path.h).
|
|
|
|
///
|
2017-08-28 23:51:22 +02:00
|
|
|
namespace ircd::fs
|
2016-07-25 10:57:54 +02:00
|
|
|
{
|
2018-01-10 01:48:05 +01:00
|
|
|
struct init;
|
2018-08-23 12:31:36 +02:00
|
|
|
struct error; // custom exception; still inherits from ircd::error
|
2018-12-30 00:27:58 +01:00
|
|
|
}
|
2016-08-14 05:35:06 +02:00
|
|
|
|
2018-12-30 00:27:58 +01:00
|
|
|
#include "error.h"
|
|
|
|
#include "path.h"
|
|
|
|
#include "iov.h"
|
|
|
|
#include "fd.h"
|
|
|
|
#include "aio.h"
|
|
|
|
#include "read.h"
|
|
|
|
#include "write.h"
|
|
|
|
#include "sync.h"
|
|
|
|
#include "stdin.h"
|
|
|
|
#include "support.h"
|
2016-08-31 10:03:44 +02:00
|
|
|
|
2018-12-30 00:27:58 +01:00
|
|
|
namespace ircd::fs
|
|
|
|
{
|
|
|
|
// Observers
|
2018-02-27 05:35:09 +01:00
|
|
|
bool exists(const string_view &path);
|
|
|
|
bool is_dir(const string_view &path);
|
|
|
|
bool is_reg(const string_view &path);
|
2017-12-21 01:33:12 +01:00
|
|
|
size_t size(const string_view &path);
|
2018-02-27 05:35:09 +01:00
|
|
|
std::vector<std::string> ls(const string_view &path);
|
2018-12-30 00:27:58 +01:00
|
|
|
std::vector<std::string> ls_r(const string_view &path);
|
2016-08-31 10:03:44 +02:00
|
|
|
|
2018-12-30 00:27:58 +01:00
|
|
|
// Modifiers
|
2018-02-27 05:37:19 +01:00
|
|
|
bool rename(std::nothrow_t, const string_view &old, const string_view &new_);
|
2018-12-30 00:27:58 +01:00
|
|
|
bool rename(const string_view &old, const string_view &new_);
|
2018-02-27 05:37:19 +01:00
|
|
|
bool remove(std::nothrow_t, const string_view &path);
|
|
|
|
bool remove(const string_view &path);
|
2018-02-27 05:35:09 +01:00
|
|
|
bool mkdir(const string_view &path);
|
2017-08-28 23:51:22 +02:00
|
|
|
}
|
2017-10-12 02:50:13 +02:00
|
|
|
|
2018-12-30 00:27:58 +01:00
|
|
|
/// Filesystem interface init / fini held by ircd::main().
|
2017-10-12 02:50:13 +02:00
|
|
|
struct ircd::fs::init
|
|
|
|
{
|
2018-11-28 03:09:12 +01:00
|
|
|
aio::init _aio_;
|
|
|
|
|
2017-10-12 02:50:13 +02:00
|
|
|
init();
|
|
|
|
~init() noexcept;
|
|
|
|
};
|