Encoder.cpp 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. /*
  2. * Copyright (c) 2020, Andreas Kling <kling@serenityos.org>
  3. * Copyright (c) 2021, kleines Filmröllchen <filmroellchen@serenityos.org>
  4. *
  5. * SPDX-License-Identifier: BSD-2-Clause
  6. */
  7. #include <AK/BitCast.h>
  8. #include <AK/ByteBuffer.h>
  9. #include <AK/String.h>
  10. #include <AK/URL.h>
  11. #include <LibCore/AnonymousBuffer.h>
  12. #include <LibCore/DateTime.h>
  13. #include <LibCore/Proxy.h>
  14. #include <LibIPC/Dictionary.h>
  15. #include <LibIPC/Encoder.h>
  16. #include <LibIPC/File.h>
  17. namespace IPC {
  18. Encoder& Encoder::operator<<(bool value)
  19. {
  20. return *this << (u8)value;
  21. }
  22. Encoder& Encoder::operator<<(u8 value)
  23. {
  24. m_buffer.data.append(value);
  25. return *this;
  26. }
  27. Encoder& Encoder::operator<<(u16 value)
  28. {
  29. m_buffer.data.ensure_capacity(m_buffer.data.size() + 2);
  30. m_buffer.data.unchecked_append((u8)value);
  31. m_buffer.data.unchecked_append((u8)(value >> 8));
  32. return *this;
  33. }
  34. void Encoder::encode_u32(u32 value)
  35. {
  36. m_buffer.data.ensure_capacity(m_buffer.data.size() + 4);
  37. m_buffer.data.unchecked_append((u8)value);
  38. m_buffer.data.unchecked_append((u8)(value >> 8));
  39. m_buffer.data.unchecked_append((u8)(value >> 16));
  40. m_buffer.data.unchecked_append((u8)(value >> 24));
  41. }
  42. void Encoder::encode_u64(u64 value)
  43. {
  44. m_buffer.data.ensure_capacity(m_buffer.data.size() + 8);
  45. m_buffer.data.unchecked_append((u8)value);
  46. m_buffer.data.unchecked_append((u8)(value >> 8));
  47. m_buffer.data.unchecked_append((u8)(value >> 16));
  48. m_buffer.data.unchecked_append((u8)(value >> 24));
  49. m_buffer.data.unchecked_append((u8)(value >> 32));
  50. m_buffer.data.unchecked_append((u8)(value >> 40));
  51. m_buffer.data.unchecked_append((u8)(value >> 48));
  52. m_buffer.data.unchecked_append((u8)(value >> 56));
  53. }
  54. Encoder& Encoder::operator<<(unsigned value)
  55. {
  56. encode_u32(value);
  57. return *this;
  58. }
  59. Encoder& Encoder::operator<<(unsigned long value)
  60. {
  61. if constexpr (sizeof(value) == 4)
  62. encode_u32(value);
  63. else
  64. encode_u64(value);
  65. return *this;
  66. }
  67. Encoder& Encoder::operator<<(unsigned long long value)
  68. {
  69. if constexpr (sizeof(value) == 4)
  70. encode_u32(value);
  71. else
  72. encode_u64(value);
  73. return *this;
  74. }
  75. Encoder& Encoder::operator<<(i8 value)
  76. {
  77. m_buffer.data.append((u8)value);
  78. return *this;
  79. }
  80. Encoder& Encoder::operator<<(i16 value)
  81. {
  82. m_buffer.data.ensure_capacity(m_buffer.data.size() + 2);
  83. m_buffer.data.unchecked_append((u8)value);
  84. m_buffer.data.unchecked_append((u8)(value >> 8));
  85. return *this;
  86. }
  87. Encoder& Encoder::operator<<(i32 value)
  88. {
  89. m_buffer.data.ensure_capacity(m_buffer.data.size() + 4);
  90. m_buffer.data.unchecked_append((u8)value);
  91. m_buffer.data.unchecked_append((u8)(value >> 8));
  92. m_buffer.data.unchecked_append((u8)(value >> 16));
  93. m_buffer.data.unchecked_append((u8)(value >> 24));
  94. return *this;
  95. }
  96. Encoder& Encoder::operator<<(i64 value)
  97. {
  98. m_buffer.data.ensure_capacity(m_buffer.data.size() + 8);
  99. m_buffer.data.unchecked_append((u8)value);
  100. m_buffer.data.unchecked_append((u8)(value >> 8));
  101. m_buffer.data.unchecked_append((u8)(value >> 16));
  102. m_buffer.data.unchecked_append((u8)(value >> 24));
  103. m_buffer.data.unchecked_append((u8)(value >> 32));
  104. m_buffer.data.unchecked_append((u8)(value >> 40));
  105. m_buffer.data.unchecked_append((u8)(value >> 48));
  106. m_buffer.data.unchecked_append((u8)(value >> 56));
  107. return *this;
  108. }
  109. Encoder& Encoder::operator<<(float value)
  110. {
  111. u32 as_u32 = bit_cast<u32>(value);
  112. return *this << as_u32;
  113. }
  114. Encoder& Encoder::operator<<(double value)
  115. {
  116. u64 as_u64 = bit_cast<u64>(value);
  117. return *this << as_u64;
  118. }
  119. Encoder& Encoder::operator<<(char const* value)
  120. {
  121. return *this << StringView { value, strlen(value) };
  122. }
  123. Encoder& Encoder::operator<<(StringView value)
  124. {
  125. m_buffer.data.append((u8 const*)value.characters_without_null_termination(), value.length());
  126. return *this;
  127. }
  128. Encoder& Encoder::operator<<(String const& value)
  129. {
  130. if (value.is_null())
  131. return *this << (i32)-1;
  132. *this << static_cast<i32>(value.length());
  133. return *this << value.view();
  134. }
  135. Encoder& Encoder::operator<<(ByteBuffer const& value)
  136. {
  137. *this << static_cast<i32>(value.size());
  138. m_buffer.data.append(value.data(), value.size());
  139. return *this;
  140. }
  141. Encoder& Encoder::operator<<(URL const& value)
  142. {
  143. return *this << value.to_string();
  144. }
  145. Encoder& Encoder::operator<<(Dictionary const& dictionary)
  146. {
  147. *this << (u64)dictionary.size();
  148. dictionary.for_each_entry([this](auto& key, auto& value) {
  149. *this << key << value;
  150. });
  151. return *this;
  152. }
  153. Encoder& Encoder::operator<<(File const& file)
  154. {
  155. int fd = file.fd();
  156. if (fd != -1) {
  157. auto result = dup(fd);
  158. if (result < 0) {
  159. perror("dup");
  160. VERIFY_NOT_REACHED();
  161. }
  162. fd = result;
  163. }
  164. m_buffer.fds.append(adopt_ref(*new AutoCloseFileDescriptor(fd)));
  165. return *this;
  166. }
  167. bool encode(Encoder& encoder, Core::AnonymousBuffer const& buffer)
  168. {
  169. encoder << buffer.is_valid();
  170. if (buffer.is_valid()) {
  171. encoder << (u32)buffer.size();
  172. encoder << IPC::File(buffer.fd());
  173. }
  174. return true;
  175. }
  176. bool encode(Encoder& encoder, Core::DateTime const& datetime)
  177. {
  178. encoder << static_cast<i64>(datetime.timestamp());
  179. return true;
  180. }
  181. bool encode(Encoder& encoder, Core::ProxyData const& proxy)
  182. {
  183. encoder << to_underlying(proxy.type);
  184. encoder << proxy.host_ipv4;
  185. encoder << proxy.port;
  186. return true;
  187. }
  188. }