This file is indexed.

/usr/include/unity-2d-private/listmodelwrapper.h is in libunity-2d-private-dev 5.10.0-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
 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
/*
 * Copyright (C) 2011 Canonical, Ltd.
 *
 * Authors:
 *  Florian Boucault <florian.boucault@canonical.com>
 *
 * This program 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; version 3.
 *
 * This program 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 this program.  If not, see <http://www.gnu.org/licenses/>.
 */

#ifndef LISTMODELWRAPPER_H
#define LISTMODELWRAPPER_H

// Qt
#include <QAbstractListModel>
#include <QList>

#include <sigc++/signal.h>
#include <vector>

template <class WrapperItem, class ItemClass>
class ListModelWrapper : public QAbstractListModel
{
    Q_ENUMS(Roles)

public:
    explicit ListModelWrapper(const std::vector<ItemClass>& list,
                              sigc::signal<void, ItemClass> itemAddedSignal,
                              sigc::signal<void, ItemClass> itemRemovedSignal,
                              QObject *parent = 0);
    ~ListModelWrapper();

    enum Roles {
        RoleItem
    };

    QVariant data(const QModelIndex& index, int role = Qt::DisplayRole) const;
    int rowCount(const QModelIndex& parent = QModelIndex()) const;

    const QList<WrapperItem*>& rawList() const;

private:
    void onItemAdded(ItemClass item);
    void onItemRemoved(ItemClass item);
    void onItemChanged(ItemClass item);

    QList<WrapperItem*> m_list;
    QMap<ItemClass, int> m_indexes;

    void addItem(ItemClass item, int index);
    void removeItem(ItemClass item, int index);
};


template <class WrapperItem, class ItemClass>
ListModelWrapper<WrapperItem, ItemClass>::ListModelWrapper(const std::vector<ItemClass>& list,
                                                           sigc::signal<void, ItemClass> itemAddedSignal,
                                                           sigc::signal<void, ItemClass> itemRemovedSignal,
                                                           QObject *parent) :
    QAbstractListModel(parent)
{
    QHash<int, QByteArray> roles;
    roles[ListModelWrapper::RoleItem] = "item";
    setRoleNames(roles);

    for (unsigned int i=0; i<list.size(); i++) {
        addItem(list[i], i);
    }
    itemAddedSignal.connect(sigc::mem_fun(this, &ListModelWrapper::onItemAdded));
    itemRemovedSignal.connect(sigc::mem_fun(this, &ListModelWrapper::onItemRemoved));
}

template <class WrapperItem, class ItemClass>
ListModelWrapper<WrapperItem, ItemClass>::~ListModelWrapper()
{
    m_indexes.clear();
    while (!m_list.isEmpty()) {
        delete m_list.takeFirst();
    }
}

template <class WrapperItem, class ItemClass>
int ListModelWrapper<WrapperItem, ItemClass>::rowCount(const QModelIndex& parent) const
{
    Q_UNUSED(parent)

    return m_list.count();
}

template <class WrapperItem, class ItemClass>
const QList<WrapperItem*>& ListModelWrapper<WrapperItem, ItemClass>::rawList() const
{
    return m_list;
}

template <class WrapperItem, class ItemClass>
QVariant ListModelWrapper<WrapperItem, ItemClass>::data(const QModelIndex& index, int role) const
{
    if (!index.isValid()) {
        return QVariant();
    }

    WrapperItem* item = m_list.at(index.row());

    if (role == ListModelWrapper::RoleItem) {
        return QVariant::fromValue(item);
    } else {
        return QVariant();
    }
}

template <class WrapperItem, class ItemClass>
void ListModelWrapper<WrapperItem, ItemClass>::onItemAdded(ItemClass item)
{
    /* FIXME: figure out actual index of item; for now items are appended */
    int index = m_list.count();
    beginInsertRows(QModelIndex(), index, index);
    addItem(item, index);
    endInsertRows();
}

template <class WrapperItem, class ItemClass>
void ListModelWrapper<WrapperItem, ItemClass>::onItemRemoved(ItemClass item)
{
    int index = m_indexes[item];
    beginInsertRows(QModelIndex(), index, index);
    removeItem(item, index);
    endInsertRows();
}

template <class WrapperItem, class ItemClass>
void ListModelWrapper<WrapperItem, ItemClass>::onItemChanged(ItemClass item)
{
    QModelIndex itemIndex = index(m_indexes[item]);
    Q_EMIT dataChanged(itemIndex, itemIndex);
}

template <class WrapperItem, class ItemClass>
void ListModelWrapper<WrapperItem, ItemClass>::addItem(ItemClass item, int index)
{
    m_indexes.insert(item, index);
    m_list.insert(index, new WrapperItem(item));
}

template <class WrapperItem, class ItemClass>
void ListModelWrapper<WrapperItem, ItemClass>::removeItem(ItemClass item, int index)
{
    m_indexes.remove(item);
    delete m_list.takeAt(index);
}

#endif // LISTMODELWRAPPER_H