File indexing completed on 2024-09-08 12:24:32
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_ATOM_LINK_H 0009 #define SYNDICATION_ATOM_LINK_H 0010 0011 #include <syndication/elementwrapper.h> 0012 0013 class QDomElement; 0014 class QString; 0015 0016 namespace Syndication 0017 { 0018 namespace Atom 0019 { 0020 /** 0021 * A link, pointing to webpages, media files on the web ("podcast"), 0022 * related content, etc. See rel() for details. 0023 * 0024 * @author Frank Osterfeld 0025 */ 0026 class SYNDICATION_EXPORT Link : public Syndication::ElementWrapper 0027 { 0028 public: 0029 /** 0030 * creates a null link object. 0031 */ 0032 Link(); 0033 0034 /** 0035 * creates a Link object wrapping an atom:link element. 0036 * @param element a DOM element, should be a atom:link element 0037 * (although not enforced), otherwise this object will not parse 0038 * anything useful 0039 */ 0040 explicit Link(const QDomElement &element); 0041 0042 /** 0043 * URL of the referenced resource (required) 0044 */ 0045 Q_REQUIRED_RESULT QString href() const; 0046 0047 /** 0048 * the relation between the feed/entry and the linked resource. 0049 * 0050 * The value of rel() is usually one of the following: 0051 * 0052 * @c "alternate": The URL points to an alternate version of the 0053 * feed/entry. In practice, this is the article described in an entry, 0054 * or the homepage of the feed. 0055 * 0056 * @c "enclosure": The link describes an Enclosure. See 0057 * Syndication::Enclosure for more information. 0058 * 0059 * @c "related": links to web resources with related content. E.g., an 0060 * article discussing KDE might link to the KDE homepage. 0061 * 0062 * @c "self": "identifies a resource equivalent to the containing 0063 * element". This is usually the URL of the feed source itself. 0064 * 0065 * @c "via": The link points to the source of the information contained 0066 * in the feed/entry 0067 * 0068 * @return the rel value specified in the feed. Default value is 0069 * @c "alternate" 0070 */ 0071 Q_REQUIRED_RESULT QString rel() const; 0072 0073 /** 0074 * MIME type of the linked resource. (optional) 0075 * 0076 * @return MIME type following (e.g., "text/html", "audio/mpeg"), 0077 * or a null string if not set 0078 */ 0079 Q_REQUIRED_RESULT QString type() const; 0080 0081 /** 0082 * the language of the linked resource. (optional) 0083 * If used together with a rel() value of "alternate", it 0084 * implies a translated version of the entry. 0085 * 0086 * @return a language tag as defined in RFC 3066, 0087 * or a null string if not specified 0088 */ 0089 Q_REQUIRED_RESULT QString hrefLanguage() const; 0090 0091 /** 0092 * human-readable information about the link. (optional) 0093 * 0094 * @return the link title as plain text ("<", "&" are text, not 0095 * markup!), or a null string if not specified 0096 */ 0097 Q_REQUIRED_RESULT QString title() const; 0098 0099 /** 0100 * size of the linked resource in bytes. (optional) 0101 * 0102 * @return file size in bytes, or 0 if not specified 0103 */ 0104 Q_REQUIRED_RESULT uint length() const; 0105 0106 /** 0107 * description of the link object for debugging purposes 0108 * 0109 * @return debug string 0110 */ 0111 Q_REQUIRED_RESULT QString debugInfo() const; 0112 }; 0113 0114 } // namespace Atom 0115 } // namespace Syndication 0116 0117 #endif // SYNDICATION_ATOM_LINK_H