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
|
/* kcalRecord.cc KPilot
**
** Copyright (C) 2006 by Adriaan de Groot <[email protected]>
** Copyright (C) 2002-2003 by Reinhold Kainhofer
** Copyright (C) 2001 by Dan Pilone
**
*/
/*
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation; either version 2 of the License, or
** (at your option) any later version.
**
** This program 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 General Public License for more details.
**
** You should have received a copy of the GNU General Public License
** along with this program in a file called COPYING; if not, write to
** the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
** MA 02110-1301, USA.
*/
/*
** Bug reports and questions can be sent to [email protected]
*/
#include "options.h"
#include <libkcal/calendar.h>
#include <libkcal/calendarlocal.h>
#include <libkcal/recurrence.h>
#include <libkcal/vcalformat.h>
#include "pilot.h"
#include "pilotRecord.h"
#include "kcalRecord.h"
void KCalSync::setCategory(PilotRecordBase *de,
const KCal::Incidence *e,
const CategoryAppInfo &info)
{
FUNCTIONSETUP;
if (!de || !e)
{
return;
}
TQString deCategory;
TQStringList eventCategories = e->categories();
if (eventCategories.size() < 1)
{
// This event has no categories.
de->setCategory(Pilot::Unfiled);
return;
}
// Quick check: does the record (not unfiled) have an entry
// in the categories list? If so, use that.
if (de->category() != Pilot::Unfiled)
{
deCategory = Pilot::categoryName(&info,de->category());
if (eventCategories.contains(deCategory))
{
// Found, so leave the category unchanged.
return;
}
}
TQStringList availableHandheldCategories = Pilot::categoryNames(&info);
// Either the record is unfiled, and should be filed, or
// it has a category set which is not in the list of
// categories that the event has. So go looking for
// a category that is available both for the event
// and on the handheld.
for ( TQStringList::ConstIterator it = eventCategories.begin();
it != eventCategories.end(); ++it )
{
// Odd, an empty category string.
if ( (*it).isEmpty() )
{
continue;
}
if (availableHandheldCategories.contains(*it))
{
// Since the string is in the list of available categories,
// this *can't* fail.
int c = Pilot::findCategory(&info,*it,false);
Q_ASSERT( Pilot::validCategory(c) );
de->setCategory(c);
return;
}
}
de->setCategory(Pilot::Unfiled);
}
void KCalSync::setCategory(KCal::Incidence *e,
const PilotRecordBase *de,
const CategoryAppInfo &info)
{
FUNCTIONSETUP;
if (!e || !de)
{
DEBUGKPILOT << fname << ": error. unable to set kcal category. e: ["
<< (void *)e << "], de: [" << (void *)de << "]" << endl;
return;
}
TQStringList cats=e->categories();
int cat = de->category();
TQString newcat = Pilot::categoryName(&info,cat);
DEBUGKPILOT << fname << ": palm category id: [" << cat <<
"], label: [" << newcat << "]" << endl;
if ( Pilot::validCategory(cat) && (cat != Pilot::Unfiled))
{
if (!cats.contains(newcat))
{
// if this event only has one category associated with it, then we can
// safely assume that what we should be doing here is changing it to match
// the palm. if there's already more than one category in the event, however, we
// won't cause data loss--we'll just append what the palm has to the
// event's categories
if (cats.count() <=1)
{
cats.clear();
}
cats.append( newcat );
e->setCategories(cats);
}
}
DEBUGKPILOT << fname << ": kcal categories now: [" << cats.join(",") << "]" << endl;
}
|