File: expressiontypechecker.h

package info (click to toggle)
analitza 4:17.08.3-2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 3,824 kB
  • sloc: cpp: 26,899; perl: 63; sh: 16; makefile: 9
file content (96 lines) | stat: -rw-r--r-- 4,530 bytes parent folder | download | duplicates (2)
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 (C) 2010 by Aleix Pol <aleixpol@kde.org>                               *
 *                                                                                   *
 *  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 EXPRESSIONTYPECHECKER_H
#define EXPRESSIONTYPECHECKER_H

#include "abstractexpressionvisitor.h"
#include "analitzaexport.h"
#include "expressiontype.h"
#include <QStack>
#include <QStringList>
#include <QSet>

namespace Analitza
{
class Variables;
class Expression;

class ANALITZA_EXPORT ExpressionTypeChecker : public AbstractExpressionVisitor
{
    public:
        ExpressionTypeChecker(Variables* v);
        
        ExpressionType check(const Expression& exp);
        
        virtual QVariant visit(const None* var) override;
        virtual QVariant visit(const Operator* var) override;
        virtual QVariant visit(const Ci* var) override;
        virtual QVariant visit(const Cn* var) override;
        virtual QVariant visit(const Container* var) override;
        virtual QVariant visit(const Vector* var) override;
        virtual QVariant visit(const List* l) override;
        virtual QVariant visit(const Matrix* c) override;
        virtual QVariant visit(const Analitza::MatrixRow* m) override;
        virtual QVariant visit(const Apply* a) override;
        virtual QVariant visit(const CustomObject* c) override;
        
        virtual QVariant result() const override { return QVariant(); }
        
        QStringList dependencies() const { return m_deps; }
        bool hasDependencies() const { return !m_deps.isEmpty(); }
        bool isCorrect() const { return m_err.isEmpty() && !current.isError(); }
        QStringList errors() const;
        
        void initializeVars(const QMap<QString, ExpressionType>& types);
        QMap<QString, ExpressionType> variablesTypes() const;
        
    private:
        ExpressionType tellTypeIdentity(const QString& name, const ExpressionType& type);
        ExpressionType solve(const Operator* o, const QVector<Object*>& parameters);
        bool inferType(const ExpressionType& c, const ExpressionType& targetType, QMap<QString, ExpressionType>* assumptions);
        QList<ExpressionType> computePairs(const QList<ExpressionType>& options, const ExpressionType& param);
        
        QMap<QString, ExpressionType> typeIs(const Object* o, const ExpressionType& type);
        template <class T>
            QMap<QString, ExpressionType> typeIs(T it, const T& itEnd, const ExpressionType& type);
            
        template <class T>
            QVariant visitListOrVector(const T* v, ExpressionType::Type t, int size);
        
        ExpressionType typeForVar(const QString& var);
        
        void addError(const QString& err);
        ExpressionType commonType(const QList<Object*>& values);
        bool isVariableDefined(const QString& id) const;
        
        uint m_stars;
        QList<QStringList> m_err;
        QStringList m_calculating;
        ExpressionType current;
        Variables* m_v;
        QMap<QString, ExpressionType> m_typeForBVar;
        QMap<QString, ExpressionType> m_vars;
        QSet<QString> m_lambdascope;
        QStack<const Object*> m_calls;
        QStringList m_deps;
};

}

#endif // EXPRESSIONTYPECHECKER_H