X-Git-Url: https://git.saurik.com/apple/javascriptcore.git/blobdiff_plain/b37bf2e156556c589aea3e1f58a377f2b1189665..f9bf01c6616d5ddcf65b13b33cedf9e387ff7a63:/API/JSStringRef.cpp diff --git a/API/JSStringRef.cpp b/API/JSStringRef.cpp index 9a307d0..8e236e4 100644 --- a/API/JSStringRef.cpp +++ b/API/JSStringRef.cpp @@ -1,4 +1,3 @@ -// -*- mode: c++; c-basic-offset: 4 -*- /* * Copyright (C) 2006, 2007 Apple Inc. All rights reserved. * @@ -27,92 +26,80 @@ #include "config.h" #include "JSStringRef.h" -#include - -#include "APICast.h" -#include -#include -#include -#include -#include -#include +#include "InitializeThreading.h" +#include "OpaqueJSString.h" #include -using namespace KJS; +using namespace JSC; using namespace WTF::Unicode; JSStringRef JSStringCreateWithCharacters(const JSChar* chars, size_t numChars) { - JSLock lock; - return toRef(UString(reinterpret_cast(chars), static_cast(numChars)).rep()->ref()); + initializeThreading(); + return OpaqueJSString::create(chars, numChars).releaseRef(); } JSStringRef JSStringCreateWithUTF8CString(const char* string) { - JSLock lock; - - size_t length = strlen(string); - Vector< ::UChar, 1024> buffer(length); - ::UChar* p = buffer.data(); - if (conversionOK != convertUTF8ToUTF16(&string, string + length, &p, p + length)) - return 0; - - return toRef(UString(reinterpret_cast(buffer.data()), p - buffer.data()).rep()->ref()); + initializeThreading(); + if (string) { + size_t length = strlen(string); + Vector buffer(length); + UChar* p = buffer.data(); + if (conversionOK == convertUTF8ToUTF16(&string, string + length, &p, p + length)) + return OpaqueJSString::create(buffer.data(), p - buffer.data()).releaseRef(); + } + + // Null string. + return OpaqueJSString::create().releaseRef(); } JSStringRef JSStringRetain(JSStringRef string) { - JSLock lock; - UString::Rep* rep = toJS(string); - return toRef(rep->ref()); + string->ref(); + return string; } void JSStringRelease(JSStringRef string) { - JSLock lock; - UString::Rep* rep = toJS(string); - rep->deref(); + string->deref(); } size_t JSStringGetLength(JSStringRef string) { - UString::Rep* rep = toJS(string); - return rep->size(); + return string->length(); } const JSChar* JSStringGetCharactersPtr(JSStringRef string) { - UString::Rep* rep = toJS(string); - return reinterpret_cast(rep->data()); + return string->characters(); } size_t JSStringGetMaximumUTF8CStringSize(JSStringRef string) { - UString::Rep* rep = toJS(string); - // Any UTF8 character > 3 bytes encodes as a UTF16 surrogate pair. - return rep->size() * 3 + 1; // + 1 for terminating '\0' + return string->length() * 3 + 1; // + 1 for terminating '\0' } size_t JSStringGetUTF8CString(JSStringRef string, char* buffer, size_t bufferSize) { - JSLock lock; - UString::Rep* rep = toJS(string); - CString cString = UString(rep).UTF8String(); + if (!bufferSize) + return 0; + + char* p = buffer; + const UChar* d = string->characters(); + ConversionResult result = convertUTF16ToUTF8(&d, d + string->length(), &p, p + bufferSize - 1, true); + *p++ = '\0'; + if (result != conversionOK && result != targetExhausted) + return 0; - size_t length = std::min(bufferSize, cString.size() + 1); // + 1 for terminating '\0' - memcpy(buffer, cString.c_str(), length); - return length; + return p - buffer; } bool JSStringIsEqual(JSStringRef a, JSStringRef b) { - JSLock lock; - - UString::Rep* aRep = toJS(a); - UString::Rep* bRep = toJS(b); - - return UString(aRep) == UString(bRep); + unsigned len = a->length(); + return len == b->length() && 0 == memcmp(a->characters(), b->characters(), len * sizeof(UChar)); } bool JSStringIsEqualToUTF8CString(JSStringRef a, const char* b)