Syndication::ParserCollection Class
template <typename T> class Syndication::ParserCollectionA collection of format-specific parser implementations. More...
Header: | #include <Syndication/ParserCollection> |
CMake: | find_package(KF6 REQUIRED COMPONENTS Syndication) target_link_libraries(mytarget PRIVATE KF6::Syndication) |
Public Functions
virtual void | changeMapper(const QString &format, Syndication::Mapper<T> *mapper) = 0 |
virtual Syndication::ErrorCode | lastError() const = 0 |
virtual QSharedPointer<T> | parse(const Syndication::DocumentSource &source, const QString &formatHint = QString()) = 0 |
virtual bool | registerParser(Syndication::AbstractParser *parser, Syndication::Mapper<T> *mapper) = 0 |
Detailed Description
To parse a feed source, pass it to the parse() method of this class.
In most cases, you should use the global singleton instance Syndication::parserCollection().
When loading the source from the web, use Loader instead of using this class directly.
Example code:
... QFile someFile(somePath); ... DocumentSource src(someFile.readAll()); someFile.close(); FeedPtr feed = parserCollection()->parse(src); if (feed) { QString title = feed->title(); QList<ItemPtr> items = feed->items(); ... }
The template parameter T is the abstraction class parsed documents should be mapped to. If you want to use your own abstraction MyFeed, implement ParserCollection<MyFeed> (Note that you have to provide mapper implementations for every feed format then).
Member Function Documentation
[pure virtual]
void ParserCollection::changeMapper(const QString &format, Syndication::Mapper<T> *mapper)
Changes the specific format to abstraction mapping for a parser.
format the format string of the parser whose mapping should be changed. See AbstractParser::format.
mapper Mapper implementation doing the mapping from the format specific representation to abstraction of type T.
[pure virtual]
Syndication::ErrorCode ParserCollection::lastError() const
Returns the error code of the last parse() call, or Success if parse() was successful or not yet called at all.
[pure virtual]
QSharedPointer<T> ParserCollection::parse(const Syndication::DocumentSource &source, const QString &formatHint = QString())
tries to parse a given source with the parsers registered. The source is passed to the first parser that accepts it.
source The source to be parsed
formatHint An optional hint which parser to test first. If there is a parser with the given hint as format string (e.g., "rss2", "atom", "rdf"...), it is asked first to accept the source. This can avoid unnecessary AbstractParser::accept() checks and speed up parsing. See also AbstractParser::format().
Returns the feed document parsed from the source, or NULL if no parser accepted the source.
[pure virtual]
bool ParserCollection::registerParser(Syndication::AbstractParser *parser, Syndication::Mapper<T> *mapper)
Adds a parser and corresponding mapper to the collection.
AbstractParser::format() must be unique in the collection. If there is already a parser with the same format string, the parser isn't added.
Note: ownership for both parser
and mapper
is taken by the implementation, so don't delete them in your code!
parser The parser to be registered
mapper the mapper that should be used for building the abstraction
Returns whether the parser was successfully registered or not.