X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/17764b01280ac7cd2e14c82581fd8d185a437fef..2c4a8bb6222b88ff96fbf25372179646ce15f706:/Replace.cpp diff --git a/Replace.cpp b/Replace.cpp index c268182..d499dbc 100644 --- a/Replace.cpp +++ b/Replace.cpp @@ -125,6 +125,14 @@ CYExpression *CYAssignment::Replace(CYContext &context) { return this; } +CYTarget *CYAttemptMember::Replace(CYContext &context) { + CYIdentifier *value(context.Unique()); + + return $C1($F(NULL, $P1($B(value)), $$ + ->* $ CYReturn($ CYCondition($V(value), $M($V(value), property_), $V(value))) + ), object_); +} + CYStatement *CYBlock::Return() { CYImplicitReturn(code_); return this; @@ -145,6 +153,15 @@ CYStatement *CYBreak::Replace(CYContext &context) { } CYTarget *CYCall::Replace(CYContext &context) { + // XXX: this also is a horrible hack but I'm still a month over schedule :( + if (CYAttemptMember *member = dynamic_cast(function_)) { + CYIdentifier *value(context.Unique()); + + return $C1($F(NULL, $P1($B(value)), $$ + ->* $ CYReturn($ CYCondition($V(value), $C($M($V(value), member->property_), arguments_), $V(value))) + ), member->object_); + } + context.Replace(function_); arguments_->Replace(context); return this; @@ -1173,6 +1190,13 @@ CYTarget *CYTemplate::Replace(CYContext &context) { return $C2($M($M($M($V("String"), $S("prototype")), $S("concat")), $S("apply")), $S(""), $ CYArray($ CYElementValue(string_, spans_->Replace(context)))); } +CYString *CYTemplate::String(CYContext &context) { + // XXX: implement this over local concat + if (spans_ != NULL) + return NULL; + return string_; +} + CYTarget *CYThis::Replace(CYContext &context) { if (context.this_ != NULL) return $V(context.this_->Identifier(context)); @@ -1262,6 +1286,15 @@ CYTarget *CYTypeExpression::Replace(CYContext &context) { return typed_->Replace(context); } +CYTarget *CYTypeFloating::Replace(CYContext &context) { + switch (length_) { + case 0: return $V("float"); + case 1: return $V("double"); + case 2: return $V("longdouble"); + default: _assert(false); + } +} + CYTarget *CYTypeInt128::Replace(CYContext &context) { return $V(signing_ == CYTypeUnsigned ? "uint128" : "int128"); }