This file is indexed.

/usr/include/Analitza5/analitza/matrix.h is in libanalitza-dev 4:16.08.3-1.

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
/*************************************************************************************
 *  Copyright (C) 2013 by Aleix Pol <aleixpol@kde.org>                               *
 *  Copyright (C) 2014 by Percy Camilo T. Aucahuasi <percy.camilo.ta@gmail.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; either version 2                   *
 *  of the License, or (at your option) any later version.                           *
 *                                                                                   *
 *  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, write to the Free Software                      *
 *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA   *
*************************************************************************************/

#ifndef MATRIX_H
#define MATRIX_H

#include "object.h"
#include "vector.h"

namespace Analitza {

class Cn;

class Vector;

class ANALITZA_EXPORT MatrixRow : public Vector
{
    public:
        MatrixRow(int size=0);
        virtual QVariant accept(AbstractExpressionVisitor* e) const override;
        
        MatrixRow* copy() const override;
};

class ANALITZA_EXPORT Matrix : public Object
{
    public:
        typedef QList<MatrixRow*>::iterator iterator;
        typedef QList<MatrixRow*>::const_iterator const_iterator;
        
        Matrix();
        /** Fills the matrix with a fixed numeric @p value, the matrix size will be @p m x @p n */
        Matrix(int m, int n, const Cn *value);
        virtual ~Matrix();
        void appendBranch(MatrixRow* o);
        
        virtual Matrix* copy() const override;
        virtual bool matches(const Object* exp, QMap< QString, const Object* >* found) const override;
        virtual QVariant accept(AbstractExpressionVisitor* exp) const override;
        const_iterator constBegin() const { return m_rows.constBegin(); }
        const_iterator constEnd() const { return m_rows.constEnd(); }
        iterator begin() { return m_rows.begin(); }
        iterator end() { return m_rows.end(); }
        QList< MatrixRow* > rows() const { return m_rows; }
        bool operator==(const Matrix& m) const;
        int rowCount() const { return m_rows.size(); }
        Analitza::Matrix::iterator erase(const Analitza::Matrix::iterator& it) { return m_rows.erase(it); }
        Object* at(int i, int j) const;
        int columnCount() const;
        bool isSquare() const;
        virtual bool isZero() const override;
        bool hasOnlyNumbers() const { return m_rows.isEmpty()? false : m_hasOnlyNumbers; }
        bool isIdentity() const;
        bool isDiagonal() const;
        
    public:
        static Matrix* identity(int n);
        
    private:
        QList<MatrixRow*> m_rows;
        bool m_hasOnlyNumbers;
};

}

#endif // MATRIX_H