TagLib  2.0.2
mpegfile.h
Go to the documentation of this file.
1 /***************************************************************************
2  copyright : (C) 2002 - 2008 by Scott Wheeler
3  email : wheeler@kde.org
4  ***************************************************************************/
5 
6 /***************************************************************************
7  * This library is free software; you can redistribute it and/or modify *
8  * it under the terms of the GNU Lesser General Public License version *
9  * 2.1 as published by the Free Software Foundation. *
10  * *
11  * This library is distributed in the hope that it will be useful, but *
12  * WITHOUT ANY WARRANTY; without even the implied warranty of *
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
14  * Lesser General Public License for more details. *
15  * *
16  * You should have received a copy of the GNU Lesser General Public *
17  * License along with this library; if not, write to the Free Software *
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA *
19  * 02110-1301 USA *
20  * *
21  * Alternatively, this file is available under the Mozilla Public *
22  * License Version 1.1. You may obtain a copy of the License at *
23  * http://www.mozilla.org/MPL/ *
24  ***************************************************************************/
25 
26 #ifndef TAGLIB_MPEGFILE_H
27 #define TAGLIB_MPEGFILE_H
28 
29 #include "tfile.h"
30 #include "taglib_export.h"
31 #include "tag.h"
32 #include "mpegproperties.h"
33 #include "id3v2.h"
34 
35 namespace TagLib {
36 
37  namespace ID3v2 { class Tag; class FrameFactory; }
38  namespace ID3v1 { class Tag; }
39  namespace APE { class Tag; }
40 
42 
43  namespace MPEG {
44 
46 
54  {
55  public:
60  enum TagTypes {
62  NoTags = 0x0000,
64  ID3v1 = 0x0001,
66  ID3v2 = 0x0002,
68  APE = 0x0004,
70  AllTags = 0xffff
71  };
72 
83  File(FileName file, bool readProperties = true,
85  ID3v2::FrameFactory *frameFactory = nullptr);
86 
100  File(FileName file, ID3v2::FrameFactory *frameFactory,
101  bool readProperties = true,
103 
120  File(IOStream *stream, bool readProperties = true,
122  ID3v2::FrameFactory *frameFactory = nullptr);
123 
140  File(IOStream *stream, ID3v2::FrameFactory *frameFactory,
141  bool readProperties = true,
143 
147  ~File() override;
148 
149  File(const File &) = delete;
150  File &operator=(const File &) = delete;
151 
169  Tag *tag() const override;
170 
177  PropertyMap properties() const override;
178 
179  void removeUnsupportedProperties(const StringList &properties) override;
180 
189  PropertyMap setProperties(const PropertyMap &) override;
190 
195  Properties *audioProperties() const override;
196 
212  bool save() override;
213 
227  bool save(int tags, StripTags strip = StripOthers,
228  ID3v2::Version version = ID3v2::v4,
229  DuplicateTags duplicate = Duplicate);
230 
248  ID3v2::Tag *ID3v2Tag(bool create = false);
249 
267  ID3v1::Tag *ID3v1Tag(bool create = false);
268 
286  APE::Tag *APETag(bool create = false);
287 
298  bool strip(int tags = AllTags, bool freeMemory = true);
299 
303  offset_t firstFrameOffset();
304 
309  offset_t nextFrameOffset(offset_t position);
310 
315  offset_t previousFrameOffset(offset_t position);
316 
320  offset_t lastFrameOffset();
321 
327  bool hasID3v1Tag() const;
328 
334  bool hasID3v2Tag() const;
335 
341  bool hasAPETag() const;
342 
350  static bool isSupported(IOStream *stream);
351 
352  private:
353  void read(bool readProperties, Properties::ReadStyle readStyle);
354  offset_t findID3v2(Properties::ReadStyle readStyle);
355 
356  class FilePrivate;
358  std::unique_ptr<FilePrivate> d;
359  };
360  } // namespace MPEG
361 } // namespace TagLib
362 
363 #endif
TagTypes
Definition: mpegfile.h:60
An APE tag implementation.
Definition: apetag.h:56
A map for format-independent <key,values> tag representations.
Definition: tpropertymap.h:122
An abstract class that provides operations on a sequence of bytes.
Definition: tiostream.h:64
A simple, generic interface to common audio metadata fields.
Definition: tag.h:48
A file class with some useful methods for tag manipulation.
Definition: tfile.h:50
An implementation of audio property reading for MP3.
Definition: mpegproperties.h:47
Read more of the file and make better values guesses.
Definition: audioproperties.h:60
The main class in the ID3v1 implementation.
Definition: id3v1tag.h:114
An MPEG file class with some useful methods specific to MPEG.
Definition: mpegfile.h:53
A factory for creating ID3v2 frames during parsing.
Definition: id3v2framefactory.h:67
const char * FileName
Definition: tiostream.h:59
#define TAGLIB_MSVC_SUPPRESS_WARNING_NEEDS_TO_HAVE_DLL_INTERFACE
Definition: taglib_export.h:55
#define TAGLIB_DEPRECATED
Definition: taglib.h:39
ID3v2.4.
Definition: id3v2.h:29
A list of strings.
Definition: tstringlist.h:43
ReadStyle
Definition: audioproperties.h:56
#define TAGLIB_EXPORT
Definition: taglib_export.h:40
Version
Definition: id3v2.h:27
The main class in the ID3v2 implementation.
Definition: id3v2tag.h:133
off_t offset_t
Definition: taglib.h:64
A namespace for all TagLib related classes and functions.
Definition: apefile.h:41