3 /// Blackberry database record parser class for calndar records.
7 Copyright (C) 2005-2009, Net Direct Inc. (http://www.netdirect.ca/)
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2 of the License, or
12 (at your option) any later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
18 See the GNU General Public License in the COPYING file at the
19 root directory of this project for more details.
22 #ifndef __BARRY_RECORD_CALENDAR_H__
23 #define __BARRY_RECORD_CALENDAR_H__
27 #include "r_recur_base.h"
36 // forward declarations
40 // NOTE: All classes here must be container-safe! Perhaps add sorting
41 // operators in the future.
46 /// \addtogroup RecordParserClasses
49 class BXEXPORT Calendar
: public RecurBase
52 typedef std::vector
<UnknownField
> UnknownsType
;
62 time_t NotificationTime
; // 0 means notification is off
69 /// This lists the available settings found in the device.
70 /// This list is based on information from MS Outlook 2007
71 /// (Free ==0 and Busy == 2)
72 /// This is FBTYPE in RFC2445 and is defined as
73 /// FREE, BUSY, BUSY-UNAVAILABLE and BUSY-TENTATIVE
75 enum FreeBusyFlagType
{
81 FreeBusyFlagType FreeBusyFlag
;
86 /// This is also called classification in Evolution and it
87 /// is the equivilant of public or private in outlook
88 /// Private is set to 0x2 in Outlook
89 /// RFC2445 CLASS is PUBLIC, PRIVATE, CONFIDENTIAL
97 ClassFlagType ClassFlag
;
100 unsigned short TimeZoneCode
; // the time zone originally used
101 // for the recurrence data...
102 // seems to have little use, but
103 // set to your current time zone
105 bool TimeZoneValid
; // true if the record contained a
109 UnknownsType Unknowns
;
112 const unsigned char* ParseField(const unsigned char *begin
,
113 const unsigned char *end
, const IConverter
*ic
= 0);
119 // Parser / Builder API (see parser.h / builder.h)
120 uint8_t GetRecType() const { return RecType
; }
121 uint32_t GetUniqueId() const { return RecordId
; }
122 void SetIds(uint8_t Type
, uint32_t Id
) { RecType
= Type
; RecordId
= Id
; }
123 void ParseHeader(const Data
&data
, size_t &offset
);
124 void ParseFields(const Data
&data
, size_t &offset
, const IConverter
*ic
= 0);
125 void BuildHeader(Data
&data
, size_t &offset
) const;
126 void BuildFields(Data
&data
, size_t &offset
, const IConverter
*ic
= 0) const;
130 void Dump(std::ostream
&os
) const;
133 bool operator<(const Calendar
&other
) const { return StartTime
< other
.StartTime
; }
136 static const char * GetDBName() { return "Calendar"; }
137 static uint8_t GetDefaultRecType() { return 5; } // or 0?
140 BXEXPORT
inline std::ostream
& operator<<(std::ostream
&os
, const Calendar
&msg
) {