X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/3b1534c097d91248e048f50f8835f791a3e507a1..068fc9b88cabadc2c70140f13db5822b612926c8:/ObjectiveC/Syntax.hpp diff --git a/ObjectiveC/Syntax.hpp b/ObjectiveC/Syntax.hpp index effaa24..e04f71d 100644 --- a/ObjectiveC/Syntax.hpp +++ b/ObjectiveC/Syntax.hpp @@ -1,20 +1,20 @@ /* Cycript - Optimizing JavaScript Compiler/Runtime - * Copyright (C) 2009-2012 Jay Freeman (saurik) + * Copyright (C) 2009-2013 Jay Freeman (saurik) */ -/* GNU Lesser General Public License, Version 3 {{{ */ +/* GNU General Public License, Version 3 {{{ */ /* - * Cycript is free software: you can redistribute it and/or modify it under - * the terms of the GNU Lesser General Public License as published by the - * Free Software Foundation, either version 3 of the License, or (at your - * option) any later version. + * Cycript is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published + * by the Free Software Foundation, either version 3 of the License, + * or (at your option) any later version. * - * Cycript is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public - * License for more details. + * Cycript is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. * - * You should have received a copy of the GNU Lesser General Public License + * You should have received a copy of the GNU General Public License * along with Cycript. If not, see . **/ /* }}} */ @@ -24,112 +24,31 @@ #include "Parser.hpp" -struct CYTypeModifier : - CYNext -{ - CYTypeModifier(CYTypeModifier *next) : - CYNext(next) - { - } - - virtual CYExpression *Replace(CYContext &context) = 0; -}; - -struct CYTypeArrayOf : - CYTypeModifier -{ - CYExpression *size_; - - CYTypeArrayOf(CYExpression *size, CYTypeModifier *next = NULL) : - CYTypeModifier(next), - size_(size) - { - } - - CYPrecedence(2) - - virtual CYExpression *Replace(CYContext &context); -}; - -struct CYTypeConstant : - CYTypeModifier -{ - CYTypeConstant(CYTypeModifier *next = NULL) : - CYTypeModifier(next) - { - } - - CYPrecedence(3) - - virtual CYExpression *Replace(CYContext &context); -}; - -struct CYTypePointerTo : - CYTypeModifier -{ - CYTypePointerTo(CYTypeModifier *next = NULL) : - CYTypeModifier(next) - { - } - - CYPrecedence(3) - - virtual CYExpression *Replace(CYContext &context); -}; - -struct CYTypeVariable : - CYTypeModifier +struct CYInstanceLiteral : + CYExpression { - CYExpression *expression_; + CYNumber *number_; - CYTypeVariable(CYExpression *expression) : - CYTypeModifier(NULL), - expression_(expression) + CYInstanceLiteral(CYNumber *number) : + number_(number) { } CYPrecedence(1) virtual CYExpression *Replace(CYContext &context); -}; - -struct CYTypedIdentifier : - CYNext -{ - CYIdentifier *identifier_; - CYTypeModifier *type_; - - CYTypedIdentifier(CYIdentifier *identifier) : - identifier_(identifier), - type_(NULL) - { - } -}; - -struct CYTypedParameter : - CYNext -{ - CYTypedIdentifier *typed_; - - CYTypedParameter(CYTypedIdentifier *typed, CYTypedParameter *next) : - CYNext(next), - typed_(typed) - { - } - - CYFunctionParameter *Parameters(CYContext &context); - CYExpression *TypeSignature(CYContext &context, CYExpression *prefix); + virtual void Output(CYOutput &out, CYFlags flags) const; }; struct CYObjCBlock : CYExpression { - CYTypeModifier *type_; + CYTypedIdentifier *typed_; CYTypedParameter *parameters_; CYStatement *statements_; - CYObjCBlock(CYTypeModifier *type, CYTypedParameter *parameters, CYStatement *statements) : - type_(type), + CYObjCBlock(CYTypedIdentifier *typed, CYTypedParameter *parameters, CYStatement *statements) : + typed_(typed), parameters_(parameters), statements_(statements) { @@ -141,22 +60,6 @@ struct CYObjCBlock : virtual void Output(CYOutput &out, CYFlags flags) const; }; -struct CYEncodedType : - CYExpression -{ - CYTypeModifier *type_; - - CYEncodedType(CYTypeModifier *type) : - type_(type) - { - } - - CYPrecedence(1) - - virtual CYExpression *Replace(CYContext &context); - virtual void Output(CYOutput &out, CYFlags flags) const; -}; - struct CYBox : CYExpression { @@ -210,13 +113,11 @@ struct CYSelector : struct CYField : CYNext { - CYExpression *type_; - CYIdentifier *name_; + CYTypedIdentifier *typed_; - CYField(CYExpression *type, CYIdentifier *name, CYField *next = NULL) : + CYField(CYTypedIdentifier *typed, CYField *next = NULL) : CYNext(next), - type_(type), - name_(name) + typed_(typed) { } @@ -282,9 +183,32 @@ struct CYProtocol : void Output(CYOutput &out) const; }; +struct CYModule : + CYNext, + CYThing +{ + CYWord *part_; + + CYModule(CYWord *part, CYModule *next = NULL) : + CYNext(next), + part_(part) + { + } + + CYString *Replace(CYContext &context, const char *separator) const; + void Output(CYOutput &out) const; +}; + struct CYImport : CYStatement { + CYModule *module_; + + CYImport(CYModule *module) : + module_(module) + { + } + virtual CYStatement *Replace(CYContext &context); virtual void Output(CYOutput &out, CYFlags flags) const; };