2018-12-31 20:04:05 +01:00
|
|
|
//
|
2022-12-31 22:28:08 +01:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2023
|
2018-12-31 20:04:05 +01:00
|
|
|
//
|
|
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "td/utils/buffer.h"
|
2023-08-05 15:09:36 +02:00
|
|
|
#include "td/utils/common.h"
|
2019-08-12 13:45:57 +02:00
|
|
|
#include "td/utils/SharedSlice.h"
|
2019-08-13 22:52:54 +02:00
|
|
|
#include "td/utils/Slice.h"
|
2018-12-31 20:04:05 +01:00
|
|
|
#include "td/utils/Status.h"
|
|
|
|
|
|
|
|
namespace td {
|
|
|
|
|
2018-12-19 15:48:39 +01:00
|
|
|
Result<BufferSlice> read_file(CSlice path, int64 size = -1, int64 offset = 0);
|
2019-08-13 22:52:54 +02:00
|
|
|
Result<string> read_file_str(CSlice path, int64 size = -1, int64 offset = 0);
|
2020-06-24 13:47:36 +02:00
|
|
|
Result<SecureString> read_file_secure(CSlice path, int64 size = -1, int64 offset = 0);
|
2018-12-31 20:04:05 +01:00
|
|
|
|
2018-10-26 16:11:20 +02:00
|
|
|
Status copy_file(CSlice from, CSlice to, int64 size = -1) TD_WARN_UNUSED_RESULT;
|
2018-12-31 20:04:05 +01:00
|
|
|
|
2020-06-24 13:47:36 +02:00
|
|
|
struct WriteFileOptions {
|
2020-06-26 01:24:13 +02:00
|
|
|
bool need_sync = false;
|
2020-06-24 13:47:36 +02:00
|
|
|
bool need_lock = true;
|
|
|
|
};
|
|
|
|
Status write_file(CSlice to, Slice data, WriteFileOptions options = {}) TD_WARN_UNUSED_RESULT;
|
2018-12-31 20:04:05 +01:00
|
|
|
|
2019-07-06 13:29:15 +02:00
|
|
|
string clean_filename(CSlice name);
|
2019-01-24 19:15:08 +01:00
|
|
|
|
2020-06-26 01:24:13 +02:00
|
|
|
// writes data to file and ensures that the file is either fully overriden, or is left intact
|
|
|
|
// uses path_tmp to temporary store data, then calls rename
|
2020-06-24 13:47:36 +02:00
|
|
|
Status atomic_write_file(CSlice path, Slice data, CSlice path_tmp = {});
|
|
|
|
|
2018-12-31 20:04:05 +01:00
|
|
|
} // namespace td
|