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/disk_writer_messages.cc | |
| 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/disk_writer_messages.cc')
| -rw-r--r-- | src/lib/disk_writer_messages.cc | 47 |
1 files changed, 43 insertions, 4 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); +} + + |
