diff options
| author | Carl Hetherington <cth@carlh.net> | 2023-01-27 00:43:05 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2023-01-29 22:49:56 +0100 |
| commit | 7bce98ec4c05081569cb66b68523e1466058ea76 (patch) | |
| tree | 8d4847ff0c6eb5c5f5c0a6ad63126d7b21c37125 /src/lib | |
| parent | ce603965fbf2021befb1d8c18fe96c677843eba5 (diff) | |
Add DiskWriterBackendResponse::write_to_nanomsg() and use it
everywhere. In the process, use raw_convert() on both ends
to avoid any locale-based problems with floating point number
separators.
Diffstat (limited to 'src/lib')
| -rw-r--r-- | src/lib/disk_writer_messages.cc | 47 | ||||
| -rw-r--r-- | src/lib/disk_writer_messages.h | 2 | ||||
| -rw-r--r-- | src/lib/ext.cc | 14 |
3 files changed, 52 insertions, 11 deletions
diff --git a/src/lib/disk_writer_messages.cc b/src/lib/disk_writer_messages.cc index e42e80ec6..a862f2fc6 100644 --- a/src/lib/disk_writer_messages.cc +++ b/src/lib/disk_writer_messages.cc @@ -22,8 +22,10 @@ #include "dcpomatic_assert.h" #include "disk_writer_messages.h" #include "nanomsg.h" +#include <dcp/raw_convert.h> +using std::string; using boost::optional; @@ -39,18 +41,18 @@ DiskWriterBackEndResponse::read_from_nanomsg(Nanomsg& nanomsg, int timeout) } else if (*s == DISK_WRITER_ERROR) { auto const m = nanomsg.receive(500); auto const n = nanomsg.receive(500); - return DiskWriterBackEndResponse::error(m.get_value_or(""), dcp::locale_convert<int>(n.get_value_or("0"))); + return DiskWriterBackEndResponse::error(m.get_value_or(""), dcp::raw_convert<int>(n.get_value_or("0"))); } else if (*s == DISK_WRITER_PONG) { return DiskWriterBackEndResponse::pong(); } else if (*s == DISK_WRITER_FORMAT_PROGRESS) { auto progress = nanomsg.receive(500); - return DiskWriterBackEndResponse::format_progress(dcp::locale_convert<float>(progress.get_value_or("0"))); + return DiskWriterBackEndResponse::format_progress(dcp::raw_convert<float>(progress.get_value_or("0"))); } else if (*s == DISK_WRITER_COPY_PROGRESS) { auto progress = nanomsg.receive(500); - return DiskWriterBackEndResponse::copy_progress(dcp::locale_convert<float>(progress.get_value_or("0"))); + return DiskWriterBackEndResponse::copy_progress(dcp::raw_convert<float>(progress.get_value_or("0"))); } else if (*s == DISK_WRITER_VERIFY_PROGRESS) { auto progress = nanomsg.receive(500); - return DiskWriterBackEndResponse::verify_progress(dcp::locale_convert<float>(progress.get_value_or("0"))); + return DiskWriterBackEndResponse::verify_progress(dcp::raw_convert<float>(progress.get_value_or("0"))); } else { DCPOMATIC_ASSERT(false); } @@ -58,3 +60,40 @@ DiskWriterBackEndResponse::read_from_nanomsg(Nanomsg& nanomsg, int timeout) return {}; } + +/** @return true if the message was sent, false if there was a timeout */ +bool +DiskWriterBackEndResponse::write_to_nanomsg(Nanomsg& nanomsg, int timeout) const +{ + string message; + + switch (_type) + { + case Type::OK: + message = String::compose("%1\n", DISK_WRITER_OK); + break; + case Type::ERROR: + message = String::compose("%1\n%2\n%3\n", DISK_WRITER_ERROR, _error_message, _error_number); + break; + case Type::PONG: + message = String::compose("%1\n", DISK_WRITER_PONG); + break; + case Type::FORMAT_PROGRESS: + message = String::compose("%1\n", DISK_WRITER_FORMAT_PROGRESS); + message += dcp::raw_convert<string>(_progress) + "\n"; + break; + case Type::COPY_PROGRESS: + message = String::compose("%1\n", DISK_WRITER_COPY_PROGRESS); + message += dcp::raw_convert<string>(_progress) + "\n"; + break; + case Type::VERIFY_PROGRESS: + message = String::compose("%1\n", DISK_WRITER_VERIFY_PROGRESS); + message += dcp::raw_convert<string>(_progress) + "\n"; + break; + } + + + return nanomsg.send(message, timeout); +} + + diff --git a/src/lib/disk_writer_messages.h b/src/lib/disk_writer_messages.h index ff6a0b394..8bd1837a8 100644 --- a/src/lib/disk_writer_messages.h +++ b/src/lib/disk_writer_messages.h @@ -137,6 +137,8 @@ public: static boost::optional<DiskWriterBackEndResponse> read_from_nanomsg(Nanomsg& nanomsg, int timeout); + bool write_to_nanomsg(Nanomsg& nanomsg, int timeout) const; + Type type() const { return _type; } diff --git a/src/lib/ext.cc b/src/lib/ext.cc index 49e63d648..29f44d90e 100644 --- a/src/lib/ext.cc +++ b/src/lib/ext.cc @@ -153,7 +153,7 @@ write (boost::filesystem::path from, boost::filesystem::path to, uint64_t& total ++progress_count; if ((progress_count % progress_frequency) == 0 && nanomsg) { - nanomsg->send(String::compose(DISK_WRITER_COPY_PROGRESS "\n%1\n", (1 - float(total_remaining) / total)), SHORT_TIMEOUT); + DiskWriterBackEndResponse::copy_progress(1 - float(total_remaining) / total).write_to_nanomsg(*nanomsg, SHORT_TIMEOUT); } } @@ -194,7 +194,7 @@ read (boost::filesystem::path from, boost::filesystem::path to, uint64_t& total_ remaining -= this_time; total_remaining -= this_time; if (nanomsg) { - nanomsg->send(String::compose(DISK_WRITER_VERIFY_PROGRESS "\n%1\n", (1 - float(total_remaining) / total)), SHORT_TIMEOUT); + DiskWriterBackEndResponse::verify_progress(1 - float(total_remaining) / total).write_to_nanomsg(*nanomsg, SHORT_TIMEOUT); } } @@ -272,7 +272,7 @@ void format_progress (void* context, float progress) { if (context) { - reinterpret_cast<Nanomsg*>(context)->send(String::compose(DISK_WRITER_FORMAT_PROGRESS "\n%1\n", progress), SHORT_TIMEOUT); + DiskWriterBackEndResponse::format_progress(progress).write_to_nanomsg(*reinterpret_cast<Nanomsg*>(context), SHORT_TIMEOUT); } } @@ -419,7 +419,7 @@ try } ext4_device_unregister("ext4_fs"); - if (nanomsg && !nanomsg->send(DISK_WRITER_OK "\n", LONG_TIMEOUT)) { + if (nanomsg && !DiskWriterBackEndResponse::ok().write_to_nanomsg(*nanomsg, LONG_TIMEOUT)) { throw CommunicationFailedError (); } @@ -427,17 +427,17 @@ try } catch (CopyError& e) { LOG_DISK("CopyError (from write): %1 %2", e.message(), e.number().get_value_or(0)); if (nanomsg) { - nanomsg->send(String::compose(DISK_WRITER_ERROR "\n%1\n%2\n", e.message(), e.number().get_value_or(0)), LONG_TIMEOUT); + DiskWriterBackEndResponse::error(e.message(), e.number().get_value_or(0)).write_to_nanomsg(*nanomsg, LONG_TIMEOUT); } } catch (VerifyError& e) { LOG_DISK("VerifyError (from write): %1 %2", e.message(), e.number()); if (nanomsg) { - nanomsg->send(String::compose(DISK_WRITER_ERROR "\n%1\n%2\n", e.message(), e.number()), LONG_TIMEOUT); + DiskWriterBackEndResponse::error(e.message(), e.number()).write_to_nanomsg(*nanomsg, LONG_TIMEOUT); } } catch (exception& e) { LOG_DISK("Exception (from write): %1", e.what()); if (nanomsg) { - nanomsg->send(String::compose(DISK_WRITER_ERROR "\n%1\n0\n", e.what()), LONG_TIMEOUT); + DiskWriterBackEndResponse::error(e.what(), 0).write_to_nanomsg(*nanomsg, LONG_TIMEOUT); } } |
