diff --git a/src/base/path.cpp b/src/base/path.cpp index 0fa65d11a..dee1c50c4 100644 --- a/src/base/path.cpp +++ b/src/base/path.cpp @@ -115,6 +115,11 @@ Path Path::rootItem() const if (slashIndex == 0) // *nix absolute path return createUnchecked(u"/"_qs); +#ifdef Q_OS_WIN + // should be `c:/` instead of `c:` + if (m_pathStr.at(slashIndex - 1) == u':') + return createUnchecked(m_pathStr.left(slashIndex + 1)); +#endif return createUnchecked(m_pathStr.left(slashIndex)); } @@ -127,6 +132,12 @@ Path Path::parentPath() const if (slashIndex == 0) // *nix absolute path return (m_pathStr.size() == 1) ? Path() : createUnchecked(u"/"_qs); +#ifdef Q_OS_WIN + // should be `c:/` instead of `c:` + // Windows "drive letter" is limited to one alphabet + if ((slashIndex == 2) && (m_pathStr.at(1) == u':')) + return createUnchecked(m_pathStr.left(slashIndex + 1)); +#endif return createUnchecked(m_pathStr.left(slashIndex)); } diff --git a/src/gui/torrentcreatordialog.cpp b/src/gui/torrentcreatordialog.cpp index 86e941344..c91953be5 100644 --- a/src/gui/torrentcreatordialog.cpp +++ b/src/gui/torrentcreatordialog.cpp @@ -180,8 +180,8 @@ void TorrentCreatorDialog::onCreateButtonClicked() } // get save path - const Path savePath = m_storeLastSavePath.get(Utils::Fs::homePath() / Path(inputPath.filename() + u".torrent")); - Path destPath {QFileDialog::getSaveFileName(this, tr("Select where to save the new torrent"), savePath.data(), tr("Torrent Files (*.torrent)"))}; + const Path lastSavePath = (m_storeLastSavePath.get(Utils::Fs::homePath()) / Path(inputPath.filename() + u".torrent")); + Path destPath {QFileDialog::getSaveFileName(this, tr("Select where to save the new torrent"), lastSavePath.data(), tr("Torrent Files (*.torrent)"))}; if (destPath.isEmpty()) return; if (!destPath.hasExtension(TORRENT_FILE_EXTENSION))