From e53a4d0a9ebea73f27fc6786a85439f9f8c00e42 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Thu, 23 Apr 2020 14:51:58 +0200 Subject: [PATCH] lib/nfs/FileReader: reset `state` in OnNfsCallback() The object's state is `IDLE` when OnNfsCallback() gets invoked, so let's use the start of the method to reset the `state` field. --- src/lib/nfs/FileReader.cxx | 9 +-------- 1 file changed, 1 insertion(+), 8 deletions(-) diff --git a/src/lib/nfs/FileReader.cxx b/src/lib/nfs/FileReader.cxx index 02900a059..27dea109f 100644 --- a/src/lib/nfs/FileReader.cxx +++ b/src/lib/nfs/FileReader.cxx @@ -180,14 +180,11 @@ NfsFileReader::OnNfsConnectionDisconnected(std::exception_ptr e) noexcept inline void NfsFileReader::OpenCallback(nfsfh *_fh) noexcept { - assert(state == State::OPEN); assert(connection != nullptr); assert(_fh != nullptr); fh = _fh; - state = State::IDLE; - try { connection->Stat(fh, *this); } catch (...) { @@ -201,13 +198,10 @@ NfsFileReader::OpenCallback(nfsfh *_fh) noexcept inline void NfsFileReader::StatCallback(const struct stat *st) noexcept { - assert(state == State::STAT); assert(connection != nullptr); assert(fh != nullptr); assert(st != nullptr); - state = State::IDLE; - if (!S_ISREG(st->st_mode)) { OnNfsFileError(std::make_exception_ptr(std::runtime_error("Not a regular file"))); return; @@ -219,7 +213,7 @@ NfsFileReader::StatCallback(const struct stat *st) noexcept void NfsFileReader::OnNfsCallback(unsigned status, void *data) noexcept { - switch (state) { + switch (std::exchange(state, State::IDLE)) { case State::INITIAL: case State::DEFER: case State::MOUNT: @@ -236,7 +230,6 @@ NfsFileReader::OnNfsCallback(unsigned status, void *data) noexcept break; case State::READ: - state = State::IDLE; OnNfsFileRead(data, status); break; }