source: icGREP/icgrep-devel/icgrep/pablo/pe_var.h @ 4410

Last change on this file since 4410 was 4410, checked in by nmedfort, 5 years ago

Changes to support 3-operand form for all instructions. CSE disabled but partially redundant now.

File size: 2.3 KB
Line 
1/*
2 *  Copyright (c) 2014 International Characters.
3 *  This software is licensed to the public under the Open Software License 3.0.
4 *  icgrep is a trademark of International Characters.
5 */
6
7#ifndef PE_VAR_H
8#define PE_VAR_H
9
10#include <pablo/pabloAST.h>
11#include <pablo/ps_assign.h>
12#include <pablo/pe_next.h>
13#include <pablo/pe_string.h>
14#include <stdexcept>
15
16namespace llvm {
17    class Value;
18    class BasicBlock;
19}
20
21namespace pablo {
22
23class Var : public PabloAST {
24    friend class PabloBlock;
25    friend class And;
26    friend class Or;
27    friend class Not;
28    friend class Sel;
29    friend class Xor;
30    friend class Zeroes;
31    friend class Ones;
32public:
33    static inline bool classof(const PabloAST * e) {
34        return e->getClassTypeId() == ClassTypeId::Var;
35    }
36    static inline bool classof(const void *) {
37        return false;
38    }
39    virtual ~Var(){
40    }
41//    virtual PabloAST * getOperand(const unsigned index) const {
42//        assert (index == 0);
43//        return mVar;
44//    }
45//    virtual unsigned getNumOperands() const {
46//        return 1;
47//    }
48//    virtual void setOperand(const unsigned index, PabloAST * value) {
49//        assert (index == 0);
50//        mVar = value;
51//        mName = getNameOf(value);
52//    }
53    inline const String * getName() const {
54        return mName;
55    }
56//    inline PabloAST * getVar() {
57//        return mVar;
58//    }
59//    inline const PabloAST * getVar() const {
60//        return mVar;
61//    }
62//    inline bool isInternal() const {
63//        return mVar != mName;
64//    }
65//    inline bool isExternal() const {
66//        return mVar == mName;
67//    }
68protected:
69    Var(PabloAST * var, PabloBlock *)
70    : PabloAST(ClassTypeId::Var)
71    //, mVar(var)
72    , mName(cast<String>(var)) // getNameOf(var))
73    {
74        var->addUser(this);
75    }
76private:
77//    static inline const String * getNameOf(const PabloAST * var) {
78//        if (isa<String>(var)) {
79//            return cast<String>(var);
80//        }
81//        if (isa<Assign>(var)) {
82//            return cast<Assign>(var)->getName();
83//        }
84//        if (isa<Next>(var)) {
85//            return cast<Next>(var)->getName();
86//        }
87//        throw std::runtime_error("Pablo Var only accepts String, Assign and Next nodes.");
88//    }
89private:
90    //PabloAST *         mVar;
91    const String *     mName;
92};
93
94}
95
96
97
98#endif // PE_VAR_H
99
100
Note: See TracBrowser for help on using the repository browser.