Further attempts at making Cycript portable to GNUstep.
[cycript.git] / Parser.hpp
CommitLineData
d15b59f5 1/* Cycript - Error.hppution Server and Disassembler
b4aa79af
JF
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
4de0686f
JF
43// XXX: wtf is this here?!
44#define CYPA 16
45
46#include <iostream>
47
5999c315 48#include <string>
c3c20102 49#include <vector>
cf7d4c69 50
4de0686f
JF
51#include <cstdlib>
52
5befe15e 53#include "location.hh"
5999c315 54#include "Pooling.hpp"
924f67b2 55
5999c315
JF
56template <typename Type_>
57struct CYNext {
58 Type_ *next_;
63b4c5a8 59
5999c315
JF
60 CYNext() :
61 next_(NULL)
62 {
63 }
cf7d4c69 64
62014ea9
JF
65 CYNext(Type_ *next) :
66 next_(next)
67 {
68 }
69
5999c315 70 void SetNext(Type_ *next) {
cf7d4c69
JF
71 next_ = next;
72 }
73};
74
5999c315 75struct CYThing {
652ec1ba 76 virtual void Output(struct CYOutput &out) const = 0;
5999c315
JF
77};
78
652ec1ba
JF
79struct CYOutput {
80 std::ostream &out_;
11c1cc16
JF
81 bool pretty_;
82 unsigned indent_;
652ec1ba 83
96a7e5c2
JF
84 enum {
85 NoMode,
86 NoLetter,
c0bc320e 87 NoPlus,
96a7e5c2
JF
88 NoHyphen,
89 Terminated
90 } mode_;
91
652ec1ba 92 CYOutput(std::ostream &out) :
11c1cc16
JF
93 out_(out),
94 pretty_(false),
96a7e5c2
JF
95 indent_(0),
96 mode_(NoMode)
652ec1ba
JF
97 {
98 }
99
96a7e5c2 100 void Check(char value);
1fdca2fa 101 void Terminate();
652ec1ba 102
96a7e5c2
JF
103 CYOutput &operator <<(char rhs);
104 CYOutput &operator <<(const char *rhs);
105
106 _finline CYOutput &operator <<(const CYThing *rhs) {
107 if (rhs != NULL)
108 rhs->Output(*this);
652ec1ba
JF
109 return *this;
110 }
111
112 _finline CYOutput &operator <<(const CYThing &rhs) {
113 rhs.Output(*this);
114 return *this;
115 }
116};
5999c315 117
e5bc40db 118struct CYPropertyName {
652ec1ba 119 virtual void PropertyName(CYOutput &out) const = 0;
e5bc40db
JF
120};
121
3b52fd1a
JF
122struct CYExpression;
123
124enum CYNeeded {
125 CYNever = -1,
126 CYSometimes = 0,
127 CYAlways = 1,
128};
129
130enum CYFlags {
131 CYNoFlags = 0,
132 CYNoBrace = (1 << 0),
133 CYNoFunction = (1 << 1),
134 CYNoIn = (1 << 2),
135 CYNoCall = (1 << 3),
136 CYNoRightHand = (1 << 4),
137 CYNoDangle = (1 << 5),
138 CYNoBF = (CYNoBrace | CYNoFunction),
139};
140
141struct CYContext {
142 apr_pool_t *pool_;
143
144 CYContext(apr_pool_t *pool) :
145 pool_(pool)
146 {
147 }
148
149 template <typename Type_>
150 void Replace(Type_ *&value) {
151 if (value != NULL)
152 while (Type_ *replace = value->Replace(*this))
153 value = replace;
154 }
155};
156
157struct CYStatement :
158 CYNext<CYStatement>
159{
160 void Single(CYOutput &out, CYFlags flags) const;
161 void Multiple(CYOutput &out, CYFlags flags = CYNoFlags) const;
162
163 CYStatement *ReplaceAll(CYContext &context);
164
165 virtual CYStatement *Replace(CYContext &context) = 0;
166
167 private:
168 virtual void Output(CYOutput &out, CYFlags flags) const = 0;
169};
170
171struct CYStatements {
172 CYStatement *first_;
173 CYStatement *last_;
174
175 CYStatements() :
176 first_(NULL),
177 last_(NULL)
178 {
179 }
180
181 operator CYStatement *() const {
182 return first_;
183 }
184
185 CYStatements &operator ->*(CYStatement *next) {
186 if (next != NULL)
187 if (first_ == NULL) {
188 first_ = next;
189 last_ = next;
190 } else for (;; last_ = last_->next_)
191 if (last_->next_ == NULL) {
192 last_->next_ = next;
193 last_ = next;
194 break;
195 }
196 return *this;
197 }
198};
199
e5bc40db 200struct CYClassName {
3b52fd1a 201 virtual CYExpression *ClassName(CYContext &context, bool object) = 0;
652ec1ba 202 virtual void ClassName(CYOutput &out, bool object) const = 0;
63b4c5a8
JF
203};
204
cf7d4c69 205struct CYWord :
e5bc40db
JF
206 CYThing,
207 CYPropertyName,
208 CYClassName
63b4c5a8 209{
cf7d4c69
JF
210 const char *word_;
211
212 CYWord(const char *word) :
213 word_(word)
214 {
215 }
216
5999c315 217 const char *Value() const {
cf7d4c69
JF
218 return word_;
219 }
220
652ec1ba 221 virtual void Output(CYOutput &out) const;
e5bc40db 222
3b52fd1a 223 virtual CYExpression *ClassName(CYContext &context, bool object);
652ec1ba
JF
224 virtual void ClassName(CYOutput &out, bool object) const;
225 virtual void PropertyName(CYOutput &out) const;
63b4c5a8
JF
226};
227
652ec1ba
JF
228_finline std::ostream &operator <<(std::ostream &lhs, const CYWord &rhs) {
229 return lhs << rhs.Value();
230}
231
cf7d4c69
JF
232struct CYIdentifier :
233 CYWord
63b4c5a8 234{
5999c315
JF
235 CYIdentifier(const char *word) :
236 CYWord(word)
237 {
cf7d4c69 238 }
63b4c5a8
JF
239};
240
62014ea9 241struct CYLabel :
3b52fd1a 242 CYStatement
62014ea9 243{
9e562cfc 244 CYIdentifier *name_;
3b52fd1a 245 CYStatement *statement_;
cf7d4c69 246
3b52fd1a
JF
247 CYLabel(CYIdentifier *name, CYStatement *statement) :
248 name_(name),
249 statement_(statement)
cf7d4c69
JF
250 {
251 }
fb98ac0c 252
3b52fd1a
JF
253 virtual CYStatement *Replace(CYContext &context);
254 virtual void Output(CYOutput &out, CYFlags flags) const;
fb98ac0c
JF
255};
256
3b52fd1a
JF
257struct CYProgram :
258 CYThing
63b4c5a8 259{
3b52fd1a 260 CYStatement *statements_;
9e562cfc 261
3b52fd1a
JF
262 CYProgram(CYStatement *statements) :
263 statements_(statements)
9e562cfc
JF
264 {
265 }
cf7d4c69 266
3b52fd1a 267 virtual void Replace(CYContext &context);
fb98ac0c 268
3b52fd1a 269 virtual void Output(CYOutput &out) const;
9e562cfc
JF
270};
271
272struct CYBlock :
3b52fd1a
JF
273 CYStatement,
274 CYThing
9e562cfc
JF
275{
276 CYStatement *statements_;
277
278 CYBlock(CYStatement *statements) :
279 statements_(statements)
280 {
cf7d4c69 281 }
9e562cfc 282
4644480a
JF
283 operator CYStatement *() const {
284 return statements_;
285 }
286
3b52fd1a
JF
287 virtual CYStatement *Replace(CYContext &context);
288
289 virtual void Output(CYOutput &out) const;
fb98ac0c 290 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
291};
292
db5e2840
JF
293enum CYState {
294 CYClear,
295 CYRestricted,
296 CYNewLine
297};
298
5999c315
JF
299class CYDriver {
300 public:
301 CYPool pool_;
e7ed5354 302
db5e2840 303 CYState state_;
e7ed5354
JF
304 void *scanner_;
305
306 const char *data_;
307 size_t size_;
48e3be8a 308 FILE *file_;
e7ed5354 309
b10bd496
JF
310 bool strict_;
311
63cd45c9 312 enum Condition {
697d6fd2 313 RegExpCondition,
691e4717
JF
314 XMLContentCondition,
315 XMLTagCondition,
63cd45c9
JF
316 };
317
5999c315 318 std::string filename_;
e7ed5354 319
5befe15e 320 struct Error {
b10bd496 321 bool warning_;
5befe15e
JF
322 cy::location location_;
323 std::string message_;
324 };
325
326 typedef std::vector<Error> Errors;
327
3b52fd1a 328 CYProgram *program_;
5befe15e 329 Errors errors_;
5999c315
JF
330
331 private:
332 void ScannerInit();
333 void ScannerDestroy();
334
335 public:
336 CYDriver(const std::string &filename);
337 ~CYDriver();
63cd45c9 338
691e4717
JF
339 Condition GetCondition();
340 void SetCondition(Condition condition);
341
342 void PushCondition(Condition condition);
343 void PopCondition();
b10bd496
JF
344
345 void Warning(const cy::location &location, const char *message);
5999c315
JF
346};
347
cac61857 348struct CYForInitialiser {
652ec1ba 349 virtual void For(CYOutput &out) const = 0;
dea834b0
JF
350};
351
cac61857 352struct CYForInInitialiser {
652ec1ba 353 virtual void ForIn(CYOutput &out, CYFlags flags) const = 0;
75b0a457 354 virtual const char *ForEachIn() const = 0;
3b52fd1a 355 virtual CYExpression *ForEachIn(CYContext &out) = 0;
b09da87b
JF
356};
357
4644480a
JF
358struct CYNumber;
359struct CYString;
360
cf7d4c69 361struct CYExpression :
5999c315 362 CYNext<CYExpression>,
cf7d4c69 363 CYForInitialiser,
e5bc40db 364 CYForInInitialiser,
96a7e5c2
JF
365 CYClassName,
366 CYThing
63b4c5a8 367{
d35a3b07 368 virtual unsigned Precedence() const = 0;
75b0a457 369
fb98ac0c
JF
370 virtual bool RightHand() const {
371 return true;
372 }
373
652ec1ba
JF
374 virtual void For(CYOutput &out) const;
375 virtual void ForIn(CYOutput &out, CYFlags flags) const;
75b0a457 376
cac61857 377 virtual const char *ForEachIn() const;
3b52fd1a 378 virtual CYExpression *ForEachIn(CYContext &out);
75b0a457 379
96a7e5c2 380 virtual void Output(CYOutput &out) const;
652ec1ba
JF
381 virtual void Output(CYOutput &out, CYFlags flags) const = 0;
382 void Output(CYOutput &out, unsigned precedence, CYFlags flags) const;
dea834b0 383
3b52fd1a 384 virtual CYExpression *ClassName(CYContext &context, bool object);
652ec1ba 385 virtual void ClassName(CYOutput &out, bool object) const;
e5bc40db 386
3b52fd1a
JF
387 CYExpression *ReplaceAll(CYContext &context);
388
389 virtual CYExpression *Replace(CYContext &context) = 0;
390
4644480a
JF
391 virtual CYExpression *Primitive(CYContext &context) {
392 return this;
393 }
394
395 virtual CYNumber *Number(CYContext &context) {
396 return NULL;
397 }
398
399 virtual CYString *String(CYContext &context) {
400 return NULL;
401 }
402
dea834b0
JF
403 virtual const char *Word() const {
404 return NULL;
405 }
63b4c5a8
JF
406};
407
b09da87b
JF
408#define CYAlphabetic(value) \
409 virtual bool Alphabetic() const { \
410 return value; \
411 }
412
d35a3b07
JF
413#define CYPrecedence(value) \
414 virtual unsigned Precedence() const { \
415 return value; \
416 }
417
fb98ac0c
JF
418#define CYRightHand(value) \
419 virtual bool RightHand() const { \
420 return value; \
421 }
422
d35a3b07
JF
423struct CYCompound :
424 CYExpression
425{
426 CYExpression *expressions_;
427
428 CYCompound(CYExpression *expressions) :
429 expressions_(expressions)
430 {
431 }
432
433 void AddPrev(CYExpression *expression) {
434 CYExpression *last(expression);
435 while (last->next_ != NULL)
436 last = last->next_;
437 last->SetNext(expressions_);
438 expressions_ = expression;
439 }
440
441 CYPrecedence(17)
442
3b52fd1a 443 virtual CYExpression *Replace(CYContext &context);
652ec1ba 444 void Output(CYOutput &out, CYFlags flags) const;
d35a3b07 445};
5999c315 446
3b52fd1a
JF
447struct CYFunctionParameter :
448 CYNext<CYFunctionParameter>,
449 CYThing
450{
451 CYIdentifier *name_;
452
453 CYFunctionParameter(CYIdentifier *name, CYFunctionParameter *next = NULL) :
454 CYNext<CYFunctionParameter>(next),
455 name_(name)
456 {
457 }
458
459 virtual void Output(CYOutput &out) const;
460};
461
75b0a457 462struct CYComprehension :
96a7e5c2
JF
463 CYNext<CYComprehension>,
464 CYThing
75b0a457 465{
75b0a457
JF
466 virtual const char *Name() const = 0;
467
3b52fd1a
JF
468 virtual CYFunctionParameter *Parameter(CYContext &context) const = 0;
469 CYFunctionParameter *Parameters(CYContext &context) const;
470 virtual CYStatement *Replace(CYContext &context, CYStatement *statement) const;
4644480a 471 virtual void Output(CYOutput &out) const = 0;
75b0a457
JF
472};
473
474struct CYForInComprehension :
475 CYComprehension
476{
477 CYIdentifier *name_;
478 CYExpression *set_;
479
480 CYForInComprehension(CYIdentifier *name, CYExpression *set) :
481 name_(name),
482 set_(set)
483 {
484 }
485
486 virtual const char *Name() const {
487 return name_->Value();
488 }
489
3b52fd1a
JF
490 virtual CYFunctionParameter *Parameter(CYContext &context) const;
491 virtual CYStatement *Replace(CYContext &context, CYStatement *statement) const;
4644480a 492 virtual void Output(CYOutput &out) const;
75b0a457
JF
493};
494
495struct CYForEachInComprehension :
496 CYComprehension
497{
498 CYIdentifier *name_;
499 CYExpression *set_;
500
501 CYForEachInComprehension(CYIdentifier *name, CYExpression *set) :
502 name_(name),
503 set_(set)
504 {
505 }
506
507 virtual const char *Name() const {
508 return name_->Value();
509 }
510
3b52fd1a
JF
511 virtual CYFunctionParameter *Parameter(CYContext &context) const;
512 virtual CYStatement *Replace(CYContext &context, CYStatement *statement) const;
4644480a 513 virtual void Output(CYOutput &out) const;
75b0a457
JF
514};
515
516struct CYIfComprehension :
517 CYComprehension
518{
519 CYExpression *test_;
520
521 CYIfComprehension(CYExpression *test) :
522 test_(test)
523 {
524 }
525
526 virtual const char *Name() const {
527 return NULL;
528 }
529
3b52fd1a
JF
530 virtual CYFunctionParameter *Parameter(CYContext &context) const;
531 virtual CYStatement *Replace(CYContext &context, CYStatement *statement) const;
4644480a 532 virtual void Output(CYOutput &out) const;
75b0a457
JF
533};
534
535struct CYArrayComprehension :
536 CYExpression
537{
538 CYExpression *expression_;
539 CYComprehension *comprehensions_;
540
541 CYArrayComprehension(CYExpression *expression, CYComprehension *comprehensions) :
542 expression_(expression),
543 comprehensions_(comprehensions)
544 {
545 }
546
547 CYPrecedence(0)
548
3b52fd1a 549 virtual CYExpression *Replace(CYContext &context);
652ec1ba 550 virtual void Output(CYOutput &out, CYFlags flags) const;
75b0a457
JF
551};
552
cf7d4c69
JF
553struct CYLiteral :
554 CYExpression
63b4c5a8 555{
d35a3b07 556 CYPrecedence(0)
fb98ac0c 557 CYRightHand(false)
cf7d4c69 558};
63b4c5a8 559
3b52fd1a
JF
560struct CYTrivial :
561 CYLiteral
562{
563 virtual CYExpression *Replace(CYContext &context);
564};
565
478d4ed0
JF
566struct CYMagic :
567 CYExpression
568{
569 CYPrecedence(0)
fb98ac0c 570 CYRightHand(false)
478d4ed0
JF
571};
572
dea834b0
JF
573struct CYRange {
574 uint64_t lo_;
575 uint64_t hi_;
576
577 CYRange(uint64_t lo, uint64_t hi) :
578 lo_(lo), hi_(hi)
579 {
580 }
581
582 bool operator [](uint8_t value) const {
583 return !(value >> 7) && (value >> 6 ? hi_ : lo_) >> (value & 0x3f) & 0x1;
584 }
585
586 void operator()(uint8_t value) {
587 if (value >> 7)
588 return;
589 (value >> 6 ? hi_ : lo_) |= uint64_t(0x1) << (value & 0x3f);
590 }
591};
592
283e7e33 593extern CYRange DigitRange_;
dea834b0
JF
594extern CYRange WordStartRange_;
595extern CYRange WordEndRange_;
596
cf7d4c69 597struct CYString :
3b52fd1a 598 CYTrivial,
e5bc40db 599 CYPropertyName
cf7d4c69
JF
600{
601 const char *value_;
5999c315 602 size_t size_;
cf7d4c69 603
3b52fd1a
JF
604 CYString() :
605 value_(NULL),
606 size_(0)
607 {
608 }
609
610 CYString(const char *value) :
611 value_(value),
612 size_(strlen(value))
613 {
614 }
615
5999c315
JF
616 CYString(const char *value, size_t size) :
617 value_(value),
618 size_(size)
cf7d4c69
JF
619 {
620 }
621
3b52fd1a
JF
622 CYString(const CYWord *word) :
623 value_(word->Value()),
5999c315 624 size_(strlen(value_))
cf7d4c69
JF
625 {
626 }
627
5999c315 628 const char *Value() const {
cf7d4c69
JF
629 return value_;
630 }
631
11c1cc16 632 virtual const char *Word() const;
dea834b0 633
4644480a
JF
634 virtual CYNumber *Number(CYContext &context);
635 virtual CYString *String(CYContext &context);
636
637 virtual CYString *Concat(CYContext &out, CYString *rhs) const;
652ec1ba
JF
638 virtual void Output(CYOutput &out, CYFlags flags) const;
639 virtual void PropertyName(CYOutput &out) const;
63b4c5a8
JF
640};
641
cf7d4c69 642struct CYNumber :
3b52fd1a 643 CYTrivial,
e5bc40db 644 CYPropertyName
cf7d4c69 645{
5999c315
JF
646 double value_;
647
648 CYNumber(double value) :
649 value_(value)
650 {
651 }
652
653 double Value() const {
654 return value_;
cf7d4c69
JF
655 }
656
4644480a
JF
657 virtual CYNumber *Number(CYContext &context);
658 virtual CYString *String(CYContext &context);
659
652ec1ba
JF
660 virtual void Output(CYOutput &out, CYFlags flags) const;
661 virtual void PropertyName(CYOutput &out) const;
cf7d4c69
JF
662};
663
63cd45c9 664struct CYRegEx :
3b52fd1a 665 CYTrivial
63cd45c9
JF
666{
667 const char *value_;
668
669 CYRegEx(const char *value) :
670 value_(value)
671 {
672 }
673
674 const char *Value() const {
675 return value_;
676 }
677
678 virtual void Output(CYOutput &out, CYFlags flags) const;
679};
680
cf7d4c69
JF
681struct CYNull :
682 CYWord,
3b52fd1a 683 CYTrivial
cf7d4c69
JF
684{
685 CYNull() :
686 CYWord("null")
687 {
688 }
5999c315 689
4644480a
JF
690 virtual CYNumber *Number(CYContext &context);
691 virtual CYString *String(CYContext &context);
692
652ec1ba 693 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
694};
695
696struct CYThis :
697 CYWord,
478d4ed0 698 CYMagic
cf7d4c69
JF
699{
700 CYThis() :
701 CYWord("this")
702 {
703 }
5999c315 704
3b52fd1a 705 virtual CYExpression *Replace(CYContext &context);
652ec1ba 706 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
707};
708
709struct CYBoolean :
3b52fd1a 710 CYTrivial
cf7d4c69 711{
5999c315 712 virtual bool Value() const = 0;
652ec1ba 713 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
714};
715
716struct CYFalse :
717 CYWord,
718 CYBoolean
719{
720 CYFalse() :
721 CYWord("false")
722 {
723 }
5999c315 724
11c1cc16
JF
725 virtual bool Value() const {
726 return false;
727 }
4644480a
JF
728
729 virtual CYNumber *Number(CYContext &context);
730 virtual CYString *String(CYContext &context);
cf7d4c69
JF
731};
732
733struct CYTrue :
734 CYWord,
735 CYBoolean
736{
737 CYTrue() :
738 CYWord("true")
739 {
740 }
5999c315 741
11c1cc16
JF
742 virtual bool Value() const {
743 return true;
744 }
4644480a
JF
745
746 virtual CYNumber *Number(CYContext &context);
747 virtual CYString *String(CYContext &context);
cf7d4c69
JF
748};
749
750struct CYVariable :
751 CYExpression
752{
753 CYIdentifier *name_;
754
755 CYVariable(CYIdentifier *name) :
756 name_(name)
757 {
758 }
5999c315 759
d35a3b07 760 CYPrecedence(0)
fb98ac0c 761 CYRightHand(false)
d35a3b07 762
3b52fd1a 763 virtual CYExpression *Replace(CYContext &context);
652ec1ba 764 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
765};
766
767struct CYPrefix :
63b4c5a8
JF
768 CYExpression
769{
770 CYExpression *rhs_;
771
cf7d4c69 772 CYPrefix(CYExpression *rhs) :
63b4c5a8
JF
773 rhs_(rhs)
774 {
775 }
5999c315 776
b09da87b 777 virtual bool Alphabetic() const = 0;
5999c315
JF
778 virtual const char *Operator() const = 0;
779
3b52fd1a
JF
780 CYPrecedence(4)
781
782 virtual CYExpression *Replace(CYContext &context);
652ec1ba 783 virtual void Output(CYOutput &out, CYFlags flags) const;
63b4c5a8
JF
784};
785
cf7d4c69 786struct CYInfix :
63b4c5a8
JF
787 CYExpression
788{
789 CYExpression *lhs_;
790 CYExpression *rhs_;
791
cf7d4c69 792 CYInfix(CYExpression *lhs, CYExpression *rhs) :
63b4c5a8
JF
793 lhs_(lhs),
794 rhs_(rhs)
795 {
796 }
5999c315 797
0ff9f149
JF
798 void SetLeft(CYExpression *lhs) {
799 lhs_ = lhs;
800 }
801
b09da87b 802 virtual bool Alphabetic() const = 0;
5999c315
JF
803 virtual const char *Operator() const = 0;
804
3b52fd1a 805 virtual CYExpression *Replace(CYContext &context);
652ec1ba 806 virtual void Output(CYOutput &out, CYFlags flags) const;
63b4c5a8
JF
807};
808
cf7d4c69 809struct CYPostfix :
63b4c5a8
JF
810 CYExpression
811{
812 CYExpression *lhs_;
813
cf7d4c69 814 CYPostfix(CYExpression *lhs) :
63b4c5a8
JF
815 lhs_(lhs)
816 {
817 }
5999c315
JF
818
819 virtual const char *Operator() const = 0;
820
3b52fd1a
JF
821 CYPrecedence(3)
822
823 virtual CYExpression *Replace(CYContext &context);
652ec1ba 824 virtual void Output(CYOutput &out, CYFlags flags) const;
63b4c5a8
JF
825};
826
cf7d4c69 827struct CYAssignment :
d35a3b07 828 CYExpression
cf7d4c69 829{
d35a3b07
JF
830 CYExpression *lhs_;
831 CYExpression *rhs_;
832
cf7d4c69 833 CYAssignment(CYExpression *lhs, CYExpression *rhs) :
d35a3b07
JF
834 lhs_(lhs),
835 rhs_(rhs)
cf7d4c69
JF
836 {
837 }
5999c315 838
0ff9f149
JF
839 void SetLeft(CYExpression *lhs) {
840 lhs_ = lhs;
841 }
842
5999c315 843 virtual const char *Operator() const = 0;
d35a3b07 844
4de0686f
JF
845 CYPrecedence(16)
846
3b52fd1a 847 virtual CYExpression *Replace(CYContext &context);
652ec1ba 848 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
849};
850
62014ea9 851struct CYArgument :
96a7e5c2
JF
852 CYNext<CYArgument>,
853 CYThing
62014ea9 854{
cf7d4c69
JF
855 CYWord *name_;
856 CYExpression *value_;
cf7d4c69 857
3b52fd1a
JF
858 CYArgument(CYExpression *value, CYArgument *next = NULL) :
859 CYNext<CYArgument>(next),
860 name_(NULL),
861 value_(value)
862 {
863 }
864
cf7d4c69 865 CYArgument(CYWord *name, CYExpression *value, CYArgument *next = NULL) :
62014ea9 866 CYNext<CYArgument>(next),
cf7d4c69 867 name_(name),
62014ea9 868 value_(value)
cf7d4c69
JF
869 {
870 }
5999c315 871
3b52fd1a 872 void Replace(CYContext &context);
652ec1ba 873 void Output(CYOutput &out) const;
cf7d4c69
JF
874};
875
876struct CYBlank :
877 public CYWord
878{
879 CYBlank() :
880 CYWord("")
881 {
882 }
883};
884
5999c315
JF
885struct CYClause :
886 CYThing,
887 CYNext<CYClause>
888{
cf7d4c69 889 CYExpression *case_;
3b52fd1a 890 CYStatement *statements_;
cf7d4c69 891
3b52fd1a 892 CYClause(CYExpression *_case, CYStatement *statements) :
cf7d4c69 893 case_(_case),
3b52fd1a 894 statements_(statements)
cf7d4c69
JF
895 {
896 }
897
fa389b0f 898 void Replace(CYContext &context);
652ec1ba 899 virtual void Output(CYOutput &out) const;
cf7d4c69
JF
900};
901
62014ea9 902struct CYElement :
96a7e5c2
JF
903 CYNext<CYElement>,
904 CYThing
62014ea9 905{
cf7d4c69 906 CYExpression *value_;
cf7d4c69
JF
907
908 CYElement(CYExpression *value, CYElement *next) :
62014ea9
JF
909 CYNext<CYElement>(next),
910 value_(value)
cf7d4c69
JF
911 {
912 }
5999c315 913
3b52fd1a 914 void Replace(CYContext &context);
652ec1ba 915 void Output(CYOutput &out) const;
5befe15e
JF
916};
917
918struct CYArray :
919 CYLiteral
920{
921 CYElement *elements_;
922
3b52fd1a 923 CYArray(CYElement *elements = NULL) :
5befe15e
JF
924 elements_(elements)
925 {
926 }
927
3b52fd1a 928 virtual CYExpression *Replace(CYContext &context);
652ec1ba 929 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
930};
931
550ee46a
JF
932struct CYProperty :
933 CYNext<CYProperty>,
934 CYThing
935{
936 CYPropertyName *name_;
937 CYExpression *value_;
938
939 CYProperty(CYPropertyName *name, CYExpression *value, CYProperty *next = NULL) :
940 CYNext<CYProperty>(next),
941 name_(name),
942 value_(value)
943 {
944 }
945
946 void Replace(CYContext &context);
947 virtual void Output(CYOutput &out) const;
948};
949
cf7d4c69
JF
950struct CYDeclaration :
951 CYForInInitialiser
952{
953 CYIdentifier *identifier_;
954 CYExpression *initialiser_;
955
550ee46a 956 CYDeclaration(CYIdentifier *identifier, CYExpression *initialiser = NULL) :
cf7d4c69
JF
957 identifier_(identifier),
958 initialiser_(initialiser)
959 {
960 }
5999c315 961
652ec1ba 962 virtual void ForIn(CYOutput &out, CYFlags flags) const;
75b0a457 963
cac61857 964 virtual const char *ForEachIn() const;
3b52fd1a
JF
965 virtual CYExpression *ForEachIn(CYContext &out);
966
967 void Replace(CYContext &context);
75b0a457 968
652ec1ba 969 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
970};
971
972struct CYDeclarations :
cac61857 973 CYNext<CYDeclarations>,
96a7e5c2
JF
974 CYForInitialiser,
975 CYThing
cf7d4c69
JF
976{
977 CYDeclaration *declaration_;
cf7d4c69 978
cacd1a88 979 CYDeclarations(CYDeclaration *declaration, CYDeclarations *next = NULL) :
cac61857
JF
980 CYNext<CYDeclarations>(next),
981 declaration_(declaration)
982 {
983 }
984
652ec1ba 985 virtual void For(CYOutput &out) const;
96a7e5c2 986
3b52fd1a 987 void Replace(CYContext &context);
550ee46a 988 CYProperty *Property(CYContext &context);
3b52fd1a 989
96a7e5c2 990 virtual void Output(CYOutput &out) const;
652ec1ba 991 virtual void Output(CYOutput &out, CYFlags flags) const;
cac61857
JF
992};
993
994struct CYVar :
995 CYStatement
996{
997 CYDeclarations *declarations_;
998
999 CYVar(CYDeclarations *declarations) :
1000 declarations_(declarations)
1001 {
1002 }
1003
3b52fd1a 1004 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1005 virtual void Output(CYOutput &out, CYFlags flags) const;
cac61857
JF
1006};
1007
1008struct CYLet :
1009 CYStatement
1010{
1011 CYDeclarations *declarations_;
3b52fd1a 1012 CYBlock code_;
cac61857
JF
1013
1014 CYLet(CYDeclarations *declarations, CYStatement *statements) :
1015 declarations_(declarations),
3b52fd1a 1016 code_(statements)
cf7d4c69
JF
1017 {
1018 }
5999c315 1019
3b52fd1a 1020 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1021 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1022};
1023
cf7d4c69
JF
1024struct CYFor :
1025 CYStatement
1026{
1027 CYForInitialiser *initialiser_;
1028 CYExpression *test_;
1029 CYExpression *increment_;
1030 CYStatement *code_;
1031
1032 CYFor(CYForInitialiser *initialiser, CYExpression *test, CYExpression *increment, CYStatement *code) :
1033 initialiser_(initialiser),
1034 test_(test),
1035 increment_(increment),
1036 code_(code)
1037 {
1038 }
5999c315 1039
3b52fd1a 1040 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1041 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1042};
1043
1044struct CYForIn :
1045 CYStatement
1046{
1047 CYForInInitialiser *initialiser_;
1048 CYExpression *set_;
1049 CYStatement *code_;
1050
1051 CYForIn(CYForInInitialiser *initialiser, CYExpression *set, CYStatement *code) :
1052 initialiser_(initialiser),
1053 set_(set),
1054 code_(code)
1055 {
1056 }
5999c315 1057
3b52fd1a 1058 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1059 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1060};
1061
75b0a457
JF
1062struct CYForEachIn :
1063 CYStatement
1064{
1065 CYForInInitialiser *initialiser_;
1066 CYExpression *set_;
1067 CYStatement *code_;
1068
1069 CYForEachIn(CYForInInitialiser *initialiser, CYExpression *set, CYStatement *code) :
1070 initialiser_(initialiser),
1071 set_(set),
1072 code_(code)
1073 {
1074 }
1075
3b52fd1a 1076 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1077 virtual void Output(CYOutput &out, CYFlags flags) const;
75b0a457
JF
1078};
1079
693d501b
JF
1080struct CYObject :
1081 CYLiteral
1082{
3b52fd1a 1083 CYProperty *properties_;
693d501b 1084
3b52fd1a
JF
1085 CYObject(CYProperty *properties) :
1086 properties_(properties)
693d501b
JF
1087 {
1088 }
1089
3b52fd1a 1090 virtual CYExpression *Replace(CYContext &context);
652ec1ba 1091 void Output(CYOutput &out, CYFlags flags) const;
693d501b
JF
1092};
1093
cf7d4c69
JF
1094struct CYMember :
1095 CYExpression
1096{
1097 CYExpression *object_;
1098 CYExpression *property_;
1099
1100 CYMember(CYExpression *object, CYExpression *property) :
1101 object_(object),
1102 property_(property)
1103 {
1104 }
5999c315 1105
9b5527f0
JF
1106 void SetLeft(CYExpression *object) {
1107 object_ = object;
1108 }
3b52fd1a
JF
1109
1110 void Replace_(CYContext &context);
9b5527f0
JF
1111};
1112
1113struct CYDirectMember :
1114 CYMember
1115{
1116 CYDirectMember(CYExpression *object, CYExpression *property) :
1117 CYMember(object, property)
1118 {
1119 }
1120
1121 CYPrecedence(1)
fb98ac0c 1122 CYRightHand(false)
9b5527f0 1123
3b52fd1a 1124 virtual CYExpression *Replace(CYContext &context);
652ec1ba 1125 virtual void Output(CYOutput &out, CYFlags flags) const;
9b5527f0
JF
1126};
1127
1128struct CYIndirectMember :
1129 CYMember
1130{
1131 CYIndirectMember(CYExpression *object, CYExpression *property) :
1132 CYMember(object, property)
1133 {
1134 }
1135
d35a3b07 1136 CYPrecedence(1)
fb98ac0c 1137 CYRightHand(false)
d35a3b07 1138
3b52fd1a 1139 virtual CYExpression *Replace(CYContext &context);
652ec1ba 1140 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1141};
1142
1143struct CYNew :
1144 CYExpression
1145{
1146 CYExpression *constructor_;
1147 CYArgument *arguments_;
1148
1149 CYNew(CYExpression *constructor, CYArgument *arguments) :
1150 constructor_(constructor),
1151 arguments_(arguments)
1152 {
1153 }
5999c315 1154
fb98ac0c
JF
1155 virtual unsigned Precedence() const {
1156 return arguments_ == NULL ? 2 : 1;
1157 }
1158
1159 CYRightHand(false)
d35a3b07 1160
3b52fd1a 1161 virtual CYExpression *Replace(CYContext &context);
652ec1ba 1162 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1163};
1164
1165struct CYCall :
1166 CYExpression
1167{
1168 CYExpression *function_;
1169 CYArgument *arguments_;
1170
3b52fd1a 1171 CYCall(CYExpression *function, CYArgument *arguments = NULL) :
cf7d4c69
JF
1172 function_(function),
1173 arguments_(arguments)
1174 {
1175 }
5999c315 1176
fb98ac0c
JF
1177 CYPrecedence(1)
1178 CYRightHand(false)
d35a3b07 1179
3b52fd1a 1180 virtual CYExpression *Replace(CYContext &context);
652ec1ba 1181 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1182};
1183
1184struct CYIf :
1185 CYStatement
1186{
1187 CYExpression *test_;
1188 CYStatement *true_;
1189 CYStatement *false_;
1190
3b52fd1a 1191 CYIf(CYExpression *test, CYStatement *_true, CYStatement *_false = NULL) :
cf7d4c69
JF
1192 test_(test),
1193 true_(_true),
1194 false_(_false)
1195 {
1196 }
5999c315 1197
3b52fd1a 1198 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1199 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1200};
1201
1202struct CYDoWhile :
1203 CYStatement
1204{
1205 CYExpression *test_;
1206 CYStatement *code_;
1207
1208 CYDoWhile(CYExpression *test, CYStatement *code) :
1209 test_(test),
1210 code_(code)
1211 {
1212 }
5999c315 1213
3b52fd1a 1214 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1215 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1216};
1217
1218struct CYWhile :
1219 CYStatement
1220{
1221 CYExpression *test_;
1222 CYStatement *code_;
1223
1224 CYWhile(CYExpression *test, CYStatement *code) :
1225 test_(test),
1226 code_(code)
1227 {
1228 }
5999c315 1229
3b52fd1a 1230 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1231 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1232};
1233
fb98ac0c 1234struct CYFunction {
cf7d4c69 1235 CYIdentifier *name_;
b09da87b 1236 CYFunctionParameter *parameters_;
3b52fd1a 1237 CYBlock code_;
cf7d4c69 1238
3b52fd1a 1239 CYFunction(CYIdentifier *name, CYFunctionParameter *parameters, CYStatement *statements) :
cf7d4c69
JF
1240 name_(name),
1241 parameters_(parameters),
3b52fd1a 1242 code_(statements)
cf7d4c69
JF
1243 {
1244 }
5999c315 1245
3b52fd1a 1246 virtual void Replace_(CYContext &context);
fb98ac0c
JF
1247 virtual void Output(CYOutput &out, CYFlags flags) const;
1248};
1249
1250struct CYFunctionExpression :
1251 CYFunction,
1252 CYExpression
1253{
3b52fd1a
JF
1254 CYFunctionExpression(CYIdentifier *name, CYFunctionParameter *parameters, CYStatement *statements) :
1255 CYFunction(name, parameters, statements)
fb98ac0c
JF
1256 {
1257 }
1258
d35a3b07 1259 CYPrecedence(0)
fb98ac0c 1260 CYRightHand(false)
d35a3b07 1261
3b52fd1a 1262 virtual CYExpression *Replace(CYContext &context);
652ec1ba 1263 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1264};
1265
fb98ac0c
JF
1266struct CYFunctionStatement :
1267 CYFunction,
b10bd496 1268 CYStatement
cf7d4c69 1269{
3b52fd1a
JF
1270 CYFunctionStatement(CYIdentifier *name, CYFunctionParameter *parameters, CYStatement *statements) :
1271 CYFunction(name, parameters, statements)
cf7d4c69
JF
1272 {
1273 }
5999c315 1274
3b52fd1a 1275 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1276 virtual void Output(CYOutput &out, CYFlags flags) const;
5999c315
JF
1277};
1278
1279struct CYExpress :
1280 CYStatement
1281{
1282 CYExpression *expression_;
1283
1284 CYExpress(CYExpression *expression) :
1285 expression_(expression)
1286 {
1287 }
1288
3b52fd1a 1289 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1290 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1291};
1292
1293struct CYContinue :
1294 CYStatement
1295{
1296 CYIdentifier *label_;
1297
1298 CYContinue(CYIdentifier *label) :
1299 label_(label)
1300 {
1301 }
5999c315 1302
3b52fd1a 1303 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1304 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1305};
1306
1307struct CYBreak :
1308 CYStatement
1309{
1310 CYIdentifier *label_;
1311
1312 CYBreak(CYIdentifier *label) :
1313 label_(label)
1314 {
1315 }
5999c315 1316
3b52fd1a 1317 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1318 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1319};
1320
1321struct CYReturn :
1322 CYStatement
1323{
1324 CYExpression *value_;
1325
1326 CYReturn(CYExpression *value) :
1327 value_(value)
1328 {
1329 }
5999c315 1330
3b52fd1a 1331 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1332 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1333};
1334
1335struct CYEmpty :
1336 CYStatement
1337{
3b52fd1a 1338 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1339 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1340};
1341
96a7e5c2
JF
1342struct CYFinally :
1343 CYThing
1344{
3b52fd1a 1345 CYBlock code_;
b10bd496 1346
3b52fd1a
JF
1347 CYFinally(CYStatement *statements) :
1348 code_(statements)
b10bd496
JF
1349 {
1350 }
1351
3b52fd1a 1352 void Replace(CYContext &context);
b10bd496
JF
1353 virtual void Output(CYOutput &out) const;
1354};
1355
37954781
JF
1356namespace cy {
1357namespace Syntax {
1358
1359struct Catch :
1360 CYThing
1361{
1362 CYIdentifier *name_;
1363 CYBlock code_;
1364
1365 Catch(CYIdentifier *name, CYStatement *statements) :
1366 name_(name),
1367 code_(statements)
1368 {
1369 }
1370
1371 void Replace(CYContext &context);
1372 virtual void Output(CYOutput &out) const;
1373};
1374
1375struct Try :
cf7d4c69
JF
1376 CYStatement
1377{
3b52fd1a 1378 CYBlock code_;
37954781 1379 Catch *catch_;
b10bd496 1380 CYFinally *finally_;
cf7d4c69 1381
37954781 1382 Try(CYStatement *statements, Catch *_catch, CYFinally *finally) :
3b52fd1a 1383 code_(statements),
cf7d4c69
JF
1384 catch_(_catch),
1385 finally_(finally)
1386 {
1387 }
5999c315 1388
3b52fd1a 1389 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1390 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1391};
1392
37954781 1393struct Throw :
cf7d4c69
JF
1394 CYStatement
1395{
1396 CYExpression *value_;
1397
37954781 1398 Throw(CYExpression *value) :
cf7d4c69
JF
1399 value_(value)
1400 {
1401 }
5999c315 1402
3b52fd1a 1403 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1404 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1405};
1406
37954781
JF
1407} }
1408
cf7d4c69
JF
1409struct CYWith :
1410 CYStatement
1411{
1412 CYExpression *scope_;
1413 CYStatement *code_;
1414
1415 CYWith(CYExpression *scope, CYStatement *code) :
1416 scope_(scope),
1417 code_(code)
1418 {
1419 }
5999c315 1420
3b52fd1a 1421 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1422 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1423};
1424
1425struct CYSwitch :
1426 CYStatement
1427{
1428 CYExpression *value_;
1429 CYClause *clauses_;
1430
1431 CYSwitch(CYExpression *value, CYClause *clauses) :
1432 value_(value),
1433 clauses_(clauses)
1434 {
1435 }
5999c315 1436
3b52fd1a 1437 virtual CYStatement *Replace(CYContext &context);
fb98ac0c 1438 virtual void Output(CYOutput &out, CYFlags flags) const;
cf7d4c69
JF
1439};
1440
1441struct CYCondition :
1442 CYExpression
1443{
1444 CYExpression *test_;
1445 CYExpression *true_;
1446 CYExpression *false_;
1447
1448 CYCondition(CYExpression *test, CYExpression *_true, CYExpression *_false) :
91a416e4 1449 test_(test),
cf7d4c69
JF
1450 true_(_true),
1451 false_(_false)
1452 {
1453 }
5999c315 1454
d35a3b07
JF
1455 CYPrecedence(15)
1456
3b52fd1a 1457 virtual CYExpression *Replace(CYContext &context);
652ec1ba 1458 virtual void Output(CYOutput &out, CYFlags flags) const;
5999c315
JF
1459};
1460
1461struct CYAddressOf :
1462 CYPrefix
1463{
1464 CYAddressOf(CYExpression *rhs) :
1465 CYPrefix(rhs)
1466 {
1467 }
1468
1469 virtual const char *Operator() const {
1470 return "&";
1471 }
1472
b09da87b 1473 CYAlphabetic(false)
d35a3b07 1474
3b52fd1a 1475 virtual CYExpression *Replace(CYContext &context);
5999c315
JF
1476};
1477
1478struct CYIndirect :
1479 CYPrefix
1480{
1481 CYIndirect(CYExpression *rhs) :
1482 CYPrefix(rhs)
1483 {
1484 }
1485
1486 virtual const char *Operator() const {
561ac418 1487 return "*";
5999c315
JF
1488 }
1489
b09da87b 1490 CYAlphabetic(false)
d35a3b07 1491
3b52fd1a 1492 virtual CYExpression *Replace(CYContext &context);
cf7d4c69
JF
1493};
1494
4644480a
JF
1495#define CYReplace \
1496 virtual CYExpression *Replace(CYContext &context);
1497
1498#define CYPostfix_(op, name, args...) \
cf7d4c69
JF
1499 struct CY ## name : \
1500 CYPostfix \
4644480a 1501 { args \
cf7d4c69
JF
1502 CY ## name(CYExpression *lhs) : \
1503 CYPostfix(lhs) \
1504 { \
1505 } \
5999c315
JF
1506 \
1507 virtual const char *Operator() const { \
1508 return op; \
1509 } \
cf7d4c69
JF
1510 };
1511
4644480a 1512#define CYPrefix_(alphabetic, op, name, args...) \
cf7d4c69
JF
1513 struct CY ## name : \
1514 CYPrefix \
4644480a 1515 { args \
cf7d4c69
JF
1516 CY ## name(CYExpression *rhs) : \
1517 CYPrefix(rhs) \
1518 { \
1519 } \
d35a3b07 1520 \
b09da87b 1521 CYAlphabetic(alphabetic) \
5999c315
JF
1522 \
1523 virtual const char *Operator() const { \
1524 return op; \
1525 } \
cf7d4c69
JF
1526 };
1527
4644480a 1528#define CYInfix_(alphabetic, precedence, op, name, args...) \
cf7d4c69
JF
1529 struct CY ## name : \
1530 CYInfix \
4644480a 1531 { args \
cf7d4c69
JF
1532 CY ## name(CYExpression *lhs, CYExpression *rhs) : \
1533 CYInfix(lhs, rhs) \
1534 { \
1535 } \
d35a3b07 1536 \
b09da87b 1537 CYAlphabetic(alphabetic) \
d35a3b07 1538 CYPrecedence(precedence) \
5999c315
JF
1539 \
1540 virtual const char *Operator() const { \
1541 return op; \
1542 } \
cf7d4c69
JF
1543 };
1544
4644480a 1545#define CYAssignment_(op, name, args...) \
cf7d4c69
JF
1546 struct CY ## name ## Assign : \
1547 CYAssignment \
4644480a 1548 { args \
cf7d4c69
JF
1549 CY ## name ## Assign(CYExpression *lhs, CYExpression *rhs) : \
1550 CYAssignment(lhs, rhs) \
1551 { \
1552 } \
5999c315
JF
1553 \
1554 virtual const char *Operator() const { \
1555 return op; \
1556 } \
cf7d4c69
JF
1557 };
1558
1559CYPostfix_("++", PostIncrement)
1560CYPostfix_("--", PostDecrement)
1561
b09da87b
JF
1562CYPrefix_(true, "delete", Delete)
1563CYPrefix_(true, "void", Void)
1564CYPrefix_(true, "typeof", TypeOf)
1565CYPrefix_(false, "++", PreIncrement)
1566CYPrefix_(false, "--", PreDecrement)
c0bc320e 1567CYPrefix_(false, "+", Affirm)
b09da87b
JF
1568CYPrefix_(false, "-", Negate)
1569CYPrefix_(false, "~", BitwiseNot)
1570CYPrefix_(false, "!", LogicalNot)
1571
1572CYInfix_(false, 5, "*", Multiply)
1573CYInfix_(false, 5, "/", Divide)
1574CYInfix_(false, 5, "%", Modulus)
4644480a 1575CYInfix_(false, 6, "+", Add, CYReplace)
b09da87b
JF
1576CYInfix_(false, 6, "-", Subtract)
1577CYInfix_(false, 7, "<<", ShiftLeft)
1578CYInfix_(false, 7, ">>", ShiftRightSigned)
1579CYInfix_(false, 7, ">>>", ShiftRightUnsigned)
1580CYInfix_(false, 8, "<", Less)
1581CYInfix_(false, 8, ">", Greater)
1582CYInfix_(false, 8, "<=", LessOrEqual)
1583CYInfix_(false, 8, ">=", GreaterOrEqual)
1584CYInfix_(true, 8, "instanceof", InstanceOf)
1585CYInfix_(true, 8, "in", In)
1586CYInfix_(false, 9, "==", Equal)
1587CYInfix_(false, 9, "!=", NotEqual)
1588CYInfix_(false, 9, "===", Identical)
1589CYInfix_(false, 9, "!==", NotIdentical)
1590CYInfix_(false, 10, "&", BitwiseAnd)
1591CYInfix_(false, 11, "^", BitwiseXOr)
1592CYInfix_(false, 12, "|", BitwiseOr)
1593CYInfix_(false, 13, "&&", LogicalAnd)
1594CYInfix_(false, 14, "||", LogicalOr)
cf7d4c69
JF
1595
1596CYAssignment_("=", )
1597CYAssignment_("*=", Multiply)
1598CYAssignment_("/=", Divide)
1599CYAssignment_("%=", Modulus)
1600CYAssignment_("+=", Add)
1601CYAssignment_("-=", Subtract)
1602CYAssignment_("<<=", ShiftLeft)
1603CYAssignment_(">>=", ShiftRightSigned)
1604CYAssignment_(">>>=", ShiftRightUnsigned)
1605CYAssignment_("&=", BitwiseAnd)
1606CYAssignment_("^=", BitwiseXOr)
1607CYAssignment_("|=", BitwiseOr)
1608
63b4c5a8 1609#endif/*CYPARSER_HPP*/