source: trunk/examples/xml/xmlstreamlint/main.cpp@ 500

Last change on this file since 500 was 2, checked in by Dmitry A. Kuminov, 16 years ago

Initially imported qt-all-opensource-src-4.5.1 from Trolltech.

File size: 3.9 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4** Contact: Qt Software Information ([email protected])
5**
6** This file is part of the examples of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial Usage
10** Licensees holding valid Qt Commercial licenses may use this file in
11** accordance with the Qt Commercial License Agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and Nokia.
14**
15** GNU Lesser General Public License Usage
16** Alternatively, this file may be used under the terms of the GNU Lesser
17** General Public License version 2.1 as published by the Free Software
18** Foundation and appearing in the file LICENSE.LGPL included in the
19** packaging of this file. Please review the following information to
20** ensure the GNU Lesser General Public License version 2.1 requirements
21** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
22**
23** In addition, as a special exception, Nokia gives you certain
24** additional rights. These rights are described in the Nokia Qt LGPL
25** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
26** package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you are unsure which license is appropriate for your use, please
37** contact the sales department at [email protected].
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42#include <QCoreApplication>
43#include <QFile>
44#include <QStringList>
45#include <QTextStream>
46#include <QXmlStreamReader>
47
48/*
49 This class exists for the sole purpose of creating a translation context.
50*/
51class XmlStreamLint
52{
53public:
54 Q_DECLARE_TR_FUNCTIONS(XmlStreamLint)
55};
56
57int main(int argc, char *argv[])
58{
59 enum ExitCode
60 {
61 Success,
62 ParseFailure,
63 ArgumentError,
64 WriteError,
65 FileFailure
66 };
67
68 QCoreApplication app(argc, argv);
69
70 QTextStream errorStream(stderr);
71
72 if (argc != 2)
73 {
74 errorStream << XmlStreamLint::tr(
75 "Usage: xmlstreamlint <path to XML file>\n");
76 return ArgumentError;
77 }
78
79 QString inputFilePath(QCoreApplication::arguments().at(1));
80 QFile inputFile(inputFilePath);
81
82 if (!QFile::exists(inputFilePath))
83 {
84 errorStream << XmlStreamLint::tr(
85 "File %1 does not exist.\n").arg(inputFilePath);
86 return FileFailure;
87
88 } else if (!inputFile.open(QIODevice::ReadOnly)) {
89 errorStream << XmlStreamLint::tr(
90 "Failed to open file %1.\n").arg(inputFilePath);
91 return FileFailure;
92 }
93
94 QFile outputFile;
95 if (!outputFile.open(stdout, QIODevice::WriteOnly))
96 {
97 errorStream << XmlStreamLint::tr("Failed to open stdout.");
98 return WriteError;
99 }
100
101//! [0]
102 QXmlStreamReader reader(&inputFile);
103 QXmlStreamWriter writer(&outputFile);
104//! [0]
105
106//! [1]
107 while (!reader.atEnd())
108 {
109 reader.readNext();
110
111 if (reader.error())
112 {
113 errorStream << XmlStreamLint::tr(
114 "Error: %1 in file %2 at line %3, column %4.\n").arg(
115 reader.errorString(), inputFilePath,
116 QString::number(reader.lineNumber()),
117 QString::number(reader.columnNumber()));
118 return ParseFailure;
119//! [1]
120
121//! [2]
122 } else
123 writer.writeCurrentToken(reader);
124 }
125//! [2]
126
127 return Success;
128}
Note: See TracBrowser for help on using the repository browser.