]> git.saurik.com Git - apple/javascriptcore.git/blame - API/OpaqueJSString.h
JavaScriptCore-7601.1.46.3.tar.gz
[apple/javascriptcore.git] / API / OpaqueJSString.h
CommitLineData
b37bf2e1 1/*
9dae56ea 2 * Copyright (C) 2008 Apple Inc. All rights reserved.
b37bf2e1
A
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
6 * are met:
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
12 *
81345200 13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
b37bf2e1
A
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
81345200 16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
b37bf2e1
A
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24 */
25
9dae56ea
A
26#ifndef OpaqueJSString_h
27#define OpaqueJSString_h
b37bf2e1 28
81345200 29#include <atomic>
6fe7ccc8 30#include <wtf/ThreadSafeRefCounted.h>
93a37866 31#include <wtf/text/WTFString.h>
b37bf2e1 32
9dae56ea
A
33namespace JSC {
34 class Identifier;
93a37866 35 class VM;
9dae56ea 36}
b37bf2e1 37
14957cd0 38struct OpaqueJSString : public ThreadSafeRefCounted<OpaqueJSString> {
ed1e77d3 39 static Ref<OpaqueJSString> create()
9dae56ea 40 {
ed1e77d3 41 return adoptRef(*new OpaqueJSString);
9dae56ea 42 }
b37bf2e1 43
ed1e77d3 44 static Ref<OpaqueJSString> create(const LChar* characters, unsigned length)
93a37866 45 {
ed1e77d3 46 return adoptRef(*new OpaqueJSString(characters, length));
93a37866
A
47 }
48
ed1e77d3 49 static Ref<OpaqueJSString> create(const UChar* characters, unsigned length)
9dae56ea 50 {
ed1e77d3 51 return adoptRef(*new OpaqueJSString(characters, length));
9dae56ea 52 }
b37bf2e1 53
ed1e77d3 54 JS_EXPORT_PRIVATE static RefPtr<OpaqueJSString> create(const String&);
b37bf2e1 55
81345200
A
56 JS_EXPORT_PRIVATE ~OpaqueJSString();
57
ed1e77d3
A
58 bool is8Bit() { return m_string.is8Bit(); }
59 const LChar* characters8() { return m_string.characters8(); }
60 const UChar* characters16() { return m_string.characters16(); }
61 unsigned length() { return m_string.length(); }
81345200
A
62
63 const UChar* characters();
b37bf2e1 64
93a37866
A
65 JS_EXPORT_PRIVATE String string() const;
66 JSC::Identifier identifier(JSC::VM*) const;
81345200
A
67
68 static bool equal(const OpaqueJSString*, const OpaqueJSString*);
b37bf2e1
A
69
70private:
14957cd0 71 friend class WTF::ThreadSafeRefCounted<OpaqueJSString>;
9dae56ea
A
72
73 OpaqueJSString()
81345200 74 : m_characters(nullptr)
9dae56ea
A
75 {
76 }
77
93a37866
A
78 OpaqueJSString(const String& string)
79 : m_string(string.isolatedCopy())
81345200 80 , m_characters(m_string.impl() && m_string.is8Bit() ? nullptr : const_cast<UChar*>(m_string.characters16()))
9dae56ea 81 {
9dae56ea
A
82 }
83
93a37866 84 OpaqueJSString(const LChar* characters, unsigned length)
81345200
A
85 : m_string(characters, length)
86 , m_characters(nullptr)
93a37866 87 {
93a37866
A
88 }
89
90 OpaqueJSString(const UChar* characters, unsigned length)
81345200
A
91 : m_string(characters, length)
92 , m_characters(m_string.impl() && m_string.is8Bit() ? nullptr : const_cast<UChar*>(m_string.characters16()))
9dae56ea 93 {
9dae56ea
A
94 }
95
93a37866 96 String m_string;
81345200
A
97
98 // This will be initialized on demand when characters() is called if the string needs up-conversion.
99 std::atomic<UChar*> m_characters;
b37bf2e1
A
100};
101
b37bf2e1 102#endif