Kaydet (Commit) 60954a8a authored tarafından Tobias Lippert's avatar Tobias Lippert Kaydeden (comit) Caolán McNamara

fdo#81532 Handle symlinks to icon themes correctly

- added logging for icon theme scanning.

Change-Id: I799c5fc09879411020142f7808da0d9f2f63dc17
Reviewed-on: https://gerrit.libreoffice.org/10406Tested-by: 's avatarRene Engelhard <rene@debian.org>
Reviewed-by: 's avatarCaolán McNamara <caolanm@redhat.com>
Tested-by: 's avatarCaolán McNamara <caolanm@redhat.com>
üst 235f84b2
...@@ -12,6 +12,7 @@ ...@@ -12,6 +12,7 @@
#include <config_folders.h> #include <config_folders.h>
#include <osl/file.hxx> #include <osl/file.hxx>
#include <rtl/bootstrap.hxx> #include <rtl/bootstrap.hxx>
#include <salhelper/linkhelper.hxx>
#include <vcl/svapp.hxx> #include <vcl/svapp.hxx>
#include <vcl/IconThemeInfo.hxx> #include <vcl/IconThemeInfo.hxx>
...@@ -20,24 +21,34 @@ namespace vcl { ...@@ -20,24 +21,34 @@ namespace vcl {
namespace { namespace {
bool const char *LOG_AREA = "vcl.app";
search_path_is_valid(const OUString& dir)
// set the status of a file. Returns false if the status could not be determined.
bool set_file_status(osl::FileStatus& status, const OUString& file)
{ {
osl::DirectoryItem dirItem; osl::DirectoryItem dirItem;
osl::FileBase::RC retvalGet = osl::DirectoryItem::get(dir, dirItem); osl::FileBase::RC retvalGet = osl::DirectoryItem::get(file, dirItem);
if (retvalGet != osl::FileBase::E_None) { if (retvalGet != osl::FileBase::E_None) {
SAL_WARN(LOG_AREA, "Could not determine status for file '" << file << "'.");
return false; return false;
} }
osl::FileStatus fileStatus(osl_FileStatus_Mask_Type); osl::FileBase::RC retvalStatus = dirItem.getFileStatus(status);
osl::FileBase::RC retvalStatus = dirItem.getFileStatus(fileStatus);
if (retvalStatus != osl::FileBase::E_None) { if (retvalStatus != osl::FileBase::E_None) {
SAL_WARN(LOG_AREA, "Could not determine status for file '" << file << "'.");
return false; return false;
} }
return true;
}
if (!fileStatus.isDirectory()) { OUString convert_to_absolute_path(const OUString& path)
return false; {
salhelper::LinkResolver resolver(0);
osl::FileBase::RC rc = resolver.fetchFileStatus(path);
if (rc != osl::FileBase::E_None) {
SAL_WARN(LOG_AREA, "Could not resolve path '" << path << "' to search for icon themes.");
throw std::runtime_error("Provided a recursive symlink to a icon theme directory that could not be resolved.");
} }
return true; return resolver.m_aStatus.getFileURL();
} }
} }
...@@ -48,12 +59,20 @@ IconThemeScanner::IconThemeScanner() ...@@ -48,12 +59,20 @@ IconThemeScanner::IconThemeScanner()
bool bool
IconThemeScanner::ScanDirectoryForIconThemes(const OUString& path) IconThemeScanner::ScanDirectoryForIconThemes(const OUString& path)
{ {
bool pathIsValid = search_path_is_valid(path); osl::FileStatus fileStatus(osl_FileStatus_Mask_Type);
if (!pathIsValid) { bool couldSetFileStatus = set_file_status(fileStatus, path);
if (!couldSetFileStatus) {
return false;
}
if (!fileStatus.isDirectory()) {
SAL_INFO(LOG_AREA, "Cannot search for icon themes in '"<< path << "'. It is not a directory.");
return false; return false;
} }
std::vector<OUString> iconThemePaths = ReadIconThemesFromPath(path); std::vector<OUString> iconThemePaths = ReadIconThemesFromPath(path);
if (iconThemePaths.empty()) { if (iconThemePaths.empty()) {
SAL_WARN(LOG_AREA, "Could not find any icon themes in the provided directory ('" <<path<<"'.");
return false; return false;
} }
mFoundIconThemes.clear(); mFoundIconThemes.clear();
...@@ -70,8 +89,11 @@ IconThemeScanner::AddIconThemeByPath(const OUString &url) ...@@ -70,8 +89,11 @@ IconThemeScanner::AddIconThemeByPath(const OUString &url)
if (!IconThemeInfo::UrlCanBeParsed(url)) { if (!IconThemeInfo::UrlCanBeParsed(url)) {
return false; return false;
} }
SAL_INFO(LOG_AREA, "Found a file that seems to be an icon theme: '" << url << "'" );
IconThemeInfo newTheme(url); IconThemeInfo newTheme(url);
mFoundIconThemes.push_back(newTheme); mFoundIconThemes.push_back(newTheme);
SAL_INFO(LOG_AREA, "Adding the file as '" << newTheme.GetDisplayName() <<
"' with id '" << newTheme.GetThemeId() << "'.");
return true; return true;
} }
...@@ -79,6 +101,7 @@ IconThemeScanner::AddIconThemeByPath(const OUString &url) ...@@ -79,6 +101,7 @@ IconThemeScanner::AddIconThemeByPath(const OUString &url)
IconThemeScanner::ReadIconThemesFromPath(const OUString& dir) IconThemeScanner::ReadIconThemesFromPath(const OUString& dir)
{ {
std::vector<OUString> found; std::vector<OUString> found;
SAL_INFO(LOG_AREA, "Scanning directory '" << dir << " for icon themes.");
osl::Directory dirToScan(dir); osl::Directory dirToScan(dir);
osl::FileBase::RC retvalOpen = dirToScan.open(); osl::FileBase::RC retvalOpen = dirToScan.open();
...@@ -93,15 +116,12 @@ IconThemeScanner::ReadIconThemesFromPath(const OUString& dir) ...@@ -93,15 +116,12 @@ IconThemeScanner::ReadIconThemesFromPath(const OUString& dir)
if (retvalStatus != osl::FileBase::E_None) { if (retvalStatus != osl::FileBase::E_None) {
continue; continue;
} }
if (!status.isRegular()) {
continue; OUString filename = convert_to_absolute_path(status.getFileURL());
} if (!FileIsValidIconTheme(filename)) {
if (!FileIsValidIconTheme(status.getFileURL())) {
continue; continue;
} }
OUString entry; found.push_back(filename);
entry = status.getFileURL();
found.push_back(entry);
} }
return found; return found;
} }
...@@ -111,20 +131,16 @@ IconThemeScanner::FileIsValidIconTheme(const OUString& filename) ...@@ -111,20 +131,16 @@ IconThemeScanner::FileIsValidIconTheme(const OUString& filename)
{ {
// check whether we can construct a IconThemeInfo from it // check whether we can construct a IconThemeInfo from it
if (!IconThemeInfo::UrlCanBeParsed(filename)) { if (!IconThemeInfo::UrlCanBeParsed(filename)) {
SAL_INFO(LOG_AREA, "File '" << filename << "' does not seem to be an icon theme.");
return false; return false;
} }
// check whether the file is a regular file
osl::DirectoryItem dirItem;
osl::FileBase::RC retvalGet = osl::DirectoryItem::get(filename, dirItem);
if (retvalGet != osl::FileBase::E_None) {
return false;
}
osl::FileStatus fileStatus(osl_FileStatus_Mask_Type); osl::FileStatus fileStatus(osl_FileStatus_Mask_Type);
osl::FileBase::RC retvalStatus = dirItem.getFileStatus(fileStatus); bool couldSetFileStatus = set_file_status(fileStatus, filename);
if (retvalStatus != osl::FileBase::E_None) { if (!couldSetFileStatus) {
return false; return false;
} }
if (!fileStatus.isRegular()) { if (!fileStatus.isRegular()) {
return false; return false;
} }
...@@ -178,6 +194,8 @@ IconThemeScanner::GetIconThemeInfo(const OUString& themeId) ...@@ -178,6 +194,8 @@ IconThemeScanner::GetIconThemeInfo(const OUString& themeId)
std::vector<IconThemeInfo>::iterator info = std::find_if(mFoundIconThemes.begin(), mFoundIconThemes.end(), std::vector<IconThemeInfo>::iterator info = std::find_if(mFoundIconThemes.begin(), mFoundIconThemes.end(),
SameTheme(themeId)); SameTheme(themeId));
if (info == mFoundIconThemes.end()) { if (info == mFoundIconThemes.end()) {
SAL_WARN(LOG_AREA, "Requested information for icon theme with id '" << themeId
<< "' which does not exist.");
throw std::runtime_error("Requested information on not-installed icon theme"); throw std::runtime_error("Requested information on not-installed icon theme");
} }
return *info; return *info;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment