X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/e91fbe93b995ee8077bbc2097c5407138dc02627..06293152b6505062453463ef34c0d90e0c8db17e:/String.hpp?ds=sidebyside diff --git a/String.hpp b/String.hpp index c912882..ec45c47 100644 --- a/String.hpp +++ b/String.hpp @@ -41,11 +41,20 @@ #define CYCRIPT_STRING_HPP #include "cycript.hpp" +#include "Pooling.hpp" + +#include struct CYUTF8String { const char *data; size_t size; + CYUTF8String(const char *data) : + data(data), + size(strlen(data)) + { + } + CYUTF8String(const char *data, size_t size) : data(data), size(size) @@ -58,6 +67,11 @@ struct CYUTF8String { } }; +static inline std::ostream &operator <<(std::ostream &lhs, CYUTF8String &rhs) { + lhs.write(rhs.data, rhs.size); + return lhs; +} + struct CYUTF16String { const uint16_t *data; size_t size; @@ -69,62 +83,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*/