mirror of
https://github.com/fumiama/fumidb.git
synced 2026-06-06 01:00:32 +08:00
finish page & file
This commit is contained in:
24
include/file.h
Normal file
24
include/file.h
Normal file
@@ -0,0 +1,24 @@
|
||||
#ifndef _FILE_H_
|
||||
#define _FILE_H_
|
||||
|
||||
#include <stdint.h>
|
||||
|
||||
// 初始化并写入数据库文件头
|
||||
int init_file_header_page(int fd);
|
||||
|
||||
// 获得数据库版本
|
||||
uint16_t get_db_version(int fd);
|
||||
|
||||
// 设置 ptr of unused blk 字段
|
||||
int set_first_unused_block(int fd, uint64_t ptr);
|
||||
|
||||
// 获得 ptr of unused blk 字段
|
||||
uint64_t get_first_unused_block(int fd);
|
||||
|
||||
// 设置 ptr of next table 字段
|
||||
int set_first_table(int fd, uint64_t ptr);
|
||||
|
||||
// 获得 ptr of next table 字段
|
||||
uint64_t get_first_table(int fd);
|
||||
|
||||
#endif
|
||||
@@ -7,27 +7,61 @@
|
||||
#define PAGESZ 4096
|
||||
#endif
|
||||
|
||||
// 获取文件中的第一个空闲页,并将其 mmap 到内存
|
||||
// 获取文件中的第一个空闲页,并将其读到内存
|
||||
// 如果现有空闲均无整页,则新分配一页
|
||||
// 返回指针的 -8 字节记录了本页在文件的偏移
|
||||
// 因此实际上分配了 PAGESZ+8 的空间
|
||||
// 返回:
|
||||
// EOF 错误
|
||||
// NULL 错误,参见 errno
|
||||
// page 指针
|
||||
void* alloc_page(int fd);
|
||||
|
||||
// 释放分配的页,将其标记为空闲以备使用
|
||||
// 刷新一页
|
||||
// 返回:
|
||||
// EOF 错误
|
||||
// EOF lseek 错误,参见 errno
|
||||
// 0/1 write size != PAGESZ
|
||||
int sync_page(int fd, void* page);
|
||||
|
||||
// 刷新并释放 page
|
||||
// 返回:
|
||||
// EOF lseek 错误,参见 errno
|
||||
// 0/1 write size != PAGESZ
|
||||
int unmount_page(int fd, void* page);
|
||||
|
||||
// 释放分配的页,将其标记为空闲以备使用
|
||||
// 同时将数据刷新到文件
|
||||
// 返回:
|
||||
// EOF 错误,参见 errno
|
||||
// 0 成功
|
||||
int free_page(int fd, void* page);
|
||||
|
||||
// 获取文件中的第一个满足 size 大小的块
|
||||
// 获取文件中的第一个满足 size 大小的块的位置
|
||||
// 返回的块大小一定是 size,实际上为 size + 8 + 2
|
||||
// 开头的 8+2 字节记录了真正的块位置与大小以备释放
|
||||
// 返回的 ptr 已经跳过这 10 个字节
|
||||
// 返回:
|
||||
// EOF 错误
|
||||
void* alloc_block(int fd, size_t size);
|
||||
// NULL 错误,参见 errno
|
||||
// blk 指针
|
||||
void* alloc_block(int fd, uint16_t size);
|
||||
|
||||
// 刷新 block 到文件
|
||||
// 返回:
|
||||
// EOF lseek 错误或 size 过大,参见 errno
|
||||
// 0/1 write size != PAGESZ
|
||||
int sync_block(int fd, void* blk);
|
||||
|
||||
// 刷新 block 到文件并释放
|
||||
// 返回:
|
||||
// EOF lseek 错误或 size 过大,参见 errno
|
||||
// 0/1 write size != PAGESZ
|
||||
int unmount_block(int fd, void* blk);
|
||||
|
||||
// 释放块,并将其标记为空闲以备使用
|
||||
// 值得注意的是,只有在本页最后一块
|
||||
// 也被释放后,这一页才会被真正释放
|
||||
// 如果该块前后也有空闲且不跨过4096
|
||||
// 将会被合并
|
||||
// 返回:
|
||||
// EOF 错误
|
||||
int free_block(int fd, void* page);
|
||||
// EOF 错误,参见 errno
|
||||
// 0 成功
|
||||
int free_block(int fd, void* blk);
|
||||
|
||||
#endif
|
||||
Reference in New Issue
Block a user