X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/c15969fd0a6280c60d2f35876b5343004fed2b11..fc44232bcff15a35c016ddfc1dc34b6503125020:/ObjectiveC/Syntax.hpp?ds=sidebyside diff --git a/ObjectiveC/Syntax.hpp b/ObjectiveC/Syntax.hpp index 92e4363..e04f71d 100644 --- a/ObjectiveC/Syntax.hpp +++ b/ObjectiveC/Syntax.hpp @@ -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; };