File: expressionparser.h

package info (click to toggle)
kdevelop-php 24.12.3-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 8,616 kB
  • sloc: cpp: 20,858; php: 15,243; xml: 136; sh: 58; makefile: 10
file content (64 lines) | stat: -rw-r--r-- 1,834 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
/*
    SPDX-FileCopyrightText: 2007 David Nolden <david.nolden.kdevelop@art-master.de>
    SPDX-FileCopyrightText: 2008 Niko Sams <niko.sams@gmail.com>

    SPDX-License-Identifier: LGPL-2.0-or-later
*/

#ifndef EXPRESSIONPARSER_H
#define EXPRESSIONPARSER_H

#include <language/duchain/duchainpointer.h>

#include "phpduchainexport.h"
#include "expressionevaluationresult.h"

namespace Php
{
struct AstNode;
class EditorIntegrator;

class KDEVPHPDUCHAIN_EXPORT ExpressionParser
{
public:
    /**
     * @param debug Enables additional output
     */
    explicit ExpressionParser(bool debug = false);

    /**
     * By default, no problems are created at the top-ducontext.
     */
    void setCreateProblems(bool v);

    /**
     * Evaluate the @p expression and find it's type and last-used declaration.
     *
     * @param offset Set this to the front-edge of the expression.
     *               Used in the ExpressionVisitor to find visible declarations.
     *
     * @see ExpressionVisitor
     */
    ExpressionEvaluationResult evaluateType(const QByteArray& expression, KDevelop::DUContextPointer context,
                                            const KDevelop::CursorInRevision &offset);
    /**
     * Sets up an ExpressionVisitor and returns it's result when visiting @p ast .
     *
     * @see ExpressionVisitor
     */
    ExpressionEvaluationResult evaluateType(AstNode* ast, EditorIntegrator* editor);

private:
    /**
     * This is private instead of reusing the method above with a default argument
     * for the offset, because we _never_ want to use this directly.
     */
    ExpressionEvaluationResult evaluateType(AstNode* ast, EditorIntegrator* editor,
                                            const KDevelop::CursorInRevision &offset);
    bool m_debug;
    bool m_createProblems;
};


}
#endif