X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/7a3459cee18e9e63919801c74175baab3e0ae0f8..fc44232bcff15a35c016ddfc1dc34b6503125020:/ObjectiveC/Replace.cpp?ds=sidebyside diff --git a/ObjectiveC/Replace.cpp b/ObjectiveC/Replace.cpp index a2a4c11..1502aa2 100644 --- a/ObjectiveC/Replace.cpp +++ b/ObjectiveC/Replace.cpp @@ -82,13 +82,13 @@ CYStatement *CYField::Replace(CYContext &context) const { $T(NULL) CYVariable *cyn($V("$cyn")); CYVariable *cyt($V("$cyt")); - CYExpression *type($C0($M(type_, $S("toString")))); + CYExpression *type($C0($M(typed_->Replace(context), $S("toString")))); return $ CYBlock($$->* - next_->Replace(context)->* $E($ CYAssign(cyt, type))->* $E($ CYAssign(cyn, $N1($V("Type"), cyt)))->* - $E($C5($V("class_addIvar"), $V("$cyc"), $S(name_->Word()), $M(cyn, $S("size")), $M(cyn, $S("alignment")), cyt)) + $E($C5($V("class_addIvar"), $V("$cyc"), $S(typed_->identifier_->Word()), $M(cyn, $S("size")), $M(cyn, $S("alignment")), cyt))->* + next_->Replace(context) ); } @@ -96,6 +96,10 @@ CYStatement *CYImport::Replace(CYContext &context) { return $ CYVar($L1($L(module_->part_->Word(), $C1($V("require"), module_->Replace(context, "/"))))); } +CYExpression *CYInstanceLiteral::Replace(CYContext &context) { + return $N1($V("Instance"), number_); +} + CYStatement *CYMessage::Replace(CYContext &context, bool replace) const { $T(NULL) CYVariable *cyn($V("$cyn")); CYVariable *cyt($V("$cyt")); @@ -202,7 +206,7 @@ CYExpression *CYSendDirect::Replace(CYContext &context) { argument = &(*argument)->next_; } - return $C2($V("objc_msgSend"), self_, ($ CYSelector(selector))->Replace(context), arguments_); + return $C2($V("objc_msgSend"), self_, selector->Replace(context), arguments_); } CYExpression *CYSendSuper::Replace(CYContext &context) {