Remove all uses of deprecatedCharacters from WebKit2
[WebKit-https.git] / Source / WebKit2 / WebProcess / WebPage / EncoderAdapter.cpp
1 /*
2  * Copyright (C) 2011 Apple Inc. All rights reserved.
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  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
14  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
15  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
17  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
23  * THE POSSIBILITY OF SUCH DAMAGE.
24  */
25
26 #include "config.h"
27 #include "EncoderAdapter.h"
28
29 #include "DataReference.h"
30 #include "WebCoreArgumentCoders.h"
31 #include <wtf/text/StringView.h>
32
33 namespace WebKit {
34
35 EncoderAdapter::EncoderAdapter()
36 {
37     // Keep format compatibility by decoding an unused uint64_t value
38     // that used to be encoded by the argument encoder.
39     m_encoder << static_cast<uint64_t>(0);
40 }
41
42 IPC::DataReference EncoderAdapter::dataReference() const
43 {
44     return IPC::DataReference(m_encoder.buffer(), m_encoder.bufferSize());
45 }
46
47 void EncoderAdapter::encodeBytes(const uint8_t* bytes, size_t size)
48 {
49     m_encoder << IPC::DataReference(bytes, size);
50 }
51
52 void EncoderAdapter::encodeBool(bool value)
53 {
54     m_encoder << value;
55 }
56
57 void EncoderAdapter::encodeUInt16(uint16_t value)
58 {
59     m_encoder << value;
60 }
61
62 void EncoderAdapter::encodeUInt32(uint32_t value)
63 {
64     m_encoder << value;
65 }
66
67 void EncoderAdapter::encodeUInt64(uint64_t value)
68 {
69     m_encoder << value;
70 }
71
72 void EncoderAdapter::encodeInt32(int32_t value)
73 {
74     m_encoder << value;
75 }
76
77 void EncoderAdapter::encodeInt64(int64_t value)
78 {
79     m_encoder << value;
80 }
81
82 void EncoderAdapter::encodeFloat(float value)
83 {
84     m_encoder << value;
85 }
86
87 void EncoderAdapter::encodeDouble(double value)
88 {
89     m_encoder << value;
90 }
91
92 void EncoderAdapter::encodeString(const String& value)
93 {
94     // This mimics the IPC binary encoding of Strings prior to r88886.
95     // Whenever the IPC binary encoding changes, we'll have to "undo" the changes here.
96     // FIXME: We shouldn't use the IPC binary encoding format for history,
97     // and we should come up with a migration strategy so we can actually bump the version number
98     // without breaking encoding/decoding of the history tree.
99
100     // Special case the null string.
101     if (value.isNull()) {
102         m_encoder << std::numeric_limits<uint32_t>::max();
103         return;
104     }
105
106     uint32_t length = value.length();
107     m_encoder << length;
108
109     uint64_t lengthInBytes = length * sizeof(UChar);
110     m_encoder << lengthInBytes;
111     m_encoder.encodeFixedLengthData(reinterpret_cast<const uint8_t*>(StringView(value).upconvertedCharacters().get()), length * sizeof(UChar), alignof(UChar));
112 }
113
114 }