m_filepath = cleanUrl.path();
if ((m_filepath.length() < 1) || (m_filepath.at(0) != QChar('/'))) {
- m_node = new ViewPropertySettings();
+ const QString file = destinationDir("global") + FILE_NAME;
+ m_node = new ViewPropertySettings(KSharedConfig::openConfig(file));
return;
}
m_filepath = destinationDir("remote") + m_filepath;
}
- const QString file(m_filepath + FILE_NAME);
+ const QString file = m_filepath + FILE_NAME;
m_node = new ViewPropertySettings(KSharedConfig::openConfig(file));
const bool useDefaultProps = !useGlobalViewProps &&
}
}
- if (m_node->additionalInfo() != info) {
- m_node->setAdditionalInfo(info);
+ const int encodedInfo = encodedAdditionalInfo(info);
+ if (m_node->additionalInfo() != encodedInfo) {
+ m_node->setAdditionalInfo(encodedInfo);
updateTimeStamp();
}
}
KFileItemDelegate::InformationList ViewProperties::additionalInfo() const
{
- const int info = m_node->additionalInfo();
-
+ const int info = decodedAdditionalInfo();
+
KFileItemDelegate::InformationList list;
if (info & SizeInfo) {
list.append(KFileItemDelegate::Size);
basePath.append("/view_properties/").append(subDir);
return KStandardDirs::locateLocal("data", basePath);
}
+
+int ViewProperties::encodedAdditionalInfo(int info) const
+{
+ int encodedInfo = m_node->additionalInfo();
+
+ switch (viewMode()) {
+ case DolphinView::DetailsView:
+ encodedInfo = (encodedInfo & 0xFFFF00) | info;
+ break;
+ case DolphinView::IconsView:
+ encodedInfo = (encodedInfo & 0xFF00FF) | (info << 8);
+ break;
+ case DolphinView::ColumnView:
+ encodedInfo = (encodedInfo & 0x00FFFF) | (info << 16);
+ break;
+ default: break;
+ }
+
+ return encodedInfo;
+}
+
+int ViewProperties::decodedAdditionalInfo() const
+{
+ int decodedInfo = m_node->additionalInfo();
+
+ switch (viewMode()) {
+ case DolphinView::DetailsView:
+ decodedInfo = decodedInfo & 0xFF;
+ if (decodedInfo == NoInfo) {
+ // a details view without any additional info makes no sense, hence
+ // provide at least a size-info and date-info as fallback
+ decodedInfo = SizeInfo | DateInfo;
+ }
+ break;
+ case DolphinView::IconsView:
+ decodedInfo = (decodedInfo >> 8) & 0xFF;
+ break;
+ case DolphinView::ColumnView:
+ decodedInfo = (decodedInfo >> 16) & 0xFF;
+ break;
+ default: break;
+ }
+
+ return decodedInfo;
+}