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
|
/*
This file is part of libkcal.
Copyright (c) 2003 Cornelius Schumacher <[email protected]>
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"
#include "icalformat.h"
#include "qtopiaformat.h"
#include <kaboutdata.h>
#include <kapplication.h>
#include <kdebug.h>
#include <klocale.h>
#include <kcmdlineargs.h>
#include <kglobal.h>
#include <kconfig.h>
#include <kstandarddirs.h>
#include <iostream>
using namespace KCal;
static const KCmdLineOptions options[] =
{
{"q", 0, 0 },
{"qtopia2icalendar", I18N_NOOP("Convert TQtopia calendar file to iCalendar"), 0 },
{"i", 0, 0 },
{"icalendar2qtopia", I18N_NOOP("Convert iCalendar to iCalendar"), 0 },
{"o", 0, 0},
{"output <file>", I18N_NOOP("Output file"), 0 },
{"+input", I18N_NOOP("Input file"), 0 },
KCmdLineLastOption
};
int main(int argc,char **argv)
{
KAboutData aboutData("convertqtopia",I18N_NOOP("TQtopia calendar file converter"),"0.1");
aboutData.addAuthor("Cornelius Schumacher", 0, "[email protected]");
TDECmdLineArgs::init(argc,argv,&aboutData);
TDECmdLineArgs::addCmdLineOptions( options );
KApplication app;
TDECmdLineArgs *args = TDECmdLineArgs::parsedArgs();
bool sourceTQtopia = false;
bool sourceIcalendar = false;
if ( args->isSet( "qtopia2icalendar" ) ) {
sourceTQtopia = true;
}
if ( args->isSet( "icalendar2qtopia" ) ) {
sourceIcalendar = true;
}
if ( sourceTQtopia && sourceIcalendar ) {
TDECmdLineArgs::usage(
i18n("Please specify only one of the conversion options.") );
}
if ( !sourceTQtopia && !sourceIcalendar ) {
TDECmdLineArgs::usage(
i18n("You have to specify one conversion option.") );
}
if ( args->count() != 1 ) {
TDECmdLineArgs::usage( i18n("Error: No input file.") );
}
TQString inputFile = args->arg( 0 );
TQString outputFile;
if ( args->isSet("output") ) outputFile = args->getOption( "output" );
kdDebug(5800) << "Input File: '" << inputFile << "'" << endl;
kdDebug(5800) << "Output File: '" << outputFile << "'" << endl;
if ( sourceTQtopia ) {
CalendarLocal cal;
TQtopiaFormat qtopiaFormat;
qtopiaFormat.load( &cal, inputFile );
ICalFormat icalendarFormat;
if ( outputFile.isEmpty() ) {
TQString out = icalendarFormat.toString( &cal );
std::cout << out.local8Bit() << std::endl;
} else {
bool success = icalendarFormat.save( &cal, outputFile );
if ( !success ) {
std::cerr << i18n( "Error saving to '%1'." ).arg( outputFile ).local8Bit()
<< std::endl;
return 1;
}
}
}
if ( sourceIcalendar ) {
std::cerr << "Not implemented yet." << std::endl;
return 1;
}
}
|