/usr/include/QtOrganizer/qorganizerrecurrencerule.h is in qtmobility-dev 1.2.0-3ubuntu5.
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 | /****************************************************************************
**
** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
** All rights reserved.
** Contact: Nokia Corporation (qt-info@nokia.com)
**
** This file is part of the Qt Mobility Components.
**
** $QT_BEGIN_LICENSE:LGPL$
** No Commercial Usage
** This file contains pre-release code and may not be distributed.
** You may use this file in accordance with the terms and conditions
** contained in the Technology Preview License Agreement accompanying
** this package.
**
** GNU Lesser General Public License Usage
** Alternatively, this file may be used under the terms of the GNU Lesser
** General Public License version 2.1 as published by the Free Software
** Foundation and appearing in the file LICENSE.LGPL included in the
** packaging of this file. Please review the following information to
** ensure the GNU Lesser General Public License version 2.1 requirements
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** In addition, as a special exception, Nokia gives you certain additional
** rights. These rights are described in the Nokia Qt LGPL Exception
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
**
** If you have questions regarding the use of this file, please contact
** Nokia at qt-info@nokia.com.
**
**
**
**
**
**
**
**
** $QT_END_LICENSE$
**
****************************************************************************/
#ifndef QORGANIZERRECURRENCERULE_H
#define QORGANIZERRECURRENCERULE_H
#include <QString>
#include <QDateTime>
#include <QSet>
#include <QHash>
#include "qtorganizerglobal.h"
QTM_BEGIN_NAMESPACE
class QOrganizerRecurrenceRulePrivate;
class Q_ORGANIZER_EXPORT QOrganizerRecurrenceRule
{
public:
QOrganizerRecurrenceRule();
~QOrganizerRecurrenceRule();
QOrganizerRecurrenceRule(const QOrganizerRecurrenceRule& other);
QOrganizerRecurrenceRule& operator=(const QOrganizerRecurrenceRule& other);
bool operator==(const QOrganizerRecurrenceRule& other) const;
// enums
enum Frequency {
Invalid = 0,
Daily,
Weekly,
Monthly,
Yearly
};
enum Month {
January = 1,
February,
March,
April,
May,
June,
July,
August,
September,
October,
November,
December
};
enum LimitType {
NoLimit = 0,
CountLimit,
DateLimit
};
void setFrequency(Frequency freq);
Frequency frequency() const;
void setLimit(int count);
void setLimit(const QDate& date);
void clearLimit();
LimitType limitType() const;
int limitCount() const;
QDate limitDate() const;
void setInterval(int interval);
int interval() const; // units of frequency
// Defaults for the below: empty
// eg: Monday,Wednesday,Thursday == every Mon, Wed and Thurs.
void setDaysOfWeek(const QSet<Qt::DayOfWeek>& days);
QSet<Qt::DayOfWeek> daysOfWeek() const;
// eg: 31,-3 == 31st day of month (if it exists) and 3rd-last day of month
void setDaysOfMonth(const QSet<int>& days);
QSet<int> daysOfMonth() const;
// eg: 47th,-5 == 47th and 5th-last day of year
void setDaysOfYear(const QSet<int>& days);
QSet<int> daysOfYear() const;
// eg: January,February == during Jan and Feb
void setMonthsOfYear(const QSet<Month>& months);
QSet<Month> monthsOfYear() const;
// eg. 13,53,-3 == weeks 13 and 53 (if it exists) and the 3rd-last week of the year
void setWeeksOfYear(const QSet<int>& weeks);
QSet<int> weeksOfYear() const;
// Default: Monday
// sets the day that the week starts on (significant for Weekly with interval > 1, and for weekOfYear)
void setFirstDayOfWeek(Qt::DayOfWeek day);
Qt::DayOfWeek firstDayOfWeek() const;
// eg. frequency = Monthly, dayOfWeek = Tuesday, positions = 1,-1 means first and last Tuesday
// of every month.
// All other criteria are applied first, then for each time period as specified by frequency,
// dates are selected via the 1-based indices specified by position.
void setPositions(const QSet<int>& pos);
QSet<int> positions() const;
private:
QSharedDataPointer<QOrganizerRecurrenceRulePrivate> d;
};
//hash functions
Q_ORGANIZER_EXPORT uint qHash(const QOrganizerRecurrenceRule& rule);
#ifndef QT_NO_DEBUG_STREAM
Q_ORGANIZER_EXPORT QDebug operator<<(QDebug dbg, const QOrganizerRecurrenceRule& rule);
#endif
inline uint qHash(QOrganizerRecurrenceRule::Month month)
{
return static_cast<uint>(month);
}
QTM_END_NAMESPACE
inline uint qHash(const QDate &date)
{
return date.toJulianDay();
}
Q_DECLARE_TYPEINFO(QTM_PREPEND_NAMESPACE(QOrganizerRecurrenceRule), Q_MOVABLE_TYPE);
Q_DECLARE_METATYPE(QTM_PREPEND_NAMESPACE(QOrganizerRecurrenceRule))
Q_DECLARE_METATYPE(QSet<QTM_PREPEND_NAMESPACE(QOrganizerRecurrenceRule)>)
Q_DECLARE_METATYPE(QSet<QDate>)
#endif
|