File indexing completed on 2024-09-15 12:05:33
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_PERSON_H 0009 #define SYNDICATION_ATOM_PERSON_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 * describes a person, with name and optional URI and e-mail address. 0022 * Used to describe authors and contributors of feeds/entries 0023 * 0024 * @author Frank Osterfeld 0025 */ 0026 class SYNDICATION_EXPORT Person : public ElementWrapper 0027 { 0028 public: 0029 /** 0030 * creates a null person object 0031 */ 0032 Person(); 0033 0034 /** 0035 * creates a Person object wrapping an Atom Person Construct (atom:author, 0036 * atom:contributor tags) 0037 * @param element a DOM element, should be a Atom Person Construct 0038 * (although not enforced), otherwise this object will not parse 0039 * anything useful 0040 */ 0041 explicit Person(const QDomElement &element); 0042 0043 /** 0044 * a human-readable name for the person. (required) 0045 * The name is a required attribute of person constructs. 0046 * 0047 * @return a human-readable name of the person 0048 */ 0049 Q_REQUIRED_RESULT QString name() const; 0050 0051 /** 0052 * A URI associated with the person (optional). Usually the homepage. 0053 * 0054 * @return the URI of the person, or a null string if not specified 0055 */ 0056 Q_REQUIRED_RESULT QString uri() const; 0057 0058 /** 0059 * returns an e-mail address associated with the person. (optional) 0060 * 0061 * @return an e-mail address, or a null string if not specified 0062 */ 0063 Q_REQUIRED_RESULT QString email() const; 0064 0065 /** 0066 * description for debugging purposes 0067 * 0068 * @return debug string 0069 */ 0070 Q_REQUIRED_RESULT QString debugInfo() const; 0071 }; 0072 0073 } // namespace Atom 0074 } // namespace Syndication 0075 0076 #endif // SYNDICATION_ATOM_PERSON_H