1
0
mirror of https://github.com/falk-werner/webfuse synced 2026-03-02 03:40:24 +00:00

add test for open

This commit is contained in:
Falk Werner
2023-01-03 19:55:27 +01:00
parent a5673b281c
commit 516749876b
5 changed files with 77 additions and 1 deletions

View File

@@ -88,6 +88,9 @@ public:
case request_type::utimens:
fs_utimens(reader, writer);
break;
case request_type::open:
fs_open(reader, writer);
break;
case request_type::create:
fs_create(reader, writer);
break;
@@ -219,6 +222,20 @@ private:
writer.write_i32(result);
}
void fs_open(messagereader & reader, messagewriter & writer)
{
auto const path = reader.read_str();
auto const flags = reader.read_openflags();
uint64_t handle = static_cast<uint64_t>(-1);
auto const result = fs_.open(path, flags, handle);
writer.write_i32(result);
if (result == 0)
{
writer.write_u64(handle);
}
}
void fs_create(messagereader & reader, messagewriter & writer)
{
auto const path = reader.read_str();

View File

@@ -2,6 +2,7 @@
#include "webfuse/filesystem/status.hpp"
#include "webfuse/filesystem/filemode.hpp"
#include "webfuse/filesystem/accessmode.hpp"
#include "webfuse/filesystem/openflags.hpp"
#include <stdexcept>
@@ -186,5 +187,13 @@ void messagereader::read_time(struct timespec &time)
time.tv_nsec = static_cast<long>(read_u32());
}
int messagereader::read_openflags()
{
auto const value = read_i32();
openflags flags(value);
return flags.to_int();
}
}

View File

@@ -41,7 +41,7 @@ public:
void read_strings(std::vector<std::string> &entries);
void read_time(struct timespec &time);
int read_openflags();
private:
std::string data;