You need to sign in or sign up before continuing.
Commit 07b50f6c authored by Max Kellermann's avatar Max Kellermann

lib/nfs/Connection: add methods {Open,Read,Close}Directory()

parent 61b3aaaa
...@@ -50,6 +50,21 @@ NfsConnection::CancellableCallback::Stat(nfs_context *ctx, ...@@ -50,6 +50,21 @@ NfsConnection::CancellableCallback::Stat(nfs_context *ctx,
} }
inline bool inline bool
NfsConnection::CancellableCallback::OpenDirectory(nfs_context *ctx,
const char *path,
Error &error)
{
int result = nfs_opendir_async(ctx, path, Callback, this);
if (result < 0) {
error.Format(nfs_domain, "nfs_opendir_async() failed: %s",
nfs_get_error(ctx));
return false;
}
return true;
}
inline bool
NfsConnection::CancellableCallback::Open(nfs_context *ctx, NfsConnection::CancellableCallback::Open(nfs_context *ctx,
const char *path, int flags, const char *path, int flags,
Error &error) Error &error)
...@@ -207,6 +222,34 @@ NfsConnection::Stat(const char *path, NfsCallback &callback, Error &error) ...@@ -207,6 +222,34 @@ NfsConnection::Stat(const char *path, NfsCallback &callback, Error &error)
} }
bool bool
NfsConnection::OpenDirectory(const char *path, NfsCallback &callback,
Error &error)
{
assert(!callbacks.Contains(callback));
auto &c = callbacks.Add(callback, *this, true);
if (!c.OpenDirectory(context, path, error)) {
callbacks.Remove(c);
return false;
}
ScheduleSocket();
return true;
}
const struct nfsdirent *
NfsConnection::ReadDirectory(struct nfsdir *dir)
{
return nfs_readdir(context, dir);
}
void
NfsConnection::CloseDirectory(struct nfsdir *dir)
{
return nfs_closedir(context, dir);
}
bool
NfsConnection::Open(const char *path, int flags, NfsCallback &callback, NfsConnection::Open(const char *path, int flags, NfsCallback &callback,
Error &error) Error &error)
{ {
......
...@@ -33,6 +33,8 @@ ...@@ -33,6 +33,8 @@
#include <forward_list> #include <forward_list>
struct nfs_context; struct nfs_context;
struct nfsdir;
struct nfsdirent;
class NfsCallback; class NfsCallback;
/** /**
...@@ -66,6 +68,8 @@ class NfsConnection : SocketMonitor, DeferredMonitor { ...@@ -66,6 +68,8 @@ class NfsConnection : SocketMonitor, DeferredMonitor {
bool Stat(nfs_context *context, const char *path, bool Stat(nfs_context *context, const char *path,
Error &error); Error &error);
bool OpenDirectory(nfs_context *context, const char *path,
Error &error);
bool Open(nfs_context *context, const char *path, int flags, bool Open(nfs_context *context, const char *path, int flags,
Error &error); Error &error);
bool Stat(nfs_context *context, struct nfsfh *fh, bool Stat(nfs_context *context, struct nfsfh *fh,
...@@ -158,6 +162,12 @@ public: ...@@ -158,6 +162,12 @@ public:
void RemoveLease(NfsLease &lease); void RemoveLease(NfsLease &lease);
bool Stat(const char *path, NfsCallback &callback, Error &error); bool Stat(const char *path, NfsCallback &callback, Error &error);
bool OpenDirectory(const char *path, NfsCallback &callback,
Error &error);
const struct nfsdirent *ReadDirectory(struct nfsdir *dir);
void CloseDirectory(struct nfsdir *dir);
bool Open(const char *path, int flags, NfsCallback &callback, bool Open(const char *path, int flags, NfsCallback &callback,
Error &error); Error &error);
bool Stat(struct nfsfh *fh, NfsCallback &callback, Error &error); bool Stat(struct nfsfh *fh, NfsCallback &callback, Error &error);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment