From 3fd8e50044c76143d5d401c5274e03bff498a713 Mon Sep 17 00:00:00 2001 From: Dirk Hohndel Date: Mon, 4 Aug 2014 22:15:58 -0700 Subject: Don't use tmpfile() It appears that at least on Win7-64 Windows tries to create the temporary file in C:\ and fails because of insufficient permissions. How stupid is that. Instead we roll our own tempfiles, based on the already existing tempfile name that is passed in. Signed-off-by: Dirk Hohndel --- qt-ui/subsurfacewebservices.cpp | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'qt-ui') diff --git a/qt-ui/subsurfacewebservices.cpp b/qt-ui/subsurfacewebservices.cpp index 6fa0b0afe..e7f81d7fa 100644 --- a/qt-ui/subsurfacewebservices.cpp +++ b/qt-ui/subsurfacewebservices.cpp @@ -5,6 +5,7 @@ #include #include #include +#include #include #include @@ -149,7 +150,10 @@ bool DivelogsDeWebServices::prepare_dives_for_divelogs(const QString &tempfile, */ if (selected && !dive->selected) continue; - f = tmpfile(); + QString innerTmpFile = tempfile; + QString tmpSuffix = QString::number(qrand() % 9999) + ".tmp"; + innerTmpFile.replace(".dld", tmpSuffix); + f = fopen(QFile::encodeName(QDir::toNativeSeparators(innerTmpFile)), "w+"); if (!f) { report_error(tr("cannot create temporary file: %s").toUtf8(), qt_error_string().toUtf8().data()); goto error_close_zip; @@ -168,7 +172,7 @@ bool DivelogsDeWebServices::prepare_dives_for_divelogs(const QString &tempfile, } membuf[streamsize] = 0; fclose(f); - + unlink(QFile::encodeName(QDir::toNativeSeparators(innerTmpFile))); /* * Parse the memory buffer into XML document and * transform it to divelogs.de format, finally dumping -- cgit v1.2.3-70-g09d2