From 5acbe8d9d860ee6cf256a2e293194d671c195327 Mon Sep 17 00:00:00 2001 From: hjk Date: Thu, 15 Jul 2021 10:51:39 +0200 Subject: [PATCH] Docker: Implement fallback for DockerDevice::readFileContents() Change-Id: I89ca268d226019a21bb73a2f039e781d0f595336 Reviewed-by: Christian Stenger --- src/plugins/docker/dockerdevice.cpp | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/src/plugins/docker/dockerdevice.cpp b/src/plugins/docker/dockerdevice.cpp index 9a19c513a50..401d4e5bbf5 100644 --- a/src/plugins/docker/dockerdevice.cpp +++ b/src/plugins/docker/dockerdevice.cpp @@ -73,6 +73,8 @@ #include #include +#include + #ifdef Q_OS_UNIX #include #include @@ -1201,8 +1203,21 @@ QByteArray DockerDevice::fileContents(const FilePath &filePath, qint64 limit, qi if (hasLocalFileAccess()) return mapToLocalAccess(filePath).fileContents(limit, offset); - QTC_CHECK(false); // FIXME: Implement - return {}; + QStringList args = {"if=" + filePath.path(), "status=none"}; + if (limit > 0 || offset > 0) { + const qint64 gcd = std::gcd(limit, offset); + args += {QString("bs=%1").arg(gcd), + QString("count=%1").arg(limit / gcd), + QString("seek=%1").arg(offset / gcd)}; + } + + QtcProcess proc; + proc.setCommand({"dd", args}); + runProcess(proc); + proc.waitForFinished(); + + QByteArray output = proc.readAllStandardOutput(); + return output; } bool DockerDevice::writeFileContents(const Utils::FilePath &filePath, const QByteArray &data) const