m_changedProps = false;
}
}
+
+ if (m_node->version() < CurrentViewPropertiesVersion) {
+ // The view-properties have an outdated version. Convert the properties
+ // to the changes of the current version.
+ if (m_node->version() < AdditionalInfoViewPropertiesVersion) {
+ convertAdditionalInfo();
+ Q_ASSERT(m_node->version() == AdditionalInfoViewPropertiesVersion);
+ }
+
+ if (m_node->version() < NameRolePropertiesVersion) {
+ convertNameRoleToTextRole();
+ Q_ASSERT(m_node->version() == NameRolePropertiesVersion);
+ }
+
+ m_node->setVersion(CurrentViewPropertiesVersion);
+ }
}
ViewProperties::~ViewProperties()
QByteArray ViewProperties::sortRole() const
{
- if (m_node->version() <= NameRolePropertiesVersion) {
- const_cast<ViewProperties*>(this)->convertNameRoleToTextRole();
- }
-
return m_node->sortRole().toLatin1();
}
void ViewProperties::setVisibleRoles(const QList<QByteArray>& roles)
{
+ if (roles == visibleRoles()) {
+ return;
+ }
+
// See ViewProperties::visibleRoles() for the storage format
// of the additional information.
roles.append("text");
// Iterate through all stored keys and append all roles that match to
- // the curren view mode.
+ // the current view mode.
const QString prefix = viewModePrefix();
const int prefixLength = prefix.length();
- QStringList visibleRoles = m_node->visibleRoles();
- const int version = m_node->version();
- if (visibleRoles.isEmpty() && version <= AdditionalInfoViewPropertiesVersion) {
- // Convert the obsolete additionalInfo-property from older versions into the
- // visibleRoles-property
- const_cast<ViewProperties*>(this)->convertAdditionalInfo();
- visibleRoles = m_node->visibleRoles();
- } else if (version <= NameRolePropertiesVersion) {
- const_cast<ViewProperties*>(this)->convertNameRoleToTextRole();
- visibleRoles = m_node->visibleRoles();
- }
-
+ const QStringList visibleRoles = m_node->visibleRoles();
foreach (const QString& visibleRole, visibleRoles) {
if (visibleRole.startsWith(prefix)) {
const QByteArray role = visibleRole.right(visibleRole.length() - prefixLength).toLatin1();
setSortFoldersFirst(props.sortFoldersFirst());
setVisibleRoles(props.visibleRoles());
setHeaderColumnWidths(props.headerColumnWidths());
+ m_node->setVersion(props.m_node->version());
}
void ViewProperties::setAutoSaveEnabled(bool autoSave)
void ViewProperties::save()
{
+ kDebug() << "Saving view-properties to" << m_filePath;
KStandardDirs::makeDir(m_filePath);
m_node->setVersion(CurrentViewPropertiesVersion);
m_node->writeConfig();
m_node->setAdditionalInfo(QStringList());
m_node->setVisibleRoles(visibleRoles);
+ m_node->setVersion(AdditionalInfoViewPropertiesVersion);
update();
}
{
QStringList visibleRoles = m_node->visibleRoles();
for (int i = 0; i < visibleRoles.count(); ++i) {
- if (visibleRoles[i].endsWith("_name")) {
+ if (visibleRoles[i].endsWith(QLatin1String("_name"))) {
const int leftLength = visibleRoles[i].length() - 5;
visibleRoles[i] = visibleRoles[i].left(leftLength) + "_text";
}
m_node->setVisibleRoles(visibleRoles);
m_node->setSortRole(sortRole);
+ m_node->setVersion(NameRolePropertiesVersion);
update();
}