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 bool IsBlock() const {
85 virtual void Show(std::ostream &out) const;
86 virtual void Output(std::ostream &out) const = 0;
87 virtual void Output(std::ostream &out, bool block) const;
88 virtual void Output_(std::ostream &out) const;
91 struct CYPropertyName {
92 virtual void PropertyName(std::ostream &out) const = 0;
96 virtual void ClassName(std::ostream &out, bool object) const = 0;
106 CYWord(const char *word) :
111 const char *Value() const {
115 virtual void Output(std::ostream &out) const;
117 virtual void ClassName(std::ostream &out, bool object) const;
118 virtual void PropertyName(std::ostream &out) const;
121 struct CYIdentifier :
124 CYIdentifier(const char *word) :
135 CYLabel(CYIdentifier *name, CYLabel *next) :
136 CYNext<CYLabel>(next),
152 void AddLabel(CYIdentifier *identifier) {
153 labels_ = new CYLabel(identifier, labels_);
156 virtual void Output_(std::ostream &out) const;
162 CYStatement *statements_;
164 CYBlock(CYStatement *statements) :
165 statements_(statements)
169 virtual bool IsBlock() const {
173 virtual void Output(std::ostream &out) const;
193 std::string filename_;
196 cy::location location_;
197 std::string message_;
200 typedef std::vector<Error> Errors;
207 void ScannerDestroy();
210 CYDriver(const std::string &filename);
215 virtual void Part(std::ostream &out) const = 0;
218 struct CYForInitialiser :
223 struct CYForInInitialiser :
230 CYNoBrace = (1 << 0),
231 CYNoFunction = (1 << 1),
232 CYNoLeader = (1 << 2),
233 CYNoTrailer = (1 << 3),
235 CYNoHyphen = (1 << 5),
236 CYNoBF = (CYNoBrace | CYNoFunction),
239 struct CYExpression :
240 CYNext<CYExpression>,
245 virtual unsigned Precedence() const = 0;
246 virtual void Part(std::ostream &out) const;
247 virtual void Output(std::ostream &out, CYFlags flags) const = 0;
248 void Output(std::ostream &out, unsigned precedence, CYFlags flags) const;
250 virtual void ClassName(std::ostream &out, bool object) const;
252 virtual const char *Word() const {
257 #define CYAlphabetic(value) \
258 virtual bool Alphabetic() const { \
262 #define CYPrecedence(value) \
263 virtual unsigned Precedence() const { \
270 CYExpression *expressions_;
272 CYCompound(CYExpression *expressions) :
273 expressions_(expressions)
277 void AddPrev(CYExpression *expression) {
278 CYExpression *last(expression);
279 while (last->next_ != NULL)
281 last->SetNext(expressions_);
282 expressions_ = expression;
287 void Output(std::ostream &out, CYFlags flags) const;
302 struct CYSelectorPart :
303 CYNext<CYSelectorPart>
308 CYSelectorPart(CYWord *name, bool value, CYSelectorPart *next) :
309 CYNext<CYSelectorPart>(next),
315 virtual void Output(std::ostream &out) const;
321 CYSelectorPart *name_;
323 CYSelector(CYSelectorPart *name) :
330 virtual void Output(std::ostream &out, CYFlags flags) const;
337 CYRange(uint64_t lo, uint64_t hi) :
342 bool operator [](uint8_t value) const {
343 return !(value >> 7) && (value >> 6 ? hi_ : lo_) >> (value & 0x3f) & 0x1;
346 void operator()(uint8_t value) {
349 (value >> 6 ? hi_ : lo_) |= uint64_t(0x1) << (value & 0x3f);
353 extern CYRange DigitRange_;
354 extern CYRange WordStartRange_;
355 extern CYRange WordEndRange_;
364 CYString(const char *value, size_t size) :
370 CYString(const CYIdentifier *identifier) :
371 value_(identifier->Value()),
372 size_(strlen(value_))
376 const char *Value() const {
380 virtual const char *Word() const {
381 if (size_ == 0 || !WordStartRange_[value_[0]])
383 for (size_t i(1); i != size_; ++i)
384 if (!WordEndRange_[value_[i]])
389 virtual void Output(std::ostream &out) const {
390 return Output(out, CYNoFlags);
393 virtual void Output(std::ostream &out, CYFlags flags) const;
394 virtual void PropertyName(std::ostream &out) const;
403 CYNumber(double value) :
408 double Value() const {
412 virtual void Output(std::ostream &out) const {
413 return Output(out, CYNoFlags);
416 virtual void Output(std::ostream &out, CYFlags flags) const;
417 virtual void PropertyName(std::ostream &out) const;
429 virtual void Output(std::ostream &out, CYFlags flags) const;
441 virtual void Output(std::ostream &out, CYFlags flags) const;
447 virtual bool Value() const = 0;
448 virtual void Output(std::ostream &out, CYFlags flags) const;
460 virtual bool Value() const;
472 virtual bool Value() const;
480 CYVariable(CYIdentifier *name) :
487 virtual void Output(std::ostream &out, CYFlags flags) const;
495 CYPrefix(CYExpression *rhs) :
500 virtual bool Alphabetic() const = 0;
501 virtual const char *Operator() const = 0;
503 virtual void Output(std::ostream &out, CYFlags flags) const;
512 CYInfix(CYExpression *lhs, CYExpression *rhs) :
518 void SetLeft(CYExpression *lhs) {
522 virtual bool Alphabetic() const = 0;
523 virtual const char *Operator() const = 0;
525 virtual void Output(std::ostream &out, CYFlags flags) const;
533 CYPostfix(CYExpression *lhs) :
538 virtual const char *Operator() const = 0;
540 virtual void Output(std::ostream &out, CYFlags flags) const;
543 struct CYAssignment :
549 CYAssignment(CYExpression *lhs, CYExpression *rhs) :
555 void SetLeft(CYExpression *lhs) {
559 virtual const char *Operator() const = 0;
561 virtual void Output(std::ostream &out, CYFlags flags) const;
568 CYExpression *value_;
570 CYArgument(CYWord *name, CYExpression *value, CYArgument *next = NULL) :
571 CYNext<CYArgument>(next),
577 void Output(std::ostream &out) const;
596 CYClause(CYExpression *_case, CYStatement *code) :
602 virtual void Output(std::ostream &out) const;
608 CYExpression *value_;
610 CYElement(CYExpression *value, CYElement *next) :
611 CYNext<CYElement>(next),
616 void Output(std::ostream &out) const;
622 CYElement *elements_;
624 CYArray(CYElement *elements) :
629 virtual void Output(std::ostream &out, CYFlags flags) const;
632 struct CYDeclaration :
636 CYIdentifier *identifier_;
637 CYExpression *initialiser_;
639 CYDeclaration(CYIdentifier *identifier, CYExpression *initialiser) :
640 identifier_(identifier),
641 initialiser_(initialiser)
645 virtual void Part(std::ostream &out) const;
646 virtual void Output(std::ostream &out) const;
649 struct CYDeclarations :
653 CYDeclaration *declaration_;
654 CYDeclarations *next_;
656 CYDeclarations(CYDeclaration *declaration, CYDeclarations *next) :
657 declaration_(declaration),
662 virtual void Part(std::ostream &out) const;
663 virtual void Output(std::ostream &out) const;
669 virtual void Output(std::ostream &out) const;
672 struct CYMessageParameter :
673 CYNext<CYMessageParameter>
679 CYMessageParameter(CYWord *tag, CYExpression *type, CYIdentifier *name) :
692 CYMessageParameter *parameter_;
695 CYMessage(bool instance, CYExpression *type, CYMessageParameter *parameter, CYSource *body) :
698 parameter_(parameter),
703 virtual void Output(std::ostream &out, bool replace) const;
711 CYExpression *super_;
713 CYMessage *messages_;
715 CYClass(CYClassName *name, CYExpression *super, CYField *fields, CYMessage *messages) :
725 virtual void Output(std::ostream &out) const;
726 virtual void Output(std::ostream &out, CYFlags flags) const;
733 CYMessage *messages_;
735 CYCategory(CYClassName *name, CYMessage *messages) :
741 virtual void Output(std::ostream &out) const;
744 struct CYFunctionParameter :
745 CYNext<CYFunctionParameter>,
750 CYFunctionParameter(CYIdentifier *name, CYFunctionParameter *next) :
751 CYNext<CYFunctionParameter>(next),
756 virtual void Output(std::ostream &out) const;
762 CYForInitialiser *initialiser_;
764 CYExpression *increment_;
767 CYFor(CYForInitialiser *initialiser, CYExpression *test, CYExpression *increment, CYStatement *code) :
768 initialiser_(initialiser),
770 increment_(increment),
775 virtual void Output(std::ostream &out) const;
781 CYForInInitialiser *initialiser_;
785 CYForIn(CYForInInitialiser *initialiser, CYExpression *set, CYStatement *code) :
786 initialiser_(initialiser),
792 virtual void Output(std::ostream &out) const;
798 CYPropertyName *name_;
799 CYExpression *value_;
801 CYProperty(CYPropertyName *name, CYExpression *value, CYProperty *next) :
802 CYNext<CYProperty>(next),
808 virtual void Output(std::ostream &out) const;
814 CYProperty *property_;
816 CYObject(CYProperty *property) :
821 void Output(std::ostream &out, CYFlags flags) const;
830 CYCatch(CYIdentifier *name, CYStatement *code) :
836 virtual void Output(std::ostream &out) const;
843 CYArgument *arguments_;
845 CYSend(CYExpression *self, CYArgument *arguments) :
847 arguments_(arguments)
853 virtual void Output(std::ostream &out, CYFlags flags) const;
859 CYExpression *object_;
860 CYExpression *property_;
862 CYMember(CYExpression *object, CYExpression *property) :
868 void SetLeft(CYExpression *object) {
873 struct CYDirectMember :
876 CYDirectMember(CYExpression *object, CYExpression *property) :
877 CYMember(object, property)
883 virtual void Output(std::ostream &out, CYFlags flags) const;
886 struct CYIndirectMember :
889 CYIndirectMember(CYExpression *object, CYExpression *property) :
890 CYMember(object, property)
896 virtual void Output(std::ostream &out, CYFlags flags) const;
902 CYExpression *constructor_;
903 CYArgument *arguments_;
905 CYNew(CYExpression *constructor, CYArgument *arguments) :
906 constructor_(constructor),
907 arguments_(arguments)
913 virtual void Output(std::ostream &out, CYFlags flags) const;
919 CYExpression *function_;
920 CYArgument *arguments_;
922 CYCall(CYExpression *function, CYArgument *arguments) :
924 arguments_(arguments)
930 virtual void Output(std::ostream &out, CYFlags flags) const;
940 CYIf(CYExpression *test, CYStatement *_true, CYStatement *_false) :
947 virtual void Output(std::ostream &out) const;
956 CYDoWhile(CYExpression *test, CYStatement *code) :
962 virtual void Output(std::ostream &out) const;
971 CYWhile(CYExpression *test, CYStatement *code) :
977 virtual void Output(std::ostream &out) const;
984 CYFunctionParameter *parameters_;
987 CYLambda(CYIdentifier *name, CYFunctionParameter *parameters, CYSource *body) :
989 parameters_(parameters),
996 virtual void Output(std::ostream &out, CYFlags flags) const;
1003 CYFunction(CYIdentifier *name, CYFunctionParameter *parameters, CYSource *body) :
1004 CYLambda(name, parameters, body)
1008 virtual void Output(std::ostream &out) const;
1014 CYExpression *expression_;
1016 CYExpress(CYExpression *expression) :
1017 expression_(expression)
1021 virtual void Output(std::ostream &out) const;
1027 CYIdentifier *label_;
1029 CYContinue(CYIdentifier *label) :
1034 virtual void Output(std::ostream &out) const;
1040 CYIdentifier *label_;
1042 CYBreak(CYIdentifier *label) :
1047 virtual void Output(std::ostream &out) const;
1053 CYExpression *value_;
1055 CYReturn(CYExpression *value) :
1060 virtual void Output(std::ostream &out) const;
1066 virtual void Output(std::ostream &out) const;
1067 virtual void Output(std::ostream &out, bool block) const;
1075 CYStatement *finally_;
1077 CYTry(CYStatement *_try, CYCatch *_catch, CYStatement *finally) :
1084 virtual void Output(std::ostream &out) const;
1090 CYExpression *value_;
1092 CYThrow(CYExpression *value) :
1097 virtual void Output(std::ostream &out) const;
1103 CYExpression *scope_;
1106 CYWith(CYExpression *scope, CYStatement *code) :
1112 virtual void Output(std::ostream &out) const;
1118 CYExpression *value_;
1121 CYSwitch(CYExpression *value, CYClause *clauses) :
1127 virtual void Output(std::ostream &out) const;
1130 struct CYCondition :
1133 CYExpression *test_;
1134 CYExpression *true_;
1135 CYExpression *false_;
1137 CYCondition(CYExpression *test, CYExpression *_true, CYExpression *_false) :
1146 virtual void Output(std::ostream &out, CYFlags flags) const;
1149 struct CYAddressOf :
1152 CYAddressOf(CYExpression *rhs) :
1157 virtual const char *Operator() const {
1164 virtual void Output(std::ostream &out, CYFlags flags) const;
1170 CYIndirect(CYExpression *rhs) :
1175 virtual const char *Operator() const {
1182 virtual void Output(std::ostream &out, CYFlags flags) const;
1185 #define CYPostfix_(op, name) \
1186 struct CY ## name : \
1189 CY ## name(CYExpression *lhs) : \
1196 virtual const char *Operator() const { \
1201 #define CYPrefix_(alphabetic, op, name) \
1202 struct CY ## name : \
1205 CY ## name(CYExpression *rhs) : \
1210 CYAlphabetic(alphabetic) \
1213 virtual const char *Operator() const { \
1218 #define CYInfix_(alphabetic, precedence, op, name) \
1219 struct CY ## name : \
1222 CY ## name(CYExpression *lhs, CYExpression *rhs) : \
1227 CYAlphabetic(alphabetic) \
1228 CYPrecedence(precedence) \
1230 virtual const char *Operator() const { \
1235 #define CYAssignment_(op, name) \
1236 struct CY ## name ## Assign : \
1239 CY ## name ## Assign(CYExpression *lhs, CYExpression *rhs) : \
1240 CYAssignment(lhs, rhs) \
1246 virtual const char *Operator() const { \
1251 CYPostfix_("++", PostIncrement)
1252 CYPostfix_("--", PostDecrement)
1254 CYPrefix_(true, "delete", Delete)
1255 CYPrefix_(true, "void", Void)
1256 CYPrefix_(true, "typeof", TypeOf)
1257 CYPrefix_(false, "++", PreIncrement)
1258 CYPrefix_(false, "--", PreDecrement)
1259 CYPrefix_(false, "-", Negate)
1260 CYPrefix_(false, "~", BitwiseNot)
1261 CYPrefix_(false, "!", LogicalNot)
1263 CYInfix_(false, 5, "*", Multiply)
1264 CYInfix_(false, 5, "/", Divide)
1265 CYInfix_(false, 5, "%", Modulus)
1266 CYInfix_(false, 6, "+", Add)
1267 CYInfix_(false, 6, "-", Subtract)
1268 CYInfix_(false, 7, "<<", ShiftLeft)
1269 CYInfix_(false, 7, ">>", ShiftRightSigned)
1270 CYInfix_(false, 7, ">>>", ShiftRightUnsigned)
1271 CYInfix_(false, 8, "<", Less)
1272 CYInfix_(false, 8, ">", Greater)
1273 CYInfix_(false, 8, "<=", LessOrEqual)
1274 CYInfix_(false, 8, ">=", GreaterOrEqual)
1275 CYInfix_(true, 8, "instanceof", InstanceOf)
1276 CYInfix_(true, 8, "in", In)
1277 CYInfix_(false, 9, "==", Equal)
1278 CYInfix_(false, 9, "!=", NotEqual)
1279 CYInfix_(false, 9, "===", Identical)
1280 CYInfix_(false, 9, "!==", NotIdentical)
1281 CYInfix_(false, 10, "&", BitwiseAnd)
1282 CYInfix_(false, 11, "^", BitwiseXOr)
1283 CYInfix_(false, 12, "|", BitwiseOr)
1284 CYInfix_(false, 13, "&&", LogicalAnd)
1285 CYInfix_(false, 14, "||", LogicalOr)
1287 CYAssignment_("=", )
1288 CYAssignment_("*=", Multiply)
1289 CYAssignment_("/=", Divide)
1290 CYAssignment_("%=", Modulus)
1291 CYAssignment_("+=", Add)
1292 CYAssignment_("-=", Subtract)
1293 CYAssignment_("<<=", ShiftLeft)
1294 CYAssignment_(">>=", ShiftRightSigned)
1295 CYAssignment_(">>>=", ShiftRightUnsigned)
1296 CYAssignment_("&=", BitwiseAnd)
1297 CYAssignment_("^=", BitwiseXOr)
1298 CYAssignment_("|=", BitwiseOr)
1300 #endif/*CYPARSER_HPP*/