File indexing completed on 2024-09-15 06:35:51

0001 /*
0002     This file is part of the syndication library
0003     SPDX-FileCopyrightText: 2006 Frank Osterfeld <osterfeld@kde.org>
0004 
0005     SPDX-License-Identifier: LGPL-2.0-or-later
0006 */
0007 
0008 #ifndef SYNDICATION_GLOBAL_H
0009 #define SYNDICATION_GLOBAL_H
0010 
0011 #include "feed.h"
0012 
0013 #include "syndication_export.h"
0014 
0015 #include <QString>
0016 
0017 namespace Syndication
0018 {
0019 class DocumentSource;
0020 template<class T>
0021 class ParserCollection;
0022 
0023 /**
0024  *
0025  * The default ParserCollection instance parsing
0026  * a DocumentSource into a Feed object.
0027  *
0028  * Use this to parse a local file or a otherwise
0029  * manually created DocumentSource object.
0030 
0031 * To retrieve a feed from the web, use Loader instead.
0032  *
0033  * Example code:
0034  *
0035  * @code
0036  * ...
0037  * QFile someFile(somePath);
0038  * ...
0039  * DocumentSource src(someFile.readAll());
0040  * someFile.close();
0041  *
0042  * FeedPtr feed = parserCollection()->parse(src);
0043  *
0044  * if (feed)
0045  * {
0046  *     QString title = feed->title();
0047  *     QList<ItemPtr> items = feed->items();
0048  *     ...
0049  * }
0050  * @endcode
0051  */
0052 SYNDICATION_EXPORT
0053 ParserCollection<Feed> *parserCollection();
0054 
0055 /**
0056  * parses a document from a source and returns a new Feed object
0057  * wrapping the feed content.
0058  * Shortcut for parserCollection()->parse().
0059  * See ParserCollection::parse() for more details.
0060  *
0061  * @param src the document source to parse
0062  * @param formatHint an optional hint which format to test first
0063  */
0064 SYNDICATION_EXPORT
0065 FeedPtr parse(const DocumentSource &src, const QString &formatHint = QString());
0066 
0067 /**
0068  * error code indicating fetching or parsing errors
0069  */
0070 enum ErrorCode {
0071     Success = 0, /**< No error occurred, feed was fetched and parsed
0072                   * successfully
0073                   */
0074     Aborted = 1, /**< file downloading/parsing was aborted by the user */
0075     Timeout = 2, /**< file download timed out */
0076 
0077     UnknownHost = 3, /**< The hostname couldn't get resolved to an IP address */
0078 
0079     FileNotFound = 4, /**< the host was contacted successfully, but reported a
0080                        * 404 error
0081                        */
0082     OtherRetrieverError = 5, /**< retriever error not covered by the error codes
0083                               * above. This is returned if a custom
0084                               * DataRetriever was used. See the
0085                               * retriever-specific status byte for more
0086                               * information on the occurred error. */
0087     InvalidXml = 6, /**< The XML is invalid. This is returned if no parser
0088                      * accepts the source and the DOM document can't be parsed.
0089                      * It is not returned if the source is not valid XML but a
0090                      * (non-XML) parser accepts it.
0091                      */
0092     XmlNotAccepted = 7, /**< The source is valid XML, but no parser accepted
0093                          * it.
0094                          */
0095     InvalidFormat = 8, /**< the source was accepted by a parser, but the actual
0096                         * parsing failed. As our parser implementations
0097                         * currently do not validate the source ("parse what you
0098                         * can get"), this code will be rarely seen.
0099                         */
0100 };
0101 
0102 } // namespace Syndication
0103 
0104 #endif // SYNDICATION_GLOBAL_H