diff options
author | wolfbeast <mcwerewolf@wolfbeast.com> | 2020-03-17 20:14:22 +0100 |
---|---|---|
committer | wolfbeast <mcwerewolf@wolfbeast.com> | 2020-03-17 20:14:22 +0100 |
commit | 6cbe27d1498666c410a3df1fe81b725f9a4056a0 (patch) | |
tree | ff627c6a44e21a1e755bffd74c330be369efec8a /security/manager | |
parent | 09abc10635f7f2d5aa9d918386b8a34590b8443a (diff) | |
download | UXP-6cbe27d1498666c410a3df1fe81b725f9a4056a0.tar UXP-6cbe27d1498666c410a3df1fe81b725f9a4056a0.tar.gz UXP-6cbe27d1498666c410a3df1fe81b725f9a4056a0.tar.lz UXP-6cbe27d1498666c410a3df1fe81b725f9a4056a0.tar.xz UXP-6cbe27d1498666c410a3df1fe81b725f9a4056a0.zip |
Issue #1467 - Part 3: Use UTF-8 file paths for NSS-SQL database.
Diffstat (limited to 'security/manager')
-rw-r--r-- | security/manager/ssl/nsNSSComponent.cpp | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/security/manager/ssl/nsNSSComponent.cpp b/security/manager/ssl/nsNSSComponent.cpp index d505b8aba..6d1e3c5f7 100644 --- a/security/manager/ssl/nsNSSComponent.cpp +++ b/security/manager/ssl/nsNSSComponent.cpp @@ -1706,16 +1706,25 @@ GetNSSProfilePath(nsAutoCString& aProfilePath) } #if defined(XP_WIN) - // Native path will drop Unicode characters that cannot be mapped to system's - // codepage, using short (canonical) path as workaround. nsCOMPtr<nsILocalFileWin> profileFileWin(do_QueryInterface(profileFile)); if (!profileFileWin) { MOZ_LOG(gPIPNSSLog, LogLevel::Error, ("Could not get nsILocalFileWin for profile directory.\n")); return NS_ERROR_FAILURE; } +#ifdef NSS_SQLSTORE + // SQLite always takes UTF-8 file paths regardless of the current system + // code page. + nsAutoString u16ProfilePath; + rv = profileFileWin->GetCanonicalPath(u16ProfilePath); + CopyUTF16toUTF8(u16ProfilePath, aProfilePath); +#else + // Native path will drop Unicode characters that cannot be mapped to system's + // codepage, using short (canonical) path as workaround. rv = profileFileWin->GetNativeCanonicalPath(aProfilePath); +#endif #else + // On non-Windows, just get the native profile path. rv = profileFile->GetNativePath(aProfilePath); #endif |