X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/d3760804d3e2a4287c71d5e9a5aa6425a967a956..5a2ae41928193b489e490abb580abc2fa53181ea:/Library.cpp diff --git a/Library.cpp b/Library.cpp index eba549a..cccd69b 100644 --- a/Library.cpp +++ b/Library.cpp @@ -140,20 +140,29 @@ static CYUTF16String CYCastUTF16String(JSStringRef value) { return CYUTF16String(JSStringGetCharactersPtr(value), JSStringGetLength(value)); } -static CYUTF8String CYPoolUTF8String(apr_pool_t *pool, JSContextRef context, JSStringRef value) { +template +_finline size_t iconv_(size_t (*iconv)(iconv_t, Type_, size_t *, char **, size_t *), iconv_t cd, char **inbuf, size_t *inbytesleft, char **outbuf, size_t *outbytesleft) { + return iconv(cd, const_cast(inbuf), inbytesleft, outbuf, outbytesleft); +} + +CYUTF8String CYPoolUTF8String(apr_pool_t *pool, JSContextRef context, JSStringRef value) { _assert(pool != NULL); CYUTF16String utf16(CYCastUTF16String(value)); const char *in(reinterpret_cast(utf16.data)); +#ifdef __GLIBC__ + iconv_t conversion(_syscall(iconv_open("UTF-8", "UCS-2"))); +#else iconv_t conversion(_syscall(iconv_open("UTF-8", "UCS-2-INTERNAL"))); +#endif size_t size(JSStringGetMaximumUTF8CStringSize(value)); char *out(new(pool) char[size]); CYUTF8String utf8(out, size); size = utf16.size * 2; - _syscall(iconv(conversion, const_cast(&in), &size, &out, &utf8.size)); + _syscall(iconv_(&iconv, conversion, const_cast(&in), &size, &out, &utf8.size)); *out = '\0'; utf8.size = out - utf8.data; @@ -241,8 +250,9 @@ void CYStringify(std::ostringstream &str, const char *data, size_t size) { break; default: + // this test is designed to be "awewsome", generating neither warnings nor incorrect results if (*value < 0x20 || *value >= 0x7f) - str << "\\x" << std::setbase(16) << std::setw(2) << std::setfill('0') << unsigned(*value); + str << "\\x" << std::setbase(16) << std::setw(2) << std::setfill('0') << unsigned(uint8_t(*value)); else simple: str << *value; } @@ -1292,14 +1302,24 @@ static JSStaticFunction Type_staticFunctions[4] = { {NULL, NULL, 0} }; +static JSObjectRef (*$JSObjectMakeArray)(JSContextRef, size_t, const JSValueRef[], JSValueRef *); + void CYSetArgs(int argc, const char *argv[]) { JSContextRef context(CYGetJSContext()); JSValueRef args[argc]; for (int i(0); i != argc; ++i) args[i] = CYCastJSValue(context, argv[i]); - JSValueRef exception(NULL); - JSObjectRef array(JSObjectMakeArray(context, argc, args, &exception)); - CYThrow(context, exception); + + JSObjectRef array; + if ($JSObjectMakeArray != NULL) { + JSValueRef exception(NULL); + array = (*$JSObjectMakeArray)(context, argc, args, &exception); + CYThrow(context, exception); + } else { + JSValueRef value(CYCallAsFunction(context, Array_, NULL, argc, args)); + array = CYCastJSObject(context, value); + } + CYSetProperty(context, System_, CYJSString("args"), array); } @@ -1361,6 +1381,8 @@ void CYInitialize() { _aprcall(apr_initialize()); _aprcall(apr_pool_create(&Pool_, NULL)); _sqlcall(sqlite3_open("/usr/lib/libcycript.db", &Bridge_)); + + $JSObjectMakeArray = reinterpret_cast(dlsym(RTLD_DEFAULT, "JSObjectMakeArray")); } apr_pool_t *CYGetGlobalPool() { @@ -1427,8 +1449,6 @@ CYJSError::CYJSError(JSContextRef context, const char *format, ...) { CYThrow(context, exception); } -void CYObjectiveC(JSContextRef context, JSObjectRef global); - JSGlobalContextRef CYGetJSContext() { CYInitialize(); @@ -1547,7 +1567,8 @@ JSGlobalContextRef CYGetJSContext() { Result_ = JSStringCreateWithUTF8CString("_"); - CYObjectiveC(context, global); + if (hooks_ != NULL && hooks_->SetupContext != NULL) + (*hooks_->SetupContext)(context); } return Context_;