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
|
|
|
|
2019-01-25 19:35:39 +01:00
|
|
|
// Forward declarations for boost because it is not included here.
|
|
|
|
namespace boost::filesystem {}
|
|
|
|
|
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;
|
2019-01-25 19:35:39 +01:00
|
|
|
|
|
|
|
// Forward interface to boost::filesystem. We do not include boost
|
|
|
|
// from here; it is used internally only. Some exposed interfaces
|
|
|
|
// may make forward-declared references to boost symbols.
|
|
|
|
namespace filesystem = boost::filesystem;
|
2019-03-16 02:40:16 +01:00
|
|
|
|
2019-04-08 01:28:21 +02:00
|
|
|
// Log facility for ircd::fs
|
|
|
|
extern log::log log;
|
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"
|
2019-04-06 21:13:16 +02:00
|
|
|
#include "op.h"
|
2018-12-30 05:02:22 +01:00
|
|
|
#include "opts.h"
|
2019-01-02 03:35:09 +01:00
|
|
|
#include "dev.h"
|
2018-12-30 00:27:58 +01:00
|
|
|
#include "fd.h"
|
2019-04-08 02:29:23 +02:00
|
|
|
#include "wait.h"
|
2018-12-30 00:27:58 +01:00
|
|
|
#include "read.h"
|
|
|
|
#include "write.h"
|
|
|
|
#include "sync.h"
|
2019-04-11 01:49:47 +02:00
|
|
|
#include "aio.h"
|
2019-08-11 07:06:08 +02:00
|
|
|
#include "iou.h"
|
2020-05-09 02:26:46 +02:00
|
|
|
#include "select.h"
|
2018-12-30 00:27:58 +01:00
|
|
|
#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
|
|
|
|
{
|
2020-06-07 08:26:28 +02:00
|
|
|
dev::init _dev_;
|
2019-08-11 07:06:08 +02:00
|
|
|
iou::init _iou_;
|
2018-11-28 03:09:12 +01:00
|
|
|
aio::init _aio_;
|
|
|
|
|
2017-10-12 02:50:13 +02:00
|
|
|
init();
|
|
|
|
~init() noexcept;
|
|
|
|
};
|