This file is indexed.

/usr/include/taglib/urllinkframe.h is in libtag1-dev 1.9.1-2.4ubuntu1.

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
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
/***************************************************************************
    copyright            : (C) 2002 - 2008 by Scott Wheeler
    email                : wheeler@kde.org
    copyright            : (C) 2006 by Urs Fleisch
    email                : ufleisch@users.sourceforge.net
 ***************************************************************************/

/***************************************************************************
 *   This library is free software; you can redistribute it and/or modify  *
 *   it under the terms of the GNU Lesser General Public License version   *
 *   2.1 as published by the Free Software Foundation.                     *
 *                                                                         *
 *   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     *
 *   Lesser General Public License for more details.                       *
 *                                                                         *
 *   You should have received a copy of the GNU Lesser General Public      *
 *   License along with this library; if not, write to the Free Software   *
 *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA         *
 *   02110-1301  USA                                                       *
 *                                                                         *
 *   Alternatively, this file is available under the Mozilla Public        *
 *   License Version 1.1.  You may obtain a copy of the License at         *
 *   http://www.mozilla.org/MPL/                                           *
 ***************************************************************************/

#ifndef TAGLIB_URLLINKFRAME_H
#define TAGLIB_URLLINKFRAME_H

#include "id3v2frame.h"

namespace TagLib {

  namespace ID3v2 {

    //! ID3v2 URL frame
    /*!
     * An implementation of ID3v2 URL link frames.
     */
    class TAGLIB_EXPORT UrlLinkFrame : public Frame
    {
      friend class FrameFactory;

    public:
      /*!
       * This is a dual purpose constructor.  \a data can either be binary data
       * that should be parsed or (at a minimum) the frame ID.
       */
      explicit UrlLinkFrame(const ByteVector &data);

      /*!
       * Destroys this UrlLinkFrame instance.
       */
      virtual ~UrlLinkFrame();

      /*!
       * Returns the URL.
       */
      virtual String url() const;

      /*!
       * Sets the URL to \a s.
       */
      virtual void setUrl(const String &s);

      // Reimplementations.

      virtual void setText(const String &s);
      virtual String toString() const;
      PropertyMap asProperties() const;

    protected:
      virtual void parseFields(const ByteVector &data);
      virtual ByteVector renderFields() const;

      /*!
       * The constructor used by the FrameFactory.
       */
      UrlLinkFrame(const ByteVector &data, Header *h);

    private:
      UrlLinkFrame(const UrlLinkFrame &);
      UrlLinkFrame &operator=(const UrlLinkFrame &);

      class UrlLinkFramePrivate;
      UrlLinkFramePrivate *d;
    };

    //! ID3v2 User defined URL frame

    /*!
     * This is a specialization of URL link frames that allows for
     * user defined entries.  Each entry has a description in addition to the
     * normal list of fields that a URL link frame has.
     *
     * This description identifies the frame and must be unique.
     */
    class TAGLIB_EXPORT UserUrlLinkFrame : public UrlLinkFrame
    {
      friend class FrameFactory;

    public:
      /*!
       * Constructs an empty user defined URL link frame.  For this to be
       * a useful frame both a description and text must be set.
       */
      explicit UserUrlLinkFrame(String::Type encoding = String::Latin1);

      /*!
       * This is a dual purpose constructor.  \a data can either be binary data
       * that should be parsed or (at a minimum) the frame ID.
       */
      explicit UserUrlLinkFrame(const ByteVector &data);

      /*!
       * Destroys this UserUrlLinkFrame instance.
       */
      virtual ~UserUrlLinkFrame();

      // Reimplementations.

      virtual String toString() const;

      /*!
       * Returns the text encoding that will be used in rendering this frame.
       * This defaults to the type that was either specified in the constructor
       * or read from the frame when parsed.
       *
       * \see setTextEncoding()
       * \see render()
       */
      String::Type textEncoding() const;

      /*!
       * Sets the text encoding to be used when rendering this frame to
       * \a encoding.
       *
       * \see textEncoding()
       * \see render()
       */
      void setTextEncoding(String::Type encoding);

      /*!
       * Returns the description for this frame.
       */
      String description() const;

      /*!
       * Sets the description of the frame to \a s.  \a s must be unique.
       */
      void setDescription(const String &s);

      /*!
       * Parses the UserUrlLinkFrame as PropertyMap. The description() is taken as key,
       * and the URL as single value.
       * - if description() is empty, the key will be "URL".
       * - otherwise, if description() is not a valid key (e.g. containing non-ASCII
       *   characters), the returned map will contain an entry "WXXX/<description>"
       *   in its unsupportedData() list.
       */
      PropertyMap asProperties() const;

      /*!
       * Searches for the user defined url frame with the description \a description
       * in \a tag.  This returns null if no matching frames were found.
       */
      static UserUrlLinkFrame *find(Tag *tag, const String &description);

    protected:
      virtual void parseFields(const ByteVector &data);
      virtual ByteVector renderFields() const;

      /*!
       * The constructor used by the FrameFactory.
       */
      UserUrlLinkFrame(const ByteVector &data, Header *h);

    private:
      UserUrlLinkFrame(const UserUrlLinkFrame &);
      UserUrlLinkFrame &operator=(const UserUrlLinkFrame &);

      class UserUrlLinkFramePrivate;
      UserUrlLinkFramePrivate *d;
    };

  }
}
#endif