]> git.saurik.com Git - cycript.git/blame - Parser.hpp
Fleshed out support for &, reworked nil internally, setup new Instance(), and impleme...
[cycript.git] / Parser.hpp
CommitLineData
b4aa79af
JF
1/* Cycript - Remove Execution Server and Disassembler
2 * Copyright (C) 2009 Jay Freeman (saurik)
3*/
4
5/* Modified BSD License {{{ */
6/*
7 * Redistribution and use in source and binary
8 * forms, with or without modification, are permitted
9 * provided that the following conditions are met:
10 *
11 * 1. Redistributions of source code must retain the
12 * above copyright notice, this list of conditions
13 * and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the
15 * above copyright notice, this list of conditions
16 * and the following disclaimer in the documentation
17 * and/or other materials provided with the
18 * distribution.
19 * 3. The name of the author may not be used to endorse
20 * or promote products derived from this software
21 * without specific prior written permission.
22 *
23 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS''
24 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING,
25 * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
26 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE
28 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
29 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
30 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
31 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
33 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
34 * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
35 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
36 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
37*/
38/* }}} */
39
63b4c5a8
JF
40#ifndef CYPARSER_HPP
41#define CYPARSER_HPP
42
cf7d4c69 43#include <cstdlib>
5999c315 44#include <string>
c3c20102 45#include <vector>
cf7d4c69 46
5befe15e 47#include "location.hh"
5999c315 48#include "Pooling.hpp"
924f67b2 49
5999c315
JF
50template <typename Type_>
51struct CYNext {
52 Type_ *next_;
63b4c5a8 53
5999c315
JF
54 CYNext() :
55 next_(NULL)
56 {
57 }
cf7d4c69 58
62014ea9
JF
59 CYNext(Type_ *next) :
60 next_(next)
61 {
62 }
63
5999c315 64 void SetNext(Type_ *next) {
cf7d4c69
JF
65 next_ = next;
66 }
67};
68
5999c315
JF
69struct CYThing {
70 virtual void Output(std::ostream &out) const = 0;
71};
72
73_finline std::ostream &operator <<(std::ostream &out, const CYThing &rhs) {
74 rhs.Output(out);
75 return out;
76}
77
5999c315 78struct CYSource :
b1ff2d78 79 CYNext<CYSource>
5999c315 80{
b1ff2d78 81 virtual void Show(std::ostream &out) const;
5999c315
JF
82 virtual void Output(std::ostream &out) const = 0;
83 virtual void Output(std::ostream &out, bool block) const;
84};
85
e5bc40db
JF
86struct CYPropertyName {
87 virtual void PropertyName(std::ostream &out) const = 0;
88};
89
90struct CYClassName {
91 virtual void ClassName(std::ostream &out) const = 0;
63b4c5a8
JF
92};
93
cf7d4c69 94struct CYWord :
e5bc40db
JF
95 CYThing,
96 CYPropertyName,
97 CYClassName
63b4c5a8 98{
cf7d4c69
JF
99 const char *word_;
100
101 CYWord(const char *word) :
102 word_(word)
103 {
104 }
105
5999c315 106 const char *Value() const {
cf7d4c69
JF
107 return word_;
108 }
109
5999c315 110 virtual void Output(std::ostream &out) const;
e5bc40db
JF
111
112 virtual void ClassName(std::ostream &out) const;
113 virtual void PropertyName(std::ostream &out) const;
63b4c5a8
JF
114};
115
cf7d4c69
JF
116struct CYIdentifier :
117 CYWord
63b4c5a8 118{
5999c315
JF
119 CYIdentifier(const char *word) :
120 CYWord(word)
121 {
cf7d4c69 122 }
63b4c5a8
JF
123};
124
62014ea9
JF
125struct CYLabel :
126 CYNext<CYLabel>
127{
cf7d4c69 128 CYIdentifier *identifier_;
cf7d4c69
JF
129
130 CYLabel(CYIdentifier *identifier, CYLabel *next) :
62014ea9
JF
131 CYNext<CYLabel>(next),
132 identifier_(identifier)
cf7d4c69
JF
133 {
134 }
135};
136
137struct CYStatement :
138 CYSource
63b4c5a8 139{
cf7d4c69
JF
140 CYLabel *label_;
141
142 void AddLabel(CYIdentifier *identifier) {
143 label_ = new CYLabel(identifier, label_);
144 }
145};
146
db5e2840
JF
147enum CYState {
148 CYClear,
149 CYRestricted,
150 CYNewLine
151};
152
5999c315
JF
153class CYDriver {
154 public:
155 CYPool pool_;
e7ed5354 156
db5e2840 157 CYState state_;
e7ed5354
JF
158 void *scanner_;
159
160 const char *data_;
161 size_t size_;
162
5999c315 163 std::string filename_;
e7ed5354 164
5befe15e
JF
165 struct Error {
166 cy::location location_;
167 std::string message_;
168 };
169
170 typedef std::vector<Error> Errors;
171
172 CYSource *source_;
173 Errors errors_;
5999c315
JF
174
175 private:
176 void ScannerInit();
177 void ScannerDestroy();
178
179 public:
180 CYDriver(const std::string &filename);
181 ~CYDriver();
182};
183
dea834b0
JF
184struct CYPart {
185 virtual void Part(std::ostream &out) const = 0;
186};
187
5999c315
JF
188struct CYForInitialiser :
189 CYPart
190{
cf7d4c69
JF
191};
192
5999c315
JF
193struct CYForInInitialiser :
194 CYPart
195{
63b4c5a8
JF
196};
197
b09da87b 198enum CYFlags {
478d4ed0
JF
199 CYNoFlags = 0,
200 CYNoBrace = (1 << 0),
201 CYNoFunction = (1 << 1),
202 CYNoLeader = (1 << 2),
203 CYNoTrailer = (1 << 3),
204 CYNoIn = (1 << 4),
b09da87b
JF
205};
206
cf7d4c69 207struct CYExpression :
5999c315 208 CYNext<CYExpression>,
cf7d4c69 209 CYForInitialiser,
e5bc40db
JF
210 CYForInInitialiser,
211 CYClassName
63b4c5a8 212{
d35a3b07 213 virtual unsigned Precedence() const = 0;
5999c315 214 virtual void Part(std::ostream &out) const;
b09da87b
JF
215 virtual void Output(std::ostream &out, CYFlags flags) const = 0;
216 void Output(std::ostream &out, unsigned precedence, CYFlags flags) const;
dea834b0 217
e5bc40db
JF
218 virtual void ClassName(std::ostream &out) const;
219
dea834b0
JF
220 virtual const char *Word() const {
221 return NULL;
222 }
63b4c5a8
JF
223};
224
b09da87b
JF
225#define CYAlphabetic(value) \
226 virtual bool Alphabetic() const { \
227 return value; \
228 }
229
d35a3b07
JF
230#define CYPrecedence(value) \
231 virtual unsigned Precedence() const { \
232 return value; \
233 }
234
235struct CYCompound :
236 CYExpression
237{
238 CYExpression *expressions_;
239
240 CYCompound(CYExpression *expressions) :
241 expressions_(expressions)
242 {
243 }
244
245 void AddPrev(CYExpression *expression) {
246 CYExpression *last(expression);
247 while (last->next_ != NULL)
248 last = last->next_;
249 last->SetNext(expressions_);
250 expressions_ = expression;
251 }
252
253 CYPrecedence(17)
254
b09da87b 255 void Output(std::ostream &out, CYFlags flags) const;
d35a3b07 256};
5999c315 257
cf7d4c69
JF
258struct CYLiteral :
259 CYExpression
63b4c5a8 260{
d35a3b07 261 CYPrecedence(0)
cf7d4c69 262};
63b4c5a8 263
478d4ed0
JF
264struct CYMagic :
265 CYExpression
266{
267 CYPrecedence(0)
268};
269
62014ea9
JF
270struct CYSelectorPart :
271 CYNext<CYSelectorPart>
e7ed5354
JF
272{
273 CYWord *name_;
274 bool value_;
e7ed5354 275
62014ea9
JF
276 CYSelectorPart(CYWord *name, bool value, CYSelectorPart *next) :
277 CYNext<CYSelectorPart>(next),
e7ed5354 278 name_(name),
62014ea9
JF
279 value_(value)
280 {
281 }
282
283 virtual void Output(std::ostream &out) const;
284};
285
286struct CYSelector :
287 CYLiteral
288{
289 CYSelectorPart *name_;
290
291 CYSelector(CYSelectorPart *name) :
292 name_(name)
e7ed5354
JF
293 {
294 }
295
dea834b0
JF
296 CYPrecedence(1)
297
b09da87b 298 virtual void Output(std::ostream &out, CYFlags flags) const;
e7ed5354
JF
299};
300
dea834b0
JF
301struct CYRange {
302 uint64_t lo_;
303 uint64_t hi_;
304
305 CYRange(uint64_t lo, uint64_t hi) :
306 lo_(lo), hi_(hi)
307 {
308 }
309
310 bool operator [](uint8_t value) const {
311 return !(value >> 7) && (value >> 6 ? hi_ : lo_) >> (value & 0x3f) & 0x1;
312 }
313
314 void operator()(uint8_t value) {
315 if (value >> 7)
316 return;
317 (value >> 6 ? hi_ : lo_) |= uint64_t(0x1) << (value & 0x3f);
318 }
319};
320
283e7e33 321extern CYRange DigitRange_;
dea834b0
JF
322extern CYRange WordStartRange_;
323extern CYRange WordEndRange_;
324
cf7d4c69
JF
325struct CYString :
326 CYLiteral,
e5bc40db 327 CYPropertyName
cf7d4c69
JF
328{
329 const char *value_;
5999c315 330 size_t size_;
cf7d4c69 331
5999c315
JF
332 CYString(const char *value, size_t size) :
333 value_(value),
334 size_(size)
cf7d4c69
JF
335 {
336 }
337
338 CYString(const CYIdentifier *identifier) :
5999c315
JF
339 value_(identifier->Value()),
340 size_(strlen(value_))
cf7d4c69
JF
341 {
342 }
343
5999c315 344 const char *Value() const {
cf7d4c69
JF
345 return value_;
346 }
347
dea834b0
JF
348 virtual const char *Word() const {
349 if (size_ == 0 || !WordStartRange_[value_[0]])
350 return NULL;
351 for (size_t i(1); i != size_; ++i)
352 if (!WordEndRange_[value_[i]])
353 return NULL;
354 return Value();
355 }
356
b09da87b
JF
357 virtual void Output(std::ostream &out) const {
358 return Output(out, CYNoFlags);
359 }
360
361 virtual void Output(std::ostream &out, CYFlags flags) const;
e5bc40db 362 virtual void PropertyName(std::ostream &out) const;
63b4c5a8
JF
363};
364
cf7d4c69 365struct CYNumber :
cf7d4c69 366 CYLiteral,
e5bc40db 367 CYPropertyName
cf7d4c69 368{
5999c315
JF
369 double value_;
370
371 CYNumber(double value) :
372 value_(value)
373 {
374 }
375
376 double Value() const {
377 return value_;
cf7d4c69
JF
378 }
379
b09da87b
JF
380 virtual void Output(std::ostream &out) const {
381 return Output(out, CYNoFlags);
382 }
383
384 virtual void Output(std::ostream &out, CYFlags flags) const;
e5bc40db 385 virtual void PropertyName(std::ostream &out) const;
cf7d4c69
JF
386};
387
388struct CYNull :
389 CYWord,
390 CYLiteral
391{
392 CYNull() :
393 CYWord("null")
394 {
395 }
5999c315 396
b09da87b 397 virtual void Output(std::ostream &out, CYFlags flags) const;
cf7d4c69
JF
398};
399
400struct CYThis :
401 CYWord,
478d4ed0 402 CYMagic
cf7d4c69
JF
403{
404 CYThis() :
405 CYWord("this")
406 {
407 }
5999c315 408
b09da87b 409 virtual void Output(std::ostream &out, CYFlags flags) const;
cf7d4c69
JF
410};
411
412struct CYBoolean :
413 CYLiteral
414{
5999c315 415 virtual bool Value() const = 0;
b09da87b 416 virtual void Output(std::ostream &out, CYFlags flags) const;
cf7d4c69
JF
417};
418
419struct CYFalse :
420 CYWord,
421 CYBoolean
422{
423 CYFalse() :
424 CYWord("false")
425 {
426 }
5999c315 427
b09da87b 428 virtual bool Value() const;
cf7d4c69
JF
429};
430
431struct CYTrue :
432 CYWord,
433 CYBoolean
434{
435 CYTrue() :
436 CYWord("true")
437 {
438 }
5999c315 439
b09da87b 440 virtual bool Value() const;
cf7d4c69
JF
441};
442
443struct CYVariable :
444 CYExpression
445{
446 CYIdentifier *name_;
447
448 CYVariable(CYIdentifier *name) :
449 name_(name)
450 {
451 }
5999c315 452
d35a3b07
JF
453 CYPrecedence(0)
454
b09da87b 455 virtual void Output(std::ostream &out, CYFlags flags) const;
cf7d4c69
JF
456};
457
458struct CYPrefix :
63b4c5a8
JF
459 CYExpression
460{
461 CYExpression *rhs_;
462
cf7d4c69 463 CYPrefix(CYExpression *rhs) :
63b4c5a8
JF
464 rhs_(rhs)
465 {
466 }
5999c315 467
b09da87b 468 virtual bool Alphabetic() const = 0;
5999c315
JF
469 virtual const char *Operator() const = 0;
470
b09da87b 471 virtual void Output(std::ostream &out, CYFlags flags) const;
63b4c5a8
JF
472};
473
cf7d4c69 474struct CYInfix :
63b4c5a8
JF
475 CYExpression
476{
477 CYExpression *lhs_;
478 CYExpression *rhs_;
479
cf7d4c69 480 CYInfix(CYExpression *lhs, CYExpression *rhs) :
63b4c5a8
JF
481 lhs_(lhs),
482 rhs_(rhs)
483 {
484 }
5999c315 485
0ff9f149
JF
486 void SetLeft(CYExpression *lhs) {
487 lhs_ = lhs;
488 }
489
b09da87b 490 virtual bool Alphabetic() const = 0;
5999c315
JF
491 virtual const char *Operator() const = 0;
492
b09da87b 493 virtual void Output(std::ostream &out, CYFlags flags) const;
63b4c5a8
JF
494};
495
cf7d4c69 496struct CYPostfix :
63b4c5a8
JF
497 CYExpression
498{
499 CYExpression *lhs_;
500
cf7d4c69 501 CYPostfix(CYExpression *lhs) :
63b4c5a8
JF
502 lhs_(lhs)
503 {
504 }
5999c315
JF
505
506 virtual const char *Operator() const = 0;
507
b09da87b 508 virtual void Output(std::ostream &out, CYFlags flags) const;
63b4c5a8
JF
509};
510
cf7d4c69 511struct CYAssignment :
d35a3b07 512 CYExpression
cf7d4c69 513{
d35a3b07
JF
514 CYExpression *lhs_;
515 CYExpression *rhs_;
516
cf7d4c69 517 CYAssignment(CYExpression *lhs, CYExpression *rhs) :
d35a3b07
JF
518 lhs_(lhs),
519 rhs_(rhs)
cf7d4c69
JF
520 {
521 }
5999c315 522
0ff9f149
JF
523 void SetLeft(CYExpression *lhs) {
524 lhs_ = lhs;
525 }
526
5999c315 527 virtual const char *Operator() const = 0;
d35a3b07 528
b09da87b 529 virtual void Output(std::ostream &out, CYFlags flags) const;
cf7d4c69
JF
530};
531
62014ea9
JF
532struct CYArgument :
533 CYNext<CYArgument>
534{
cf7d4c69
JF
535 CYWord *name_;
536 CYExpression *value_;
cf7d4c69
JF
537
538 CYArgument(CYWord *name, CYExpression *value, CYArgument *next = NULL) :
62014ea9 539 CYNext<CYArgument>(next),
cf7d4c69 540 name_(name),
62014ea9 541 value_(value)
cf7d4c69
JF
542 {
543 }
5999c315 544
d35a3b07 545 void Output(std::ostream &out) const;
cf7d4c69
JF
546};
547
548struct CYBlank :
549 public CYWord
550{
551 CYBlank() :
552 CYWord("")
553 {
554 }
555};
556
5999c315
JF
557struct CYClause :
558 CYThing,
559 CYNext<CYClause>
560{
cf7d4c69
JF
561 CYExpression *case_;
562 CYStatement *code_;
cf7d4c69
JF
563
564 CYClause(CYExpression *_case, CYStatement *code) :
565 case_(_case),
566 code_(code)
567 {
568 }
569
5999c315 570 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
571};
572
62014ea9
JF
573struct CYElement :
574 CYNext<CYElement>
575{
cf7d4c69 576 CYExpression *value_;
cf7d4c69
JF
577
578 CYElement(CYExpression *value, CYElement *next) :
62014ea9
JF
579 CYNext<CYElement>(next),
580 value_(value)
cf7d4c69
JF
581 {
582 }
5999c315 583
5befe15e
JF
584 void Output(std::ostream &out) const;
585};
586
587struct CYArray :
588 CYLiteral
589{
590 CYElement *elements_;
591
592 CYArray(CYElement *elements) :
593 elements_(elements)
594 {
595 }
596
b09da87b 597 virtual void Output(std::ostream &out, CYFlags flags) const;
cf7d4c69
JF
598};
599
600struct CYDeclaration :
5999c315 601 CYThing,
cf7d4c69
JF
602 CYForInInitialiser
603{
604 CYIdentifier *identifier_;
605 CYExpression *initialiser_;
606
607 CYDeclaration(CYIdentifier *identifier, CYExpression *initialiser) :
608 identifier_(identifier),
609 initialiser_(initialiser)
610 {
611 }
5999c315
JF
612
613 virtual void Part(std::ostream &out) const;
614 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
615};
616
617struct CYDeclarations :
618 CYStatement,
619 CYForInitialiser
620{
621 CYDeclaration *declaration_;
622 CYDeclarations *next_;
623
624 CYDeclarations(CYDeclaration *declaration, CYDeclarations *next) :
625 declaration_(declaration),
626 next_(next)
627 {
628 }
5999c315
JF
629
630 virtual void Part(std::ostream &out) const;
631 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
632};
633
b09da87b
JF
634struct CYField :
635 CYNext<CYField>
636{
637 virtual void Output(std::ostream &out) const;
638};
639
640struct CYMessageParameter :
641 CYNext<CYMessageParameter>
642{
643 CYWord *tag_;
644 CYExpression *type_;
645 CYIdentifier *name_;
646
647 CYMessageParameter(CYWord *tag, CYExpression *type, CYIdentifier *name) :
648 tag_(tag),
649 type_(type),
650 name_(name)
651 {
652 }
653};
654
655struct CYMessage :
e5bc40db 656 CYNext<CYMessage>
b09da87b
JF
657{
658 bool instance_;
659 CYExpression *type_;
660 CYMessageParameter *parameter_;
661 CYSource *body_;
662
663 CYMessage(bool instance, CYExpression *type, CYMessageParameter *parameter, CYSource *body) :
664 instance_(instance),
665 type_(type),
666 parameter_(parameter),
667 body_(body)
668 {
669 }
670
e5bc40db 671 virtual void Output(std::ostream &out, bool replace) const;
b09da87b
JF
672};
673
674struct CYClass :
675 CYSource
676{
677 CYIdentifier *name_;
678 CYExpression *super_;
679 CYField *fields_;
680 CYMessage *messages_;
681
682 CYClass(CYIdentifier *name, CYExpression *super, CYField *fields, CYMessage *messages) :
683 name_(name),
684 super_(super),
685 fields_(fields),
686 messages_(messages)
687 {
688 }
689
690 virtual void Output(std::ostream &out) const;
691};
692
e5bc40db
JF
693struct CYCategory :
694 CYSource
695{
696 CYClassName *name_;
697 CYMessage *messages_;
698
699 CYCategory(CYClassName *name, CYMessage *messages) :
700 name_(name),
701 messages_(messages)
702 {
703 }
704
705 virtual void Output(std::ostream &out) const;
706};
707
b09da87b
JF
708struct CYFunctionParameter :
709 CYNext<CYFunctionParameter>,
5999c315
JF
710 CYThing
711{
cf7d4c69 712 CYIdentifier *name_;
cf7d4c69 713
b09da87b
JF
714 CYFunctionParameter(CYIdentifier *name, CYFunctionParameter *next) :
715 CYNext<CYFunctionParameter>(next),
62014ea9 716 name_(name)
cf7d4c69
JF
717 {
718 }
5999c315
JF
719
720 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
721};
722
723struct CYFor :
724 CYStatement
725{
726 CYForInitialiser *initialiser_;
727 CYExpression *test_;
728 CYExpression *increment_;
729 CYStatement *code_;
730
731 CYFor(CYForInitialiser *initialiser, CYExpression *test, CYExpression *increment, CYStatement *code) :
732 initialiser_(initialiser),
733 test_(test),
734 increment_(increment),
735 code_(code)
736 {
737 }
5999c315
JF
738
739 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
740};
741
742struct CYForIn :
743 CYStatement
744{
745 CYForInInitialiser *initialiser_;
746 CYExpression *set_;
747 CYStatement *code_;
748
749 CYForIn(CYForInInitialiser *initialiser, CYExpression *set, CYStatement *code) :
750 initialiser_(initialiser),
751 set_(set),
752 code_(code)
753 {
754 }
5999c315
JF
755
756 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
757};
758
62014ea9
JF
759struct CYProperty :
760 CYNext<CYProperty>
761{
e5bc40db 762 CYPropertyName *name_;
cf7d4c69 763 CYExpression *value_;
cf7d4c69 764
e5bc40db 765 CYProperty(CYPropertyName *name, CYExpression *value, CYProperty *next) :
62014ea9 766 CYNext<CYProperty>(next),
cf7d4c69 767 name_(name),
62014ea9 768 value_(value)
cf7d4c69
JF
769 {
770 }
5999c315 771
5999c315 772 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
773};
774
693d501b
JF
775struct CYObject :
776 CYLiteral
777{
778 CYProperty *property_;
779
780 CYObject(CYProperty *property) :
781 property_(property)
782 {
783 }
784
b09da87b 785 void Output(std::ostream &out, CYFlags flags) const;
693d501b
JF
786};
787
5999c315
JF
788struct CYCatch :
789 CYThing
790{
cf7d4c69
JF
791 CYIdentifier *name_;
792 CYStatement *code_;
793
794 CYCatch(CYIdentifier *name, CYStatement *code) :
795 name_(name),
796 code_(code)
797 {
798 }
5999c315
JF
799
800 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
801};
802
b09da87b 803struct CYSend :
63b4c5a8
JF
804 CYExpression
805{
cf7d4c69
JF
806 CYExpression *self_;
807 CYArgument *arguments_;
63b4c5a8 808
b09da87b 809 CYSend(CYExpression *self, CYArgument *arguments) :
cf7d4c69
JF
810 self_(self),
811 arguments_(arguments)
63b4c5a8
JF
812 {
813 }
5999c315 814
d35a3b07
JF
815 CYPrecedence(0)
816
b09da87b 817 virtual void Output(std::ostream &out, CYFlags flags) const;
63b4c5a8
JF
818};
819
cf7d4c69
JF
820struct CYMember :
821 CYExpression
822{
823 CYExpression *object_;
824 CYExpression *property_;
825
826 CYMember(CYExpression *object, CYExpression *property) :
827 object_(object),
828 property_(property)
829 {
830 }
5999c315 831
9b5527f0
JF
832 void SetLeft(CYExpression *object) {
833 object_ = object;
834 }
835};
836
837struct CYDirectMember :
838 CYMember
839{
840 CYDirectMember(CYExpression *object, CYExpression *property) :
841 CYMember(object, property)
842 {
843 }
844
845 CYPrecedence(1)
846
847 virtual void Output(std::ostream &out, CYFlags flags) const;
848};
849
850struct CYIndirectMember :
851 CYMember
852{
853 CYIndirectMember(CYExpression *object, CYExpression *property) :
854 CYMember(object, property)
855 {
856 }
857
d35a3b07
JF
858 CYPrecedence(1)
859
b09da87b 860 virtual void Output(std::ostream &out, CYFlags flags) const;
cf7d4c69
JF
861};
862
863struct CYNew :
864 CYExpression
865{
866 CYExpression *constructor_;
867 CYArgument *arguments_;
868
869 CYNew(CYExpression *constructor, CYArgument *arguments) :
870 constructor_(constructor),
871 arguments_(arguments)
872 {
873 }
5999c315 874
d35a3b07
JF
875 CYPrecedence(1)
876
b09da87b 877 virtual void Output(std::ostream &out, CYFlags flags) const;
cf7d4c69
JF
878};
879
880struct CYCall :
881 CYExpression
882{
883 CYExpression *function_;
884 CYArgument *arguments_;
885
886 CYCall(CYExpression *function, CYArgument *arguments) :
887 function_(function),
888 arguments_(arguments)
889 {
890 }
5999c315 891
d35a3b07
JF
892 CYPrecedence(2)
893
b09da87b 894 virtual void Output(std::ostream &out, CYFlags flags) const;
cf7d4c69
JF
895};
896
897struct CYIf :
898 CYStatement
899{
900 CYExpression *test_;
901 CYStatement *true_;
902 CYStatement *false_;
903
904 CYIf(CYExpression *test, CYStatement *_true, CYStatement *_false) :
905 test_(test),
906 true_(_true),
907 false_(_false)
908 {
909 }
5999c315
JF
910
911 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
912};
913
914struct CYDoWhile :
915 CYStatement
916{
917 CYExpression *test_;
918 CYStatement *code_;
919
920 CYDoWhile(CYExpression *test, CYStatement *code) :
921 test_(test),
922 code_(code)
923 {
924 }
5999c315
JF
925
926 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
927};
928
929struct CYWhile :
930 CYStatement
931{
932 CYExpression *test_;
933 CYStatement *code_;
934
935 CYWhile(CYExpression *test, CYStatement *code) :
936 test_(test),
937 code_(code)
938 {
939 }
5999c315
JF
940
941 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
942};
943
944struct CYLambda :
945 CYExpression
946{
947 CYIdentifier *name_;
b09da87b 948 CYFunctionParameter *parameters_;
cf7d4c69
JF
949 CYSource *body_;
950
b09da87b 951 CYLambda(CYIdentifier *name, CYFunctionParameter *parameters, CYSource *body) :
cf7d4c69
JF
952 name_(name),
953 parameters_(parameters),
954 body_(body)
955 {
956 }
5999c315 957
d35a3b07
JF
958 CYPrecedence(0)
959
b09da87b 960 virtual void Output(std::ostream &out, CYFlags flags) const;
cf7d4c69
JF
961};
962
963struct CYFunction :
5999c315
JF
964 CYLambda,
965 CYSource
cf7d4c69 966{
b09da87b 967 CYFunction(CYIdentifier *name, CYFunctionParameter *parameters, CYSource *body) :
cf7d4c69
JF
968 CYLambda(name, parameters, body)
969 {
970 }
5999c315
JF
971
972 virtual void Output(std::ostream &out) const;
973};
974
975struct CYExpress :
976 CYStatement
977{
978 CYExpression *expression_;
979
980 CYExpress(CYExpression *expression) :
981 expression_(expression)
982 {
983 }
984
985 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
986};
987
988struct CYContinue :
989 CYStatement
990{
991 CYIdentifier *label_;
992
993 CYContinue(CYIdentifier *label) :
994 label_(label)
995 {
996 }
5999c315
JF
997
998 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
999};
1000
1001struct CYBreak :
1002 CYStatement
1003{
1004 CYIdentifier *label_;
1005
1006 CYBreak(CYIdentifier *label) :
1007 label_(label)
1008 {
1009 }
5999c315
JF
1010
1011 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
1012};
1013
1014struct CYReturn :
1015 CYStatement
1016{
1017 CYExpression *value_;
1018
1019 CYReturn(CYExpression *value) :
1020 value_(value)
1021 {
1022 }
5999c315
JF
1023
1024 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
1025};
1026
1027struct CYEmpty :
1028 CYStatement
1029{
5999c315
JF
1030 virtual void Output(std::ostream &out) const;
1031 virtual void Output(std::ostream &out, bool block) const;
cf7d4c69
JF
1032};
1033
1034struct CYTry :
1035 CYStatement
1036{
1037 CYStatement *try_;
1038 CYCatch *catch_;
1039 CYStatement *finally_;
1040
1041 CYTry(CYStatement *_try, CYCatch *_catch, CYStatement *finally) :
1042 try_(_try),
1043 catch_(_catch),
1044 finally_(finally)
1045 {
1046 }
5999c315
JF
1047
1048 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
1049};
1050
1051struct CYThrow :
1052 CYStatement
1053{
1054 CYExpression *value_;
1055
1056 CYThrow(CYExpression *value) :
1057 value_(value)
1058 {
1059 }
5999c315
JF
1060
1061 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
1062};
1063
1064struct CYWith :
1065 CYStatement
1066{
1067 CYExpression *scope_;
1068 CYStatement *code_;
1069
1070 CYWith(CYExpression *scope, CYStatement *code) :
1071 scope_(scope),
1072 code_(code)
1073 {
1074 }
5999c315
JF
1075
1076 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
1077};
1078
1079struct CYSwitch :
1080 CYStatement
1081{
1082 CYExpression *value_;
1083 CYClause *clauses_;
1084
1085 CYSwitch(CYExpression *value, CYClause *clauses) :
1086 value_(value),
1087 clauses_(clauses)
1088 {
1089 }
5999c315
JF
1090
1091 virtual void Output(std::ostream &out) const;
cf7d4c69
JF
1092};
1093
1094struct CYCondition :
1095 CYExpression
1096{
1097 CYExpression *test_;
1098 CYExpression *true_;
1099 CYExpression *false_;
1100
1101 CYCondition(CYExpression *test, CYExpression *_true, CYExpression *_false) :
91a416e4 1102 test_(test),
cf7d4c69
JF
1103 true_(_true),
1104 false_(_false)
1105 {
1106 }
5999c315 1107
d35a3b07
JF
1108 CYPrecedence(15)
1109
b09da87b 1110 virtual void Output(std::ostream &out, CYFlags flags) const;
5999c315
JF
1111};
1112
1113struct CYAddressOf :
1114 CYPrefix
1115{
1116 CYAddressOf(CYExpression *rhs) :
1117 CYPrefix(rhs)
1118 {
1119 }
1120
1121 virtual const char *Operator() const {
1122 return "&";
1123 }
1124
b09da87b 1125 CYAlphabetic(false)
d35a3b07
JF
1126 CYPrecedence(2)
1127
b09da87b 1128 virtual void Output(std::ostream &out, CYFlags flags) const;
5999c315
JF
1129};
1130
1131struct CYIndirect :
1132 CYPrefix
1133{
1134 CYIndirect(CYExpression *rhs) :
1135 CYPrefix(rhs)
1136 {
1137 }
1138
1139 virtual const char *Operator() const {
1140 return "*";
1141 }
1142
b09da87b 1143 CYAlphabetic(false)
d35a3b07
JF
1144 CYPrecedence(1)
1145
b09da87b 1146 virtual void Output(std::ostream &out, CYFlags flags) const;
cf7d4c69
JF
1147};
1148
1149#define CYPostfix_(op, name) \
1150 struct CY ## name : \
1151 CYPostfix \
1152 { \
1153 CY ## name(CYExpression *lhs) : \
1154 CYPostfix(lhs) \
1155 { \
1156 } \
d35a3b07
JF
1157 \
1158 CYPrecedence(3) \
5999c315
JF
1159 \
1160 virtual const char *Operator() const { \
1161 return op; \
1162 } \
cf7d4c69
JF
1163 };
1164
b09da87b 1165#define CYPrefix_(alphabetic, op, name) \
cf7d4c69
JF
1166 struct CY ## name : \
1167 CYPrefix \
1168 { \
1169 CY ## name(CYExpression *rhs) : \
1170 CYPrefix(rhs) \
1171 { \
1172 } \
d35a3b07 1173 \
b09da87b 1174 CYAlphabetic(alphabetic) \
d35a3b07 1175 CYPrecedence(4) \
5999c315
JF
1176 \
1177 virtual const char *Operator() const { \
1178 return op; \
1179 } \
cf7d4c69
JF
1180 };
1181
b09da87b 1182#define CYInfix_(alphabetic, precedence, op, name) \
cf7d4c69
JF
1183 struct CY ## name : \
1184 CYInfix \
1185 { \
1186 CY ## name(CYExpression *lhs, CYExpression *rhs) : \
1187 CYInfix(lhs, rhs) \
1188 { \
1189 } \
d35a3b07 1190 \
b09da87b 1191 CYAlphabetic(alphabetic) \
d35a3b07 1192 CYPrecedence(precedence) \
5999c315
JF
1193 \
1194 virtual const char *Operator() const { \
1195 return op; \
1196 } \
cf7d4c69
JF
1197 };
1198
1199#define CYAssignment_(op, name) \
1200 struct CY ## name ## Assign : \
1201 CYAssignment \
1202 { \
1203 CY ## name ## Assign(CYExpression *lhs, CYExpression *rhs) : \
1204 CYAssignment(lhs, rhs) \
1205 { \
1206 } \
d35a3b07
JF
1207 \
1208 CYPrecedence(16) \
5999c315
JF
1209 \
1210 virtual const char *Operator() const { \
1211 return op; \
1212 } \
cf7d4c69
JF
1213 };
1214
1215CYPostfix_("++", PostIncrement)
1216CYPostfix_("--", PostDecrement)
1217
b09da87b
JF
1218CYPrefix_(true, "delete", Delete)
1219CYPrefix_(true, "void", Void)
1220CYPrefix_(true, "typeof", TypeOf)
1221CYPrefix_(false, "++", PreIncrement)
1222CYPrefix_(false, "--", PreDecrement)
1223CYPrefix_(false, "-", Negate)
1224CYPrefix_(false, "~", BitwiseNot)
1225CYPrefix_(false, "!", LogicalNot)
1226
1227CYInfix_(false, 5, "*", Multiply)
1228CYInfix_(false, 5, "/", Divide)
1229CYInfix_(false, 5, "%", Modulus)
1230CYInfix_(false, 6, "+", Add)
1231CYInfix_(false, 6, "-", Subtract)
1232CYInfix_(false, 7, "<<", ShiftLeft)
1233CYInfix_(false, 7, ">>", ShiftRightSigned)
1234CYInfix_(false, 7, ">>>", ShiftRightUnsigned)
1235CYInfix_(false, 8, "<", Less)
1236CYInfix_(false, 8, ">", Greater)
1237CYInfix_(false, 8, "<=", LessOrEqual)
1238CYInfix_(false, 8, ">=", GreaterOrEqual)
1239CYInfix_(true, 8, "instanceof", InstanceOf)
1240CYInfix_(true, 8, "in", In)
1241CYInfix_(false, 9, "==", Equal)
1242CYInfix_(false, 9, "!=", NotEqual)
1243CYInfix_(false, 9, "===", Identical)
1244CYInfix_(false, 9, "!==", NotIdentical)
1245CYInfix_(false, 10, "&", BitwiseAnd)
1246CYInfix_(false, 11, "^", BitwiseXOr)
1247CYInfix_(false, 12, "|", BitwiseOr)
1248CYInfix_(false, 13, "&&", LogicalAnd)
1249CYInfix_(false, 14, "||", LogicalOr)
cf7d4c69
JF
1250
1251CYAssignment_("=", )
1252CYAssignment_("*=", Multiply)
1253CYAssignment_("/=", Divide)
1254CYAssignment_("%=", Modulus)
1255CYAssignment_("+=", Add)
1256CYAssignment_("-=", Subtract)
1257CYAssignment_("<<=", ShiftLeft)
1258CYAssignment_(">>=", ShiftRightSigned)
1259CYAssignment_(">>>=", ShiftRightUnsigned)
1260CYAssignment_("&=", BitwiseAnd)
1261CYAssignment_("^=", BitwiseXOr)
1262CYAssignment_("|=", BitwiseOr)
1263
63b4c5a8 1264#endif/*CYPARSER_HPP*/