/***************************************************************************
- * Copyright (C) 2006 by Peter Penz *
- * peter.penz@gmx.at *
+ * Copyright (C) 2006-2010 by Peter Penz <peter.penz@gmx.at> *
+ * Copyright (C) 2006 by Aaron J. Seigo <aseigo@kde.org> *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
- * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
***************************************************************************/
-#include <assert.h>
+#include "viewproperties.h"
-#include <QDateTime>
-#include <QFile>
+#include "additionalinfoaccessor.h"
+#include "dolphin_directoryviewpropertysettings.h"
+#include "dolphin_generalsettings.h"
+#include <kcomponentdata.h>
#include <klocale.h>
#include <kstandarddirs.h>
#include <kurl.h>
-#include <kinstance.h>
-#include "viewproperties.h"
-#include "dolphinsettings.h"
-#include "generalsettings.h"
+#include <QDate>
+#include <QFile>
+#include <QFileInfo>
-#define FILE_NAME "/.directory"
+#include "settings/dolphinsettings.h"
ViewProperties::ViewProperties(const KUrl& url) :
- m_changedProps(false),
- m_autoSave(true),
- m_node(0)
+ m_changedProps(false),
+ m_autoSave(true),
+ m_node(0)
{
- KUrl cleanUrl(url);
-
- cleanUrl.cleanPath();
- m_filepath = cleanUrl.path();
-
- if ((m_filepath.length() < 1) || (m_filepath.at(0) != QChar('/'))) {
- m_node = new ViewPropertySettings();
- return;
- }
-
- // We try and save it to a file in the directory being viewed.
+ // We try and save it to the file .directory in the directory being viewed.
// If the directory is not writable by the user or the directory is not local,
// we store the properties information in a local file.
- QString rootDir("/"); // TODO: should this be set to the root of the bookmark, if any?
- if (cleanUrl.isLocalFile()) {
- QFileInfo info(m_filepath);
-
+ GeneralSettings* settings = DolphinSettings::instance().generalSettings();
+ const bool useGlobalViewProps = settings->globalViewProps();
+ if (useGlobalViewProps) {
+ m_filePath = destinationDir("global");
+ } else if (url.isLocalFile()) {
+ m_filePath = url.toLocalFile();
+ const QFileInfo info(m_filePath);
if (!info.isWritable()) {
- QString basePath = KGlobal::instance()->instanceName();
- basePath.append("/view_properties/local");
- rootDir = KStandardDirs::locateLocal("data", basePath);
- m_filepath = rootDir + m_filepath;
+ m_filePath = destinationDir("local") + m_filePath;
}
+ } else {
+ m_filePath = destinationDir("remote") + m_filePath;
}
- else {
- QString basePath = KGlobal::instance()->instanceName();
- basePath.append("/view_properties/remote/").append(cleanUrl.host());
- rootDir = KStandardDirs::locateLocal("data", basePath);
- m_filepath = rootDir + m_filepath;
- }
- m_node = new ViewPropertySettings(KSharedConfig::openConfig(m_filepath + FILE_NAME));
+ const QString file = m_filePath + QDir::separator() + QLatin1String(".directory");
+ m_node = new ViewPropertySettings(KSharedConfig::openConfig(file));
+
+ const bool useDefaultProps = !useGlobalViewProps &&
+ (!QFileInfo(file).exists() ||
+ (m_node->timestamp() < settings->viewPropsTimestamp()));
+ if (useDefaultProps) {
+ // If the .directory file does not exist or the timestamp is too old,
+ // use the values from the global .directory file instead, which acts
+ // as default view for new folders in this case.
+ settings->setGlobalViewProps(true);
+
+ ViewProperties defaultProps(url);
+ setDirProperties(defaultProps);
+
+ settings->setGlobalViewProps(false);
+ m_changedProps = false;
+ }
}
ViewProperties::~ViewProperties()
return m_node->showPreview();
}
-
void ViewProperties::setShowHiddenFiles(bool show)
{
if (m_node->showHiddenFiles() != show) {
}
}
+void ViewProperties::setCategorizedSorting(bool categorized)
+{
+ if (m_node->categorizedSorting() != categorized) {
+ m_node->setCategorizedSorting(categorized);
+ updateTimeStamp();
+ }
+}
+
+bool ViewProperties::categorizedSorting() const
+{
+ return m_node->categorizedSorting();
+}
+
bool ViewProperties::showHiddenFiles() const
{
return m_node->showHiddenFiles();
return static_cast<Qt::SortOrder>(m_node->sortOrder());
}
+void ViewProperties::setSortFoldersFirst(bool foldersFirst)
+{
+ if (m_node->sortFoldersFirst() != foldersFirst) {
+ m_node->setSortFoldersFirst(foldersFirst);
+ updateTimeStamp();
+ }
+}
+
+bool ViewProperties::sortFoldersFirst() const
+{
+ return m_node->sortFoldersFirst();
+}
+
+void ViewProperties::setAdditionalInfo(const KFileItemDelegate::InformationList& list)
+{
+ AdditionalInfoAccessor& infoAccessor = AdditionalInfoAccessor::instance();
+
+ int infoMask = 0;
+ foreach (KFileItemDelegate::Information currentInfo, list) {
+ infoMask = infoMask | infoAccessor.bitValue(currentInfo);
+ }
+
+ const int encodedInfo = encodedAdditionalInfo(infoMask);
+ if (m_node->additionalInfo() != encodedInfo) {
+ m_node->setAdditionalInfo(encodedInfo);
+ updateTimeStamp();
+ }
+}
+
+KFileItemDelegate::InformationList ViewProperties::additionalInfo() const
+{
+ KFileItemDelegate::InformationList usedInfos;
+
+ const int decodedInfo = decodedAdditionalInfo();
+
+ AdditionalInfoAccessor& infoAccessor = AdditionalInfoAccessor::instance();
+ const KFileItemDelegate::InformationList infos = infoAccessor.keys();
+
+ foreach (const KFileItemDelegate::Information info, infos) {
+ if (decodedInfo & infoAccessor.bitValue(info)) {
+ usedInfos.append(info);
+ }
+ }
+
+ return usedInfos;
+}
+
+
+void ViewProperties::setDirProperties(const ViewProperties& props)
+{
+ setViewMode(props.viewMode());
+ setShowPreview(props.showPreview());
+ setShowHiddenFiles(props.showHiddenFiles());
+ setCategorizedSorting(props.categorizedSorting());
+ setSorting(props.sorting());
+ setSortOrder(props.sortOrder());
+ setSortFoldersFirst(props.sortFoldersFirst());
+ setAdditionalInfo(props.additionalInfo());
+}
+
void ViewProperties::setAutoSaveEnabled(bool autoSave)
{
m_autoSave = autoSave;
void ViewProperties::save()
{
- const bool rememberSettings = !DolphinSettings::instance().generalSettings()->globalViewProps();
- if (rememberSettings) {
- KStandardDirs::makeDir(m_filepath);
- m_node->writeConfig();
- m_changedProps = false;
- }
+ KStandardDirs::makeDir(m_filePath);
+ m_node->writeConfig();
+ m_changedProps = false;
}
-ViewProperties::ViewProperties(const ViewProperties& props)
+KUrl ViewProperties::mirroredDirectory()
{
- assert(false);
+ QString basePath = KGlobal::mainComponent().componentName();
+ basePath.append("/view_properties/");
+ return KUrl(KStandardDirs::locateLocal("data", basePath));
}
-ViewProperties& ViewProperties::operator = (const ViewProperties& props)
+QString ViewProperties::destinationDir(const QString& subDir) const
{
- assert(false);
+ QString basePath = KGlobal::mainComponent().componentName();
+ 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 == 0) {
+ // A details view without any additional info makes no sense, hence
+ // provide at least a size-info and date-info as fallback
+ AdditionalInfoAccessor& infoAccessor = AdditionalInfoAccessor::instance();
+ decodedInfo = infoAccessor.bitValue(KFileItemDelegate::Size) |
+ infoAccessor.bitValue(KFileItemDelegate::ModificationTime);
+ }
+ break;
+ case DolphinView::IconsView:
+ decodedInfo = (decodedInfo >> 8) & 0xFF;
+ break;
+ case DolphinView::ColumnView:
+ decodedInfo = (decodedInfo >> 16) & 0xFF;
+ break;
+ default: break;
+ }
+
+ return decodedInfo;
}