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;
86 struct CYPropertyName {
87 virtual void PropertyName(std::ostream &out) const = 0;
91 virtual void ClassName(std::ostream &out) const = 0;
101 CYWord(const char *word) :
106 const char *Value() const {
110 virtual void Output(std::ostream &out) const;
112 virtual void ClassName(std::ostream &out) const;
113 virtual void PropertyName(std::ostream &out) const;
116 struct CYIdentifier :
119 CYIdentifier(const char *word) :
128 CYIdentifier *identifier_;
130 CYLabel(CYIdentifier *identifier, CYLabel *next) :
131 CYNext<CYLabel>(next),
132 identifier_(identifier)
142 void AddLabel(CYIdentifier *identifier) {
143 label_ = new CYLabel(identifier, label_);
163 std::string filename_;
166 cy::location location_;
167 std::string message_;
170 typedef std::vector<Error> Errors;
177 void ScannerDestroy();
180 CYDriver(const std::string &filename);
185 virtual void Part(std::ostream &out) const = 0;
188 struct CYForInitialiser :
193 struct CYForInInitialiser :
200 CYNoBrace = (1 << 0),
201 CYNoFunction = (1 << 1),
202 CYNoLeader = (1 << 2),
203 CYNoTrailer = (1 << 3),
207 struct CYExpression :
208 CYNext<CYExpression>,
213 virtual unsigned Precedence() const = 0;
214 virtual void Part(std::ostream &out) const;
215 virtual void Output(std::ostream &out, CYFlags flags) const = 0;
216 void Output(std::ostream &out, unsigned precedence, CYFlags flags) const;
218 virtual void ClassName(std::ostream &out) const;
220 virtual const char *Word() const {
225 #define CYAlphabetic(value) \
226 virtual bool Alphabetic() const { \
230 #define CYPrecedence(value) \
231 virtual unsigned Precedence() const { \
238 CYExpression *expressions_;
240 CYCompound(CYExpression *expressions) :
241 expressions_(expressions)
245 void AddPrev(CYExpression *expression) {
246 CYExpression *last(expression);
247 while (last->next_ != NULL)
249 last->SetNext(expressions_);
250 expressions_ = expression;
255 void Output(std::ostream &out, CYFlags flags) const;
270 struct CYSelectorPart :
271 CYNext<CYSelectorPart>
276 CYSelectorPart(CYWord *name, bool value, CYSelectorPart *next) :
277 CYNext<CYSelectorPart>(next),
283 virtual void Output(std::ostream &out) const;
289 CYSelectorPart *name_;
291 CYSelector(CYSelectorPart *name) :
298 virtual void Output(std::ostream &out, CYFlags flags) const;
305 CYRange(uint64_t lo, uint64_t hi) :
310 bool operator [](uint8_t value) const {
311 return !(value >> 7) && (value >> 6 ? hi_ : lo_) >> (value & 0x3f) & 0x1;
314 void operator()(uint8_t value) {
317 (value >> 6 ? hi_ : lo_) |= uint64_t(0x1) << (value & 0x3f);
321 extern CYRange DigitRange_;
322 extern CYRange WordStartRange_;
323 extern CYRange WordEndRange_;
332 CYString(const char *value, size_t size) :
338 CYString(const CYIdentifier *identifier) :
339 value_(identifier->Value()),
340 size_(strlen(value_))
344 const char *Value() const {
348 virtual const char *Word() const {
349 if (size_ == 0 || !WordStartRange_[value_[0]])
351 for (size_t i(1); i != size_; ++i)
352 if (!WordEndRange_[value_[i]])
357 virtual void Output(std::ostream &out) const {
358 return Output(out, CYNoFlags);
361 virtual void Output(std::ostream &out, CYFlags flags) const;
362 virtual void PropertyName(std::ostream &out) const;
371 CYNumber(double value) :
376 double Value() const {
380 virtual void Output(std::ostream &out) const {
381 return Output(out, CYNoFlags);
384 virtual void Output(std::ostream &out, CYFlags flags) const;
385 virtual void PropertyName(std::ostream &out) const;
397 virtual void Output(std::ostream &out, CYFlags flags) const;
409 virtual void Output(std::ostream &out, CYFlags flags) const;
415 virtual bool Value() const = 0;
416 virtual void Output(std::ostream &out, CYFlags flags) const;
428 virtual bool Value() const;
440 virtual bool Value() const;
448 CYVariable(CYIdentifier *name) :
455 virtual void Output(std::ostream &out, CYFlags flags) const;
463 CYPrefix(CYExpression *rhs) :
468 virtual bool Alphabetic() const = 0;
469 virtual const char *Operator() const = 0;
471 virtual void Output(std::ostream &out, CYFlags flags) const;
480 CYInfix(CYExpression *lhs, CYExpression *rhs) :
486 virtual bool Alphabetic() const = 0;
487 virtual const char *Operator() const = 0;
489 virtual void Output(std::ostream &out, CYFlags flags) const;
497 CYPostfix(CYExpression *lhs) :
502 virtual const char *Operator() const = 0;
504 virtual void Output(std::ostream &out, CYFlags flags) const;
507 struct CYAssignment :
513 CYAssignment(CYExpression *lhs, CYExpression *rhs) :
519 virtual const char *Operator() const = 0;
521 virtual void Output(std::ostream &out, CYFlags flags) const;
528 CYExpression *value_;
530 CYArgument(CYWord *name, CYExpression *value, CYArgument *next = NULL) :
531 CYNext<CYArgument>(next),
537 void Output(std::ostream &out) const;
556 CYClause(CYExpression *_case, CYStatement *code) :
562 virtual void Output(std::ostream &out) const;
568 CYExpression *value_;
570 CYElement(CYExpression *value, CYElement *next) :
571 CYNext<CYElement>(next),
576 void Output(std::ostream &out) const;
582 CYElement *elements_;
584 CYArray(CYElement *elements) :
589 virtual void Output(std::ostream &out, CYFlags flags) const;
592 struct CYDeclaration :
596 CYIdentifier *identifier_;
597 CYExpression *initialiser_;
599 CYDeclaration(CYIdentifier *identifier, CYExpression *initialiser) :
600 identifier_(identifier),
601 initialiser_(initialiser)
605 virtual void Part(std::ostream &out) const;
606 virtual void Output(std::ostream &out) const;
609 struct CYDeclarations :
613 CYDeclaration *declaration_;
614 CYDeclarations *next_;
616 CYDeclarations(CYDeclaration *declaration, CYDeclarations *next) :
617 declaration_(declaration),
622 virtual void Part(std::ostream &out) const;
623 virtual void Output(std::ostream &out) const;
629 virtual void Output(std::ostream &out) const;
632 struct CYMessageParameter :
633 CYNext<CYMessageParameter>
639 CYMessageParameter(CYWord *tag, CYExpression *type, CYIdentifier *name) :
652 CYMessageParameter *parameter_;
655 CYMessage(bool instance, CYExpression *type, CYMessageParameter *parameter, CYSource *body) :
658 parameter_(parameter),
663 virtual void Output(std::ostream &out, bool replace) const;
670 CYExpression *super_;
672 CYMessage *messages_;
674 CYClass(CYIdentifier *name, CYExpression *super, CYField *fields, CYMessage *messages) :
682 virtual void Output(std::ostream &out) const;
689 CYMessage *messages_;
691 CYCategory(CYClassName *name, CYMessage *messages) :
697 virtual void Output(std::ostream &out) const;
700 struct CYFunctionParameter :
701 CYNext<CYFunctionParameter>,
706 CYFunctionParameter(CYIdentifier *name, CYFunctionParameter *next) :
707 CYNext<CYFunctionParameter>(next),
712 virtual void Output(std::ostream &out) const;
718 CYForInitialiser *initialiser_;
720 CYExpression *increment_;
723 CYFor(CYForInitialiser *initialiser, CYExpression *test, CYExpression *increment, CYStatement *code) :
724 initialiser_(initialiser),
726 increment_(increment),
731 virtual void Output(std::ostream &out) const;
737 CYForInInitialiser *initialiser_;
741 CYForIn(CYForInInitialiser *initialiser, CYExpression *set, CYStatement *code) :
742 initialiser_(initialiser),
748 virtual void Output(std::ostream &out) const;
754 CYPropertyName *name_;
755 CYExpression *value_;
757 CYProperty(CYPropertyName *name, CYExpression *value, CYProperty *next) :
758 CYNext<CYProperty>(next),
764 virtual void Output(std::ostream &out) const;
770 CYProperty *property_;
772 CYObject(CYProperty *property) :
777 void Output(std::ostream &out, CYFlags flags) const;
786 CYCatch(CYIdentifier *name, CYStatement *code) :
792 virtual void Output(std::ostream &out) const;
799 CYArgument *arguments_;
801 CYSend(CYExpression *self, CYArgument *arguments) :
803 arguments_(arguments)
809 virtual void Output(std::ostream &out, CYFlags flags) const;
815 CYExpression *object_;
816 CYExpression *property_;
818 CYMember(CYExpression *object, CYExpression *property) :
826 virtual void Output(std::ostream &out, CYFlags flags) const;
832 CYExpression *constructor_;
833 CYArgument *arguments_;
835 CYNew(CYExpression *constructor, CYArgument *arguments) :
836 constructor_(constructor),
837 arguments_(arguments)
843 virtual void Output(std::ostream &out, CYFlags flags) const;
849 CYExpression *function_;
850 CYArgument *arguments_;
852 CYCall(CYExpression *function, CYArgument *arguments) :
854 arguments_(arguments)
860 virtual void Output(std::ostream &out, CYFlags flags) const;
870 CYIf(CYExpression *test, CYStatement *_true, CYStatement *_false) :
877 virtual void Output(std::ostream &out) const;
886 CYDoWhile(CYExpression *test, CYStatement *code) :
892 virtual void Output(std::ostream &out) const;
901 CYWhile(CYExpression *test, CYStatement *code) :
907 virtual void Output(std::ostream &out) const;
914 CYFunctionParameter *parameters_;
917 CYLambda(CYIdentifier *name, CYFunctionParameter *parameters, CYSource *body) :
919 parameters_(parameters),
926 virtual void Output(std::ostream &out, CYFlags flags) const;
933 CYFunction(CYIdentifier *name, CYFunctionParameter *parameters, CYSource *body) :
934 CYLambda(name, parameters, body)
938 virtual void Output(std::ostream &out) const;
944 CYExpression *expression_;
946 CYExpress(CYExpression *expression) :
947 expression_(expression)
951 virtual void Output(std::ostream &out) const;
957 CYIdentifier *label_;
959 CYContinue(CYIdentifier *label) :
964 virtual void Output(std::ostream &out) const;
970 CYIdentifier *label_;
972 CYBreak(CYIdentifier *label) :
977 virtual void Output(std::ostream &out) const;
983 CYExpression *value_;
985 CYReturn(CYExpression *value) :
990 virtual void Output(std::ostream &out) const;
996 virtual void Output(std::ostream &out) const;
997 virtual void Output(std::ostream &out, bool block) const;
1005 CYStatement *finally_;
1007 CYTry(CYStatement *_try, CYCatch *_catch, CYStatement *finally) :
1014 virtual void Output(std::ostream &out) const;
1020 CYExpression *value_;
1022 CYThrow(CYExpression *value) :
1027 virtual void Output(std::ostream &out) const;
1033 CYExpression *scope_;
1036 CYWith(CYExpression *scope, CYStatement *code) :
1042 virtual void Output(std::ostream &out) const;
1048 CYExpression *value_;
1051 CYSwitch(CYExpression *value, CYClause *clauses) :
1057 virtual void Output(std::ostream &out) const;
1060 struct CYCondition :
1063 CYExpression *test_;
1064 CYExpression *true_;
1065 CYExpression *false_;
1067 CYCondition(CYExpression *test, CYExpression *_true, CYExpression *_false) :
1076 virtual void Output(std::ostream &out, CYFlags flags) const;
1079 struct CYAddressOf :
1082 CYAddressOf(CYExpression *rhs) :
1087 virtual const char *Operator() const {
1094 virtual void Output(std::ostream &out, CYFlags flags) const;
1100 CYIndirect(CYExpression *rhs) :
1105 virtual const char *Operator() const {
1112 virtual void Output(std::ostream &out, CYFlags flags) const;
1115 #define CYPostfix_(op, name) \
1116 struct CY ## name : \
1119 CY ## name(CYExpression *lhs) : \
1126 virtual const char *Operator() const { \
1131 #define CYPrefix_(alphabetic, op, name) \
1132 struct CY ## name : \
1135 CY ## name(CYExpression *rhs) : \
1140 CYAlphabetic(alphabetic) \
1143 virtual const char *Operator() const { \
1148 #define CYInfix_(alphabetic, precedence, op, name) \
1149 struct CY ## name : \
1152 CY ## name(CYExpression *lhs, CYExpression *rhs) : \
1157 CYAlphabetic(alphabetic) \
1158 CYPrecedence(precedence) \
1160 virtual const char *Operator() const { \
1165 #define CYAssignment_(op, name) \
1166 struct CY ## name ## Assign : \
1169 CY ## name ## Assign(CYExpression *lhs, CYExpression *rhs) : \
1170 CYAssignment(lhs, rhs) \
1176 virtual const char *Operator() const { \
1181 CYPostfix_("++", PostIncrement)
1182 CYPostfix_("--", PostDecrement)
1184 CYPrefix_(true, "delete", Delete)
1185 CYPrefix_(true, "void", Void)
1186 CYPrefix_(true, "typeof", TypeOf)
1187 CYPrefix_(false, "++", PreIncrement)
1188 CYPrefix_(false, "--", PreDecrement)
1189 CYPrefix_(false, "-", Negate)
1190 CYPrefix_(false, "~", BitwiseNot)
1191 CYPrefix_(false, "!", LogicalNot)
1193 CYInfix_(false, 5, "*", Multiply)
1194 CYInfix_(false, 5, "/", Divide)
1195 CYInfix_(false, 5, "%", Modulus)
1196 CYInfix_(false, 6, "+", Add)
1197 CYInfix_(false, 6, "-", Subtract)
1198 CYInfix_(false, 7, "<<", ShiftLeft)
1199 CYInfix_(false, 7, ">>", ShiftRightSigned)
1200 CYInfix_(false, 7, ">>>", ShiftRightUnsigned)
1201 CYInfix_(false, 8, "<", Less)
1202 CYInfix_(false, 8, ">", Greater)
1203 CYInfix_(false, 8, "<=", LessOrEqual)
1204 CYInfix_(false, 8, ">=", GreaterOrEqual)
1205 CYInfix_(true, 8, "instanceof", InstanceOf)
1206 CYInfix_(true, 8, "in", In)
1207 CYInfix_(false, 9, "==", Equal)
1208 CYInfix_(false, 9, "!=", NotEqual)
1209 CYInfix_(false, 9, "===", Identical)
1210 CYInfix_(false, 9, "!==", NotIdentical)
1211 CYInfix_(false, 10, "&", BitwiseAnd)
1212 CYInfix_(false, 11, "^", BitwiseXOr)
1213 CYInfix_(false, 12, "|", BitwiseOr)
1214 CYInfix_(false, 13, "&&", LogicalAnd)
1215 CYInfix_(false, 14, "||", LogicalOr)
1217 CYAssignment_("=", )
1218 CYAssignment_("*=", Multiply)
1219 CYAssignment_("/=", Divide)
1220 CYAssignment_("%=", Modulus)
1221 CYAssignment_("+=", Add)
1222 CYAssignment_("-=", Subtract)
1223 CYAssignment_("<<=", ShiftLeft)
1224 CYAssignment_(">>=", ShiftRightSigned)
1225 CYAssignment_(">>>=", ShiftRightUnsigned)
1226 CYAssignment_("&=", BitwiseAnd)
1227 CYAssignment_("^=", BitwiseXOr)
1228 CYAssignment_("|=", BitwiseOr)
1230 #endif/*CYPARSER_HPP*/