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
|
/*
This file is part of libkcal.
Copyright (c) 2003 Cornelius Schumacher <schumacher@kde.org>
Copyright (C) 2005 Reinhold Kainhofer <reinhold@kainhofe.com>
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.
*/
#include "calendarlocal.h"
extern "C" {
#include "icaltimezone.h"
}
#include <kaboutdata.h>
#include <kapplication.h>
#include <kdebug.h>
#include <kcmdlineargs.h>
#include <tqfile.h>
using namespace KCal;
static const KCmdLineOptions options[] =
{
{ "verbose", "Verbose output", 0 },
{ "+input", "Name of input file", 0 },
{ "[+output]", "optional name of output file for the recurrence dates", 0 },
KCmdLineLastOption
};
int main( int argc, char **argv )
{
KAboutData aboutData( "testrecurrencenew", "Load recurrence rules with the new class and print out debug messages", "0.1" );
KCmdLineArgs::init( argc, argv, &aboutData );
KCmdLineArgs::addCmdLineOptions( options );
KApplication app( false, false );
KCmdLineArgs *args = KCmdLineArgs::parsedArgs();
if ( args->count() < 1 ) {
args->usage( "Wrong number of arguments." );
}
// use zoneinfo data from source dir
set_zone_directory( KDETOPSRCDIR "/libkcal/libical/zoneinfo" );
TQString input = TQFile::decodeName( args->arg( 0 ) );
kdDebug(5800) << "Input file: " << input << endl;
TQTextStream *outstream;
outstream = 0;
TQString fn("");
if ( args->count() > 1 ) {
fn = args->arg( 1 );
kdDebug() << "We have a file name given: " << fn << endl;
}
TQFile outfile( fn );
if ( !fn.isEmpty() && outfile.open( IO_WriteOnly ) ) {
kdDebug() << "Opened output file!!!" << endl;
outstream = new TQTextStream( &outfile );
}
CalendarLocal cal( TQString::tqfromLatin1("UTC") );
if ( !cal.load( input ) ) return 1;
TQString tz = cal.nonKDECustomProperty( "X-LibKCal-Testsuite-OutTZ" );
if ( !tz.isEmpty() ) {
cal.setTimeZoneIdViewOnly( tz );
}
Incidence::List inc = cal.incidences();
for ( Incidence::List::Iterator it = inc.begin(); it != inc.end(); ++it ) {
Incidence *incidence = *it;
kdDebug(5800) << "*+*+*+*+*+*+*+*+*+*" << endl;
kdDebug(5800) << " -> " << incidence->summary() << " <- " << endl;
incidence->recurrence()->dump();
TQDateTime dt( incidence->dtStart().addSecs(-2) );
int i=0;
if ( outstream ) {
// Output to file for testing purposes
while (dt.isValid() && i<500 ) {
++i;
dt = dt.addSecs( 1 );
dt = incidence->recurrence()->getNextDateTime( dt );
(*outstream) << dt.toString( TQt::ISODate ) << endl;
}
} else {
incidence->recurrence()->dump();
// Output to konsole
while ( dt.isValid() && i<10 ) {
++i;
kdDebug(5800) << "-------------------------------------------" << endl;
dt = incidence->recurrence()->getNextDateTime( dt );
kdDebug(5800) << " *~*~*~*~ Next date is: " << dt << endl;
dt = dt.addSecs( 1 );
}
}
}
delete outstream;
outfile.close();
return 0;
}
|