// _gen/mycpp/examples/expr.asdl.h is generated by asdl_main.py #ifndef EXPR_ASDL #define EXPR_ASDL #include #include "mycpp/runtime.h" #include "asdl/cpp_runtime.h" namespace expr_asdl { // use struct instead of namespace so 'using' works consistently #define ASDL_NAMES struct class expr_t; class Measure_v; class MeasuredDoc; enum class tok_e { Const = 1, Var = 2, Op1 = 3, Op2 = 4, Paren = 5, Eof = 6, Invalid = 7, }; typedef tok_e tok_t; BigStr* tok_str(tok_e tag, bool dot = true); ASDL_NAMES expr_e { enum no_name { Const = 1, Var = 2, Binary = 3, }; }; BigStr* expr_str(int tag, bool dot = true); class expr_t { protected: expr_t() { } public: int tag() const { return ObjHeader::FromObject(this)->type_tag; } hnode_t* PrettyTree(bool do_abbrev, Dict* seen = nullptr); DISALLOW_COPY_AND_ASSIGN(expr_t) }; class expr__Const : public expr_t { public: expr__Const(int i) : i(i) { } static expr__Const* CreateNull(bool alloc_lists = false) { return Alloc(-1); } hnode_t* PrettyTree(bool do_abbrev, Dict* seen = nullptr); static constexpr ObjHeader obj_header() { return ObjHeader::AsdlClass(static_cast(expr_e::Const), 0); } int i; DISALLOW_COPY_AND_ASSIGN(expr__Const) }; class expr__Var : public expr_t { public: expr__Var(BigStr* name) : name(name) { } static expr__Var* CreateNull(bool alloc_lists = false) { return Alloc(kEmptyString); } hnode_t* PrettyTree(bool do_abbrev, Dict* seen = nullptr); static constexpr ObjHeader obj_header() { return ObjHeader::AsdlClass(static_cast(expr_e::Var), 1); } BigStr* name; DISALLOW_COPY_AND_ASSIGN(expr__Var) }; class expr__Binary : public expr_t { public: expr__Binary(BigStr* op, expr_t* left, expr_t* right) : op(op), left(left), right(right) { } static expr__Binary* CreateNull(bool alloc_lists = false) { return Alloc(kEmptyString, nullptr, nullptr); } hnode_t* PrettyTree(bool do_abbrev, Dict* seen = nullptr); static constexpr ObjHeader obj_header() { return ObjHeader::AsdlClass(static_cast(expr_e::Binary), 3); } BigStr* op; expr_t* left; expr_t* right; DISALLOW_COPY_AND_ASSIGN(expr__Binary) }; ASDL_NAMES expr { typedef expr__Const Const; typedef expr__Var Var; typedef expr__Binary Binary; }; class Measure_v { public: Measure_v(int a, int b) : a(a), b(b) { } static Measure_v* CreateNull(bool alloc_lists = false) { return Alloc(-1, -1); } hnode_t* PrettyTree(bool do_abbrev, Dict* seen = nullptr); static constexpr ObjHeader obj_header() { return ObjHeader::AsdlClass(65, 0); } int a; int b; DISALLOW_COPY_AND_ASSIGN(Measure_v) }; class MeasuredDoc { public: MeasuredDoc(BigStr* s, Measure_v* measure) : s(s), measure(measure) { } static MeasuredDoc* CreateNull(bool alloc_lists = false) { return Alloc(kEmptyString, nullptr); } hnode_t* PrettyTree(bool do_abbrev, Dict* seen = nullptr); static constexpr ObjHeader obj_header() { return ObjHeader::AsdlClass(66, 2); } BigStr* s; Measure_v* measure; DISALLOW_COPY_AND_ASSIGN(MeasuredDoc) }; class CompoundWord : public List { public: CompoundWord() : List() { } CompoundWord(List* plain_list) : List(plain_list) { } static CompoundWord* New() { return Alloc(); } static CompoundWord* Take(List* plain_list) { auto* result = Alloc(plain_list); plain_list->SetTaken(); return result; } hnode_t* PrettyTree(bool do_abbrev, Dict* seen = nullptr); static constexpr ObjHeader obj_header() { return ObjHeader::TaggedSubtype(64, field_mask()); } DISALLOW_COPY_AND_ASSIGN(CompoundWord) }; } // namespace expr_asdl #endif // EXPR_ASDL