This file is indexed.

/usr/include/lastfm/RadioStation is in liblastfm-dev 0.4.0~really0.3.3-0ubuntu1.

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
/*
   Copyright 2009 Last.fm Ltd. 
      - Primarily authored by Max Howell, Jono Cole and Doug Mansell

   This file is part of liblastfm.

   liblastfm is free software: you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation, either version 3 of the License, or
   (at your option) any later version.

   liblastfm 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 General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with liblastfm.  If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef LASTFM_RADIO_STATION_H
#define LASTFM_RADIO_STATION_H

#include <lastfm/User>
#include <lastfm/Tag>
#include <lastfm/Artist>


namespace lastfm
{
    /** @author <jono@last.fm> 
      */
    class LASTFM_DLLEXPORT RadioStation
    {
    public:
        RadioStation()
        {}
        RadioStation( const QString& s ) : m_url( s )
        {}
        explicit RadioStation( const QUrl& u ) : m_url( u.toString() )
        {}
    
        static RadioStation library( const lastfm::User& user )         { return "lastfm://user/" + user + "/personal"; }
        static RadioStation recommendations( const lastfm::User& user ) { return "lastfm://user/" + user + "/recommended"; }
        static RadioStation neighbourhood( const lastfm::User& user )   { return "lastfm://user/" + user + "/neighbours"; }
        static RadioStation lovedTracks( const lastfm::User& user )     { return "lastfm://user/" + user + "/loved"; }
        static RadioStation globalTag( const lastfm::Tag& tag )         { return "lastfm://globaltags/" + tag; }
        static RadioStation similar( const lastfm::Artist& artist )     { return "lastfm://artist/" + artist + "/similarartists"; }

        static RadioStation rql( const QString& rql )
        {
            RadioStation station;
            station.m_rql = rql;
            station.m_url = "lastfm://rql/" + QString(rql.toUtf8().toBase64());
            return station;
        }

        /** eg. "mxcl's Loved Tracks"
          * It is worth noting that the Radio doesn't set the title of RadioStation 
          * object until we have tuned to it, and then we only set the one we give 
          * you back.
          */    
        QString title() const { return m_title; }
        /** the Last.fm url, eg. lastfm://user/mxcl/loved */
        QString url() const { return m_url; }
        QString rql() const { return m_rql; }

        void setTitle( const QString& s ) { m_title = s; }

        bool isLegacyPlaylist() const
        {
            return m_url.startsWith( "lastfm://play/" ) ||
                   m_url.startsWith( "lastfm://preview/" ) ||
                   m_url.startsWith( "lastfm://track/" ) ||
                   m_url.startsWith( "lastfm://playlist/" );
        }

        // good for getRecentStations:
        static QList<RadioStation> list( QNetworkReply* );
    
    private:
        QString m_rql;
        QString m_url;
        QString m_title;
    };
}


Q_DECLARE_METATYPE( lastfm::RadioStation )


inline QDebug operator<<( QDebug d, const lastfm::RadioStation& station )
{
    return d << station.url();
}

#endif