This file is indexed.

/usr/include/kholidays/holidayregionselector.h is in kdepimlibs5-dev 4:4.14.10-7+b2.

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
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
/*
  This file is part of the kholidays library.

  Copyright 2010 John Layt <john@layt.net>

  This library is free software; you can redistribute it and/or
  modify it under the terms of the GNU Library General Public
  License as published by the Free Software Foundation; either
  version 2 of the License, or (at your option) any later version.

  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 KHOLIDAYS_HOLIDAYREGIONSELECTOR_H
#define KHOLIDAYS_HOLIDAYREGIONSELECTOR_H

#include "kholidays_export.h"

#include <QTreeWidget>

class QString;
class QStringList;

namespace KHolidays {

class HolidayRegion;

class KHOLIDAYS_EXPORT HolidayRegionSelector : public QWidget
{
  Q_OBJECT
  Q_PROPERTY( QAbstractItemView::SelectionMode listSelectionMode
              READ selectionMode WRITE setSelectionMode )

  Q_PROPERTY( bool enableRegionUseFlags
              READ regionUseFlagsEnabled WRITE setRegionUseFlagsEnabled )

  Q_PROPERTY( bool hideSearch
              READ searchHidden WRITE setSearchHidden )

  Q_PROPERTY( bool hideDescription
              READ descriptionHidden WRITE setDescriptionHidden )

  Q_PROPERTY( bool hideLanguage
              READ languageHidden WRITE setLanguageHidden )

  Q_PROPERTY( QStringList languageFilter
              READ languageFilter WRITE setLanguageFilter )

  public:
    /**
     * Describes the Selection Status of a Holiday Region.
     */
    enum SelectionStatus {
      RegionHidden,             ///< The Holiday Region is not displayed
      RegionDisabled,           ///< The Holiday Region is not available for selection
      RegionAvailable,          ///< The Holiday Region is available for selection
      RegionSelected            ///< The Holiday Region is selected
    };

    /**
     * Describes the Usage of a Holiday Region.
     */
    enum RegionUseFlag {
      NotUsed            = 0x00,    ///< The Holiday Region is not used
      UseInformationOnly = 0x01,    ///< The Holiday Region is used for information only
      UseDaysOff         = 0x02     ///< The Holiday Region is used for Days Off
    };
    Q_DECLARE_FLAGS( RegionUseFlags, RegionUseFlag )

    /**
     * Constructs a default Holiday Region selection widget.
     *
     * This widget will automatically be populated with all available Holiday Regions,
     * will display all available features including a serach bar and various details
     * columns, and will operate in Multi Selection mode.  If you require fewer details
     * or regions displayed or to operate in single or no selection mode, then you must
     * configure these after the widget is created.
     *
     * By default multiple Region Use selections are available to the user.  This is
     * normally used to set if holidays are to be used for days off or information only.
     * These Use options can be overridden or disabled, or the text displayed modifed
     * as required.
     *
     * @param parent The parent widget.
     */
    explicit HolidayRegionSelector( QWidget *parent = 0 );

    /**
     * Destructor
     */
    virtual ~HolidayRegionSelector();

    /**
     * Return a list of all Holiday Regions available
     *
     * @return List of all Holiday Region Codes
     */
    QStringList holidayRegions() const;

    /**
     * Set what selection mode the Region list uses.
     *
     * The Selection Mode determines how many Holiday Regions can be selected in the list:
     *  - If NoSelection mode then the widget is display only and the user cannot select any
     *    Holiday Region.
     *  - If SingleSelection mode then only a single Holiday Region can be chosen.
     *  - If MultiSelection mode then more than one Holiday Regions can be chosen.
     *
     * @see selectionMode
     * @param selectionMode The selection mode to use
     */
    void setSelectionMode( QAbstractItemView::SelectionMode selectionMode );

    /**
     * Return what selection mode the Region list uses.
     *
     * @see setSelectionMode
     * @return The selection mode used
     */
    QAbstractItemView::SelectionMode selectionMode() const;

    /**
     * Set if Region Use Flags are enabled
     *
     * If Region Use Flags are disabled then the user can only select a Region
     * with a binary on/off check box.  The selection status is set and returned
     * using the holidayRegionStatus and setHolidayRegionStatus methods.
     *
     * If the Region Use Flags are enabled then the user can select from multiple
     * options for how a Region can be used via a combo box.  The use flags are
     * set and returned using the setRegionUseFlags and regionUseFlags methods.
     *
     * @see setSelectionMode
     * @param listSelectionMode The list selection mode to use
     */
    void setRegionUseFlagsEnabled( bool enableRegionUseFlags );

    /**
     * Returns if Region Use Flags are enabled.
     *
     * @see setRegionUseFlagsEnabled
     * @return if the Region Use Flags are enabled
     */
    bool regionUseFlagsEnabled() const;

    /**
     * Set the Selection Status for a Holiday Region.
     *
     * @see selectionStatus
     * @param holidayRegionCode The Holiday Region to set the Status for
     * @param status The Selection Status of the Holiday Region
     */
    void setSelectionStatus( const QString &holidayRegionCode,
                             HolidayRegionSelector::SelectionStatus status );

    /**
     * Returns the current Selection Status for a Holiday Region.
     *
     * @see setSelectionStatus
     * @param holidayRegionCode The Holiday Region required
     * @return The current Selection Status for the Holiday Region
     */
    HolidayRegionSelector::SelectionStatus selectionStatus(
      const QString &holidayRegionCode ) const;

    /**
     * Returns the current Selection Status for all Holiday Regions.
     *
     * @see setSelectionStatus
     * @return A QHash of all Holiday Regions and their current Selection Status
     */
    QHash<QString, HolidayRegionSelector::SelectionStatus> selectionStatus() const;

    /**
     * Returns the list of Holiday Regions with a required Selection Status,
     * defults to returning all selected Regions.
     *
     * @see setSelectionStatus
     * @see selectionStatus
     * @param selectionStatus The selection status to match, defaults to RegionSelected
     * @return A list of selected Holiday Regions
     */
    QStringList selection( HolidayRegionSelector::SelectionStatus selectionStatus =
                           HolidayRegionSelector::RegionSelected ) const;

    /**
     * Returns the list of Holiday Regions with a required Region Use Flag.
     *
     * @see setRegionUseFlags
     * @see regionUseFlags
     * @param regionUseFlags The Region Use flags to match
     * @return A list of matching Holiday Regions
     */
    QStringList selection( HolidayRegionSelector::RegionUseFlags regionUseFlags ) const;

    /**
     * Clear the current Selection Status of all Holiday Regions including Region Use Flags.
     *
     * @see setSelectionStatus
     * @see selectionStatus
     * @see selection
     */
    void clearSelection();

    /**
     * Set the Region Use Flags for a Holiday Region.
     *
     * @see regionUseFlags
     * @param holidayRegionCode The Holiday Region to set the Use Flags for
     * @param regionUseFlags The Use Flags for the Holiday Region
     */
    void setRegionUseFlags( const QString &holidayRegionCode,
                            HolidayRegionSelector::RegionUseFlags regionUseFlags );

    /**
     * Returns the current Region Use Flags for a Holiday Region.
     *
     * @see setRegionUseFlags
     * @param holidayRegionCode The Holiday Region required
     * @return The current Use Flags for the Holiday Region
     */
    HolidayRegionSelector::RegionUseFlags regionUseFlags( const QString &holidayRegionCode ) const;

    /**
     * Returns the current Region Use Flags for all Holiday Regions.
     *
     * @see setRegionUseFlags
     * @return A QHash of Holiday Regions and their current Region Use Flags
     */
    QHash<QString, HolidayRegionSelector::RegionUseFlags> regionUseFlags() const;

    /**
     * Set a language filter on the Holiday Regions to be displayed.
     *
     * Only Holiday Regions in a language included in the filter will be
     * displayed in the widget, i.e. all other Holiday Regions will have
     * a SelectionStatus of RegionHidden.
     *
     * Setting a null list disables the display filter, i.e. all Holiday
     * Regions are displayed.
     *
     * @see languageFilter
     * @param languages A list of languages to filter for
     */
    void setLanguageFilter( const QStringList &languages );

    /**
     * Return the current language filter, a null list implies no filter is set.
     *
     * @see setLanguageFilter
     * @return The list of languages currently being displayed
     */
    QStringList languageFilter() const;

    /**
     * Set if the search line to be hidden or displayed.
     *
     * @see searchHidden
     * @param hideSearch If the search is to be hidden
     */
    void setSearchHidden( bool hideSearch );

    /**
     * Return if the search line is currently hidden.
     *
     * @see setSearchHidden
     * @return If the search line is hidden
     */
    bool searchHidden() const;

    /**
     * Set if the Holiday Region Language field is to be hidden or displayed.
     *
     * @see languageHidden
     * @param hideLanguage If the language field is to be hidden
     */
    void setLanguageHidden( bool hideLanguage );

    /**
     * Return if the Holiday Region Language field is currently hidden.
     *
     * @see setLanguageHidden
     * @return If the language field is hidden
     */
    bool languageHidden() const;

    /**
     * Set if the Holiday Region Description field is to be hidden or displayed.
     *
     * @see descriptionHidden
     * @param hideDescription If the description field is to be hidden
     */
    void setDescriptionHidden( bool hideDescription );

    /**
     * Return if the Holiday Region Description field is currently hidden.
     *
     * @see setDescriptionHidden
     * @return If the description field is hidden
     */
    bool descriptionHidden() const;

  private Q_SLOTS:
    void itemChanged( QTreeWidgetItem *item, int column );
    void itemChanged( int index );

  Q_SIGNALS:
    void selectionChanged();

  private:
    class Private;
    Private *const d;
};

} // namespace KHolidays

Q_DECLARE_OPERATORS_FOR_FLAGS( KHolidays::HolidayRegionSelector::RegionUseFlags )

#endif // KHOLIDAYS_HOLIDAYREGIONSELECTOR_H