1 /* Cycript - Remove Execution Server and Disassembler
2 * Copyright (C) 2009 Jay Freeman (saurik)
5 /* Modified BSD License {{{ */
7 * Redistribution and use in source and binary
8 * forms, with or without modification, are permitted
9 * provided that the following conditions are met:
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
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.
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.
47 #include "location.hh"
48 #include "Pooling.hpp"
50 template <typename Type_>
64 void SetNext(Type_ *next) {
70 virtual void Output(std::ostream &out) const = 0;
73 _finline std::ostream &operator <<(std::ostream &out, const CYThing &rhs) {
81 virtual void Show(std::ostream &out) const;
82 virtual void Output(std::ostream &out) const = 0;
83 virtual void Output(std::ostream &out, bool block) const;
89 virtual const char *Name() const = 0;
97 CYWord(const char *word) :
102 const char *Value() const {
106 virtual const char *Name() const {
110 virtual void Output(std::ostream &out) const;
113 struct CYIdentifier :
116 CYIdentifier(const char *word) :
125 CYIdentifier *identifier_;
127 CYLabel(CYIdentifier *identifier, CYLabel *next) :
128 CYNext<CYLabel>(next),
129 identifier_(identifier)
139 void AddLabel(CYIdentifier *identifier) {
140 label_ = new CYLabel(identifier, label_);
160 std::string filename_;
163 cy::location location_;
164 std::string message_;
167 typedef std::vector<Error> Errors;
174 void ScannerDestroy();
177 CYDriver(const std::string &filename);
182 virtual void Part(std::ostream &out) const = 0;
185 struct CYForInitialiser :
190 struct CYForInInitialiser :
197 CYNoBrace = (1 << 0),
198 CYNoFunction = (1 << 1),
199 CYNoLeader = (1 << 2),
200 CYNoTrailer = (1 << 3),
204 struct CYExpression :
205 CYNext<CYExpression>,
209 virtual unsigned Precedence() const = 0;
210 virtual void Part(std::ostream &out) const;
211 virtual void Output(std::ostream &out, CYFlags flags) const = 0;
212 void Output(std::ostream &out, unsigned precedence, CYFlags flags) const;
214 virtual const char *Word() const {
219 #define CYAlphabetic(value) \
220 virtual bool Alphabetic() const { \
224 #define CYPrecedence(value) \
225 virtual unsigned Precedence() const { \
232 CYExpression *expressions_;
234 CYCompound(CYExpression *expressions) :
235 expressions_(expressions)
239 void AddPrev(CYExpression *expression) {
240 CYExpression *last(expression);
241 while (last->next_ != NULL)
243 last->SetNext(expressions_);
244 expressions_ = expression;
249 void Output(std::ostream &out, CYFlags flags) const;
264 struct CYSelectorPart :
265 CYNext<CYSelectorPart>
270 CYSelectorPart(CYWord *name, bool value, CYSelectorPart *next) :
271 CYNext<CYSelectorPart>(next),
277 virtual void Output(std::ostream &out) const;
283 CYSelectorPart *name_;
285 CYSelector(CYSelectorPart *name) :
292 virtual void Output(std::ostream &out, CYFlags flags) const;
299 CYRange(uint64_t lo, uint64_t hi) :
304 bool operator [](uint8_t value) const {
305 return !(value >> 7) && (value >> 6 ? hi_ : lo_) >> (value & 0x3f) & 0x1;
308 void operator()(uint8_t value) {
311 (value >> 6 ? hi_ : lo_) |= uint64_t(0x1) << (value & 0x3f);
315 extern CYRange WordStartRange_;
316 extern CYRange WordEndRange_;
325 CYString(const char *value, size_t size) :
331 CYString(const CYIdentifier *identifier) :
332 value_(identifier->Value()),
333 size_(strlen(value_))
337 const char *Value() const {
341 virtual const char *Name() const {
345 virtual const char *Word() const {
346 if (size_ == 0 || !WordStartRange_[value_[0]])
348 for (size_t i(1); i != size_; ++i)
349 if (!WordEndRange_[value_[i]])
354 virtual void Output(std::ostream &out) const {
355 return Output(out, CYNoFlags);
358 virtual void Output(std::ostream &out, CYFlags flags) const;
367 CYNumber(double value) :
372 double Value() const {
376 virtual const char *Name() const {
380 virtual void Output(std::ostream &out) const {
381 return Output(out, CYNoFlags);
384 virtual void Output(std::ostream &out, CYFlags flags) const;
396 virtual void Output(std::ostream &out, CYFlags flags) const;
408 virtual void Output(std::ostream &out, CYFlags flags) const;
414 virtual bool Value() const = 0;
415 virtual void Output(std::ostream &out, CYFlags flags) const;
427 virtual bool Value() const;
439 virtual bool Value() const;
447 CYVariable(CYIdentifier *name) :
454 virtual void Output(std::ostream &out, CYFlags flags) const;
462 CYPrefix(CYExpression *rhs) :
467 virtual bool Alphabetic() const = 0;
468 virtual const char *Operator() const = 0;
470 virtual void Output(std::ostream &out, CYFlags flags) const;
479 CYInfix(CYExpression *lhs, CYExpression *rhs) :
485 virtual bool Alphabetic() const = 0;
486 virtual const char *Operator() const = 0;
488 virtual void Output(std::ostream &out, CYFlags flags) const;
496 CYPostfix(CYExpression *lhs) :
501 virtual const char *Operator() const = 0;
503 virtual void Output(std::ostream &out, CYFlags flags) const;
506 struct CYAssignment :
512 CYAssignment(CYExpression *lhs, CYExpression *rhs) :
518 virtual const char *Operator() const = 0;
520 virtual void Output(std::ostream &out, CYFlags flags) const;
527 CYExpression *value_;
529 CYArgument(CYWord *name, CYExpression *value, CYArgument *next = NULL) :
530 CYNext<CYArgument>(next),
536 void Output(std::ostream &out) const;
555 CYClause(CYExpression *_case, CYStatement *code) :
561 virtual void Output(std::ostream &out) const;
567 CYExpression *value_;
569 CYElement(CYExpression *value, CYElement *next) :
570 CYNext<CYElement>(next),
575 void Output(std::ostream &out) const;
581 CYElement *elements_;
583 CYArray(CYElement *elements) :
588 virtual void Output(std::ostream &out, CYFlags flags) const;
591 struct CYDeclaration :
595 CYIdentifier *identifier_;
596 CYExpression *initialiser_;
598 CYDeclaration(CYIdentifier *identifier, CYExpression *initialiser) :
599 identifier_(identifier),
600 initialiser_(initialiser)
604 virtual void Part(std::ostream &out) const;
605 virtual void Output(std::ostream &out) const;
608 struct CYDeclarations :
612 CYDeclaration *declaration_;
613 CYDeclarations *next_;
615 CYDeclarations(CYDeclaration *declaration, CYDeclarations *next) :
616 declaration_(declaration),
621 virtual void Part(std::ostream &out) const;
622 virtual void Output(std::ostream &out) const;
628 virtual void Output(std::ostream &out) const;
631 struct CYMessageParameter :
632 CYNext<CYMessageParameter>
638 CYMessageParameter(CYWord *tag, CYExpression *type, CYIdentifier *name) :
651 CYMessageParameter *parameter_;
654 CYMessage(bool instance, CYExpression *type, CYMessageParameter *parameter, CYSource *body) :
657 parameter_(parameter),
662 virtual void Output(std::ostream &out) const;
669 CYExpression *super_;
671 CYMessage *messages_;
673 CYClass(CYIdentifier *name, CYExpression *super, CYField *fields, CYMessage *messages) :
681 virtual void Output(std::ostream &out) const;
684 struct CYFunctionParameter :
685 CYNext<CYFunctionParameter>,
690 CYFunctionParameter(CYIdentifier *name, CYFunctionParameter *next) :
691 CYNext<CYFunctionParameter>(next),
696 virtual void Output(std::ostream &out) const;
702 CYForInitialiser *initialiser_;
704 CYExpression *increment_;
707 CYFor(CYForInitialiser *initialiser, CYExpression *test, CYExpression *increment, CYStatement *code) :
708 initialiser_(initialiser),
710 increment_(increment),
715 virtual void Output(std::ostream &out) const;
721 CYForInInitialiser *initialiser_;
725 CYForIn(CYForInInitialiser *initialiser, CYExpression *set, CYStatement *code) :
726 initialiser_(initialiser),
732 virtual void Output(std::ostream &out) const;
739 CYExpression *value_;
741 CYProperty(CYName *name, CYExpression *value, CYProperty *next) :
742 CYNext<CYProperty>(next),
748 virtual void Output(std::ostream &out) const;
754 CYProperty *property_;
756 CYObject(CYProperty *property) :
761 void Output(std::ostream &out, CYFlags flags) const;
770 CYCatch(CYIdentifier *name, CYStatement *code) :
776 virtual void Output(std::ostream &out) const;
783 CYArgument *arguments_;
785 CYSend(CYExpression *self, CYArgument *arguments) :
787 arguments_(arguments)
793 virtual void Output(std::ostream &out, CYFlags flags) const;
799 CYExpression *object_;
800 CYExpression *property_;
802 CYMember(CYExpression *object, CYExpression *property) :
810 virtual void Output(std::ostream &out, CYFlags flags) const;
816 CYExpression *constructor_;
817 CYArgument *arguments_;
819 CYNew(CYExpression *constructor, CYArgument *arguments) :
820 constructor_(constructor),
821 arguments_(arguments)
827 virtual void Output(std::ostream &out, CYFlags flags) const;
833 CYExpression *function_;
834 CYArgument *arguments_;
836 CYCall(CYExpression *function, CYArgument *arguments) :
838 arguments_(arguments)
844 virtual void Output(std::ostream &out, CYFlags flags) const;
854 CYIf(CYExpression *test, CYStatement *_true, CYStatement *_false) :
861 virtual void Output(std::ostream &out) const;
870 CYDoWhile(CYExpression *test, CYStatement *code) :
876 virtual void Output(std::ostream &out) const;
885 CYWhile(CYExpression *test, CYStatement *code) :
891 virtual void Output(std::ostream &out) const;
898 CYFunctionParameter *parameters_;
901 CYLambda(CYIdentifier *name, CYFunctionParameter *parameters, CYSource *body) :
903 parameters_(parameters),
910 virtual void Output(std::ostream &out, CYFlags flags) const;
917 CYFunction(CYIdentifier *name, CYFunctionParameter *parameters, CYSource *body) :
918 CYLambda(name, parameters, body)
922 virtual void Output(std::ostream &out) const;
928 CYExpression *expression_;
930 CYExpress(CYExpression *expression) :
931 expression_(expression)
935 virtual void Output(std::ostream &out) const;
941 CYIdentifier *label_;
943 CYContinue(CYIdentifier *label) :
948 virtual void Output(std::ostream &out) const;
954 CYIdentifier *label_;
956 CYBreak(CYIdentifier *label) :
961 virtual void Output(std::ostream &out) const;
967 CYExpression *value_;
969 CYReturn(CYExpression *value) :
974 virtual void Output(std::ostream &out) const;
980 virtual void Output(std::ostream &out) const;
981 virtual void Output(std::ostream &out, bool block) const;
989 CYStatement *finally_;
991 CYTry(CYStatement *_try, CYCatch *_catch, CYStatement *finally) :
998 virtual void Output(std::ostream &out) const;
1004 CYExpression *value_;
1006 CYThrow(CYExpression *value) :
1011 virtual void Output(std::ostream &out) const;
1017 CYExpression *scope_;
1020 CYWith(CYExpression *scope, CYStatement *code) :
1026 virtual void Output(std::ostream &out) const;
1032 CYExpression *value_;
1035 CYSwitch(CYExpression *value, CYClause *clauses) :
1041 virtual void Output(std::ostream &out) const;
1044 struct CYCondition :
1047 CYExpression *test_;
1048 CYExpression *true_;
1049 CYExpression *false_;
1051 CYCondition(CYExpression *test, CYExpression *_true, CYExpression *_false) :
1060 virtual void Output(std::ostream &out, CYFlags flags) const;
1063 struct CYAddressOf :
1066 CYAddressOf(CYExpression *rhs) :
1071 virtual const char *Operator() const {
1078 virtual void Output(std::ostream &out, CYFlags flags) const;
1084 CYIndirect(CYExpression *rhs) :
1089 virtual const char *Operator() const {
1096 virtual void Output(std::ostream &out, CYFlags flags) const;
1099 #define CYPostfix_(op, name) \
1100 struct CY ## name : \
1103 CY ## name(CYExpression *lhs) : \
1110 virtual const char *Operator() const { \
1115 #define CYPrefix_(alphabetic, op, name) \
1116 struct CY ## name : \
1119 CY ## name(CYExpression *rhs) : \
1124 CYAlphabetic(alphabetic) \
1127 virtual const char *Operator() const { \
1132 #define CYInfix_(alphabetic, precedence, op, name) \
1133 struct CY ## name : \
1136 CY ## name(CYExpression *lhs, CYExpression *rhs) : \
1141 CYAlphabetic(alphabetic) \
1142 CYPrecedence(precedence) \
1144 virtual const char *Operator() const { \
1149 #define CYAssignment_(op, name) \
1150 struct CY ## name ## Assign : \
1153 CY ## name ## Assign(CYExpression *lhs, CYExpression *rhs) : \
1154 CYAssignment(lhs, rhs) \
1160 virtual const char *Operator() const { \
1165 CYPostfix_("++", PostIncrement)
1166 CYPostfix_("--", PostDecrement)
1168 CYPrefix_(true, "delete", Delete)
1169 CYPrefix_(true, "void", Void)
1170 CYPrefix_(true, "typeof", TypeOf)
1171 CYPrefix_(false, "++", PreIncrement)
1172 CYPrefix_(false, "--", PreDecrement)
1173 CYPrefix_(false, "-", Negate)
1174 CYPrefix_(false, "~", BitwiseNot)
1175 CYPrefix_(false, "!", LogicalNot)
1177 CYInfix_(false, 5, "*", Multiply)
1178 CYInfix_(false, 5, "/", Divide)
1179 CYInfix_(false, 5, "%", Modulus)
1180 CYInfix_(false, 6, "+", Add)
1181 CYInfix_(false, 6, "-", Subtract)
1182 CYInfix_(false, 7, "<<", ShiftLeft)
1183 CYInfix_(false, 7, ">>", ShiftRightSigned)
1184 CYInfix_(false, 7, ">>>", ShiftRightUnsigned)
1185 CYInfix_(false, 8, "<", Less)
1186 CYInfix_(false, 8, ">", Greater)
1187 CYInfix_(false, 8, "<=", LessOrEqual)
1188 CYInfix_(false, 8, ">=", GreaterOrEqual)
1189 CYInfix_(true, 8, "instanceof", InstanceOf)
1190 CYInfix_(true, 8, "in", In)
1191 CYInfix_(false, 9, "==", Equal)
1192 CYInfix_(false, 9, "!=", NotEqual)
1193 CYInfix_(false, 9, "===", Identical)
1194 CYInfix_(false, 9, "!==", NotIdentical)
1195 CYInfix_(false, 10, "&", BitwiseAnd)
1196 CYInfix_(false, 11, "^", BitwiseXOr)
1197 CYInfix_(false, 12, "|", BitwiseOr)
1198 CYInfix_(false, 13, "&&", LogicalAnd)
1199 CYInfix_(false, 14, "||", LogicalOr)
1201 CYAssignment_("=", )
1202 CYAssignment_("*=", Multiply)
1203 CYAssignment_("/=", Divide)
1204 CYAssignment_("%=", Modulus)
1205 CYAssignment_("+=", Add)
1206 CYAssignment_("-=", Subtract)
1207 CYAssignment_("<<=", ShiftLeft)
1208 CYAssignment_(">>=", ShiftRightSigned)
1209 CYAssignment_(">>>=", ShiftRightUnsigned)
1210 CYAssignment_("&=", BitwiseAnd)
1211 CYAssignment_("^=", BitwiseXOr)
1212 CYAssignment_("|=", BitwiseOr)
1214 #endif/*CYPARSER_HPP*/