2019-07-27 22:44:32 +08:00
|
|
|
|
#pragma once
|
2017-06-02 14:47:24 +08:00
|
|
|
|
#include "../acl_cpp_define.hpp"
|
|
|
|
|
#include "istream.hpp"
|
|
|
|
|
#include "ostream.hpp"
|
2014-11-19 00:25:21 +08:00
|
|
|
|
|
|
|
|
|
namespace acl {
|
|
|
|
|
|
|
|
|
|
class string;
|
|
|
|
|
|
|
|
|
|
class ACL_CPP_API fstream
|
|
|
|
|
: public istream
|
|
|
|
|
, public ostream
|
|
|
|
|
{
|
|
|
|
|
public:
|
|
|
|
|
fstream(void);
|
|
|
|
|
virtual ~fstream(void);
|
|
|
|
|
|
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 根据文件路径打开文件流, 这是最基础的打开文件的方式
|
|
|
|
|
* @param path {const char*} 文件名
|
|
|
|
|
* @param oflags {unsigned int} 标志位, We're assuming that
|
2015-12-03 17:00:07 +08:00
|
|
|
|
* O_RDONLY: 0x0000, O_WRONLY: 0x0001, O_RDWR: 0x0002,
|
|
|
|
|
* O_APPEND: 0x0008, O_CREAT: 0x0100, O_TRUNC: 0x0200,
|
|
|
|
|
* O_EXCL: 0x0400; just for win32, O_TEXT: 0x4000,
|
|
|
|
|
* O_BINARY: 0x8000, O_RAW: O_BINARY, O_SEQUENTIAL: 0x0020,
|
|
|
|
|
* O_RANDOM: 0x0010.
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* @param mode {int} 打开文件句柄时的模式(如: 0600)
|
|
|
|
|
* @return {bool} 打开文件是否成功
|
2014-11-19 00:25:21 +08:00
|
|
|
|
*/
|
|
|
|
|
bool open(const char* path, unsigned int oflags, int mode);
|
|
|
|
|
|
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 以读/写方式打开文件流,当文件不存在时则创建新文件,当文件存在时则
|
|
|
|
|
* 将文件清空, 文件属性为 0700
|
|
|
|
|
* @param path {const char*} 文件名
|
|
|
|
|
* @return {bool} 打开文件是否成功
|
2014-11-19 00:25:21 +08:00
|
|
|
|
*/
|
|
|
|
|
bool open_trunc(const char* path);
|
|
|
|
|
|
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 以读/写方式建新文件,文件属性为 0700, 若文件不存在则创建新文件,
|
|
|
|
|
* 若存在则打开旧文件
|
|
|
|
|
* @return {bool} 文件创建是否成功
|
2014-11-19 00:25:21 +08:00
|
|
|
|
*/
|
|
|
|
|
bool create(const char* path);
|
|
|
|
|
|
2016-01-17 13:35:12 +08:00
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 将本类对象对应的文件从磁盘上删除,该函数只有当内部知道文件路径
|
|
|
|
|
* 时才能正确删除文件,否则无法删除
|
|
|
|
|
* @return {bool} 删除文件是否成功
|
2016-01-17 13:35:12 +08:00
|
|
|
|
*/
|
|
|
|
|
bool remove(void);
|
|
|
|
|
|
2016-10-21 15:02:50 +08:00
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 将当前文件重命名为指定文件名,针对 WINDOWS 平台,需要先关闭当前文件
|
|
|
|
|
* 句柄,当重命名成功后再重新打开新的目标文件
|
|
|
|
|
* @param from_path {const char*} 源文件名
|
|
|
|
|
* @param to_path {const char*} 目标文件名
|
|
|
|
|
* @return {bool} 命名是否成功
|
2016-10-21 15:02:50 +08:00
|
|
|
|
*/
|
|
|
|
|
bool rename(const char* from_path, const char* to_path);
|
|
|
|
|
|
2015-06-29 17:33:11 +08:00
|
|
|
|
#if defined(_WIN32) || defined(_WIN64)
|
2014-11-19 00:25:21 +08:00
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 根据系统的文件句柄打开 fstream 文件流对象
|
|
|
|
|
* @param fh 系统文件句柄
|
|
|
|
|
* @param oflags 打开标志位
|
|
|
|
|
* @param path {const char*} 非 NULL 时当被作为该文件句柄的文件路径
|
|
|
|
|
* 来存储,以便于 file_path, remove 使用
|
2014-11-19 00:25:21 +08:00
|
|
|
|
*/
|
2016-01-17 13:35:12 +08:00
|
|
|
|
void open(void* fh, unsigned int oflags, const char* path = NULL);
|
2014-11-19 00:25:21 +08:00
|
|
|
|
|
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 移动文件指针位置
|
|
|
|
|
* @param offset {__int64} 偏移量
|
|
|
|
|
* @param whence {int} 移动方向:SEEK_SET(从文件起始位置后移动),
|
|
|
|
|
* SEEK_CUR(从当前文件指针位置向后移动), SEEK_END(从文件尾向前移动)
|
|
|
|
|
* @return {acl_off_t} 正常时返回值 >= 0,出错时返回 -1
|
2014-11-19 00:25:21 +08:00
|
|
|
|
*/
|
|
|
|
|
__int64 fseek(__int64 offset, int whence);
|
|
|
|
|
|
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 获得当前系统文件指针在文件中的偏移位置
|
|
|
|
|
* @return {acl_off_t} 正常时返回值 >= 0,出错时返回 -1
|
2014-11-19 00:25:21 +08:00
|
|
|
|
*/
|
2019-07-07 11:00:12 +08:00
|
|
|
|
__int64 ftell(void);
|
2014-11-19 00:25:21 +08:00
|
|
|
|
|
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 将文件尺寸截断至指定大小
|
|
|
|
|
* @param length {acl_off_t} 文件截断后的大小尺寸
|
|
|
|
|
* @return {bool} 是否成功
|
2014-11-19 00:25:21 +08:00
|
|
|
|
*/
|
|
|
|
|
bool ftruncate(__int64 length);
|
|
|
|
|
|
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 获得当前文件的大小
|
|
|
|
|
* @return {acl_off_t} 正常时返回值 >= 0,出错返回 -1
|
2014-11-19 00:25:21 +08:00
|
|
|
|
*/
|
|
|
|
|
__int64 fsize(void) const;
|
|
|
|
|
|
2019-07-24 16:12:58 +08:00
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 静态方法用于获取指定文件的文件大小
|
|
|
|
|
* @param path {const char*} 非空字符串指定文件路径
|
|
|
|
|
* @return {__int64} 正常时返回值 >= 0,出错时返回 -1
|
2019-07-24 16:12:58 +08:00
|
|
|
|
*/
|
|
|
|
|
static __int64 fsize(const char* path);
|
|
|
|
|
|
2014-11-19 00:25:21 +08:00
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 返回系统文件句柄
|
|
|
|
|
* @return 系统文件句柄,出错时返回 ACL_FILE_INVALID
|
2014-11-19 00:25:21 +08:00
|
|
|
|
*/
|
2019-07-07 11:00:12 +08:00
|
|
|
|
void* file_handle(void) const;
|
2014-11-19 00:25:21 +08:00
|
|
|
|
#else
|
2016-01-17 13:35:12 +08:00
|
|
|
|
void open(int fh, unsigned int oflags, const char* path = NULL);
|
2014-11-19 00:25:21 +08:00
|
|
|
|
long long int fseek(long long int offset, int whence);
|
2019-07-07 11:00:12 +08:00
|
|
|
|
long long int ftell(void);
|
2014-11-19 00:25:21 +08:00
|
|
|
|
bool ftruncate(long long int length);
|
|
|
|
|
long long int fsize(void) const;
|
2019-07-24 16:12:58 +08:00
|
|
|
|
static long long int fsize(const char* path);
|
2019-07-07 11:00:12 +08:00
|
|
|
|
int file_handle(void) const;
|
2014-11-19 00:25:21 +08:00
|
|
|
|
#endif
|
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 获得文件的全路径
|
|
|
|
|
* @return {const char*} 若返回空则表示文件还未打开或出错
|
2014-11-19 00:25:21 +08:00
|
|
|
|
*/
|
2019-07-07 11:00:12 +08:00
|
|
|
|
const char* file_path(void) const;
|
2018-07-05 13:56:10 +08:00
|
|
|
|
|
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 当文件打开后,该方法用来对文件加锁
|
|
|
|
|
* @param exclude {bool} 加锁方式是否是独占锁,默认是独占锁,如果该值
|
|
|
|
|
* 为 false, 则为共享锁
|
|
|
|
|
* @return {bool} 返回 false 表示加锁失败,可通过 acl::last_serror 查看
|
|
|
|
|
* 出错原因
|
2018-07-05 13:56:10 +08:00
|
|
|
|
*/
|
|
|
|
|
bool lock(bool exclude = true);
|
|
|
|
|
|
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 当文件打开后,该方法用来尝试对文件加锁,如果加锁成功则返回 true,如
|
|
|
|
|
* 果该文件已经被其它进程加锁,则返回 false
|
|
|
|
|
* @param exclude {bool} 加锁方式是否是独占锁,默认是独占锁,如果该值
|
|
|
|
|
* 为 false, 则为共享锁
|
|
|
|
|
* @return {bool} 返回 false 表示加锁失败,可通过 acl::last_serror 查看
|
|
|
|
|
* 出错原因
|
2018-07-05 13:56:10 +08:00
|
|
|
|
*/
|
|
|
|
|
bool try_lock(bool exclude = true);
|
|
|
|
|
|
|
|
|
|
/**
|
2019-07-27 22:44:32 +08:00
|
|
|
|
* 当调用 lock 或 try_lock 成功后可以调用本方法对文件解锁
|
|
|
|
|
* @return {bool} 解锁是否成功
|
2018-07-05 13:56:10 +08:00
|
|
|
|
*/
|
|
|
|
|
bool unlock(void);
|
2014-11-19 00:25:21 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
} // namespace acl
|