Normalize realpath(3) output to composed form
All strings coming out of POSIX API calls are converted to composed form by QFile::decodeName. Do the same for realpath(3) output. This is especially important for HFS+, which will store file names in decomposed form, and APIs will therefore return strings in decomposed form. Task-number: QTBUG-55896 Change-Id: I5e51f4e5712ff26bf9644cbcf9a9603995748892 Reviewed-by: Morten Johan Sørvig <morten.sorvig@qt.io>
This commit is contained in:
parent
557abfc327
commit
49d3bb0058
@ -276,7 +276,7 @@ QFileSystemEntry QFileSystemEngine::canonicalName(const QFileSystemEntry &entry,
|
|||||||
if (ret) {
|
if (ret) {
|
||||||
data.knownFlagsMask |= QFileSystemMetaData::ExistsAttribute;
|
data.knownFlagsMask |= QFileSystemMetaData::ExistsAttribute;
|
||||||
data.entryFlags |= QFileSystemMetaData::ExistsAttribute;
|
data.entryFlags |= QFileSystemMetaData::ExistsAttribute;
|
||||||
QString canonicalPath = QDir::cleanPath(QString::fromLocal8Bit(ret));
|
QString canonicalPath = QDir::cleanPath(QFile::decodeName(ret));
|
||||||
free(ret);
|
free(ret);
|
||||||
return QFileSystemEntry(canonicalPath);
|
return QFileSystemEntry(canonicalPath);
|
||||||
} else if (errno == ENOENT) { // file doesn't exist
|
} else if (errno == ENOENT) { // file doesn't exist
|
||||||
|
@ -770,6 +770,19 @@ void tst_QFileInfo::canonicalFilePath()
|
|||||||
QDir::current().rmdir(linkTarget);
|
QDir::current().rmdir(linkTarget);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef Q_OS_DARWIN
|
||||||
|
{
|
||||||
|
// Check if canonicalFilePath's result is in Composed normalization form.
|
||||||
|
QString path = QString::fromLatin1("caf\xe9");
|
||||||
|
QDir dir(QDir::tempPath());
|
||||||
|
dir.mkdir(path);
|
||||||
|
QString canonical = QFileInfo(dir.filePath(path)).canonicalFilePath();
|
||||||
|
QString roundtrip = QFile::decodeName(QFile::encodeName(canonical));
|
||||||
|
QCOMPARE(canonical, roundtrip);
|
||||||
|
dir.rmdir(path);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void tst_QFileInfo::fileName_data()
|
void tst_QFileInfo::fileName_data()
|
||||||
|
Loading…
Reference in New Issue
Block a user