X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/d15b59f5d4f43d12719c5ce37518246058b405c6..17fe7546f6ef4df0bc8b0394e39d929c93d5c1f4:/String.hpp diff --git a/String.hpp b/String.hpp index 5c47ca1..754cdbc 100644 --- a/String.hpp +++ b/String.hpp @@ -1,4 +1,4 @@ -/* Cycript - Error.hppution Server and Disassembler +/* Cycript - Inlining/Optimizing JavaScript Compiler * Copyright (C) 2009 Jay Freeman (saurik) */ @@ -41,6 +41,7 @@ #define CYCRIPT_STRING_HPP #include "cycript.hpp" +#include "Pooling.hpp" struct CYUTF8String { const char *data; @@ -69,62 +70,11 @@ struct CYUTF16String { } }; -JSStringRef CYCopyJSString(const char *value); -JSStringRef CYCopyJSString(JSStringRef value); -JSStringRef CYCopyJSString(CYUTF8String value); -JSStringRef CYCopyJSString(JSContextRef context, JSValueRef value); - -class CYJSString { - private: - JSStringRef string_; - - void Clear_() { - if (string_ != NULL) - JSStringRelease(string_); - } - - public: - CYJSString(const CYJSString &rhs) : - string_(CYCopyJSString(rhs.string_)) - { - } - - template - CYJSString(Arg0_ arg0) : - string_(CYCopyJSString(arg0)) - { - } - - template - CYJSString(Arg0_ arg0, Arg1_ arg1) : - string_(CYCopyJSString(arg0, arg1)) - { - } - - CYJSString &operator =(const CYJSString &rhs) { - Clear_(); - string_ = CYCopyJSString(rhs.string_); - return *this; - } - - ~CYJSString() { - Clear_(); - } - - void Clear() { - Clear_(); - string_ = NULL; - } - - operator JSStringRef() const { - return string_; - } -}; - size_t CYGetIndex(const CYUTF8String &value); bool CYIsKey(CYUTF8String value); bool CYGetOffset(const char *value, ssize_t &index); -const char *CYPoolCString(apr_pool_t *pool, JSContextRef context, JSValueRef value); +CYUTF8String CYPoolUTF8String(apr_pool_t *pool, CYUTF16String utf16); +CYUTF16String CYPoolUTF16String(apr_pool_t *pool, CYUTF8String utf8); #endif/*CYCRIPT_STRING_HPP*/