/usr/include/kservicegroup.h is in kdelibs5-dev 4:4.8.5-0ubuntu0.6.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 | /* This file is part of the KDE project
Copyright (C) 2000 Waldo Bastian <bastian@kde.org>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License version 2 as published by the Free Software Foundation.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
*/
#ifndef KSERVICEGROUP_H
#define KSERVICEGROUP_H
#include <kdecore_export.h>
#include <ksycocaentry.h>
#include <kservice.h>
class KBuildServiceGroupFactory;
class KServiceGroupPrivate;
/**
* KServiceGroup represents a group of service, for example
* screensavers.
* This class is typically used like this:
*
* \code
* // Start from root group
* KServiceGroup::Ptr group = KServiceGroup::root();
* if (!group || !group->isValid()) return;
*
* KServiceGroup::List list = group->entries();
*
* // Iterate over all entries in the group
* for( KServiceGroup::List::ConstIterator it = list.begin();
* it != list.end(); it++)
* {
* KSycocaEntry *p = (*it);
* if (p->isType(KST_KService))
* {
* KService *s = static_cast<KService *>(p);
* printf("Name = %s\n", s->name().toLatin1());
* }
* else if (p->isType(KST_KServiceGroup))
* {
* KServiceGroup *g = static_cast<KServiceGroup *>(p);
* // Sub group ...
* }
* }
* \endcode
*
* @short Represents a group of services
*/
class KDECORE_EXPORT KServiceGroup : public KSycocaEntry
{
friend class KBuildServiceGroupFactory;
public:
typedef KSharedPtr<KServiceGroup> Ptr;
typedef KSharedPtr<KSycocaEntry> SPtr;
typedef QList<SPtr> List;
public:
/**
* Construct a dummy servicegroup indexed with @p name.
* @param name the name of the service group
*/
KServiceGroup( const QString & name );
/**
* Construct a service and take all information from a config file
* @param _fullpath full path to the config file
* @param _relpath relative path to the config file
*/
KServiceGroup( const QString & _fullpath, const QString & _relpath );
/**
* @internal construct a service from a stream.
* The stream must already be positionned at the correct offset
*/
KServiceGroup( QDataStream& _str, int offset, bool deep );
virtual ~KServiceGroup();
/**
* Returns the relative path of the service group.
* @return the service group's relative path
*/
QString relPath() const;
/**
* Returns the caption of this group.
* @return the caption of this group
*/
QString caption() const;
/**
* Returns the name of the icon associated with the group.
* @return the name of the icon associated with the group,
* or QString() if not set
*/
QString icon() const;
/**
* Returns the comment about this service group.
* @return the descriptive comment for the group, if there is one,
* or QString() if not set
*/
QString comment() const;
/**
* Returns the total number of displayable services in this group and
* any of its subgroups.
* @return the number of child services
*/
int childCount() const;
/**
* Returns true if the NoDisplay flag was set, i.e. if this
* group should be hidden from menus, while still being in ksycoca.
* @return true to hide this service group, false to display it
*/
bool noDisplay() const;
/**
* Return true if we want to display empty menu entry
* @return true to show this service group as menu entry is empty, false to hide it
*/
bool showEmptyMenu() const;
void setShowEmptyMenu( bool b);
/**
* @return true to show an inline header into menu
*/
bool showInlineHeader() const;
void setShowInlineHeader(bool _b);
/**
* @return true to show an inline alias item into menu
*/
bool inlineAlias() const;
void setInlineAlias(bool _b);
/**
* @return true if we allow to inline menu.
*/
bool allowInline() const;
void setAllowInline(bool _b);
/**
* @return inline limite value
*/
int inlineValue() const;
void setInlineValue(int _val);
/**
* Returns a list of untranslated generic names that should be
* be suppressed when showing this group.
* E.g. The group "Games/Arcade" might want to suppress the generic name
* "Arcade Game" since it's redundant in this particular context.
*/
QStringList suppressGenericNames() const;
/**
* @internal
* Sets information related to the layout of services in this group.
*/
void setLayoutInfo(const QStringList &layout);
/**
* @internal
* Returns information related to the layout of services in this group.
*/
QStringList layoutInfo() const;
/**
* List of all Services and ServiceGroups within this
* ServiceGroup.
* @param sorted true to sort items
* @param excludeNoDisplay true to exclude items marked "NoDisplay"
* @param allowSeparators true to allow separator items to be included
* @param sortByGenericName true to sort GenericName+Name instead of Name+GenericName
* @return the list of entries
*/
List entries(bool sorted, bool excludeNoDisplay, bool allowSeparators, bool sortByGenericName=false);
List entries(bool sorted, bool excludeNoDisplay);
/**
* List of all Services and ServiceGroups within this
* ServiceGroup.
* @param sorted true to sort items
* @return the list of entried
*/
List entries(bool sorted = false);
/**
* options for groupEntries and serviceEntries
*/
enum EntriesOption
{
NoOptions = 0x0,
SortEntries = 0x1, /*< sort items */
ExcludeNoDisplay = 0x2, /*< exclude items marked "NoDisplay" */
AllowSeparators = 0x4, /*< allow separator items to be included */
SortByGenericName = 0x8 /*< sort by GenericName+Name instead of Name+GenericName */
};
Q_DECLARE_FLAGS(EntriesOptions, EntriesOption)
/**
* subgroups for this service group
*/
QList<Ptr> groupEntries(EntriesOptions options = ExcludeNoDisplay);
/**
* entries of this service group
*/
KService::List serviceEntries(EntriesOptions options = ExcludeNoDisplay);
/**
* Returns a non-empty string if the group is a special base group.
* By default, "Settings/" is the kcontrol base group ("settings")
* and "System/Screensavers/" is the screensavers base group ("screensavers").
* This allows moving the groups without breaking those apps.
*
* The base group is defined by the X-KDE-BaseGroup key
* in the .directory file.
* @return the base group name, or null if no base group
*/
QString baseGroupName() const;
/**
* Returns a path to the .directory file describing this service group.
* The path is either absolute or relative to the "apps" resource.
*/
QString directoryEntryPath() const;
/**
* Returns the group for the given baseGroupName.
* Can return 0L if the directory (or the .directory file) was deleted.
* @return the base group with the given name, or 0 if not available.
*
* This mechanism was fragile and isn't used in kde4 anymore.
* @deprecated Use a servicetype and a proper trader query instead, for a better
* way of finding related services.
*/
#ifndef KDE_NO_DEPRECATED
static KDE_DEPRECATED Ptr baseGroup( const QString &baseGroupName );
#endif
/**
* Returns the root service group.
* @return the root service group
*/
static Ptr root();
/**
* Returns the group with the given relative path.
* @param relPath the path of the service group
* @return the group with the given relative path name.
*/
static Ptr group(const QString &relPath);
/**
* Returns the group of services that have X-KDE-ParentApp equal
* to @p parent (siblings).
* @param parent the name of the service's parent
* @return the services group
*/
static Ptr childGroup(const QString &parent);
protected:
/**
* @internal
* Add a service to this group
*/
void addEntry( const KSycocaEntry::Ptr& entry);
private:
Q_DECLARE_PRIVATE(KServiceGroup)
};
#endif
|