summaryrefslogtreecommitdiffstats
path: root/kdecore
diff options
context:
space:
mode:
authorMichele Calgaro <michele.calgaro@yahoo.it>2020-01-28 23:12:32 +0900
committerSlávek Banko <slavek.banko@axis.cz>2021-02-03 17:50:46 +0100
commit54800d9de61bed34b73dfdb2525a4878ae03858b (patch)
tree5424c8863b78f8d718dc87dde556c04a3db22173 /kdecore
parentd5b27c1f518de51f2c50ef3dfda9994a95d49b7c (diff)
downloadtdelibs-54800d9de61bed34b73dfdb2525a4878ae03858b.tar.gz
tdelibs-54800d9de61bed34b73dfdb2525a4878ae03858b.zip
Improved support for XDG folders without requiring xdg-user-dirs to be installed.
Signed-off-by: Michele Calgaro <michele.calgaro@yahoo.it> (cherry picked from commit 394c9f5c0e1b464aa8bc22bd65c5268acd43994d)
Diffstat (limited to 'kdecore')
-rw-r--r--kdecore/kconfigbase.cpp6
-rw-r--r--kdecore/kglobalsettings.cpp194
-rw-r--r--kdecore/kglobalsettings.h82
3 files changed, 167 insertions, 115 deletions
diff --git a/kdecore/kconfigbase.cpp b/kdecore/kconfigbase.cpp
index 130e35148..13ab4fac7 100644
--- a/kdecore/kconfigbase.cpp
+++ b/kdecore/kconfigbase.cpp
@@ -321,6 +321,12 @@ TQString KConfigBase::readEntry( const char *pKey,
else if (aVarName == "XDG_PICTURES_DIR") {
result = KGlobalSettings::picturesPath();
}
+ else if (aVarName == "XDG_PUBLICSHARE_DIR") {
+ result = KGlobalSettings::publicSharePath();
+ }
+ else if (aVarName == "XDG_TEMPLATES_DIR") {
+ result = KGlobalSettings::templatesPath();
+ }
else if (aVarName == "XDG_VIDEOS_DIR") {
result = KGlobalSettings::videosPath();
}
diff --git a/kdecore/kglobalsettings.cpp b/kdecore/kglobalsettings.cpp
index 7696e74a8..71f8f7c58 100644
--- a/kdecore/kglobalsettings.cpp
+++ b/kdecore/kglobalsettings.cpp
@@ -87,42 +87,90 @@ TQColor *KGlobalSettings::alternateColor = 0;
KGlobalSettings::KMouseSettings *KGlobalSettings::s_mouseSettings = 0;
-// helper function for reading xdg user dirs: it is required in order to take
-// care of locale stuff
-void readXdgUserDirs(TQString *desktop, TQString *documents, TQString *videos, TQString *music,
- TQString *download, TQString *pictures, TQString *templates, TQString *publicShare)
+// Helper function for reading xdg user dirs.
+// Returns sane values in case the user dir file can't be read
+static void readXdgUserDirs(TQString *desktop, TQString *documents, TQString *download, TQString *music,
+ TQString *pictures, TQString *publicShare, TQString *templates, TQString *videos)
{
- TQFile f( TQDir::homeDirPath() + "/.config/user-dirs.dirs" );
-
- if (!f.open(IO_ReadOnly))
- return;
-
- // set the codec for the current locale
- TQTextStream s(&f);
- s.setCodec( TQTextCodec::codecForLocale() );
-
- TQString line = s.readLine();
- while (!line.isNull())
+ TQFile dirsFile(TQDir::homeDirPath() + "/.config/user-dirs.dirs");
+ if (dirsFile.open(IO_ReadOnly))
{
- if (line.startsWith("XDG_DESKTOP_DIR="))
- *desktop = line.remove("XDG_DESKTOP_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
- else if (line.startsWith("XDG_DOCUMENTS_DIR="))
- *documents = line.remove("XDG_DOCUMENTS_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
- else if (line.startsWith("XDG_MUSIC_DIR="))
- *videos = line.remove("XDG_MUSIC_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
- else if (line.startsWith("XDG_DOWNLOAD_DIR="))
- *download = line.remove("XDG_DOWNLOAD_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
- else if (line.startsWith("XDG_VIDEOS_DIR="))
- *music = line.remove("XDG_VIDEOS_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
- else if (line.startsWith("XDG_PICTURES_DIR="))
- *pictures = line.remove("XDG_PICTURES_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
- else if (line.startsWith("XDG_TEMPLATES_DIR="))
- *templates = line.remove("XDG_TEMPLATES_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
- else if (line.startsWith("XDG_PUBLICSHARE_DIR="))
- *publicShare = line.remove("XDG_PUBLICSHARE_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
-
- line = s.readLine();
+ // set the codec for the current locale
+ TQTextStream stream(&dirsFile);
+ stream.setCodec(TQTextCodec::codecForLocale());
+
+ while (!stream.atEnd())
+ {
+ TQString line = stream.readLine();
+ if (line.startsWith("XDG_DESKTOP_DIR="))
+ {
+ *desktop = line.remove("XDG_DESKTOP_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
+ }
+ else if (line.startsWith("XDG_DOCUMENTS_DIR="))
+ {
+ *documents = line.remove("XDG_DOCUMENTS_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
+ }
+ else if (line.startsWith("XDG_DOWNLOAD_DIR="))
+ {
+ *download = line.remove("XDG_DOWNLOAD_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
+ }
+ else if (line.startsWith("XDG_MUSIC_DIR="))
+ {
+ *music = line.remove("XDG_MUSIC_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
+ }
+ else if (line.startsWith("XDG_PICTURES_DIR="))
+ {
+ *pictures = line.remove("XDG_PICTURES_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
+ }
+ else if (line.startsWith("XDG_PUBLICSHARE_DIR="))
+ {
+ *publicShare = line.remove("XDG_PUBLICSHARE_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
+ }
+ else if (line.startsWith("XDG_TEMPLATES_DIR="))
+ {
+ *templates = line.remove("XDG_TEMPLATES_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
+ }
+ else if (line.startsWith("XDG_VIDEOS_DIR="))
+ {
+ *videos = line.remove("XDG_VIDEOS_DIR=").remove("\"").replace("$HOME", TQDir::homeDirPath());
+ }
+ }
+ dirsFile.close();
}
+
+ // Use sane values in case some paths are missing
+ if (desktop->isEmpty())
+ {
+ *desktop = TQDir::homeDirPath() + "/" + i18n("Desktop") + "/";
+ }
+ if (documents->isEmpty())
+ {
+ *documents = TQDir::homeDirPath() + "/" + i18n("Documents") + "/";
+ }
+ if (download->isEmpty())
+ {
+ *download = TQDir::homeDirPath() + "/" + i18n("Downloads") + "/";
+ }
+ if (music->isEmpty())
+ {
+ *music = TQDir::homeDirPath() + "/" + i18n("Music") + "/";
+ }
+ if (pictures->isEmpty())
+ {
+ *pictures = TQDir::homeDirPath() + "/" + i18n("Pictures") + "/";
+ }
+ if (publicShare->isEmpty())
+ {
+ *publicShare = TQDir::homeDirPath() + "/" + i18n("Public") + "/";
+ }
+ if (templates->isEmpty())
+ {
+ *templates = TQDir::homeDirPath() + "/" + i18n("Templates") + "/";
+ }
+ if (videos->isEmpty())
+ {
+ *videos = TQDir::homeDirPath() + "/" + i18n("Videos") + "/";
+ }
}
int KGlobalSettings::dndEventDelay()
@@ -525,63 +573,61 @@ TQFont KGlobalSettings::largeFont(const TQString &text)
return *_largeFont;
}
-void KGlobalSettings::initStatic() // should be called initPaths(). Don't put anything else here.
+void KGlobalSettings::initPaths()
{
- if ( s_desktopPath != 0 )
- return;
+ if (s_desktopPath)
+ {
+ return;
+ }
- s_desktopPath = new TQString();
s_autostartPath = new TQString();
s_trashPath = new TQString();
+ s_desktopPath = new TQString();
s_documentPath = new TQString();
- s_videosPath = new TQString();
- s_musicPath = new TQString();
s_downloadPath = new TQString();
+ s_musicPath = new TQString();
s_picturesPath = new TQString();
- s_templatesPath = new TQString();
s_publicSharePath = new TQString();
+ s_templatesPath = new TQString();
+ s_videosPath = new TQString();
KConfigGroup g( KGlobal::config(), "Paths" );
- // Read desktop and documents path using XDG_USER_DIRS
- readXdgUserDirs(s_desktopPath, s_documentPath, s_musicPath, s_videosPath,
- s_downloadPath, s_picturesPath, s_templatesPath, s_publicSharePath);
-
- if (s_desktopPath->isEmpty() == true) {
- *s_desktopPath = TQDir::homeDirPath() + "/Desktop/";
- }
+ // Read xdg folder paths
+ readXdgUserDirs(s_desktopPath, s_documentPath, s_downloadPath, s_musicPath,
+ s_picturesPath, s_publicSharePath, s_templatesPath, s_videosPath);
- *s_desktopPath = TQDir::cleanDirPath( *s_desktopPath );
- if ( !s_desktopPath->endsWith("/") )
+ *s_desktopPath = TQDir::cleanDirPath(*s_desktopPath);
+ if (!s_desktopPath->endsWith("/"))
s_desktopPath->append('/');
- *s_documentPath = TQDir::cleanDirPath( *s_documentPath );
- if ( !s_documentPath->endsWith("/"))
+ *s_documentPath = TQDir::cleanDirPath(*s_documentPath);
+ if (!s_documentPath->endsWith("/"))
s_documentPath->append('/');
- *s_musicPath = TQDir::cleanDirPath( *s_musicPath );
- if ( !s_musicPath->endsWith("/"))
- s_musicPath->append('/');
-
- *s_videosPath = TQDir::cleanDirPath( *s_videosPath );
- if ( !s_videosPath->endsWith("/"))
- s_videosPath->append('/');
-
- *s_downloadPath = TQDir::cleanDirPath( *s_downloadPath );
- if ( !s_downloadPath->endsWith("/"))
+ *s_downloadPath = TQDir::cleanDirPath(*s_downloadPath);
+ if (!s_downloadPath->endsWith("/"))
s_downloadPath->append('/');
- *s_picturesPath = TQDir::cleanDirPath( *s_picturesPath );
- if ( !s_picturesPath->endsWith("/"))
+ *s_musicPath = TQDir::cleanDirPath(*s_musicPath);
+ if (!s_musicPath->endsWith("/"))
+ s_musicPath->append('/');
+
+ *s_picturesPath = TQDir::cleanDirPath(*s_picturesPath);
+ if (!s_picturesPath->endsWith("/"))
s_picturesPath->append('/');
- *s_templatesPath = TQDir::cleanDirPath( *s_templatesPath );
- if ( !s_templatesPath->endsWith("/"))
+ *s_publicSharePath = TQDir::cleanDirPath(*s_publicSharePath);
+ if (!s_publicSharePath->endsWith("/"))
+ s_publicSharePath->append('/');
+
+ *s_templatesPath = TQDir::cleanDirPath(*s_templatesPath);
+ if (!s_templatesPath->endsWith("/"))
s_templatesPath->append('/');
- *s_publicSharePath = TQDir::cleanDirPath( *s_publicSharePath );
- if ( !s_publicSharePath->endsWith("/"))
- s_publicSharePath->append('/');
+ *s_videosPath = TQDir::cleanDirPath(*s_videosPath);
+ if (!s_videosPath->endsWith("/"))
+ s_videosPath->append('/');
// Trash Path - TODO remove in KDE4 (kio_trash can't use it for interoperability reasons)
*s_trashPath = *s_desktopPath + i18n("Trash") + "/";
@@ -647,18 +693,18 @@ void KGlobalSettings::rereadPathSettings()
s_desktopPath = 0L;
delete s_documentPath;
s_documentPath = 0L;
- delete s_videosPath;
- s_videosPath = 0L;
- delete s_picturesPath;
- s_picturesPath = 0L;
delete s_downloadPath;
s_downloadPath = 0L;
delete s_musicPath;
s_musicPath = 0L;
- delete s_templatesPath;
- s_templatesPath = 0L;
+ delete s_picturesPath;
+ s_picturesPath = 0L;
delete s_publicSharePath;
s_publicSharePath = 0L;
+ delete s_templatesPath;
+ s_templatesPath = 0L;
+ delete s_videosPath;
+ s_videosPath = 0L;
}
KGlobalSettings::KMouseSettings & KGlobalSettings::mouseSettings()
diff --git a/kdecore/kglobalsettings.h b/kdecore/kglobalsettings.h
index 0ef6e1883..546fac2b5 100644
--- a/kdecore/kglobalsettings.h
+++ b/kdecore/kglobalsettings.h
@@ -227,67 +227,67 @@ class KDECORE_EXPORT KGlobalSettings
static KMouseSettings & mouseSettings();
/**
- * The path to the desktop directory of the current user.
- * @return the user's desktop directory
- */
- static TQString desktopPath() { initStatic(); return *s_desktopPath; }
-
- /**
* The path to the autostart directory of the current user.
* @return the path of the autostart directory
*/
- static TQString autostartPath() { initStatic(); return *s_autostartPath; }
+ static TQString autostartPath() { initPaths(); return *s_autostartPath; }
/**
* DEPRECATED (starting from kde-3.4).
* This isn't where the trash contents is, anymore.
* Use KIO::trash() to trash files, "trash:/" to list the trash contents.
*/
- static TQString trashPath() { initStatic(); return *s_trashPath; }
+ static TQString trashPath() { initPaths(); return *s_trashPath; }
// KDE4: if you want to remove the above, move it to kdesktop/init.cc, which needs
// to know the old location of the trash
/**
+ * The path to the desktop directory of the current user.
+ * @return the user's desktop directory
+ */
+ static TQString desktopPath() { initPaths(); return *s_desktopPath; }
+
+ /**
* The path where documents are stored of the current user.
* @return the path of the document directory
*/
- static TQString documentPath() { initStatic(); return *s_documentPath; }
+ static TQString documentPath() { initPaths(); return *s_documentPath; }
/**
* The path where documents are stored of the current user.
- * @return the path of the videos directory
+ * @return the path of the downloads directory
*/
- static TQString videosPath() { initStatic(); return *s_videosPath; }
+ static TQString downloadPath() { initPaths(); return *s_downloadPath; }
/**
* The path where documents are stored of the current user.
* @return the path of the music directory
*/
- static TQString musicPath() { initStatic(); return *s_musicPath; }
+ static TQString musicPath() { initPaths(); return *s_musicPath; }
/**
* The path where documents are stored of the current user.
- * @return the path of the downloads directory
+ * @return the path of the pictures directory
*/
- static TQString downloadPath() { initStatic(); return *s_downloadPath; }
+ static TQString picturesPath() { initPaths(); return *s_picturesPath; }
/**
- * The path where documents are stored of the current user.
- * @return the path of the pictures directory
+ * The path of the public share of the current user.
+ * @return the path of the public share directory
*/
- static TQString picturesPath() { initStatic(); return *s_picturesPath; }
+ static TQString publicSharePath() { initPaths(); return *s_publicSharePath; }
/**
* The path where templates are stored of the current user.
* @return the path of the templates directory
*/
- static TQString templatesPath() { initStatic(); return *s_templatesPath; }
+ static TQString templatesPath() { initPaths(); return *s_templatesPath; }
/**
- * The path of the public share of the current user.
- * @return the path of the public share directory
+ * The path where documents are stored of the current user.
+ * @return the path of the videos directory
*/
- static TQString publicSharePath() { initStatic(); return *s_publicSharePath; }
+ static TQString videosPath() { initPaths(); return *s_videosPath; }
/**
* The default color to use when highlighting toolbar buttons.
@@ -572,7 +572,7 @@ private:
/**
* reads in all paths from kdeglobals
*/
- static void initStatic();
+ static void initPaths();
/**
* initialize colors
*/
@@ -591,16 +591,16 @@ private:
static void rereadMouseSettings();
- static TQString* s_desktopPath;
- static TQString* s_autostartPath;
- static TQString* s_trashPath;
- static TQString* s_documentPath;
- static TQString* s_picturesPath;
- static TQString* s_templatesPath;
- static TQString* s_publicSharePath;
- static TQString* s_downloadPath;
- static TQString* s_musicPath;
- static TQString* s_videosPath;
+ static TQString *s_desktopPath;
+ static TQString *s_autostartPath;
+ static TQString *s_trashPath;
+ static TQString *s_documentPath;
+ static TQString *s_picturesPath;
+ static TQString *s_templatesPath;
+ static TQString *s_publicSharePath;
+ static TQString *s_downloadPath;
+ static TQString *s_musicPath;
+ static TQString *s_videosPath;
static TQFont *_generalFont;
static TQFont *_fixedFont;
static TQFont *_toolBarFont;
@@ -608,15 +608,15 @@ private:
static TQFont *_windowTitleFont;
static TQFont *_taskbarFont;
static TQFont *_largeFont;
- static TQColor * _trinity4Blue;
- static TQColor * _inactiveBackground;
- static TQColor * _inactiveForeground;
- static TQColor * _activeBackground;
- static TQColor * _buttonBackground;
- static TQColor * _selectBackground;
- static TQColor * _linkColor;
- static TQColor * _visitedLinkColor;
- static TQColor * alternateColor;
+ static TQColor *_trinity4Blue;
+ static TQColor *_inactiveBackground;
+ static TQColor *_inactiveForeground;
+ static TQColor *_activeBackground;
+ static TQColor *_buttonBackground;
+ static TQColor *_selectBackground;
+ static TQColor *_linkColor;
+ static TQColor *_visitedLinkColor;
+ static TQColor *alternateColor;
static KMouseSettings *s_mouseSettings;
friend class KApplication;