From c1e47429f10697cd560735a0d281e2ee2835fd2d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=8E=8B=E5=AD=90=E5=86=B2?= Date: Tue, 6 Aug 2019 15:33:34 +0800 Subject: [PATCH] feat: interfaces for fileinfo --- gio-qt/include/dgiofileinfo.h | 2 ++ gio-qt/source/dgiofileinfo.cpp | 51 +++++++++++++++++++++++++++++++--- test/tst_simplefileinfo.cpp | 1 + 3 files changed, 50 insertions(+), 4 deletions(-) diff --git a/gio-qt/include/dgiofileinfo.h b/gio-qt/include/dgiofileinfo.h index a75a324..112f47f 100644 --- a/gio-qt/include/dgiofileinfo.h +++ b/gio-qt/include/dgiofileinfo.h @@ -51,6 +51,8 @@ public: QString displayName() const; DGioFileType fileType() const; quint64 fileSize() const; + QString contentType() const; + QString iconString() const; QStringList themedIconNames() const; // filesystem info. diff --git a/gio-qt/source/dgiofileinfo.cpp b/gio-qt/source/dgiofileinfo.cpp index 005573d..9926516 100644 --- a/gio-qt/source/dgiofileinfo.cpp +++ b/gio-qt/source/dgiofileinfo.cpp @@ -32,6 +32,7 @@ public: Glib::RefPtr getGmmFileInfoInstance() const; + Glib::RefPtr icon() const; bool getAttributeBoolean(const std::string &attribute) const; quint64 getAttributeUint64(const std::string &attribute) const; QString getAttributeString(const std::string &attribute) const; @@ -58,6 +59,11 @@ Glib::RefPtr DGioFileInfoPrivate::getGmmFileInfoInstance() const return m_gmmFileInfoPtr; } +Glib::RefPtr DGioFileInfoPrivate::icon() const +{ + return getGmmFileInfoInstance()->get_icon(); +} + bool DGioFileInfoPrivate::getAttributeBoolean(const std::string &attribute) const { return m_gmmFileInfoPtr->get_attribute_boolean(attribute); @@ -118,8 +124,10 @@ DGioFileType DGioFileInfo::fileType() const /*! * \brief DGioFileInfo::fileSize + * * Wrapper of Gio::FileInfo::get_size() - * \return + * + * \return the file size in bytes. */ quint64 DGioFileInfo::fileSize() const { @@ -128,13 +136,48 @@ quint64 DGioFileInfo::fileSize() const return static_cast(d->getGmmFileInfoInstance()->get_size()); } +/*! + * \brief get the file content type (MimeType). + * + * Wrapper of Gio::FileInfo::get_content_type() + * + * \return a single MimeType of the file, such as "text/plain". + */ +QString DGioFileInfo::contentType() const +{ + Q_D(const DGioFileInfo); + + return QString::fromStdString(d->getGmmFileInfoInstance()->get_content_type()); +} + +/*! + * \brief DGioFileInfo::iconString + * + * Wrapper of Gio::FileInfo::get_icon() and then Gio::Icon::to_string(). + * + * Notice the returned value can be in two different form: + * + * - a native path (such as "/path/to/my icon.png") without escaping if the file for icon is a native + * file. If the file is not native, the returned string is the result of g_file_get_uri() + * (such as "sftp://path/to/my%20icon.png"). + * + * - a icon name if icon is a ThemedIcon with exactly one name, the encoding is simply the name (such as + * network-server), or a list of theme names (such as ". GThemedIcon text-plain text-x-generic text-plain-symbolic"). + * + * \return the icon string as discribed above. + */ +QString DGioFileInfo::iconString() const +{ + Q_D(const DGioFileInfo); + + return QString::fromStdString(d->icon()->to_string()); +} + QStringList DGioFileInfo::themedIconNames() const { Q_D(const DGioFileInfo); - Glib::RefPtr icon = d->getGmmFileInfoInstance()->get_icon(); - - return DGioPrivate::getThemedIconNames(icon); + return DGioPrivate::getThemedIconNames(d->icon()); } bool DGioFileInfo::fsReadOnly() const diff --git a/test/tst_simplefileinfo.cpp b/test/tst_simplefileinfo.cpp index 74aa869..2913650 100644 --- a/test/tst_simplefileinfo.cpp +++ b/test/tst_simplefileinfo.cpp @@ -31,6 +31,7 @@ void DGioSimpleFileInfoTest::testCase_RegularFile() QCOMPARE(file->basename(), tmpFileInfo.fileName()); QCOMPARE(file->path(), tmpFileInfo.absoluteFilePath()); QCOMPARE(fi->fileSize(), tmpFileInfo.size()); + qDebug() << fi->iconString() << fi->contentType(); QVERIFY(fi->themedIconNames().contains("text-plain")); // is this check okay? better approach? }