X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/c8072005fada01d772595ec64adca449134f421e..5098937b73e873f64a51e8aabcb1bb6491d8e6ac:/src/dolphinmodel.cpp diff --git a/src/dolphinmodel.cpp b/src/dolphinmodel.cpp index 6ca2dd8e6..26221a094 100644 --- a/src/dolphinmodel.cpp +++ b/src/dolphinmodel.cpp @@ -46,6 +46,7 @@ #include #include #include +#include DolphinModel::DolphinModel(QObject *parent) : KDirModel(parent) @@ -159,8 +160,58 @@ QVariant DolphinModel::data(const QModelIndex &index, int role) const } case KDirModel::Permissions: - retString = item.permissionsString(); + { + QString user; + QString group; + QString others; + + QFileInfo info(item.url().pathOrUrl()); + + if (info.permission(QFile::ReadUser)) + user = i18n("Read, "); + + if (info.permission(QFile::WriteUser)) + user += i18n("Write, "); + + if (info.permission(QFile::ExeUser)) + user += i18n("Execute, "); + + if (user.isEmpty()) + user = i18n("Forbidden"); + else + user = user.mid(0, user.count() - 2); + + if (info.permission(QFile::ReadGroup)) + group = i18n("Read, "); + + if (info.permission(QFile::WriteGroup)) + group += i18n("Write, "); + + if (info.permission(QFile::ExeGroup)) + group += i18n("Execute, "); + + if (group.isEmpty()) + group = i18n("Forbidden"); + else + group = group.mid(0, group.count() - 2); + + if (info.permission(QFile::ReadOther)) + others = i18n("Read, "); + + if (info.permission(QFile::WriteOther)) + others += i18n("Write, "); + + if (info.permission(QFile::ExeOther)) + others += i18n("Execute, "); + + if (others.isEmpty()) + others = i18n("Forbidden"); + else + others = others.mid(0, others.count() - 2); + + retString = i18nc("This shows files and folders permissions: user, group and others", "(User: %1) (Group: %2) (Others: %3)", user, group, others); break; + } case KDirModel::Owner: retString = item.user();