/usr/include/syndication/enclosure.h is in kdepimlibs5-dev 4:4.14.10-7+b2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 | /*
* This file is part of the syndication library
*
* Copyright (C) 2006 Frank Osterfeld <osterfeld@kde.org>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*
*/
#ifndef SYNDICATION_ENCLOSURE_H
#define SYNDICATION_ENCLOSURE_H
#include "ksyndication_export.h"
#include <boost/shared_ptr.hpp>
#include <QtCore/QString>
namespace Syndication {
class Enclosure;
//@cond PRIVATE
typedef boost::shared_ptr<Enclosure> EnclosurePtr;
//@endcond
/**
* An enclosure describes a (media) file available on the net.
*
* Most of the time, enclosures are used for "podcasts", i.e. audio
* files announced and distributed via syndication.
*
* @author Frank Osterfeld
*/
class SYNDICATION_EXPORT Enclosure
{
public:
/**
* destructor
*/
virtual ~Enclosure();
/**
* returns whether this enclosure is a null object.
*/
virtual bool isNull() const = 0;
/**
* The URL of the linked resource (required).
*/
virtual QString url() const = 0;
/**
* title of the enclosure. This is a human-readable description of the
* linked file. If available, the title should be used in user interfaces
* instead of the URL. If no title is set (e.g., RSS2 enclosures don't
* have titles), use url() as fallback.
*
* @return title describing the enclosure, or a null string if not
* specified.
*/
virtual QString title() const = 0;
/**
* mimetype of the enclosure.
* TODO: link mimetype specs
*
* Examples are @c "audio/mpeg" for MP3, or @c "application/pdf" for
* PDF.
*
* @return the mimetype of the file, or a null string if not
* specified
*/
virtual QString type() const = 0;
/**
* returns the length of the linked file in bytes
*
* @return the length of the file in bytes, 0 if not specified
*/
virtual uint length() const = 0;
/**
* for audio/video files, the duration of the file in seconds
*
* @return the duration of the file in seconds, or 0 if not specified
*/
virtual uint duration() const = 0;
/**
* description of this enclosure for debugging purposes
*
* @return debug string
*/
virtual QString debugInfo() const;
};
} // namespace Syndication
#endif // SYNDICATION_ENCLOSURE_H
|