aboutsummaryrefslogtreecommitdiffstats
path: root/contrib
diff options
context:
space:
mode:
authorvvvv <vvvv@ydb.tech>2022-09-16 19:43:31 +0300
committervvvv <vvvv@ydb.tech>2022-09-16 19:43:31 +0300
commit537a6ece545495ed4cfa87840624b35964bef3d9 (patch)
treeb27444e50c26bc40d58977c80e67b8ac4fcb7587 /contrib
parentfc6228adb13e707d9218f74d753d669dd3950c66 (diff)
downloadydb-537a6ece545495ed4cfa87840624b35964bef3d9.tar.gz
generic arrow function resolver
Diffstat (limited to 'contrib')
-rw-r--r--contrib/restricted/boost/beast/CHANGELOG.md2332
-rw-r--r--contrib/restricted/boost/beast/CODE_OF_CONDUCT.md9
-rw-r--r--contrib/restricted/boost/beast/CONTRIBUTING.md65
-rw-r--r--contrib/restricted/boost/beast/LICENSE_1_0.txt23
-rw-r--r--contrib/restricted/boost/beast/README.md212
-rw-r--r--contrib/restricted/boost/boost/beast.hpp21
-rw-r--r--contrib/restricted/boost/boost/beast/core.hpp41
-rw-r--r--contrib/restricted/boost/boost/beast/core/bind_handler.hpp78
-rw-r--r--contrib/restricted/boost/boost/beast/core/buffered_read_stream.hpp372
-rw-r--r--contrib/restricted/boost/boost/beast/core/buffers_adapter.hpp164
-rw-r--r--contrib/restricted/boost/boost/beast/core/buffers_cat.hpp119
-rw-r--r--contrib/restricted/boost/boost/beast/core/buffers_prefix.hpp237
-rw-r--r--contrib/restricted/boost/boost/beast/core/buffers_suffix.hpp160
-rw-r--r--contrib/restricted/boost/boost/beast/core/buffers_to_string.hpp59
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/allocator.hpp42
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/base64.hpp251
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/bind_handler.hpp217
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/buffers_ref.hpp67
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/clamp.hpp59
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/config.hpp54
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/cpu_info.hpp99
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/empty_base_optimization.hpp100
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/integer_sequence.hpp143
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/ostream.hpp319
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/sha1.hpp313
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/static_ostream.hpp142
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/static_string.hpp135
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/type_traits.hpp472
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/variant.hpp267
-rw-r--r--contrib/restricted/boost/boost/beast/core/detail/varint.hpp79
-rw-r--r--contrib/restricted/boost/boost/beast/core/error.hpp58
-rw-r--r--contrib/restricted/boost/boost/beast/core/file.hpp45
-rw-r--r--contrib/restricted/boost/boost/beast/core/file_base.hpp89
-rw-r--r--contrib/restricted/boost/boost/beast/core/file_posix.hpp175
-rw-r--r--contrib/restricted/boost/boost/beast/core/file_stdio.hpp158
-rw-r--r--contrib/restricted/boost/boost/beast/core/file_win32.hpp177
-rw-r--r--contrib/restricted/boost/boost/beast/core/flat_buffer.hpp342
-rw-r--r--contrib/restricted/boost/boost/beast/core/flat_static_buffer.hpp254
-rw-r--r--contrib/restricted/boost/boost/beast/core/handler_ptr.hpp191
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/buffered_read_stream.ipp257
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/buffers_adapter.ipp517
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/buffers_cat.ipp376
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/buffers_prefix.ipp258
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/buffers_suffix.ipp250
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/file_posix.ipp349
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/file_stdio.ipp239
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/file_win32.ipp364
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/flat_buffer.ipp475
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/flat_static_buffer.ipp151
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/handler_ptr.ipp128
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/multi_buffer.ipp1063
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/read_size.ipp80
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/static_buffer.ipp169
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/static_string.ipp618
-rw-r--r--contrib/restricted/boost/boost/beast/core/impl/string_param.ipp108
-rw-r--r--contrib/restricted/boost/boost/beast/core/multi_buffer.hpp322
-rw-r--r--contrib/restricted/boost/boost/beast/core/ostream.hpp104
-rw-r--r--contrib/restricted/boost/boost/beast/core/read_size.hpp64
-rw-r--r--contrib/restricted/boost/boost/beast/core/span.hpp215
-rw-r--r--contrib/restricted/boost/boost/beast/core/static_buffer.hpp222
-rw-r--r--contrib/restricted/boost/boost/beast/core/static_string.hpp1112
-rw-r--r--contrib/restricted/boost/boost/beast/core/string.hpp132
-rw-r--r--contrib/restricted/boost/boost/beast/core/string_param.hpp130
-rw-r--r--contrib/restricted/boost/boost/beast/core/type_traits.hpp480
-rw-r--r--contrib/restricted/boost/boost/beast/http.hpp38
-rw-r--r--contrib/restricted/boost/boost/beast/http/basic_dynamic_body.hpp167
-rw-r--r--contrib/restricted/boost/boost/beast/http/basic_file_body.hpp539
-rw-r--r--contrib/restricted/boost/boost/beast/http/basic_parser.hpp621
-rw-r--r--contrib/restricted/boost/boost/beast/http/buffer_body.hpp227
-rw-r--r--contrib/restricted/boost/boost/beast/http/chunk_encode.hpp736
-rw-r--r--contrib/restricted/boost/boost/beast/http/detail/basic_parsed_list.hpp198
-rw-r--r--contrib/restricted/boost/boost/beast/http/detail/basic_parser.hpp896
-rw-r--r--contrib/restricted/boost/boost/beast/http/detail/chunk_encode.hpp247
-rw-r--r--contrib/restricted/boost/boost/beast/http/detail/rfc7230.hpp473
-rw-r--r--contrib/restricted/boost/boost/beast/http/detail/type_traits.hpp218
-rw-r--r--contrib/restricted/boost/boost/beast/http/dynamic_body.hpp30
-rw-r--r--contrib/restricted/boost/boost/beast/http/empty_body.hpp131
-rw-r--r--contrib/restricted/boost/boost/beast/http/error.hpp156
-rw-r--r--contrib/restricted/boost/boost/beast/http/field.hpp410
-rw-r--r--contrib/restricted/boost/boost/beast/http/fields.hpp767
-rw-r--r--contrib/restricted/boost/boost/beast/http/file_body.hpp35
-rw-r--r--contrib/restricted/boost/boost/beast/http/impl/basic_parser.ipp928
-rw-r--r--contrib/restricted/boost/boost/beast/http/impl/chunk_encode.ipp707
-rw-r--r--contrib/restricted/boost/boost/beast/http/impl/error.ipp120
-rw-r--r--contrib/restricted/boost/boost/beast/http/impl/field.ipp562
-rw-r--r--contrib/restricted/boost/boost/beast/http/impl/fields.ipp1393
-rw-r--r--contrib/restricted/boost/boost/beast/http/impl/file_body_win32.ipp595
-rw-r--r--contrib/restricted/boost/boost/beast/http/impl/message.ipp437
-rw-r--r--contrib/restricted/boost/boost/beast/http/impl/parser.ipp136
-rw-r--r--contrib/restricted/boost/boost/beast/http/impl/read.ipp838
-rw-r--r--contrib/restricted/boost/boost/beast/http/impl/rfc7230.ipp572
-rw-r--r--contrib/restricted/boost/boost/beast/http/impl/serializer.ipp454
-rw-r--r--contrib/restricted/boost/boost/beast/http/impl/status.ipp252
-rw-r--r--contrib/restricted/boost/boost/beast/http/impl/verb.ipp341
-rw-r--r--contrib/restricted/boost/boost/beast/http/impl/write.ipp908
-rw-r--r--contrib/restricted/boost/boost/beast/http/message.hpp1003
-rw-r--r--contrib/restricted/boost/boost/beast/http/parser.hpp465
-rw-r--r--contrib/restricted/boost/boost/beast/http/read.hpp765
-rw-r--r--contrib/restricted/boost/boost/beast/http/rfc7230.hpp329
-rw-r--r--contrib/restricted/boost/boost/beast/http/serializer.hpp398
-rw-r--r--contrib/restricted/boost/boost/beast/http/span_body.hpp169
-rw-r--r--contrib/restricted/boost/boost/beast/http/status.hpp167
-rw-r--r--contrib/restricted/boost/boost/beast/http/string_body.hpp197
-rw-r--r--contrib/restricted/boost/boost/beast/http/type_traits.hpp200
-rw-r--r--contrib/restricted/boost/boost/beast/http/vector_body.hpp183
-rw-r--r--contrib/restricted/boost/boost/beast/http/verb.hpp157
-rw-r--r--contrib/restricted/boost/boost/beast/http/write.hpp569
-rw-r--r--contrib/restricted/boost/boost/beast/version.hpp28
-rw-r--r--contrib/restricted/boost/boost/beast/websocket.hpp22
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/detail/error.hpp78
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/detail/frame.hpp309
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/detail/hybi13.hpp75
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/detail/mask.hpp148
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/detail/pausation.hpp162
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/detail/pmd_extension.hpp364
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/detail/stream_base.hpp221
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/detail/type_traits.hpp36
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/detail/utf8_checker.hpp344
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/error.hpp254
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/impl/accept.ipp782
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/impl/close.ipp446
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/impl/error.ipp162
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/impl/handshake.ipp420
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/impl/ping.ipp275
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/impl/read.ipp1376
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/impl/rfc6455.ipp40
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/impl/ssl.ipp61
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/impl/stream.ipp894
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/impl/teardown.ipp226
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/impl/write.ipp890
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/option.hpp73
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/rfc6455.hpp215
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/role.hpp59
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/ssl.hpp84
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/stream.hpp3578
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/stream_fwd.hpp28
-rw-r--r--contrib/restricted/boost/boost/beast/websocket/teardown.hpp174
-rw-r--r--contrib/restricted/boost/boost/beast/zlib.hpp20
-rw-r--r--contrib/restricted/boost/boost/beast/zlib/deflate_stream.hpp404
-rw-r--r--contrib/restricted/boost/boost/beast/zlib/detail/bitstream.hpp207
-rw-r--r--contrib/restricted/boost/boost/beast/zlib/detail/deflate_stream.hpp3006
-rw-r--r--contrib/restricted/boost/boost/beast/zlib/detail/inflate_stream.hpp1310
-rw-r--r--contrib/restricted/boost/boost/beast/zlib/detail/ranges.hpp104
-rw-r--r--contrib/restricted/boost/boost/beast/zlib/detail/window.hpp167
-rw-r--r--contrib/restricted/boost/boost/beast/zlib/error.hpp139
-rw-r--r--contrib/restricted/boost/boost/beast/zlib/impl/error.ipp140
-rw-r--r--contrib/restricted/boost/boost/beast/zlib/inflate_stream.hpp220
-rw-r--r--contrib/restricted/boost/boost/beast/zlib/zlib.hpp184
148 files changed, 2641 insertions, 50141 deletions
diff --git a/contrib/restricted/boost/beast/CHANGELOG.md b/contrib/restricted/boost/beast/CHANGELOG.md
new file mode 100644
index 0000000000..bf481e2ca2
--- /dev/null
+++ b/contrib/restricted/boost/beast/CHANGELOG.md
@@ -0,0 +1,2332 @@
+Version 167:
+
+* Revert: Tidy up calls to post()
+
+--------------------------------------------------------------------------------
+
+Version 166:
+
+* Use boost::is_convertible as a workaround
+
+--------------------------------------------------------------------------------
+
+Version 165:
+
+* Fix BOOST_NO_CXX11_ALLOCATOR check
+* Tidy up a warning
+
+--------------------------------------------------------------------------------
+
+Version 164:
+
+* Fix masking on continuation frames
+* Add Access-Control-Expose-Headers field constant
+
+--------------------------------------------------------------------------------
+
+Version 163:
+
+* Tidy up calls to post()
+* Fix narrowing warnings
+
+--------------------------------------------------------------------------------
+
+Version 162:
+
+* Add asio_handler_invoke overloads for stream algorithms
+* Improve websocket::stream::control_callback javadoc
+
+--------------------------------------------------------------------------------
+
+Version 161:
+
+* Don't copy the handler in write_some_op
+* Add move-only handler tests
+* Fix handler parameter javadocs
+
+--------------------------------------------------------------------------------
+
+Version 160:
+
+* Examples clear the HTTP message before reading
+
+--------------------------------------------------------------------------------
+
+Version 159:
+
+* Fix typo in release notes
+* Safe treatment of zero-length string arguments in basic_fields
+* Some basic_fields operations now give the strong exception guarantee
+
+--------------------------------------------------------------------------------
+
+Version 158:
+
+* Tidy up end_of_stream javadoc
+* Tidy up websocket docs
+* Examples set reuse_address(true)
+* Advanced servers support clean shutdown via SIGINT or SIGTERM
+* DynamicBuffer input areas are not mutable
+* Tidy up some documentation
+
+API Changes:
+
+* get_lowest_layer is a type alias
+
+Actions required:
+
+* Replace instances of `typename get_lowest_layer<T>::type`
+ with `get_lowest_layer<T>`.
+
+--------------------------------------------------------------------------------
+
+Version 157:
+
+* Fix teardown for TIME_WAIT
+* Fix big-endian websocket masking
+
+--------------------------------------------------------------------------------
+
+Version 156:
+
+* Don't use typeid
+* Add release notes to documentation
+* Fix stale link for void-or-deduced
+
+--------------------------------------------------------------------------------
+
+Version 155:
+
+* Fix memory leak in advanced server examples
+* Fix soft-mutex assert in websocket stream
+* Fix fallthrough warnings
+* Tidy up bind_handler doc
+
+--------------------------------------------------------------------------------
+
+Version 154:
+
+* Type check completion handlers
+* bind_handler doc update
+* bind_handler works with boost placeholders
+
+--------------------------------------------------------------------------------
+
+Version 153:
+
+* Remove BOOST_VERSION checks
+* Use make_error_code for setting an error_code from errc
+* Use boost::winapi::GetLastError() consistently
+* Update README.md for branches
+* Avoid string_view::clear
+* Fix iterator version of basic_fields::erase
+* Fix use-after-move in example request handlers
+* Add Bishop Fox interview media
+
+--------------------------------------------------------------------------------
+
+Version 152:
+
+* Refactor detect_ssl_op
+* Disable gdb on Travis for Meltdown
+
+WebSocket:
+
+* Redistribute the read tests in the translation units
+* Refactor error headers
+* Add WebSocket error conditions
+
+API Changes:
+
+* Refactor WebSocket errors (API Change):
+
+Actions Required:
+
+* Code which explicitly compares error_code values against the
+ constant `websocket::error::handshake_failed` should compare
+ against `websocket::condition::handshake_failed` instead.
+
+* Code which explicitly compares error_code values against the
+ constant `websocket::error::failed` should compare
+ against `websocket::condition::protocol_violation` instead.
+
+--------------------------------------------------------------------------------
+
+Version 151:
+
+* Sanitizer failures are errors
+* Depend on container_hash
+* Fix high-ASCII in source file
+
+WebSocket:
+
+* Control callback is invoked on the execution context
+* Add stream_fwd.hpp
+* Remove unnecessary include
+
+API Changes:
+
+* http::parser is not MoveConstructible
+* permessage-deflate is a compile-time feature
+
+--------------------------------------------------------------------------------
+
+Version 150:
+
+* handler_ptr tests
+* Documentation
+
+API Changes:
+
+* serializer::reader_impl is deprecated
+
+Actions Required:
+
+* Call serializer::writer_impl instead of reader_impl
+
+--------------------------------------------------------------------------------
+
+Version 149:
+
+* built-in r-value return values can't be assigned
+* Tidy up ssl_stream special members
+* Fix CMakeLists.txt variable
+* Protect calls from macros
+* pausation always allocates
+* Don't copy completion handlers
+* handler_ptr is move-only
+* Fix Travis memory utilization
+
+API Changes:
+
+* handler_ptr gives the strong exception guarantee
+
+Actions Required:
+
+* Change the constructor signature for state objects
+ used with handler_ptr to receive a const reference to
+ the handler.
+
+--------------------------------------------------------------------------------
+
+Version 148:
+
+* Install codecov on codecov CI targets only
+* Update reports for hybrid assessment
+* Handle invalid deflate frames
+
+--------------------------------------------------------------------------------
+
+Version 147:
+
+* Don't use boost::string_ref
+* Use iterator wrapper in detail::buffers_range
+
+HTTP:
+
+* Tidy up basic_fields exception specifiers
+
+WebSocket:
+
+* control callback is copied or moved
+* Send idle pings in advanced servers
+
+--------------------------------------------------------------------------------
+
+Version 146:
+
+* Fix some typos
+* Faster ascii_tolower
+* Documentation tidying
+* Fix typo in examples documentation
+* Add detail::aligned_union and tidy up
+* Use variant in buffers_cat_view
+
+API Changes:
+
+* Remove unintended public members of handler_ptr
+
+--------------------------------------------------------------------------------
+
+Version 145:
+
+* Rename some detail functions
+* Refactor basic_fields allocator internals
+* Refactor HTTP async read composed operations
+* null_buffers is deprecated
+* Version 124 works with Boost 1.65.1 and earlier
+* basic_fields does not support fancy pointers
+
+--------------------------------------------------------------------------------
+
+Version 144-hf1:
+
+* Update reports for hybrid assessment
+* Handle invalid deflate frames
+* Install codecov on codecov CI targets only
+
+--------------------------------------------------------------------------------
+
+Version 144:
+
+* Fix websocket permessage-deflate negotiation
+
+--------------------------------------------------------------------------------
+
+Version 143:
+
+* Fix autobahn report link
+
+--------------------------------------------------------------------------------
+
+Version 142:
+
+* Warn about upcoming API changes to certain concepts
+* Fix name typo in http write test
+
+--------------------------------------------------------------------------------
+
+Version 141:
+
+* Tidy up some documentation
+
+--------------------------------------------------------------------------------
+
+Version 140:
+
+* Fix some integer warnings in 64-bit builds
+* Fix utf8_checker test failures
+* Fix signature for async_read_some, and tests
+* Tidy up basic_parser
+* Some basic_fields special members are protected
+
+--------------------------------------------------------------------------------
+
+Version 139:
+
+* Revisit boost library min/max guidance
+
+--------------------------------------------------------------------------------
+
+Version 138:
+
+* Tidy up some documentation
+
+--------------------------------------------------------------------------------
+
+Version 137:
+
+* ConstBufferSequence mandates pointer equivalence
+* Add FieldsWriter constructor requirement
+* Tidy up some documented constructor syntax
+
+--------------------------------------------------------------------------------
+
+Version 136:
+
+* Tidy up message doc image
+
+--------------------------------------------------------------------------------
+
+Version 135:
+
+* Fix typo in example server help text
+
+--------------------------------------------------------------------------------
+
+Version 134:
+
+* Add static_buffer_base default constructor definition
+
+--------------------------------------------------------------------------------
+
+Version 133:
+
+* Remove const&& overload of message::body
+
+--------------------------------------------------------------------------------
+
+Version 132:
+
+* Tidy up project folders in CMakeLists.txt
+* Rename Cmake variables for clarity
+* Add ref-qualified overloads for message::body
+* Tidy up FieldsReader doc
+
+API Changes:
+
+* Fields::writer replaces Fields::reader
+* BodyReader and BodyWriter names are swapped
+
+Actions Required:
+
+* Rename reader to writer for user defined Fields
+* Swap the reader and writer names for user defined Body types
+* Swap use of is_body_reader and is_body_writer
+
+--------------------------------------------------------------------------------
+
+Version 131:
+
+* basic_fields returns const values
+* Set SNI hostname in example SSL clients
+
+--------------------------------------------------------------------------------
+
+Version 130:
+
+* Tidy up fallthrough warning
+* Remove cxx11_sfinae_expr build requirement from tests
+
+--------------------------------------------------------------------------------
+
+Version 129:
+
+* Add autobahn test report to doc
+* Documentation tidying
+* Fix prepare_payload: chunked is HTTP/1.1
+
+--------------------------------------------------------------------------------
+
+Version 128:
+
+* Update doc links
+* Add explicit-failures-markup.xml
+
+HTTP:
+
+* Add message::need_eof
+* Use message::need_eof in example servers
+* Use synchronous writes in chunk output example
+
+WebSocket:
+
+* Fix utf8 validation for autobahn
+* Temporarily disable utf8 validation tests
+* Tidy up fast websocket server host names
+
+API Changes:
+
+* Remove serializer::keep_alive
+* Remove serializer::chunked
+* Add has_content_length_impl to Fields
+* Add message::has_content_length
+* Rename some basic_parser observers
+
+Actions Required:
+
+* Call message::keep_alive instead of serializer::keep_alive
+* Call serializer::get::chunked instead of serializer::chunked
+* Implement has_content_length_impl for user-defined Fields
+* Remove the "is_" prefix from call sites invoking certain basic_parser members
+
+--------------------------------------------------------------------------------
+
+Version 127:
+
+* Add BOOST_BEAST_NO_POSIX_FADVISE
+* Version command line option for HTTP client examples
+* More Jamfile compiler requirements for tests
+
+--------------------------------------------------------------------------------
+
+Version 126:
+
+* Add CppCon2017 presentation link
+* Update README.md
+* Update stream write documentation for end of stream changes
+* Tidy up unused variable warnings
+* Don't return end_of_stream on win32 file body writes
+* Fix doc typo
+* Fix shadowing in session_alloc
+* Fix executor type compilation
+* Add Travis tests with the default compilers
+* Update Boost.WinAPI usage to the new location and namespace.
+* Fix buffered_read_stream async_read_some signature
+
+--------------------------------------------------------------------------------
+
+Version 125:
+
+API Changes:
+
+* Update for Net-TS Asio
+
+Actions Required:
+
+* Use BOOST_ASIO_HANDLER_TYPE instead of handler_type
+* Use BOOST_ASIO_INITFN_RESULT_TYPE instead of async_result
+* Use boost::asio::async_completion
+* Use boost::asio::is_dynamic_buffer
+* Use boost::asio::is_const_buffer_sequence
+* Use boost::asio::is_mutable_buffer_sequence
+* boost::asio::associated_allocator_t replaces handler_alloc
+
+--------------------------------------------------------------------------------
+
+Version 124:
+
+* Fix for a test matrix compiler
+* Fix basic_fields javadoc
+
+API Changes:
+
+* http write returns success on connection close
+
+Actions Required:
+
+* Add code to servers to close the connection after successfully
+ writing a message where `message::keep_alive()` would return `false`.
+
+--------------------------------------------------------------------------------
+
+Version 123:
+
+* Use unit-test subtree
+* Fix spurious race in websocket close test
+* Check compiler feature in Jamfile
+* Clear previous message fields in parser
+
+--------------------------------------------------------------------------------
+
+Version 122:
+
+* Add test for issue 807
+* assert on empty buffer in websocket read
+* Fix zlib symbol conflicts
+* CMake 3.5.1 is required
+* config.hpp is not a public header
+* Add missing case in error test
+
+--------------------------------------------------------------------------------
+
+Version 121:
+
+* Add test for issue 802
+* Fix enum and non-enum in conditional exp. warning
+
+--------------------------------------------------------------------------------
+
+Version 120:
+
+* Fix spurious strand_ in advanced_server_flex
+* OpenSSL targets are optional (CMake)
+
+--------------------------------------------------------------------------------
+
+Version 119:
+
+* Tidy up doc badge links
+
+--------------------------------------------------------------------------------
+
+Version 118:
+
+* file_win32 opens for read-only in shared mode
+* Remove unused strands in server examples
+* Update build instructions
+* Doc root is at index.html
+
+HTTP:
+
+* Fix writing header into std::ostream
+
+--------------------------------------------------------------------------------
+
+Version 117:
+
+* Add buffers_to_string
+
+API Changes:
+
+* buffers_suffix replaces consuming_buffers
+* buffers_prefix replaces buffer_prefix
+* buffers_prefix_view replaces buffer_prefix_view
+* buffers_front replaces buffer_front
+* buffers_cat replaces buffer_cat
+* buffers_cat_view replaces buffer_cat_view
+* Remove buffers_suffix::get
+
+Actions Required:
+
+* Use buffers_suffix instead of consuming_buffers
+* Use buffers_prefix instead of buffer_prefix
+* Use buffers_prefix_view instead of buffer_prefix_view
+* Use buffers_front instead of buffer_front
+* Use buffers_cat instead of buffer_cat
+* Use buffers_cat_view instead of buffer_cat_view
+* Avoid calling buffers_suffix::get
+
+--------------------------------------------------------------------------------
+
+Version 116:
+
+API Changes:
+
+* message::body is a member function
+* message::version is a member function
+
+Actions Required:
+
+* Call member function message::body instead of accessing
+ the data member at call sites.
+
+* Call member function message::version instead of accessing
+ the version member at call sites.
+
+--------------------------------------------------------------------------------
+
+Version 115:
+
+* Update README.md master doc link
+
+--------------------------------------------------------------------------------
+
+Version 114:
+
+(No changes)
+
+--------------------------------------------------------------------------------
+
+Version 113:
+
+* Fix handler signature in async_read_header
+* Remove field_range copy constructor
+
+--------------------------------------------------------------------------------
+
+Version 112:
+
+* Update websocket notes
+
+API Changes:
+
+* WebSocket writes return the bytes transferred
+
+* HTTP reads and writes return bytes transferred
+
+Actions Required:
+
+* Modify websocket write completion handlers to receive
+ the extra std::size_t bytes_transferred parameter.
+
+* Modify HTTP read and/or write completion handlers to
+ receive the extra std::size_t bytes_transferred parameter.
+
+--------------------------------------------------------------------------------
+
+Version 111:
+
+WebSocket:
+
+* Fix utf8 check split code point at buffer end
+* Refactor stream operations and tests plus coverage
+* Suspended ops special members
+
+--------------------------------------------------------------------------------
+
+Version 110:
+
+* Refactor stream open state variable
+* Refactor websocket stream members
+* Refactor websocket stream: fixes and tests
+* Add test::stream::lowest_layer
+* Fix invalid iterator in test reporter
+
+--------------------------------------------------------------------------------
+
+Version 109:
+
+* refactor test::stream
+
+WebSocket:
+
+* Fix async_read_some handler signature
+* websocket close fixes and tests
+* websocket handshake uses coroutine
+* websocket ping tests
+* Fix websocket close_op resume state
+* websocket write tests
+* split up websocket tests
+* websocket read tests
+
+API Changes:
+
+* websocket accept refactoring
+
+Actions Required:
+
+* Do not call websocket accept overloads which take
+ both a message and a buffer sequence, as it is
+ illegal per rfc6455.
+
+--------------------------------------------------------------------------------
+
+Version 108:
+
+* Fix argument parsing in HTTP examples
+* Don't use async_write_msg in examples
+
+--------------------------------------------------------------------------------
+
+Version 107:
+
+* Use test::stream
+
+WebSocket
+
+* Fix done state for WebSocket reads
+* Fix utf8 check for compressed frames
+* Rename frame and header buffer types
+
+--------------------------------------------------------------------------------
+
+Version 106:
+
+* Dynamic buffer input areas are mutable
+* Add flat_static_buffer::reset
+
+HTTP:
+
+* Fix for basic_parser::skip(true) and docs
+
+WebSocket:
+
+* websocket test improvements
+* Remove obsolete write_op
+* Refactor write_op
+* Refactor ping_op
+* Refactor fail_op
+* Refactor read_op
+* Refactor close_op
+* Refactor read_op + fail_op
+* Websocket close will automatically drain
+* Autobahn|Testsuite fixes
+* Tidy up utf8_checker and tests
+
+--------------------------------------------------------------------------------
+
+Version 105:
+
+* Fix compile error in websocket snippet
+* Tidy up Jamfile and tests
+
+--------------------------------------------------------------------------------
+
+Version 104:
+
+* Remove unused include
+* Use #error in config.hpp
+* Only set -std=c++11 on Travis
+* Only set /permissive- on Appveyor
+* Tidy up some test warnings
+* tools/ renamed from build/
+
+WebSocket:
+
+* Fix pausation::save
+
+--------------------------------------------------------------------------------
+
+Version 103:
+
+* Boost test matrix fixes
+* Tidy up allocator usage
+* Example HTTP server fixes
+
+--------------------------------------------------------------------------------
+
+Version 102:
+
+* Section headings in examples
+
+--------------------------------------------------------------------------------
+
+Version 101:
+
+* Refactor all examples
+
+--------------------------------------------------------------------------------
+
+Version 100:
+
+* Fix doc convenience includes
+* Fix doc includes
+* Remove unused test header
+* Rename test macros
+* Reorder define test macro params
+* vcxproj workaround for include symlinks
+* Add variadic min/max
+
+WebSocket:
+
+* Remove obsolete frame tests
+* Refactor fail/clode code
+* Call do_fail from read_some
+* eof on accept returns error::closed
+* Fix stream::read_size_hint calculation
+* Documentation
+
+API Changes:
+
+* Calls to stream::close and stream::async_close will
+ automatically perform the required read operations
+
+* drain_buffer is removed
+
+* role_type replaces teardown_tag
+
+Actions Required:
+
+* Remove calling code which drains the connection after
+ calling stream::close or stream::async_close
+
+* Replace code which uses drain_buffer. For websocket::stream,
+ it is no longer necessary to manually drain the connection
+ after closing.
+
+* Modify signatures of teardown and async_teardown to use
+ role_type instead of teardown_tag
+
+* Change calls to teardown and async_teardown to pass the
+ correct role_type, client or server, depending on context.
+
+--------------------------------------------------------------------------------
+
+Version 99:
+
+* Log the value of LIB_DIR for doc builds (debug)
+* Use correct handler signature in fail_op
+* Fix doc typo
+
+--------------------------------------------------------------------------------
+
+Version 98:
+
+* basic_fields::key_compare is noexcept
+* Fix bench-zlib cmake
+* Use unique names Jam projects
+* Trim utf8 checker test
+
+--------------------------------------------------------------------------------
+
+Version 97:
+
+* Update redirect
+
+--------------------------------------------------------------------------------
+
+Version 96:
+
+* Move bench/ to test/
+* Move extras/ to test/
+* Use <valgrind> property
+* Rename wsload compile target
+* Fix library.json
+* Update boostorg links
+* Add bench-zlib
+* Faster zlib tests
+* Less compression on websocket test
+
+--------------------------------------------------------------------------------
+
+Version 95:
+
+* Tidy up Travis build scripts
+* Move scripts to build/
+* Fix race in test::pipe
+* close on test::pipe teardown
+* Add test::stream
+* Tidy up static_buffer braced init
+* Fix html redirect
+* Add valgrind variant, fix false positives
+
+--------------------------------------------------------------------------------
+
+Version 94:
+
+* Use off-site Quick Start link temporarily
+
+--------------------------------------------------------------------------------
+
+Version 93:
+
+* Unset BOOST_COROUTINES_NO_DEPRECATION_WARNING
+
+--------------------------------------------------------------------------------
+
+Version 92:
+
+* Fix typo in test/CMakeLists.txt
+* basic_fields::value_type is not copyable
+* Update repository links in source comments
+* Ignore Content-Length in some cases
+* Tidy up doc snippet paths
+* Use off-site doc link
+
+--------------------------------------------------------------------------------
+
+Version 91:
+
+* Adjust redirect html
+* Don't build pre-C++11
+* source.dox is path-independent
+* Tidy up namespace qualifiers
+* Tidy up MSVC CMakeLists.txt
+* Optimize buffered_read_stream
+* constexpr in derived buffers
+* Set BOOST_ASIO_NO_DEPRECATED
+* Use Asio array optimization in static_buffer_base
+* Rename wstest source file
+* Use fopen_s on Windows
+* Fix Appveyor script
+* Update project metadata
+* Move benchmarks to bench/
+* Fix doc title
+* Build stand-alone doc
+* Update doc copyrights
+* Refactor test build scripts
+
+WebSocket:
+
+* Tidy up websocket javadocs
+* Refactor accept, handshake ops
+* Use read buffer instead of buffered stream
+
+API Changes
+
+* control frame callbacks are non-const references
+
+Actions Required:
+
+* Modify calls to set the control frame callback, to
+ pass non-const reference instances, and manage the
+ lifetime of the instance.
+
+--------------------------------------------------------------------------------
+
+Version 90:
+
+* Fix websocket read of zero length message
+* Fix typo in equal_range
+* Output to integrated documentation
+
+--------------------------------------------------------------------------------
+
+Version 89:
+
+* Fix CONTRIBUTING.md links
+
+--------------------------------------------------------------------------------
+
+Version 88:
+
+* Update doc links in README.md
+* Refactor tests Jamfile
+* Don't use program_options
+
+WebSocket:
+
+* Fix uninitialized frame done
+
+--------------------------------------------------------------------------------
+
+Version 87:
+
+* Update appveyor for Boost branch
+* Rename to BEAST_EXPECT
+* variant fixes and tests
+* Update README, add CONTRIBUTING.md and CODE_OF_CONDUCT.md
+
+--------------------------------------------------------------------------------
+
+Version 86:
+
+* Boost prep
+* Remove use of lexical_cast
+* Use custom variant
+* Update README.md
+* Add local-travis.sh
+* Use winapi
+* Update CMakeLists.txt for boost
+* Update documentation for boost
+* Update copyrights
+* Remove spurious declaration
+* Tidy up Jamfile
+* Normalize doc build scripts
+* Use configured doxygen and xsltproc
+* Fix Deferred Body Type Example Documentation
+* Add library metadata
+
+API Changes:
+
+* websocket read returns the number of bytes inserted
+
+Actions Required:
+
+* Change the signature of completion handlers used with
+ websocket::stream::async_read to void(error_code, std::size_t)
+
+--------------------------------------------------------------------------------
+
+Version 85:
+
+* Fix test failure
+* Tidy up test warning
+
+--------------------------------------------------------------------------------
+
+Version 84:
+
+* Tidy up buffer_front
+* static_buffer::consume improvement
+* multi_buffer is type-check friendly
+* bind_handler allows placeholders
+* Add consuming_buffers::get
+
+WebSocket:
+
+* WebSocket read optimization
+
+API Changes:
+
+* websocket::stream::read_buffer_size is removed
+
+Actions Required:
+
+* Remove calls websocket::stream::read_buffer_size
+* Use read_some and write_some instead of read_frame and write_frame
+
+--------------------------------------------------------------------------------
+
+Version 83:
+
+* Add flat_static_buffer::mutable_data
+* Add buffer_front
+* Add wstest compression option
+* Turn some flat_static_buffer_tests on
+* Documentation work
+* read_some, async_read_some return bytes used
+* Fix private timer::clock_type
+
+WebSocket
+
+* Add wstest compression option
+* Fix buffer lifetime in websocket write
+
+API Changes:
+
+* Add static_buffer
+
+Actions Required:
+
+* Callers who depend on static_buffer returning sequences of
+ exactly length one should switch to flat_static_buffer.
+
+--------------------------------------------------------------------------------
+
+Version 82:
+
+* Documentation tidying
+* is_invocable works with move-only types
+* Use std::function and reference wrapper
+* Add session_alloc to example/common
+* Silence spurious warning
+
+HTTP
+
+* Fix extraneous argument in async_write_header
+
+WebSocket
+
+* stream tidying
+* Add rd_close_ to websocket stream state
+* stream uses flat_buffer
+* accept requires a message
+* Add wstest benchmark tool
+
+API Changes:
+
+* Rename to flat_static_buffer and flat_static_buffer_base
+
+Actions Required:
+
+* Rename static_buffer to flat_static_buffer_base
+* Rename static_buffer_n to flat_static_buffer
+
+--------------------------------------------------------------------------------
+
+Version 81:
+
+* Pass string_view by value
+* better is_final on empty_base_optimization
+* Suppress incorrect GCC warning
+* multi_buffer ctor is explicit
+* File is not copy-constructible
+
+API Changes:
+
+* Refactor basic_parser, chunk parsing:
+
+Actions Required:
+
+* Adjust signatures for required members of user-defined
+ subclasses of basic_parser
+
+* Use the new basic_parser chunk callbacks for accessing
+ chunk extensions and chunk bodies.
+
+--------------------------------------------------------------------------------
+
+Version 80:
+
+* Javadoc tidying
+* Add basic_dynamic_body.hpp
+* Shrink buffer_prefix_view
+* Remove unused file_path
+* Add basic_file_body.hpp
+* buffers_ref is Assignable
+
+HTTP
+
+* Shrink chunk header buffer sequence size
+
+API Changes:
+
+* Refactor chunked-encoding serialization
+
+Actions Required:
+
+* Remove references to ChunkDecorators. Use the new chunk-encoding
+ buffer sequences to manually produce a chunked payload body in
+ the case where control over the chunk-extensions and/or trailers
+ is required.
+
+--------------------------------------------------------------------------------
+
+Version 79:
+
+* Remove spurious fallthrough guidance
+
+--------------------------------------------------------------------------------
+
+Version 78:
+
+* Add span
+* Documentation work
+* Use make_unique_noinit
+* Fix warning in zlib
+* Header file tidying
+* Tidy up FieldsReader doc
+* Add Boost.Locale utf8 benchmark comparison
+* Tidy up dstream for existing Boost versions
+* Tidy up file_posix unused variable
+* Fix warning in root ca declaration
+
+HTTP:
+
+* Tidy up basic_string_body
+* Add vector_body
+* span, string, vector bodies are public
+* Fix spurious uninitialized warning
+* fields temp string uses allocator
+
+API Changes:
+
+* Add message::keep_alive()
+* Add message::chunked() and message::content_length()
+* Remove string_view_body
+
+Actions Required:
+
+* Change user defined implementations of Fields and
+ FieldsReader to meet the new requirements.
+
+* Use span_body<char> instead of string_view_body
+
+--------------------------------------------------------------------------------
+
+Version 77:
+
+* file_posix works without large file support
+
+--------------------------------------------------------------------------------
+
+Version 76:
+
+* Always go through write_some
+* Use Boost.Config
+* BodyReader may construct from a non-const message
+* Add serializer::get
+* Add serializer::chunked
+* Serializer members are not const
+* serializing file_body is not const
+* Add file_body_win32
+* Fix parse illegal characters in obs-fold
+* Disable SSE4.2 optimizations
+
+API Changes:
+
+* Rename to serializer::keep_alive
+* BodyReader, BodyWriter use two-phase init
+
+Actions Required:
+
+* Use serializer::keep_alive instead of serializer::close and
+ take the logical NOT of the return value.
+
+* Modify instances of user-defined BodyReader and BodyWriter
+ types to perfrom two-phase initialization, as per the
+ updated documented type requirements.
+
+--------------------------------------------------------------------------------
+
+Version 75:
+
+* Use file_body for valid requests, string_body otherwise.
+* Construct buffer_prefix_view in-place
+* Shrink serializer buffers using buffers_ref
+* Tidy up BEAST_NO_BIG_VARIANTS
+* Shrink serializer buffers using buffers_ref
+* Add serializer::limit
+* file_body tests
+* Using SSE4.2 intrinsics in basic_parser if available
+
+--------------------------------------------------------------------------------
+
+Version 74:
+
+* Add file_stdio and File concept
+* Add file_win32
+* Add file_body
+* Remove common/file_body.hpp
+* Add file_posix
+* Fix Beast include directories for cmake targets
+* remove redundant flush() from example
+
+--------------------------------------------------------------------------------
+
+Version 73:
+
+* Jamroot tweak
+* Verify certificates in SSL clients
+* Adjust benchmarks
+* Initialize local variable in basic_parser
+* Fixes for gcc-4.8
+
+HTTP:
+
+* basic_parser optimizations
+* Add basic_parser tests
+
+API Changes:
+
+* Refactor header and message constructors
+* serializer::next replaces serializer::get
+
+Actions Required:
+
+* Evaluate each message constructor call site and
+ adjust the constructor argument list as needed.
+
+* Use serializer::next instead of serializer::get at call sites
+
+--------------------------------------------------------------------------------
+
+Version 72:
+
+HTTP:
+
+* Tidy up set payload in http-server-fast
+* Refine Body::size specification
+* Newly constructed responses have a 200 OK result
+* Refactor file_body for best practices
+* Add http-server-threaded example
+* Documentation tidying
+* Various improvements to http_server_fast.cpp
+
+WebSocket:
+
+* Add websocket-server-async example
+
+--------------------------------------------------------------------------------
+
+Version 71:
+
+* Fix extra ; warning
+* Documentation revision
+* Fix spurious on_chunk invocation
+* Call prepare_payload in HTTP example
+* Check trailers in test
+* Fix buffer overflow handling for string_body and mutable_body
+* Concept check in basic_dynamic_body
+* Tidy up http_sync_port error check
+* Tidy up Jamroot /permissive-
+
+WebSockets:
+
+* Fine tune websocket op asserts
+* Refactor websocket composed ops
+* Allow close, ping, and write to happen concurrently
+* Fix race in websocket read op
+* Fix websocket write op
+* Add cmake options for examples and tests
+
+API Changes:
+
+* Return `std::size_t` from `Body::writer::put`
+
+Actions Required:
+
+* Return the number of bytes actually transferred from the
+ input buffers in user defined `Body::writer::put` functions.
+
+--------------------------------------------------------------------------------
+
+Version 70:
+
+* Serialize in one step when possible
+* Add basic_parser header and body limits
+* Add parser::on_header to set a callback
+* Fix BEAST_FALLTHROUGH
+* Fix HEAD response in file_service
+
+API Changes:
+
+* Rename to message::base
+* basic_parser default limits are now 1MB/8MB
+
+Actions Required:
+
+* Change calls to message::header_part() with message::base()
+
+* Call body_limit and/or header_limit as needed to adjust the
+ limits to suitable values if the defaults are insufficient.
+
+--------------------------------------------------------------------------------
+
+Version 69:
+
+* basic_parser optimizations
+* Use BEAST_FALLTHROUGH to silence warnings
+* Add /permissive- to msvc toolchain
+
+--------------------------------------------------------------------------------
+
+Version 68:
+
+* Split common tests to a new project
+* Small speed up in fields comparisons
+* Adjust buffer size in fast server
+* Use string_ref in older Boost versions
+* Optimize field lookups
+* Add const_body, mutable_body to examples
+* Link statically on cmake MSVC
+
+API Changes:
+
+* Change BodyReader, BodyWriter requirements
+* Remove BodyReader::is_deferred
+* http::error::bad_target replaces bad_path
+
+Actions Required:
+
+* Change user defined instances of BodyReader and BodyWriter
+ to meet the new requirements.
+
+* Replace references to http::error::bad_path with http::error::bad_target
+
+--------------------------------------------------------------------------------
+
+Version 67:
+
+* Fix doc example link
+* Add http-server-small example
+* Merge stream_base to stream and tidy
+* Use boost::string_view
+* Rename to http-server-fast
+* Appveyor use Boost 1.64.0
+* Group common example headers
+
+API Changes:
+
+* control_callback replaces ping_callback
+
+Actions Required:
+
+* Change calls to websocket::stream::ping_callback to use
+ websocket::stream::control_callback
+
+* Change user defined ping callbacks to have the new
+ signature and adjust the callback definition appropriately.
+
+--------------------------------------------------------------------------------
+
+Version 66:
+
+* string_param optimizations
+* Add serializer request/response aliases
+* Make consuming_buffers smaller
+* Fix costly potential value-init in parser
+* Fix unused parameter warning
+* Handle bad_alloc in parser
+* Tidy up message piecewise ctors
+* Add header aliases
+* basic_fields optimizations
+* Add http-server example
+* Squelch spurious warning on gcc
+
+--------------------------------------------------------------------------------
+
+Version 65:
+
+* Enable narrowing warning on msvc cmake
+* Fix integer types in deflate_stream::bi_reverse
+* Fix narrowing in static_ostream
+* Fix narrowing in ostream
+* Fix narrowing in inflate_stream
+* Fix narrowing in deflate_stream
+* Fix integer warnings
+* Enable unused variable warning on msvc cmake
+
+--------------------------------------------------------------------------------
+
+Version 64:
+
+* Simplify buffered_read_stream composed op
+* Simplify ssl teardown composed op
+* Simplify websocket write_op
+* Exemplars are compiled code
+* Better User-Agent in examples
+* async_write requires a non-const message
+* Doc tidying
+* Add link_directories to cmake
+
+API Changes:
+
+* Remove make_serializer
+
+Actions Required:
+
+* Replace calls to make_serializer with variable declarations
+
+--------------------------------------------------------------------------------
+
+Version 63:
+
+* Use std::to_string instead of lexical_cast
+* Don't use cached Boost
+* Put num_jobs back up on Travis
+* Only build and run tests in variant=coverage
+* Move benchmarks to a separate project
+* Only run the tests under ubasan
+* Tidy up CMakeLists.txt
+* Tidy up Jamfiles
+* Control running with valgrind explicitly
+
+--------------------------------------------------------------------------------
+
+Version 62:
+
+* Remove libssl-dev from a Travis matrix item
+* Increase detail::static_ostream coverage
+* Add server-framework tests
+* Doc fixes and tidy
+* Tidy up namespaces in examples
+* Clear the error faster
+* Avoid explicit operator bool for error
+* Add http::is_fields trait
+* Squelch harmless not_connected errors
+* Put slow tests back for coverage builds
+
+API Changes:
+
+* parser requires basic_fields
+* Refine FieldsReader concept
+* message::prepare_payload replaces message::prepare
+
+Actions Required:
+
+* Callers using `parser` with Fields types other than basic_fields
+ will need to create their own subclass of basic_parser to work
+ with their custom fields type.
+
+* Implement chunked() and keep_alive() for user defined FieldsReader types.
+
+* Change calls to msg.prepare to msg.prepare_payload. For messages
+ with a user-defined Fields, provide the function prepare_payload_impl
+ in the fields type according to the Fields requirements.
+
+--------------------------------------------------------------------------------
+
+Version 61:
+
+* Remove Spirit dependency
+* Use generic_cateogry for errno
+* Reorganize SSL examples
+* Tidy up some integer conversion warnings
+* Add message::header_part()
+* Tidy up names in error categories
+* Flush the output stream in the example
+* Clean close in Secure WebSocket client
+* Add server-framework SSL HTTP and WebSocket ports
+* Fix shadowing warnings
+* Tidy up http-crawl example
+* Add multi_port to server-framework
+* Tidy up resolver calls
+* Use one job on CI
+* Don't run slow tests on certain targets
+
+API Changes:
+
+* header::version is unsigned
+* status-codes is unsigned
+
+--------------------------------------------------------------------------------
+
+Version 60:
+
+* String comparisons are public interfaces
+* Fix response message type in async websocket accept
+* New server-framework, full featured server example
+
+--------------------------------------------------------------------------------
+
+Version 59:
+
+* Integrated Beast INTERFACE (cmake)
+* Fix base64 alphabet
+* Remove obsolete doc/README.md
+
+API Changes:
+
+* Change Body::size signature (API Change):
+
+Actions Required:
+
+* For any user-defined models of Body, change the function signature
+ to accept `value_type const&` and modify the function definition
+ accordingly.
+
+--------------------------------------------------------------------------------
+
+Version 58:
+
+* Fix unaligned reads in utf8-checker
+* Qualify size_t in message template
+* Reorganize examples
+* Specification for http read
+* Avoid `std::string` in websocket
+* Fix basic_fields insert ordering
+* basic_fields::set optimization
+* basic_parser::put doc
+* Use static string in basic_fields::reader
+* Remove redundant code
+* Fix parsing chunk size with leading zeroes
+* Better message formal parameter names
+
+API Changes:
+
+* `basic_fields::set` renamed from `basic_fields::replace`
+
+Actions Required:
+
+* Rename calls to `basic_fields::replace` to `basic_fields::set`
+
+--------------------------------------------------------------------------------
+
+Version 57:
+
+* Fix message.hpp javadocs
+* Fix warning in basic_parser.cpp
+* Integrate docca for documentation and tidy
+
+--------------------------------------------------------------------------------
+
+Version 56:
+
+* Add provisional IANA header field names
+* Add string_view_body
+* Call on_chunk when the extension is empty
+* HTTP/1.1 is the default version
+* Try harder to find Boost (cmake)
+* Reset error codes
+* More basic_parser tests
+* Add an INTERFACE cmake target
+* Convert buffer in range loops
+
+--------------------------------------------------------------------------------
+
+Version 55:
+
+* Don't allocate memory to handle obs-fold
+* Avoid a parser allocation using non-flat buffer
+* read_size replaces read_size_helper
+
+--------------------------------------------------------------------------------
+
+Version 54:
+
+* static_buffer coverage
+* flat_buffer coverage
+* multi_buffer coverage
+* consuming_buffers members and coverage
+* basic_fields members and coverage
+* Add string_param
+* Retain ownership when reading using a message
+* Fix incorrect use of [[fallthrough]]
+
+API Changes:
+
+* basic_fields refactor
+
+--------------------------------------------------------------------------------
+
+Version 53:
+
+* Fix basic_parser::maybe_flatten
+* Fix read_size_helper usage
+
+--------------------------------------------------------------------------------
+
+Version 52:
+
+* flat_buffer is an AllocatorAwareContainer
+* Add drain_buffer class
+
+API Changes:
+
+* `auto_fragment` is a member of `stream`
+* `binary`, `text` are members of `stream`
+* read_buffer_size is a member of `stream`
+* read_message_max is a member of `stream`
+* `write_buffer_size` is a member of `stream`
+* `ping_callback` is a member of stream
+* Remove `opcode` from `read`, `async_read`
+* `read_frame` returns `bool` fin
+* `opcode` is private
+* finish(error_code&) is a BodyReader requirement
+
+Actions Required:
+
+* Change call sites which use `auto_fragment` with `set_option`
+ to call `stream::auto_fragment` instead.
+
+* Change call sites which use message_type with `set_option`
+ to call `stream::binary` or `stream::text` instead.
+
+* Change call sites which use `read_buffer_size` with `set_option` to
+ call `stream::read_buffer_size` instead.
+
+* Change call sites which use `read_message_max` with `set_option` to
+ call `stream::read_message_max` instead.
+
+* Change call sites which use `write_buffer_size` with `set_option` to
+ call `stream::write_buffer_size` instead.
+
+* Change call sites which use `ping_callback1 with `set_option` to
+ call `stream::ping_callback` instead.
+
+* Remove the `opcode` reference parameter from calls to synchronous
+ and asynchronous read functions, replace the logic with calls to
+ `stream::got_binary` and `stream::got_text` instead.
+
+* Remove the `frame_info` parameter from all read frame call sites
+
+* Check the return value 'fin' for calls to `read_frame`
+
+* Change ReadHandlers passed to `async_read_frame` to have
+ the signature `void(error_code, bool fin)`, use the `bool`
+ to indicate if the frame is the last frame.
+
+* Remove all occurrences of the `opcode` enum at call sites
+
+--------------------------------------------------------------------------------
+
+Version 51
+
+* Fix operator<< for header
+* Tidy up file_body
+* Fix file_body::get() not setting the more flag correctly
+* Use BOOST_FALLTHROUGH
+* Use BOOST_STRINGIZE
+* DynamicBuffer benchmarks
+* Add construct, destroy to handler_alloc
+* Fix infinite loop in basic_parser
+
+API Changes:
+
+* Tune up static_buffer
+* multi_buffer implementation change
+
+Actions Required:
+
+* Call sites passing a number to multi_buffer's constructor
+ will need to be adjusted, see the corresponding commit message.
+
+--------------------------------------------------------------------------------
+
+Version 50
+
+* parser is constructible from other body types
+* Add field enumeration
+* Use allocator more in basic_fields
+* Fix basic_fields allocator awareness
+* Use field in basic_fields and call sites
+* Use field in basic_parser
+* Tidy up basic_fields, header, and field concepts
+* Fields concept work
+* Body documentation work
+* Add missing handler_alloc nested types
+* Fix chunk delimiter parsing
+* Fix test::pipe read_size
+* Fix chunk header parsing
+
+API Changes:
+
+* Remove header_parser
+* Add verb to on_request for parsers
+* Refactor prepare
+* Protect basic_fields special members
+* Remove message connection settings
+* Remove message free functions
+* Remove obsolete serializer allocator
+* http read_some, async_read_some don't return bytes
+
+--------------------------------------------------------------------------------
+
+Version 49
+
+* Use <iosfwd> instead of <ostream>
+
+HTTP:
+
+* Add HEAD request example
+
+API Changes:
+
+* Refactor method and verb
+* Canonicalize string_view parameter types
+* Tidy up empty_body writer error
+* Refactor header status, reason, and target
+
+--------------------------------------------------------------------------------
+
+Version 48
+
+* Make buffer_prefix_view public
+* Remove detail::sync_ostream
+* Tidy up core type traits
+
+API Changes:
+
+* Tidy up chunk decorator
+* Rename to buffer_cat_view
+* Consolidate parsers to parser.hpp
+* Rename to parser
+
+--------------------------------------------------------------------------------
+
+Version 47
+
+* Disable operator<< for buffer_body
+* buffer_size overload for basic_multi_buffer::const_buffers_type
+* Fix undefined behavior in pausation
+* Fix leak in basic_flat_buffer
+
+API Changes:
+
+* Refactor treatment of request-method
+* Refactor treatment of status code and obsolete reason
+* Refactor HTTP serialization and parsing
+
+--------------------------------------------------------------------------------
+
+Version 46
+
+* Add test::pipe
+* Documentation work
+
+API Changes:
+
+* Remove HTTP header aliases
+* Refactor HTTP serialization
+* Refactor type traits
+
+--------------------------------------------------------------------------------
+
+Version 45
+
+* Workaround for boost::asio::basic_streambuf type check
+* Fix message doc image
+* Better test::enable_yield_to
+* Fix header::reason
+* Documentation work
+* buffer_view skips empty buffer sequences
+* Disable reverse_iterator buffer_view test
+
+--------------------------------------------------------------------------------
+
+Version 44
+
+* Use BOOST_THROW_EXCEPTION
+* Tidy up read_size_helper and dynamic buffers
+* Require Boost 1.58.0 or later
+* Tidy up and make get_lowest_layer public
+* Use BOOST_STATIC_ASSERT
+* Fix async return values in docs
+* Fix README websocket example
+* Add buffers_adapter regression test
+* Tidy up is_dynamic_buffer traits test
+* Make buffers_adapter meet requirements
+
+--------------------------------------------------------------------------------
+
+Version 43
+
+* Require Boost 1.64.0
+* Fix strict aliasing warnings in buffers_view
+* Tidy up buffer_prefix overloads and test
+* Add write limit to test::string_ostream
+* Additional constructors for consuming_buffers
+
+--------------------------------------------------------------------------------
+
+Version 42
+
+* Fix javadoc typo
+* Add formal review notes
+* Make buffers_view a public interface
+
+--------------------------------------------------------------------------------
+
+Version 41
+
+* Trim Appveyor matrix rows
+* Concept revision and documentation
+* Remove coveralls integration
+* Tidy up formal parameter names
+
+WebSocket
+
+* Tidy up websocket::close_code enum and constructors
+
+API Changes
+
+* Return http::error::end_of_stream on HTTP read eof
+* Remove placeholders
+* Rename prepare_buffer(s) to buffer_prefix
+* Remove handler helpers, tidy up hook invocations
+
+--------------------------------------------------------------------------------
+
+Version 40
+
+* Add to_static_string
+* Consolidate get_lowest_layer in type_traits.hpp
+* Fix basic_streambuf movable trait
+* Tidy up .travis.yml
+
+--------------------------------------------------------------------------------
+
+Version 39
+
+Beast versions are now identified by a single integer which
+is incremented on each merge. The macro BEAST_VERSION
+identifies the version number, currently at 39. A version
+setting commit will always be at the tip of the master
+and develop branches.
+
+* Use beast::string_view alias
+* Fixed braced-init error with older gcc
+
+HTTP
+
+* Tidy up basic_parser javadocs
+
+WebSocket:
+
+* Add websocket async echo ssl server test:
+* Fix eof error on ssl::stream shutdown
+
+API Changes:
+
+* Refactor http::header contents
+* New ostream() returns dynamic buffer output stream
+* New buffers() replaces to_string()
+* Rename to multi_buffer, basic_multi_buffer
+* Rename to flat_buffer, basic_flat_buffer
+* Rename to static_buffer, static_buffer_n
+* Rename to buffered_read_stream
+* Harmonize concepts and identifiers with net-ts
+* Tidy up HTTP reason_string
+
+--------------------------------------------------------------------------------
+
+1.0.0-b38
+
+* Refactor static_string
+* Refactor base64
+* Use static_string for WebSocket handshakes
+* Simplify get_lowest_layer test
+* Add test_allocator to extras/test
+* More flat_streambuf tests
+* WebSocket doc work
+* Prevent basic_fields operator[] assignment
+
+API Changes:
+
+* Refactor WebSocket error codes
+* Remove websocket::keep_alive option
+
+--------------------------------------------------------------------------------
+
+1.0.0-b37
+
+* CMake hide command lines in .vcxproj Output windows"
+* Rename to detail::is_invocable
+* Rename project to http-bench
+* Fix flat_streambuf
+* Add ub sanitizer blacklist
+* Add -funsigned-char to asan build target
+* Fix narrowing warning in table constants
+
+WebSocket:
+
+* Add is_upgrade() free function
+* Document websocket::stream thread safety
+* Rename to websocket::detail::pausation
+
+API Changes:
+
+* Provide websocket::stream accept() overloads
+* Refactor websocket decorators
+* Move everything in basic_fields.hpp to fields.hpp
+* Rename to http::dynamic_body, consolidate header
+
+--------------------------------------------------------------------------------
+
+1.0.0-b36
+
+* Update README.md
+
+--------------------------------------------------------------------------------
+
+1.0.0-b35
+
+* Add Appveyor build scripts and badge
+* Tidy up MSVC CMake configuration
+* Make close_code a proper enum
+* Add flat_streambuf
+* Rename to BEAST_DOXYGEN
+* Update .gitignore for VS2017
+* Fix README.md CMake instructions
+
+API Changes:
+
+* New HTTP interfaces
+* Remove http::empty_body
+
+--------------------------------------------------------------------------------
+
+1.0.0-b34
+
+* Fix and tidy up CMake build scripts
+
+--------------------------------------------------------------------------------
+
+1.0.0-b33
+
+* Require Visual Studio 2015 Update 3 or later
+
+HTTP
+
+* Use fwrite return value in file_body
+
+WebSocket
+
+* Set internal state correctly when writing frames
+* Add decorator unit test
+* Add write_frames unit test
+
+--------------------------------------------------------------------------------
+
+1.0.0-b32
+
+* Add io_service completion invariants test
+* Update CMake scripts for finding packages
+
+API Changes:
+
+* Remove http Writer suspend and resume feature
+
+--------------------------------------------------------------------------------
+
+1.0.0-b31
+
+* Tidy up build settings
+* Add missing dynabuf_readstream member
+
+WebSocket
+
+* Move the handler, don't copy it
+
+--------------------------------------------------------------------------------
+
+1.0.0-b30
+
+WebSocket
+
+* Fix race in pings during reads
+* Fix race in close frames during reads
+* Fix race when write suspends
+* Allow concurrent websocket async ping and writes
+
+--------------------------------------------------------------------------------
+
+1.0.0-b29
+
+* Fix compilation error in non-template class
+* Document type-pun in buffer_cat
+* Correctly check ostream modifier (/extras)
+
+HTTP
+
+* Fix Body requirements doc
+* Fix illegal HTTP characters accepted as hex zero
+* Fix Writer return value documentation
+
+WebSocket
+
+* Fix race in writes during reads
+* Fix doc link typo
+
+--------------------------------------------------------------------------------
+
+1.0.0-b28
+
+* Split out and rename test stream classes
+* Restyle async result constructions
+* Fix HTTP split parse edge case
+
+--------------------------------------------------------------------------------
+
+1.0.0-b27
+
+* Tidy up tests and docs
+* Add documentation building instructions
+
+API Changes:
+
+* Invoke callback on pings and pongs
+* Move basic_streambuf to streambuf.hpp
+
+--------------------------------------------------------------------------------
+
+1.0.0-b26
+
+* Tidy up warnings and tests
+
+--------------------------------------------------------------------------------
+
+1.0.0-b25
+
+* Fixes for WebSocket echo server
+* Fix 32-bit arm7 warnings
+* Remove unnecessary include
+* WebSocket server examples and test tidying
+* Fix deflate setup bug
+
+API Changes:
+
+* Better handler_ptr
+
+--------------------------------------------------------------------------------
+
+1.0.0-b24
+
+* bjam use clang on MACOSX
+* Simplify Travis package install specification
+* Add optional yield_to arguments
+* Make decorator copyable
+* Add WebSocket permessage-deflate extension support
+
+--------------------------------------------------------------------------------
+
+1.0.0-b23
+
+* Tune websocket echo server for performance
+* Add file and line number to thrown exceptions
+* Better logging in async echo server
+* Add copy special members
+* Fix message constructor and special members
+* Travis CI improvements
+
+--------------------------------------------------------------------------------
+
+1.0.0-b22
+
+* Fix broken Intellisense
+* Implement the Asio deallocation-before-invocation guarantee
+* Add handler helpers
+* Avoid copies in handler_alloc
+* Update README.md example programs
+* Fix websocket stream read documentation
+* Disable Boost.Coroutine deprecation warning
+* Update documentation examples
+
+--------------------------------------------------------------------------------
+
+1.0.0-b21
+
+* Remove extraneous includes
+
+--------------------------------------------------------------------------------
+
+1.0.0-b20
+
+ZLib
+
+* Add ZLib module
+
+API Changes:
+
+* Rename HTTP identifiers
+
+--------------------------------------------------------------------------------
+
+1.0.0-b19
+
+* Boost library min/max guidance
+* Improvements to code coverage
+* Use boost::lexical_cast instead of std::to_string
+* Fix prepare_buffers value_type
+* Fix consuming_buffers value_type
+* Better buffer_cat
+
+HTTP
+
+* Make chunk_encode public
+* Add write, async_write, operator<< for message_headers
+* Add read, async_read for message_headers
+* Fix with_body example
+
+WebSocket
+
+* Optimize utf8 validation
+* Optimize mask operations
+
+API Changes:
+
+* Refactor message and message_headers declarations
+* prepared_buffers is private
+* consume_buffers is removed
+
+--------------------------------------------------------------------------------
+
+1.0.0-b18
+
+* Increase optimization settings for MSVC builds
+
+HTTP
+
+* Check invariants in parse_op:
+* Clean up message docs
+
+WebSocket
+
+* Write buffer option does not change capacity
+* Close connection during async_read on close frame
+* Add pong, async pong to stream
+
+Core
+
+* Meet DynamicBuffer requirements for static_streambuf
+* Fix write_frame masking and auto-fragment handling
+
+Extras
+
+* unit_test::suite fixes:
+ - New overload of fail() specifies file and line
+ - BEAST_EXPECTS only evaluates the reason string on a failure
+* Add zlib module
+
+--------------------------------------------------------------------------------
+
+1.0.0-b17
+
+* Change implicit to default value in example
+* Tidy up some declarations
+* Fix basic_streambuf::capacity
+* Add basic_streambuf::alloc_size
+* Parser callbacks may not throw
+* Fix Reader concept doc typo
+* Add is_Reader trait
+* Tidy up basic_headers for documentation
+* Tidy up documentation
+* Add basic_parser_v1::reset
+* Fix handling of body_what::pause in basic_parser_v1
+* Add headers_parser
+* Engaged invokable is destructible
+* Improve websocket example in README.md
+* Refactor read_size_helper
+
+API Changes:
+
+* Added init() to Reader requirements
+* Reader must be nothrow constructible
+* Reader is now constructed right before reading the body
+ - The message passed on construction is filled in
+* Rework HTTP concepts:
+ - Writer uses write instead of operator()
+ - Refactor traits to use void_t
+ - Remove is_ReadableBody, is_WritableBody
+ - Add has_reader, has_writer, is_Reader, is_Writer
+ - More friendly compile errors on failed concept checks
+* basic_parser_v1 requires all callbacks present
+* on_headers parser callback now returns void
+* on_body_what is a new required parser callback returning body_what
+
+--------------------------------------------------------------------------------
+
+1.0.0-b16
+
+* Make value optional in param-list
+* Frame processing routines are member functions
+* Fix on_headers called twice from basic_parser_v1
+* Constrain parser_v1 constructor
+* Improve first line serialization
+* Add pause option to on_headers interface
+* Refactor base_parser_v1 callback traits:
+* Refine Parser concept
+* Relax ForwardIterator requirements in FieldSequence
+* Fix websocket failure testing
+* Refine Writer concept and fix exemplar in documentation
+
+API Changes:
+
+* Rename mask_buffer_size to write_buffer_size
+* Make auto_fragment a boolean option
+
+The message class hierarchy is refactored (breaking change):
+
+* One message class now models both HTTP/1 and HTTP/2 messages
+* message_v1, request_v1, response_v1 removed
+* New classes basic_request and basic_response model
+ messages without the body.
+
+ Error resolution: Callers should use message, request,
+ and response instead of message_v1, request_v1, and
+ response_v1 respectively.
+
+--------------------------------------------------------------------------------
+
+1.0.0-b15
+
+* rfc7230 section 3.3.2 compliance
+* Add HTTPS example
+* Add Secure WebSocket example
+* Fix message_v1 constructor
+* Tidy up DynamicBuffer requirements
+* Tidy up error types and headers
+* Fix handling empty HTTP headers in parser_v1
+
+--------------------------------------------------------------------------------
+
+1.0.0-b14
+
+* Add missing rebind to handler_alloc
+* Fix error handling in http server examples
+* Fix CMake scripts for MinGW
+* Use BOOST_ASSERT
+* Better WebSocket decorator
+* Update and tidy documentation
+
+--------------------------------------------------------------------------------
+
+1.0.0-b13
+
+* dstream improvements
+* Remove bin and bin64 directories
+* Tidy up .vcxproj file groupings
+
+--------------------------------------------------------------------------------
+
+1.0.0-b12
+
+* Use -p to print suites from unit test main.
+* BEAST_EXPECTS to add a reason string to test failures
+* Fix unit test runner to output all case names
+* Update README for build requirements
+* Rename to CHANGELOG.md
+
+--------------------------------------------------------------------------------
+
+1.0.0-b11
+
+* Set URI in generated WebSocket Upgrade requests
+* Rename echo server class and file names
+* Rename to DynamicBuffer in some code and documentation
+* Fix integer warnings in Windows builds
+* Add 32 and 64 bit Windows build support
+* Update README for build instructions and more
+* Add repository and documention banners
+
+--------------------------------------------------------------------------------
+
+1.0.0-b10
+
+* Fix compilation warnings
+* Add websocketpp comparison to HTML documentation
+
+--------------------------------------------------------------------------------
+
+1.0.0-b9
+
+* Fix CMakeLists.txt
+
+--------------------------------------------------------------------------------
+
+1.0.0-b8
+
+* Fix include in example code
+* Fix basic_headers rfc2616 Section 4.2 compliance
+
+--------------------------------------------------------------------------------
+
+1.0.0-b7
+
+* Fix prepare by calling init. prepare() can throw depending on the
+ implementation of Writer. Publicly provided beast::http writers never throw.
+* Fixes to example HTTP server
+* Fully qualify ambiguous calls to read and parse
+* Remove deprecated http::stream wrapper
+* Example HTTP server now calculates the MIME-type
+* Fixes and documentation for teardown and use with SSL:
+* Add example code to rfc7230 javadocs
+* Remove extraneous header file <beast/http/status.hpp>
+* Add skip_body parser option
+
+--------------------------------------------------------------------------------
+
+1.0.0-b6
+
+* Use SFINAE on return values
+* Use beast::error_code instead of nested types
+* Tidy up use of GENERATING_DOCS
+* Remove obsolete RFC2616 functions
+* Add message swap members and free functions
+* Add HTTP field value parser containers: ext_list, param_list, token_list
+* Fixes for some corner cases in basic_parser_v1
+* Configurable limits on headers and body sizes in basic_parser_v1
+
+API Changes:
+
+* ci_equal is moved to beast::http namespace, in rfc7230.hpp
+
+* "DynamicBuffer","dynabuf" renamed from "Streambuf", "streambuf". See:
+ http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2015/n4478.html#requirements.dynamic_buffers
+
+* basic_parser_v1 adheres to rfc7230 as strictly as possible
+
+--------------------------------------------------------------------------------
diff --git a/contrib/restricted/boost/beast/CODE_OF_CONDUCT.md b/contrib/restricted/boost/beast/CODE_OF_CONDUCT.md
new file mode 100644
index 0000000000..f20c98a738
--- /dev/null
+++ b/contrib/restricted/boost/beast/CODE_OF_CONDUCT.md
@@ -0,0 +1,9 @@
+# Code of Conduct
+
+* Be respectful of others
+
+* Please use professional conduct
+
+* Treat others the way you want to be treated
+
+Thank you!
diff --git a/contrib/restricted/boost/beast/CONTRIBUTING.md b/contrib/restricted/boost/beast/CONTRIBUTING.md
new file mode 100644
index 0000000000..de3f11cf1a
--- /dev/null
+++ b/contrib/restricted/boost/beast/CONTRIBUTING.md
@@ -0,0 +1,65 @@
+# Contributing to Beast
+
+Thank you for taking the time to read this document!
+
+:heart_eyes: **please star the Boost.Beast repository!** :heart_eyes:
+
+First make sure you're on the
+[official repository page](https://github.com/boostorg/beast/blob/master/CONTRIBUTING.md),
+then just press the button labeled "star" in the top right of the page
+to give Beast a star! Your stars create generate additional visibility,
+which leads to more users, more bug reports, more fixes, more testing,
+more features, and a better product!
+
+<a href="https://github.com/boostorg/beast/blob/master/CONTRIBUTING.md">
+<img width="400" height = "150" alt = "Please Star the Repository"
+ src="https://raw.githubusercontent.com/vinniefalco/BeastAssets/master/StarTheRepo.png">
+</a>
+
+Click the image above to make sure you're on the official
+Boost repository page so you can give Beast a star!
+
+# Ways to Contribute
+
+No contribution to Beast is too big or too small! We are
+always happy to see user participation in all of its forms.
+Here are some of the ways that you can contribute (this is
+by no means an exhaustive list):
+
+* Submit a
+ [bug report](https://github.com/boostorg/beast/issues).
+ We love hearing about broken things, so
+ that we can fix them. Any problem is fair game, this includes
+ the documentation examples, tests, and repository as well as the
+ library itself. Bug reports should be opened on the
+ [Issues](https://github.com/boostorg/beast/issues) page.
+
+* Provide
+ [feedback](https://github.com/boostorg/beast/issues).
+ about the library. If you have used, are using,
+ or are thinking about using the library we want to hear about it!
+ The more information you provide, the better we will be able
+ to ensure that Beast meets your needs. You can provide feedback
+ as an issue, or email the author directly.
+
+* Test Beast. When changes are made, they are submitted as a
+ [Pull Request](https://github.com/boostorg/beast/pulls).
+ Everyone is welcome to examine these upcoming changes, test them,
+ and report on the results. This form of quality assurance is very
+ helpful so we can keep delivering a great product. Consider
+ subscribing to repository notifications to get alerted to new
+ pull requests.
+
+* Code Review on
+ [Pull Requests](https://github.com/boostorg/beast/pulls).
+ This is one of the most valuable ways to contribute, because it helps
+ to improve code and features, and helps to find bugs, before the code
+ gets merged. A little bit of time investment from just a few people on
+ each pull request goes a **long** way to increasing the quality of the
+ final product. For tips on how to participate in pull requests please
+ view the
+ [README.md](https://github.com/boostorg/beast#contributing-we-need-your-help).
+
+* Use Beast in your next application! At the end of the day, it is the
+ goal of the library to provide utility to users so the best way you
+ can contribute is simply to use the library!
diff --git a/contrib/restricted/boost/beast/LICENSE_1_0.txt b/contrib/restricted/boost/beast/LICENSE_1_0.txt
new file mode 100644
index 0000000000..36b7cd93cd
--- /dev/null
+++ b/contrib/restricted/boost/beast/LICENSE_1_0.txt
@@ -0,0 +1,23 @@
+Boost Software License - Version 1.0 - August 17th, 2003
+
+Permission is hereby granted, free of charge, to any person or organization
+obtaining a copy of the software and accompanying documentation covered by
+this license (the "Software") to use, reproduce, display, distribute,
+execute, and transmit the Software, and to prepare derivative works of the
+Software, and to permit third-parties to whom the Software is furnished to
+do so, all subject to the following:
+
+The copyright notices in the Software and this entire statement, including
+the above license grant, this restriction and the following disclaimer,
+must be included in all copies of the Software, in whole or in part, and
+all derivative works of the Software, unless such copies or derivative
+works are solely in the form of machine-executable object code generated by
+a source language processor.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
+SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
+FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
+ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+DEALINGS IN THE SOFTWARE.
diff --git a/contrib/restricted/boost/beast/README.md b/contrib/restricted/boost/beast/README.md
new file mode 100644
index 0000000000..62220de99f
--- /dev/null
+++ b/contrib/restricted/boost/beast/README.md
@@ -0,0 +1,212 @@
+<img width="880" height = "80" alt = "Boost.Beast Title"
+ src="https://raw.githubusercontent.com/boostorg/beast/master/doc/images/readme2.png">
+
+# HTTP and WebSocket built on Boost.Asio in C++11
+
+Branch | Linux/OSX | Windows | Coverage | Documentation | Matrix
+------------|-----------|---------|----------|---------------|--------
+[master](https://github.com/boostorg/beast/tree/master) | [![Build Status](https://travis-ci.org/boostorg/beast.svg?branch=master)](https://travis-ci.org/boostorg/beast) | [![Build status](https://ci.appveyor.com/api/projects/status/g0llpbvhpjuxjnlw/branch/master?svg=true)](https://ci.appveyor.com/project/vinniefalco/beast/branch/master) | [![codecov](https://codecov.io/gh/boostorg/Beast/branch/master/graph/badge.svg)](https://codecov.io/gh/boostorg/beast/branch/master) | [![Documentation](https://img.shields.io/badge/documentation-master-brightgreen.svg)](http://www.boost.org/doc/libs/master/libs/beast/doc/html/index.html) | [![Matrix](https://img.shields.io/badge/matrix-master-brightgreen.svg)](http://www.boost.org/development/tests/master/developer/beast.html)
+[develop](https://github.com/boostorg/beast/tree/develop) | [![Build Status](https://travis-ci.org/boostorg/beast.svg?branch=develop)](https://travis-ci.org/boostorg/beast) | [![Build status](https://ci.appveyor.com/api/projects/status/g0llpbvhpjuxjnlw/branch/develop?svg=true)](https://ci.appveyor.com/project/vinniefalco/beast/branch/develop) | [![codecov](https://codecov.io/gh/boostorg/Beast/branch/develop/graph/badge.svg)](https://codecov.io/gh/boostorg/beast/branch/develop) | [![Documentation](https://img.shields.io/badge/documentation-develop-brightgreen.svg)](http://www.boost.org/doc/libs/develop/libs/beast/index.html) | [![Matrix](https://img.shields.io/badge/matrix-develop-brightgreen.svg)](http://www.boost.org/development/tests/develop/developer/beast.html)
+
+## Contents
+
+- [Introduction](#introduction)
+- [Appearances](#appearances)
+- [Description](#description)
+- [Requirements](#requirements)
+- [Git Branches](#branches)
+- [Building](#building)
+- [Usage](#usage)
+- [License](#license)
+- [Contact](#contact)
+- [Contributing](#Contributing)
+
+## Introduction
+
+Beast is a C++ header-only library serving as a foundation for writing
+interoperable networking libraries by providing **low-level HTTP/1,
+WebSocket, and networking protocol** vocabulary types and algorithms
+using the consistent asynchronous model of Boost.Asio.
+
+This library is designed for:
+
+* **Symmetry:** Algorithms are role-agnostic; build clients, servers, or both.
+
+* **Ease of Use:** Boost.Asio users will immediately understand Beast.
+
+* **Flexibility:** Users make the important decisions such as buffer or
+ thread management.
+
+* **Performance:** Build applications handling thousands of connections or more.
+
+* **Basis for Further Abstraction.** Components are well-suited for building upon.
+
+## Appearances
+
+| <a href="https://www.bishopfox.com/case_study/securing-beast/">Bishop Fox 2018</a> |
+| ------------ |
+| <a href="https://youtu.be/4TtyYbGDAj0"><img width="320" height = "180" alt="Beast Security Review" src="https://raw.githubusercontent.com/vinniefalco/BeastAssets/master/BishopFox2018.png"></a> |
+
+| <a href="https://raw.githubusercontent.com/vinniefalco/CppCon2017/master/Make%20Classes%20Great%20Again%20-%20Vinnie%20Falco%20-%20CppCon%202017.pdf">CppCon 2017</a> | <a href="http://cppcast.com/2017/01/vinnie-falco/">CppCast 2017</a> | <a href="https://raw.githubusercontent.com/vinniefalco/BeastAssets/master/CppCon2016.pdf">CppCon 2016</a> |
+| ------------ | ------------ | ----------- |
+| <a href="https://www.youtube.com/watch?v=WsUnnYEKPnI"><img width="320" height = "180" alt="Beast" src="https://raw.githubusercontent.com/vinniefalco/CppCon2017/master/CppCon2017.png"></a> | <a href="http://cppcast.com/2017/01/vinnie-falco/"><img width="180" height="180" alt="Vinnie Falco" src="https://avatars1.githubusercontent.com/u/1503976?v=3&u=76c56d989ef4c09625256662eca2775df78a16ad&s=180"></a> | <a href="https://www.youtube.com/watch?v=uJZgRcvPFwI"><img width="320" height = "180" alt="Beast" src="https://raw.githubusercontent.com/vinniefalco/BeastAssets/master/CppCon2016.png"></a> |
+
+## Description
+
+This software is in its first official release. Interfaces
+may change in response to user feedback. For recent changes
+see the [CHANGELOG](CHANGELOG.md).
+
+* [Official Site](https://github.com/boostorg/beast)
+* [Documentation](http://www.boost.org/doc/libs/master/libs/beast/) (master branch)
+* [Autobahn|Testsuite WebSocket Results](https://vinniefalco.github.io/boost/beast/reports/autobahn/index.html)
+
+## Requirements
+
+This library is for programmers familiar with Boost.Asio. Users
+who wish to use asynchronous interfaces should already know how to
+create concurrent network programs using callbacks or coroutines.
+
+* **C++11:** Robust support for most language features.
+* **Boost:** Boost.Asio and some other parts of Boost.
+* **OpenSSL:** Optional, for using TLS/Secure sockets.
+
+When using Microsoft Visual C++, Visual Studio 2015 Update 3 or later is required.
+
+One of these components is required in order to build the tests and examples:
+
+* Properly configured bjam/b2
+* CMake 3.5.1 or later (Windows only)
+
+## Branches
+
+The official repository contains the following branches:
+
+* [**master**](https://github.com/boostorg/beast/tree/master) This
+ holds the most recent snapshot with code that is known to be stable.
+
+* [**develop**](https://github.com/boostorg/beast/tree/develop) This
+ holds the most recent snapshot. It may contain unstable code.
+
+Each of these branches requires a corresponding Boost branch and
+all of its subprojects. For example, if you wish to use the **master**
+branch version of Beast, you should clone the Boost superproject,
+switch to the **master** branch in the superproject and acquire
+all the Boost libraries corresponding to that branch including Beast.
+
+Or, to use the latest shipping version of Beast, simply use it
+from the corresponding distribution of Boost.
+
+## Building
+
+Beast is header-only. To use it just add the necessary `#include` line
+to your source files, like this:
+```C++
+#include <boost/beast.hpp>
+```
+
+To build your program successfully, you'll need to add the Boost.System
+library to link with. If you use coroutines you'll also need to link
+with the Boost.Coroutine library. Please visit the Boost documentation
+for instructions on how to do this for your particular build system.
+
+To build the documentation, examples, tests, and benchmarks it is
+necessary to first obtain the Boost "superproject" along with sources of
+all of the Boost libraries, then run the `b2` command to build the Boost
+libraries.
+Instructions for doing so may be found on
+the [Boost Wiki](https://github.com/boostorg/boost/wiki/Getting-Started).
+These commamnds will build the programs and documentation that come
+with Beast (omit the cxxflags parameter when building using MSVC):
+
+```
+cd boost # The directory containing the Boost superproject and libraries
+b2 libs/beast/test cxxflags="-std=c++11" # bjam must be in your $PATH
+b2 libs/beast/example cxxflags="-std=c++11"
+b2 libs/beast/doc
+```
+
+On Windows platforms only, CMake may be used to generate a Visual Studio
+solution and a set of Visual Studio project files using these commands:
+
+```
+cd boost # The directory containing the Boost superproject and libraries
+cd libs/beast
+mkdir bin
+cd bin
+cmake .. # for 32-bit Windows builds, or
+cmake -G"Visual Studio 14 2015 Win64" .. # for 64-bit Windows builds (VS2015), or
+cmake -G"Visual Studio 15 2017 Win64" .. # for 64-bit Windows builds (VS2017)
+```
+
+The files in the repository are laid out thusly:
+
+```
+./
+ bin/ Create this to hold executables and project files
+ bin64/ Create this to hold 64-bit Windows executables and project files
+ doc/ Source code and scripts for the documentation
+ include/ Where the header files live
+ extras/ Additional APIs, may change
+ example/ Self contained example programs
+ meta/ Metadata for Boost integration
+ scripts/ Small scripts used with CI systems
+ test/ Unit tests
+```
+
+## Usage
+
+These examples are complete, self-contained programs that you can build
+and run yourself (they are in the `example` directory).
+
+http://www.boost.org/doc/libs/develop/libs/beast/doc/html/beast/quick_start.html
+
+## License
+
+Distributed under the Boost Software License, Version 1.0.
+(See accompanying file [LICENSE_1_0.txt](LICENSE_1_0.txt) or copy at
+http://www.boost.org/LICENSE_1_0.txt)
+
+## Contact
+
+Please report issues or questions here:
+https://github.com/boostorg/beast/issues
+
+---
+
+## Contributing (We Need Your Help!)
+
+If you would like to contribute to Beast and help us maintain high
+quality, consider performing code reviews on active pull requests.
+Any feedback from users and stakeholders, even simple questions about
+how things work or why they were done a certain way, carries value
+and can be used to improve the library. Code review provides these
+benefits:
+
+* Identify bugs
+* Documentation proof-reading
+* Adjust interfaces to suit use-cases
+* Simplify code
+
+You can look through the Closed pull requests to get an idea of how
+reviews are performed. To give a code review just sign in with your
+GitHub account and then add comments to any open pull requests below,
+don't be shy!
+<p>https://github.com/boostorg/beast/pulls</p>
+
+Here are some resources to learn more about
+code reviews:
+
+* <a href="https://blog.scottnonnenberg.com/top-ten-pull-request-review-mistakes/">Top 10 Pull Request Review Mistakes</a>
+* <a href="https://smartbear.com/SmartBear/media/pdfs/best-kept-secrets-of-peer-code-review.pdf">Best Kept Secrets of Peer Code Review (pdf)</a>
+* <a href="http://support.smartbear.com/support/media/resources/cc/11_Best_Practices_for_Peer_Code_Review.pdf">11 Best Practices for Peer Code Review (pdf)</a>
+* <a href="http://www.evoketechnologies.com/blog/code-review-checklist-perform-effective-code-reviews/">Code Review Checklist – To Perform Effective Code Reviews</a>
+* <a href="https://www.codeproject.com/Articles/524235/Codeplusreviewplusguidelines">Code review guidelines</a>
+* <a href="https://github.com/isocpp/CppCoreGuidelines/blob/master/CppCoreGuidelines.md">C++ Core Guidelines</a>
+* <a href="https://doc.lagout.org/programmation/C/CPP101.pdf">C++ Coding Standards (Sutter & Andrescu)</a>
+
+Beast thrives on code reviews and any sort of feedback from users and
+stakeholders about its interfaces. Even if you just have questions,
+asking them in the code review or in issues provides valuable information
+that can be used to improve the library - do not hesitate, no question
+is insignificant or unimportant!
diff --git a/contrib/restricted/boost/boost/beast.hpp b/contrib/restricted/boost/boost/beast.hpp
deleted file mode 100644
index f2d74ed84b..0000000000
--- a/contrib/restricted/boost/boost/beast.hpp
+++ /dev/null
@@ -1,21 +0,0 @@
-//
-// Copyright (c) 2013-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HPP
-#define BOOST_BEAST_HPP
-
-#include <boost/beast/core/detail/config.hpp> // must come first
-
-#include <boost/beast/core.hpp>
-#include <boost/beast/http.hpp>
-#include <boost/beast/version.hpp>
-#include <boost/beast/websocket.hpp>
-#include <boost/beast/zlib.hpp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core.hpp b/contrib/restricted/boost/boost/beast/core.hpp
deleted file mode 100644
index 620d42ada6..0000000000
--- a/contrib/restricted/boost/boost/beast/core.hpp
+++ /dev/null
@@ -1,41 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_CORE_HPP
-#define BOOST_BEAST_CORE_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-
-#include <boost/beast/core/bind_handler.hpp>
-#include <boost/beast/core/buffered_read_stream.hpp>
-#include <boost/beast/core/buffers_adapter.hpp>
-#include <boost/beast/core/buffers_cat.hpp>
-#include <boost/beast/core/buffers_prefix.hpp>
-#include <boost/beast/core/buffers_suffix.hpp>
-#include <boost/beast/core/buffers_to_string.hpp>
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/core/file.hpp>
-#include <boost/beast/core/file_base.hpp>
-#include <boost/beast/core/file_posix.hpp>
-#include <boost/beast/core/file_stdio.hpp>
-#include <boost/beast/core/file_win32.hpp>
-#include <boost/beast/core/flat_buffer.hpp>
-#include <boost/beast/core/flat_static_buffer.hpp>
-#include <boost/beast/core/handler_ptr.hpp>
-#include <boost/beast/core/multi_buffer.hpp>
-#include <boost/beast/core/ostream.hpp>
-#include <boost/beast/core/read_size.hpp>
-#include <boost/beast/core/span.hpp>
-#include <boost/beast/core/static_buffer.hpp>
-#include <boost/beast/core/static_string.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/core/string_param.hpp>
-#include <boost/beast/core/type_traits.hpp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/bind_handler.hpp b/contrib/restricted/boost/boost/beast/core/bind_handler.hpp
deleted file mode 100644
index 0fb7b8233b..0000000000
--- a/contrib/restricted/boost/boost/beast/core/bind_handler.hpp
+++ /dev/null
@@ -1,78 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_BIND_HANDLER_HPP
-#define BOOST_BEAST_BIND_HANDLER_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/core/detail/bind_handler.hpp>
-#include <type_traits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-
-/** Bind parameters to a completion handler, creating a new handler.
-
- This function creates a new handler which, when invoked, calls
- the original handler with the list of bound arguments. Any
- parameters passed in the invocation will be substituted for
- placeholders present in the list of bound arguments. Parameters
- which are not matched to placeholders are silently discarded.
-
- The passed handler and arguments are forwarded into the returned
- handler, whose associated allocator and associated executor will
- will be the same as those of the original handler.
-
- Example:
-
- @code
- template<class AsyncReadStream, class ReadHandler>
- void
- signal_aborted(AsyncReadStream& stream, ReadHandler&& handler)
- {
- boost::asio::post(
- stream.get_executor(),
- bind_handler(std::forward<ReadHandler>(handler),
- boost::asio::error::operation_aborted, 0));
- }
- @endcode
-
- @param handler The handler to wrap.
-
- @param args A list of arguments to bind to the handler.
- The arguments are forwarded into the returned object. These
- arguments may include placeholders, which will operate in
- a fashion identical to a call to `std::bind`.
-*/
-template<class Handler, class... Args>
-#if BOOST_BEAST_DOXYGEN
-implementation_defined
-#else
-detail::bound_handler<
- typename std::decay<Handler>::type, Args...>
-#endif
-bind_handler(Handler&& handler, Args&&... args)
-{
-#if 0
- // Can't do this because of placeholders
- static_assert(is_completion_handler<
- Handler, void(Args...)>::value,
- "Handler requirements not met");
-#endif
- return detail::bound_handler<typename std::decay<
- Handler>::type, Args...>(std::forward<
- Handler>(handler), std::forward<Args>(args)...);
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/buffered_read_stream.hpp b/contrib/restricted/boost/boost/beast/core/buffered_read_stream.hpp
deleted file mode 100644
index 974062309f..0000000000
--- a/contrib/restricted/boost/boost/beast/core/buffered_read_stream.hpp
+++ /dev/null
@@ -1,372 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_BUFFERED_READ_STREAM_HPP
-#define BOOST_BEAST_BUFFERED_READ_STREAM_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/core/multi_buffer.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/asio/async_result.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/asio/io_context.hpp>
-#include <cstdint>
-#include <utility>
-
-namespace boost {
-namespace beast {
-
-/** A @b Stream with attached @b DynamicBuffer to buffer reads.
-
- This wraps a @b Stream implementation so that calls to write are
- passed through to the underlying stream, while calls to read will
- first consume the input sequence stored in a @b DynamicBuffer which
- is part of the object.
-
- The use-case for this class is different than that of the
- `boost::asio::buffered_readstream`. It is designed to facilitate
- the use of `boost::asio::read_until`, and to allow buffers
- acquired during detection of handshakes to be made transparently
- available to callers. A hypothetical implementation of the
- buffered version of `boost::asio::ssl::stream::async_handshake`
- could make use of this wrapper.
-
- Uses:
-
- @li Transparently leave untouched input acquired in calls
- to `boost::asio::read_until` behind for subsequent callers.
-
- @li "Preload" a stream with handshake input data acquired
- from other sources.
-
- Example:
- @code
- // Process the next HTTP header on the stream,
- // leaving excess bytes behind for the next call.
- //
- template<class DynamicBuffer>
- void process_http_message(
- buffered_read_stream<DynamicBuffer>& stream)
- {
- // Read up to and including the end of the HTTP
- // header, leaving the sequence in the stream's
- // buffer. read_until may read past the end of the
- // headers; the return value will include only the
- // part up to the end of the delimiter.
- //
- std::size_t bytes_transferred =
- boost::asio::read_until(
- stream.next_layer(), stream.buffer(), "\r\n\r\n");
-
- // Use buffers_prefix() to limit the input
- // sequence to only the data up to and including
- // the trailing "\r\n\r\n".
- //
- auto header_buffers = buffers_prefix(
- bytes_transferred, stream.buffer().data());
-
- ...
-
- // Discard the portion of the input corresponding
- // to the HTTP headers.
- //
- stream.buffer().consume(bytes_transferred);
-
- // Everything we read from the stream
- // is part of the content-body.
- }
- @endcode
-
- @tparam Stream The type of stream to wrap.
-
- @tparam DynamicBuffer The type of stream buffer to use.
-*/
-template<class Stream, class DynamicBuffer>
-class buffered_read_stream
-{
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
-
- template<class Buffers, class Handler>
- class read_some_op;
-
- DynamicBuffer buffer_;
- std::size_t capacity_ = 0;
- Stream next_layer_;
-
-public:
- /// The type of the internal buffer
- using buffer_type = DynamicBuffer;
-
- /// The type of the next layer.
- using next_layer_type =
- typename std::remove_reference<Stream>::type;
-
- /// The type of the lowest layer.
- using lowest_layer_type = get_lowest_layer<next_layer_type>;
-
- /** Move constructor.
-
- @note The behavior of move assignment on or from streams
- with active or pending operations is undefined.
- */
- buffered_read_stream(buffered_read_stream&&) = default;
-
- /** Move assignment.
-
- @note The behavior of move assignment on or from streams
- with active or pending operations is undefined.
- */
- buffered_read_stream& operator=(buffered_read_stream&&) = default;
-
- /** Construct the wrapping stream.
-
- @param args Parameters forwarded to the `Stream` constructor.
- */
- template<class... Args>
- explicit
- buffered_read_stream(Args&&... args);
-
- /// Get a reference to the next layer.
- next_layer_type&
- next_layer()
- {
- return next_layer_;
- }
-
- /// Get a const reference to the next layer.
- next_layer_type const&
- next_layer() const
- {
- return next_layer_;
- }
-
- /// Get a reference to the lowest layer.
- lowest_layer_type&
- lowest_layer()
- {
- return next_layer_.lowest_layer();
- }
-
- /// Get a const reference to the lowest layer.
- lowest_layer_type const&
- lowest_layer() const
- {
- return next_layer_.lowest_layer();
- }
-
- /** Get the executor associated with the object.
-
- This function may be used to obtain the executor object that the stream
- uses to dispatch handlers for asynchronous operations.
-
- @return A copy of the executor that stream will use to dispatch handlers.
-
- @note This function participates in overload resolution only if
- `NextLayer` has a member function named `get_executor`.
- */
-#if BOOST_BEAST_DOXYGEN
- implementation_defined
-#else
- template<
- class T = next_layer_type,
- class = typename std::enable_if<
- has_get_executor<next_layer_type>::value>::type>
- auto
-#endif
- get_executor() noexcept ->
- decltype(std::declval<T&>().get_executor())
- {
- return next_layer_.get_executor();
- }
-
- /** Access the internal buffer.
-
- The internal buffer is returned. It is possible for the
- caller to break invariants with this function. For example,
- by causing the internal buffer size to increase beyond
- the caller defined maximum.
- */
- DynamicBuffer&
- buffer()
- {
- return buffer_;
- }
-
- /// Access the internal buffer
- DynamicBuffer const&
- buffer() const
- {
- return buffer_;
- }
-
- /** Set the maximum buffer size.
-
- This changes the maximum size of the internal buffer used
- to hold read data. No bytes are discarded by this call. If
- the buffer size is set to zero, no more data will be buffered.
-
- Thread safety:
- The caller is responsible for making sure the call is
- made from the same implicit or explicit strand.
-
- @param size The number of bytes in the read buffer.
-
- @note This is a soft limit. If the new maximum size is smaller
- than the amount of data in the buffer, no bytes are discarded.
- */
- void
- capacity(std::size_t size)
- {
- capacity_ = size;
- }
-
- /** Read some data from the stream.
-
- This function is used to read data from the stream.
- The function call will block until one or more bytes of
- data has been read successfully, or until an error occurs.
-
- @param buffers One or more buffers into which the data will be read.
-
- @return The number of bytes read.
-
- @throws system_error Thrown on failure.
- */
- template<class MutableBufferSequence>
- std::size_t
- read_some(MutableBufferSequence const& buffers);
-
- /** Read some data from the stream.
-
- This function is used to read data from the stream.
- The function call will block until one or more bytes of
- data has been read successfully, or until an error occurs.
-
- @param buffers One or more buffers into which the data will be read.
-
- @param ec Set to the error, if any occurred.
-
- @return The number of bytes read, or 0 on error.
- */
- template<class MutableBufferSequence>
- std::size_t
- read_some(MutableBufferSequence const& buffers,
- error_code& ec);
-
- /** Start an asynchronous read.
-
- This function is used to asynchronously read data from
- the stream. The function call always returns immediately.
-
- @param buffers One or more buffers into which the data
- will be read. Although the buffers object may be copied
- as necessary, ownership of the underlying memory blocks
- is retained by the caller, which must guarantee that they
- remain valid until the handler is called.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& error, // result of operation
- std::size_t bytes_transferred // number of bytes transferred
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<class MutableBufferSequence, class ReadHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
- async_read_some(MutableBufferSequence const& buffers,
- ReadHandler&& handler);
-
- /** Write some data to the stream.
-
- This function is used to write data to the stream.
- The function call will block until one or more bytes of the
- data has been written successfully, or until an error occurs.
-
- @param buffers One or more data buffers to be written to the stream.
-
- @return The number of bytes written.
-
- @throws system_error Thrown on failure.
- */
- template<class ConstBufferSequence>
- std::size_t
- write_some(ConstBufferSequence const& buffers)
- {
- static_assert(is_sync_write_stream<next_layer_type>::value,
- "SyncWriteStream requirements not met");
- return next_layer_.write_some(buffers);
- }
-
- /** Write some data to the stream.
-
- This function is used to write data to the stream.
- The function call will block until one or more bytes of the
- data has been written successfully, or until an error occurs.
-
- @param buffers One or more data buffers to be written to the stream.
-
- @param ec Set to the error, if any occurred.
-
- @return The number of bytes written.
- */
- template<class ConstBufferSequence>
- std::size_t
- write_some(ConstBufferSequence const& buffers,
- error_code& ec)
- {
- static_assert(is_sync_write_stream<next_layer_type>::value,
- "SyncWriteStream requirements not met");
- return next_layer_.write_some(buffers, ec);
- }
-
- /** Start an asynchronous write.
-
- This function is used to asynchronously write data from
- the stream. The function call always returns immediately.
-
- @param buffers One or more data buffers to be written to
- the stream. Although the buffers object may be copied as
- necessary, ownership of the underlying memory blocks is
- retained by the caller, which must guarantee that they
- remain valid until the handler is called.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& error, // result of operation
- std::size_t bytes_transferred // number of bytes transferred
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<class ConstBufferSequence, class WriteHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
- async_write_some(ConstBufferSequence const& buffers,
- WriteHandler&& handler);
-};
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/buffered_read_stream.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/buffers_adapter.hpp b/contrib/restricted/boost/boost/beast/core/buffers_adapter.hpp
deleted file mode 100644
index 826183ed06..0000000000
--- a/contrib/restricted/boost/boost/beast/core/buffers_adapter.hpp
+++ /dev/null
@@ -1,164 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_BUFFERS_ADAPTER_HPP
-#define BOOST_BEAST_BUFFERS_ADAPTER_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-
-/** Adapts a @b MutableBufferSequence into a @b DynamicBuffer.
-
- This class wraps a @b MutableBufferSequence to meet the requirements
- of @b DynamicBuffer. Upon construction the input and output sequences are
- empty. A copy of the mutable buffer sequence object is stored; however,
- ownership of the underlying memory is not transferred. The caller is
- responsible for making sure that referenced memory remains valid
- for the duration of any operations.
-
- The size of the mutable buffer sequence determines the maximum
- number of bytes which may be prepared and committed.
-
- @tparam MutableBufferSequence The type of mutable buffer sequence to wrap.
-*/
-template<class MutableBufferSequence>
-class buffers_adapter
-{
- static_assert(boost::asio::is_mutable_buffer_sequence<MutableBufferSequence>::value,
- "MutableBufferSequence requirements not met");
-
- using iter_type = typename
- detail::buffer_sequence_iterator<
- MutableBufferSequence>::type;
-
- MutableBufferSequence bs_;
- iter_type begin_;
- iter_type out_;
- iter_type end_;
- std::size_t max_size_;
- std::size_t in_pos_ = 0; // offset in *begin_
- std::size_t in_size_ = 0; // size of input sequence
- std::size_t out_pos_ = 0; // offset in *out_
- std::size_t out_end_ = 0; // output end offset
-
- template<class Deduced>
- buffers_adapter(Deduced&& other,
- std::size_t nbegin, std::size_t nout,
- std::size_t nend)
- : bs_(std::forward<Deduced>(other).bs_)
- , begin_(std::next(bs_.begin(), nbegin))
- , out_(std::next(bs_.begin(), nout))
- , end_(std::next(bs_.begin(), nend))
- , max_size_(other.max_size_)
- , in_pos_(other.in_pos_)
- , in_size_(other.in_size_)
- , out_pos_(other.out_pos_)
- , out_end_(other.out_end_)
- {
- }
-
-public:
-#if BOOST_BEAST_DOXYGEN
- /// The type used to represent the input sequence as a list of buffers.
- using const_buffers_type = implementation_defined;
-
- /// The type used to represent the output sequence as a list of buffers.
- using mutable_buffers_type = implementation_defined;
-
-#else
- class const_buffers_type;
-
- class mutable_buffers_type;
-
-#endif
-
- /// Move constructor.
- buffers_adapter(buffers_adapter&& other);
-
- /// Copy constructor.
- buffers_adapter(buffers_adapter const& other);
-
- /// Move assignment.
- buffers_adapter& operator=(buffers_adapter&& other);
-
- /// Copy assignment.
- buffers_adapter& operator=(buffers_adapter const&);
-
- /** Construct a buffers adapter.
-
- @param buffers The mutable buffer sequence to wrap. A copy of
- the object will be made, but ownership of the memory is not
- transferred.
- */
- explicit
- buffers_adapter(MutableBufferSequence const& buffers);
-
- /// Returns the largest size output sequence possible.
- std::size_t
- max_size() const
- {
- return max_size_;
- }
-
- /// Get the size of the input sequence.
- std::size_t
- size() const
- {
- return in_size_;
- }
-
- /// Returns the maximum sum of the sizes of the input sequence and output sequence the buffer can hold without requiring reallocation.
- std::size_t
- capacity() const
- {
- return max_size_;
- }
-
- /** Get a list of buffers that represents the output sequence, with the given size.
-
- @throws std::length_error if the size would exceed the limit
- imposed by the underlying mutable buffer sequence.
-
- @note Buffers representing the input sequence acquired prior to
- this call remain valid.
- */
- mutable_buffers_type
- prepare(std::size_t n);
-
- /** Move bytes from the output sequence to the input sequence.
-
- @note Buffers representing the input sequence acquired prior to
- this call remain valid.
- */
- void
- commit(std::size_t n);
-
- /** Get a list of buffers that represents the input sequence.
-
- @note These buffers remain valid across subsequent calls to `prepare`.
- */
- const_buffers_type
- data() const;
-
- /// Remove bytes from the input sequence.
- void
- consume(std::size_t n);
-};
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/buffers_adapter.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/buffers_cat.hpp b/contrib/restricted/boost/boost/beast/core/buffers_cat.hpp
deleted file mode 100644
index 1d711b3b30..0000000000
--- a/contrib/restricted/boost/boost/beast/core/buffers_cat.hpp
+++ /dev/null
@@ -1,119 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_BUFFERS_CAT_HPP
-#define BOOST_BEAST_BUFFERS_CAT_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <tuple>
-
-namespace boost {
-namespace beast {
-
-/** A buffer sequence representing a concatenation of buffer sequences.
-
- @see @ref buffers_cat
-*/
-template<class... Buffers>
-class buffers_cat_view
-{
- std::tuple<Buffers...> bn_;
-
-public:
- /** The type of buffer returned when dereferencing an iterator.
-
- If every buffer sequence in the view is a @b MutableBufferSequence,
- then `value_type` will be `boost::asio::mutable_buffer`.
- Otherwise, `value_type` will be `boost::asio::const_buffer`.
- */
-#if BOOST_BEAST_DOXYGEN
- using value_type = implementation_defined;
-#else
- using value_type = typename
- detail::common_buffers_type<Buffers...>::type;
-#endif
-
- /// The type of iterator used by the concatenated sequence
- class const_iterator;
-
- /// Constructor
- buffers_cat_view(buffers_cat_view&&) = default;
-
- /// Assignment
- buffers_cat_view& operator=(buffers_cat_view&&) = default;
-
- /// Assignment
- buffers_cat_view& operator=(buffers_cat_view const&) = default;
-
- /** Constructor
-
- @param buffers The list of buffer sequences to concatenate.
- Copies of the arguments will be made; however, the ownership
- of memory is not transferred.
- */
- explicit
- buffers_cat_view(Buffers const&... buffers);
-
- //-----
-
- /// Required for @b BufferSequence
- buffers_cat_view(buffers_cat_view const&) = default;
-
- /// Required for @b BufferSequence
- const_iterator
- begin() const;
-
- /// Required for @b BufferSequence
- const_iterator
- end() const;
-};
-
-/** Concatenate 2 or more buffer sequences.
-
- This function returns a constant or mutable buffer sequence which,
- when iterated, efficiently concatenates the input buffer sequences.
- Copies of the arguments passed will be made; however, the returned
- object does not take ownership of the underlying memory. The
- application is still responsible for managing the lifetime of the
- referenced memory.
-
- @param buffers The list of buffer sequences to concatenate.
-
- @return A new buffer sequence that represents the concatenation of
- the input buffer sequences. This buffer sequence will be a
- @b MutableBufferSequence if each of the passed buffer sequences is
- also a @b MutableBufferSequence; otherwise the returned buffer
- sequence will be a @b ConstBufferSequence.
-
- @see @ref buffers_cat_view
-*/
-#if BOOST_BEAST_DOXYGEN
-template<class... BufferSequence>
-buffers_cat_view<BufferSequence...>
-buffers_cat(BufferSequence const&... buffers)
-#else
-template<class B1, class B2, class... Bn>
-inline
-buffers_cat_view<B1, B2, Bn...>
-buffers_cat(B1 const& b1, B2 const& b2, Bn const&... bn)
-#endif
-{
- static_assert(
- detail::is_all_const_buffer_sequence<B1, B2, Bn...>::value,
- "BufferSequence requirements not met");
- return buffers_cat_view<B1, B2, Bn...>{b1, b2, bn...};
-}
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/buffers_cat.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/buffers_prefix.hpp b/contrib/restricted/boost/boost/beast/core/buffers_prefix.hpp
deleted file mode 100644
index 858723fe7d..0000000000
--- a/contrib/restricted/boost/boost/beast/core/buffers_prefix.hpp
+++ /dev/null
@@ -1,237 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_BUFFERS_PREFIX_HPP
-#define BOOST_BEAST_BUFFERS_PREFIX_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/optional/optional.hpp>
-#include <cstdint>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-
-/** A buffer sequence adapter that shortens the sequence size.
-
- The class adapts a buffer sequence to efficiently represent
- a shorter subset of the original list of buffers starting
- with the first byte of the original sequence.
-
- @tparam BufferSequence The buffer sequence to adapt.
-*/
-template<class BufferSequence>
-class buffers_prefix_view
-{
- using buffers_type = typename
- std::decay<BufferSequence>::type;
-
- using iter_type = typename
- detail::buffer_sequence_iterator<buffers_type>::type;
-
- BufferSequence bs_;
- std::size_t size_;
- iter_type end_;
-
- template<class Deduced>
- buffers_prefix_view(
- Deduced&& other, std::size_t dist)
- : bs_(std::forward<Deduced>(other).bs_)
- , size_(other.size_)
- , end_(std::next(bs_.begin(), dist))
- {
- }
-
- void
- setup(std::size_t size);
-
-public:
- /// The type for each element in the list of buffers.
- using value_type = typename std::conditional<
- std::is_convertible<typename
- std::iterator_traits<iter_type>::value_type,
- boost::asio::mutable_buffer>::value,
- boost::asio::mutable_buffer,
- boost::asio::const_buffer>::type;
-
-#if BOOST_BEAST_DOXYGEN
- /// A bidirectional iterator type that may be used to read elements.
- using const_iterator = implementation_defined;
-
-#else
- class const_iterator;
-
-#endif
-
- /// Move constructor.
- buffers_prefix_view(buffers_prefix_view&&);
-
- /// Copy constructor.
- buffers_prefix_view(buffers_prefix_view const&);
-
- /// Move assignment.
- buffers_prefix_view& operator=(buffers_prefix_view&&);
-
- /// Copy assignment.
- buffers_prefix_view& operator=(buffers_prefix_view const&);
-
- /** Construct a buffer sequence prefix.
-
- @param size The maximum number of bytes in the prefix.
- If this is larger than the size of passed, buffers,
- the resulting sequence will represent the entire
- input sequence.
-
- @param buffers The buffer sequence to adapt. A copy of
- the sequence will be made, but ownership of the underlying
- memory is not transferred.
- */
- buffers_prefix_view(
- std::size_t size,
- BufferSequence const& buffers);
-
- /** Construct a buffer sequence prefix in-place.
-
- @param size The maximum number of bytes in the prefix.
- If this is larger than the size of passed, buffers,
- the resulting sequence will represent the entire
- input sequence.
-
- @param args Arguments forwarded to the contained buffers constructor.
- */
- template<class... Args>
- buffers_prefix_view(
- std::size_t size,
- boost::in_place_init_t,
- Args&&... args);
-
- /// Get a bidirectional iterator to the first element.
- const_iterator
- begin() const;
-
- /// Get a bidirectional iterator to one past the last element.
- const_iterator
- end() const;
-};
-
-/** Returns a prefix of a constant buffer.
-
- The returned buffer points to the same memory as the
- passed buffer, but with a size that is equal to or less
- than the size of the original buffer.
-
- @param size The size of the returned buffer.
-
- @param buffer The buffer to shorten. The underlying
- memory is not modified.
-
- @return A new buffer that points to the first `size`
- bytes of the original buffer.
-*/
-inline
-boost::asio::const_buffer
-buffers_prefix(std::size_t size,
- boost::asio::const_buffer buffer)
-{
- return {buffer.data(),
- (std::min)(size, buffer.size())};
-}
-
-/** Returns a prefix of a mutable buffer.
-
- The returned buffer points to the same memory as the
- passed buffer, but with a size that is equal to or less
- than the size of the original buffer.
-
- @param size The size of the returned buffer.
-
- @param buffer The buffer to shorten. The underlying
- memory is not modified.
-
- @return A new buffer that points to the first `size` bytes
- of the original buffer.
-*/
-inline
-boost::asio::mutable_buffer
-buffers_prefix(std::size_t size,
- boost::asio::mutable_buffer buffer)
-{
- return {buffer.data(),
- (std::min)(size, buffer.size())};
-}
-
-/** Returns a prefix of a buffer sequence.
-
- This function returns a new buffer sequence which when iterated,
- presents a shorter subset of the original list of buffers starting
- with the first byte of the original sequence.
-
- @param size The maximum number of bytes in the wrapped
- sequence. If this is larger than the size of passed,
- buffers, the resulting sequence will represent the
- entire input sequence.
-
- @param buffers An instance of @b ConstBufferSequence or
- @b MutableBufferSequence to adapt. A copy of the sequence
- will be made, but ownership of the underlying memory is
- not transferred.
-*/
-template<class BufferSequence>
-#if BOOST_BEAST_DOXYGEN
-buffers_prefix_view<BufferSequence>
-#else
-inline
-typename std::enable_if<
- ! std::is_same<BufferSequence,
- boost::asio::const_buffer>::value &&
- ! std::is_same<BufferSequence,
- boost::asio::mutable_buffer>::value,
- buffers_prefix_view<BufferSequence>>::type
-#endif
-buffers_prefix(std::size_t size, BufferSequence const& buffers)
-{
- static_assert(
- boost::asio::is_const_buffer_sequence<BufferSequence>::value ||
- boost::asio::is_mutable_buffer_sequence<BufferSequence>::value,
- "BufferSequence requirements not met");
- return buffers_prefix_view<BufferSequence>(size, buffers);
-}
-
-/** Returns the first buffer in a buffer sequence
-
- This returns the first buffer in the buffer sequence.
- If the buffer sequence is an empty range, the returned
- buffer will have a zero buffer size.
-
- @param buffers The buffer sequence. If the sequence is
- mutable, the returned buffer sequence will also be mutable.
- Otherwise, the returned buffer sequence will be constant.
-*/
-template<class BufferSequence>
-typename std::conditional<
- boost::asio::is_mutable_buffer_sequence<BufferSequence>::value,
- boost::asio::mutable_buffer,
- boost::asio::const_buffer>::type
-buffers_front(BufferSequence const& buffers)
-{
- auto const first =
- boost::asio::buffer_sequence_begin(buffers);
- if(first == boost::asio::buffer_sequence_end(buffers))
- return {};
- return *first;
-}
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/buffers_prefix.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/buffers_suffix.hpp b/contrib/restricted/boost/boost/beast/core/buffers_suffix.hpp
deleted file mode 100644
index 3959694577..0000000000
--- a/contrib/restricted/boost/boost/beast/core/buffers_suffix.hpp
+++ /dev/null
@@ -1,160 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_BUFFERS_SUFFIX_HPP
-#define BOOST_BEAST_BUFFERS_SUFFIX_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/optional.hpp>
-#include <cstdint>
-#include <iterator>
-#include <utility>
-
-namespace boost {
-namespace beast {
-
-/** Adapter to trim the front of a `BufferSequence`.
-
- This adapter wraps a buffer sequence to create a new sequence
- which may be incrementally consumed. Bytes consumed are removed
- from the front of the buffer. The underlying memory is not changed,
- instead the adapter efficiently iterates through a subset of
- the buffers wrapped.
-
- The wrapped buffer is not modified, a copy is made instead.
- Ownership of the underlying memory is not transferred, the application
- is still responsible for managing its lifetime.
-
- @tparam BufferSequence The buffer sequence to wrap.
-
- @par Example
-
- This function writes the entire contents of a buffer sequence
- to the specified stream.
-
- @code
- template<class SyncWriteStream, class ConstBufferSequence>
- void send(SyncWriteStream& stream, ConstBufferSequence const& buffers)
- {
- buffers_suffix<ConstBufferSequence> bs{buffers};
- while(boost::asio::buffer_size(bs) > 0)
- bs.consume(stream.write_some(bs));
- }
- @endcode
-*/
-template<class BufferSequence>
-class buffers_suffix
-{
- using buffers_type =
- typename std::decay<BufferSequence>::type;
-
- using iter_type = typename
- detail::buffer_sequence_iterator<buffers_type>::type;
-
- BufferSequence bs_;
- iter_type begin_;
- std::size_t skip_ = 0;
-
- template<class Deduced>
- buffers_suffix(Deduced&& other, std::size_t dist)
- : bs_(std::forward<Deduced>(other).bs_)
- , begin_(std::next(
- boost::asio::buffer_sequence_begin(bs_),
- dist))
- , skip_(other.skip_)
- {
- }
-
-public:
- /** The type for each element in the list of buffers.
-
- If the buffers in the underlying sequence are convertible to
- `boost::asio::mutable_buffer`, then this type will be
- `boost::asio::mutable_buffer`, else this type will be
- `boost::asio::const_buffer`.
- */
-#if BOOST_BEAST_DOXYGEN
- using value_type = implementation_defined;
-#else
- using value_type = typename std::conditional<
- std::is_convertible<typename
- std::iterator_traits<iter_type>::value_type,
- boost::asio::mutable_buffer>::value,
- boost::asio::mutable_buffer,
- boost::asio::const_buffer>::type;
-#endif
-
-#if BOOST_BEAST_DOXYGEN
- /// A bidirectional iterator type that may be used to read elements.
- using const_iterator = implementation_defined;
-
-#else
- class const_iterator;
-
-#endif
-
- /// Constructor
- buffers_suffix();
-
- /// Constructor
- buffers_suffix(buffers_suffix&&);
-
- /// Constructor
- buffers_suffix(buffers_suffix const&);
-
- /** Constructor
-
- A copy of the buffer sequence is made. Ownership of the
- underlying memory is not transferred or copied.
- */
- explicit
- buffers_suffix(BufferSequence const& buffers);
-
- /** Constructor
-
- This constructs the buffer sequence in-place from
- a list of arguments.
-
- @param args Arguments forwarded to the buffers constructor.
- */
- template<class... Args>
- buffers_suffix(boost::in_place_init_t, Args&&... args);
-
- /// Assignment
- buffers_suffix& operator=(buffers_suffix&&);
-
- /// Assignment
- buffers_suffix& operator=(buffers_suffix const&);
-
- /// Get a bidirectional iterator to the first element.
- const_iterator
- begin() const;
-
- /// Get a bidirectional iterator to one past the last element.
- const_iterator
- end() const;
-
- /** Remove bytes from the beginning of the sequence.
-
- @param amount The number of bytes to remove. If this is
- larger than the number of bytes remaining, all the
- bytes remaining are removed.
- */
- void
- consume(std::size_t amount);
-};
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/buffers_suffix.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/buffers_to_string.hpp b/contrib/restricted/boost/boost/beast/core/buffers_to_string.hpp
deleted file mode 100644
index aae3d3aa57..0000000000
--- a/contrib/restricted/boost/boost/beast/core/buffers_to_string.hpp
+++ /dev/null
@@ -1,59 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_BUFFERS_TO_STRING_HPP
-#define BOOST_BEAST_BUFFERS_TO_STRING_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <string>
-
-namespace boost {
-namespace beast {
-
-/** Return a string representing the contents of a buffer sequence.
-
- This function returns a string representing an entire buffer
- sequence. Nulls and unprintable characters in the buffer
- sequence are inserted to the resulting string as-is. No
- character conversions are performed.
-
- @param buffers The buffer sequence to convert
-
- @par Example
-
- This function writes a buffer sequence converted to a string
- to `std::cout`.
-
- @code
- template<class ConstBufferSequence>
- void print(ConstBufferSequence const& buffers)
- {
- std::cout << buffers_to_string(buffers) << std::endl;
- }
- @endcode
-*/
-template<class ConstBufferSequence>
-std::string
-buffers_to_string(ConstBufferSequence const& buffers)
-{
- std::string result;
- result.reserve(boost::asio::buffer_size(buffers));
- for(boost::asio::const_buffer buffer :
- detail::buffers_range(buffers))
- result.append(reinterpret_cast<
- char const*>(buffer.data()), buffer.size());
- return result;
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/allocator.hpp b/contrib/restricted/boost/boost/beast/core/detail/allocator.hpp
deleted file mode 100644
index e893f5c274..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/allocator.hpp
+++ /dev/null
@@ -1,42 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_DETAIL_ALLOCATOR_HPP
-#define BOOST_BEAST_DETAIL_ALLOCATOR_HPP
-
-#include <boost/config.hpp>
-#ifdef BOOST_NO_CXX11_ALLOCATOR
-#include <boost/container/allocator_traits.hpp>
-#else
-#include <memory>
-#endif
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-// This is a workaround for allocator_traits
-// implementations which falsely claim C++11
-// compatibility.
-
-#ifdef BOOST_NO_CXX11_ALLOCATOR
-template<class Alloc>
-using allocator_traits = boost::container::allocator_traits<Alloc>;
-
-#else
-template<class Alloc>
-using allocator_traits = std::allocator_traits<Alloc>;
-
-#endif
-
-} // detail
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/base64.hpp b/contrib/restricted/boost/boost/beast/core/detail/base64.hpp
deleted file mode 100644
index 6cb3f67a77..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/base64.hpp
+++ /dev/null
@@ -1,251 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-/*
- Portions from http://www.adp-gmbh.ch/cpp/common/base64.html
- Copyright notice:
-
- base64.cpp and base64.h
-
- Copyright (C) 2004-2008 Rene Nyffenegger
-
- This source code is provided 'as-is', without any express or implied
- warranty. In no event will the author be held liable for any damages
- arising from the use of this software.
-
- Permission is granted to anyone to use this software for any purpose,
- including commercial applications, and to alter it and redistribute it
- freely, subject to the following restrictions:
-
- 1. The origin of this source code must not be misrepresented; you must not
- claim that you wrote the original source code. If you use this source code
- in a product, an acknowledgment in the product documentation would be
- appreciated but is not required.
-
- 2. Altered source versions must be plainly marked as such, and must not be
- misrepresented as being the original source code.
-
- 3. This notice may not be removed or altered from any source distribution.
-
- Rene Nyffenegger rene.nyffenegger@adp-gmbh.ch
-
-*/
-
-#ifndef BOOST_BEAST_DETAIL_BASE64_HPP
-#define BOOST_BEAST_DETAIL_BASE64_HPP
-
-#include <cctype>
-#include <string>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-namespace base64 {
-
-inline
-char const*
-get_alphabet()
-{
- static char constexpr tab[] = {
- "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
- };
- return &tab[0];
-}
-
-inline
-signed char const*
-get_inverse()
-{
- static signed char constexpr tab[] = {
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 0-15
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 16-31
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63, // 32-47
- 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, -1, -1, -1, // 48-63
- -1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, // 64-79
- 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1, // 80-95
- -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, // 96-111
- 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1, -1, -1, // 112-127
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 128-143
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 144-159
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 160-175
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 176-191
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 192-207
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 208-223
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 224-239
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1 // 240-255
- };
- return &tab[0];
-}
-
-
-/// Returns max chars needed to encode a base64 string
-inline
-std::size_t constexpr
-encoded_size(std::size_t n)
-{
- return 4 * ((n + 2) / 3);
-}
-
-/// Returns max bytes needed to decode a base64 string
-inline
-std::size_t constexpr
-decoded_size(std::size_t n)
-{
- return n / 4 * 3; // requires n&3==0, smaller
- //return 3 * n / 4;
-}
-
-/** Encode a series of octets as a padded, base64 string.
-
- The resulting string will not be null terminated.
-
- @par Requires
-
- The memory pointed to by `out` points to valid memory
- of at least `encoded_size(len)` bytes.
-
- @return The number of characters written to `out`. This
- will exclude any null termination.
-*/
-template<class = void>
-std::size_t
-encode(void* dest, void const* src, std::size_t len)
-{
- char* out = static_cast<char*>(dest);
- char const* in = static_cast<char const*>(src);
- auto const tab = base64::get_alphabet();
-
- for(auto n = len / 3; n--;)
- {
- *out++ = tab[ (in[0] & 0xfc) >> 2];
- *out++ = tab[((in[0] & 0x03) << 4) + ((in[1] & 0xf0) >> 4)];
- *out++ = tab[((in[2] & 0xc0) >> 6) + ((in[1] & 0x0f) << 2)];
- *out++ = tab[ in[2] & 0x3f];
- in += 3;
- }
-
- switch(len % 3)
- {
- case 2:
- *out++ = tab[ (in[0] & 0xfc) >> 2];
- *out++ = tab[((in[0] & 0x03) << 4) + ((in[1] & 0xf0) >> 4)];
- *out++ = tab[ (in[1] & 0x0f) << 2];
- *out++ = '=';
- break;
-
- case 1:
- *out++ = tab[ (in[0] & 0xfc) >> 2];
- *out++ = tab[((in[0] & 0x03) << 4)];
- *out++ = '=';
- *out++ = '=';
- break;
-
- case 0:
- break;
- }
-
- return out - static_cast<char*>(dest);
-}
-
-/** Decode a padded base64 string into a series of octets.
-
- @par Requires
-
- The memory pointed to by `out` points to valid memory
- of at least `decoded_size(len)` bytes.
-
- @return The number of octets written to `out`, and
- the number of characters read from the input string,
- expressed as a pair.
-*/
-template<class = void>
-std::pair<std::size_t, std::size_t>
-decode(void* dest, char const* src, std::size_t len)
-{
- char* out = static_cast<char*>(dest);
- auto in = reinterpret_cast<unsigned char const*>(src);
- unsigned char c3[3], c4[4];
- int i = 0;
- int j = 0;
-
- auto const inverse = base64::get_inverse();
-
- while(len-- && *in != '=')
- {
- auto const v = inverse[*in];
- if(v == -1)
- break;
- ++in;
- c4[i] = v;
- if(++i == 4)
- {
- c3[0] = (c4[0] << 2) + ((c4[1] & 0x30) >> 4);
- c3[1] = ((c4[1] & 0xf) << 4) + ((c4[2] & 0x3c) >> 2);
- c3[2] = ((c4[2] & 0x3) << 6) + c4[3];
-
- for(i = 0; i < 3; i++)
- *out++ = c3[i];
- i = 0;
- }
- }
-
- if(i)
- {
- c3[0] = ( c4[0] << 2) + ((c4[1] & 0x30) >> 4);
- c3[1] = ((c4[1] & 0xf) << 4) + ((c4[2] & 0x3c) >> 2);
- c3[2] = ((c4[2] & 0x3) << 6) + c4[3];
-
- for(j = 0; j < i - 1; j++)
- *out++ = c3[j];
- }
-
- return {out - static_cast<char*>(dest),
- in - reinterpret_cast<unsigned char const*>(src)};
-}
-
-} // base64
-
-template<class = void>
-std::string
-base64_encode (std::uint8_t const* data,
- std::size_t len)
-{
- std::string dest;
- dest.resize(base64::encoded_size(len));
- dest.resize(base64::encode(&dest[0], data, len));
- return dest;
-}
-
-inline
-std::string
-base64_encode(std::string const& s)
-{
- return base64_encode (reinterpret_cast <
- std::uint8_t const*> (s.data()), s.size());
-}
-
-template<class = void>
-std::string
-base64_decode(std::string const& data)
-{
- std::string dest;
- dest.resize(base64::decoded_size(data.size()));
- auto const result = base64::decode(
- &dest[0], data.data(), data.size());
- dest.resize(result.first);
- return dest;
-}
-
-} // detail
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/bind_handler.hpp b/contrib/restricted/boost/boost/beast/core/detail/bind_handler.hpp
deleted file mode 100644
index 48046df923..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/bind_handler.hpp
+++ /dev/null
@@ -1,217 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_DETAIL_BIND_HANDLER_HPP
-#define BOOST_BEAST_DETAIL_BIND_HANDLER_HPP
-
-#include <boost/beast/core/detail/integer_sequence.hpp>
-#include <boost/asio/associated_allocator.hpp>
-#include <boost/asio/associated_executor.hpp>
-#include <boost/asio/handler_continuation_hook.hpp>
-#include <boost/asio/handler_invoke_hook.hpp>
-#include <boost/core/ignore_unused.hpp>
-#include <boost/is_placeholder.hpp>
-#include <functional>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-/* Nullary handler that calls Handler with bound arguments.
-
- The bound handler provides the same io_context execution
- guarantees as the original handler.
-*/
-template<class Handler, class... Args>
-class bound_handler
-{
- // Can't friend partial specializations,
- // so we just friend the whole thing.
- template<class T, class Executor>
- friend struct boost::asio::associated_executor;
-
- using args_type = std::tuple<
- typename std::decay<Args>::type...>;
-
- Handler h_;
- args_type args_;
-
- template<class Arg, class Vals>
- static
- typename std::enable_if<
- std::is_placeholder<typename
- std::decay<Arg>::type>::value == 0 &&
- boost::is_placeholder<typename
- std::decay<Arg>::type>::value == 0,
- Arg&&>::type
- extract(Arg&& arg, Vals& vals)
- {
- boost::ignore_unused(vals);
- return arg;
- }
-
- template<class Arg, class Vals>
- static
- typename std::enable_if<
- std::is_placeholder<typename
- std::decay<Arg>::type>::value != 0,
- typename std::tuple_element<
- std::is_placeholder<
- typename std::decay<Arg>::type>::value - 1,
- Vals>>::type::type&&
- extract(Arg&&, Vals&& vals)
- {
- return std::get<std::is_placeholder<
- typename std::decay<Arg>::type>::value - 1>(
- std::forward<Vals>(vals));
- }
-
- template<class Arg, class Vals>
- static
- typename std::enable_if<
- boost::is_placeholder<typename
- std::decay<Arg>::type>::value != 0,
- typename std::tuple_element<
- boost::is_placeholder<
- typename std::decay<Arg>::type>::value - 1,
- Vals>>::type::type&&
- extract(Arg&&, Vals&& vals)
- {
- return std::get<boost::is_placeholder<
- typename std::decay<Arg>::type>::value - 1>(
- std::forward<Vals>(vals));
- }
-
- template<
- class ArgsTuple,
- std::size_t... S>
- static
- void
- invoke(
- Handler& h,
- ArgsTuple& args,
- std::tuple<>&&,
- index_sequence<S...>)
- {
- boost::ignore_unused(args);
- h(std::get<S>(args)...);
- }
-
- template<
- class ArgsTuple,
- class ValsTuple,
- std::size_t... S>
- static
- void
- invoke(
- Handler& h,
- ArgsTuple& args,
- ValsTuple&& vals,
- index_sequence<S...>)
- {
- boost::ignore_unused(args);
- boost::ignore_unused(vals);
- h(extract(std::get<S>(args),
- std::forward<ValsTuple>(vals))...);
- }
-
-public:
- using result_type = void;
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- bound_handler(bound_handler&&) = default;
- bound_handler(bound_handler const&) = delete;
-
- template<class DeducedHandler>
- explicit
- bound_handler(
- DeducedHandler&& handler, Args&&... args)
- : h_(std::forward<DeducedHandler>(handler))
- , args_(std::forward<Args>(args)...)
- {
- }
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(h_);
- }
-
- friend
- bool
- asio_handler_is_continuation(bound_handler* h)
- {
- using boost::asio::asio_handler_is_continuation;
- return asio_handler_is_continuation(std::addressof(h->h_));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, bound_handler* h)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f, std::addressof(h->h_));
- }
-
- template<class... Values>
- void
- operator()(Values&&... values)
- {
- invoke(h_, args_,
- std::forward_as_tuple(
- std::forward<Values>(values)...),
- index_sequence_for<Args...>());
- }
-
- template<class... Values>
- void
- operator()(Values&&... values) const
- {
- invoke(h_, args_,
- std::forward_as_tuple(
- std::forward<Values>(values)...),
- index_sequence_for<Args...>());
- }
-};
-
-} // detail
-} // beast
-
-namespace asio {
-template<class Handler, class... Args, class Executor>
-struct associated_executor<
- beast::detail::bound_handler<Handler, Args...>, Executor>
-{
- using type = typename
- associated_executor<Handler, Executor>::type;
-
- static
- type
- get(beast::detail::bound_handler<Handler, Args...> const& h,
- Executor const& ex = Executor()) noexcept
- {
- return associated_executor<
- Handler, Executor>::get(h.h_, ex);
- }
-};
-} // asio
-
-} // boost
-
-namespace std {
-template<class Handler, class... Args>
-void
-bind(boost::beast::detail::bound_handler<
- Handler, Args...>, ...) = delete;
-} // std
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/buffers_ref.hpp b/contrib/restricted/boost/boost/beast/core/detail/buffers_ref.hpp
deleted file mode 100644
index e56a9764fd..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/buffers_ref.hpp
+++ /dev/null
@@ -1,67 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_DETAIL_BUFFERS_REF_HPP
-#define BOOST_BEAST_DETAIL_BUFFERS_REF_HPP
-
-#include <boost/beast/core/type_traits.hpp>
-#include <iterator>
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-// A very lightweight reference to a buffer sequence
-template<class BufferSequence>
-class buffers_ref
-{
- BufferSequence const* buffers_;
-
-public:
- using const_iterator = typename
- buffer_sequence_iterator<BufferSequence>::type;
-
- using value_type = typename std::iterator_traits<
- const_iterator>::value_type;
-
- buffers_ref(buffers_ref const&) = default;
- buffers_ref& operator=(buffers_ref const&) = default;
-
- explicit
- buffers_ref(BufferSequence const& buffers)
- : buffers_(std::addressof(buffers))
- {
- }
-
- const_iterator
- begin() const
- {
- return boost::asio::buffer_sequence_begin(*buffers_);
- }
-
- const_iterator
- end() const
- {
- return boost::asio::buffer_sequence_end(*buffers_);
- }
-};
-
-// Return a reference to a buffer sequence
-template<class BufferSequence>
-buffers_ref<BufferSequence>
-make_buffers_ref(BufferSequence const& buffers)
-{
- return buffers_ref<BufferSequence>(buffers);
-}
-
-} // detail
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/clamp.hpp b/contrib/restricted/boost/boost/beast/core/detail/clamp.hpp
deleted file mode 100644
index 95a8fab425..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/clamp.hpp
+++ /dev/null
@@ -1,59 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_CORE_DETAIL_CLAMP_HPP
-#define BOOST_BEAST_CORE_DETAIL_CLAMP_HPP
-
-#include <cstdlib>
-#include <limits>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-template<class UInt>
-static
-std::size_t
-clamp(UInt x)
-{
- if(x >= (std::numeric_limits<std::size_t>::max)())
- return (std::numeric_limits<std::size_t>::max)();
- return static_cast<std::size_t>(x);
-}
-
-template<class UInt>
-static
-std::size_t
-clamp(UInt x, std::size_t limit)
-{
- if(x >= limit)
- return limit;
- return static_cast<std::size_t>(x);
-}
-
-// return `true` if x + y > z, which are unsigned
-template<
- class U1, class U2, class U3>
-constexpr
-bool
-sum_exceeds(U1 x, U2 y, U3 z)
-{
- static_assert(
- std::is_unsigned<U1>::value &&
- std::is_unsigned<U2>::value &&
- std::is_unsigned<U3>::value, "");
- return y > z || x > z - y;
-}
-
-} // detail
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/config.hpp b/contrib/restricted/boost/boost/beast/core/detail/config.hpp
deleted file mode 100644
index 68e3dda8ee..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/config.hpp
+++ /dev/null
@@ -1,54 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_CORE_DETAIL_CONFIG_HPP
-#define BOOST_BEAST_CORE_DETAIL_CONFIG_HPP
-
-#include <boost/config.hpp>
-#include <boost/version.hpp>
-
-// Available to every header
-#include <boost/config.hpp>
-#include <boost/core/ignore_unused.hpp>
-#include <boost/static_assert.hpp>
-
-/*
- _MSC_VER and _MSC_FULL_VER by version:
-
- 14.0 (2015) 1900 190023026
- 14.0 (2015 Update 1) 1900 190023506
- 14.0 (2015 Update 2) 1900 190023918
- 14.0 (2015 Update 3) 1900 190024210
-*/
-
-#if defined(BOOST_MSVC)
-# if BOOST_MSVC_FULL_VER < 190024210
-# error Beast requires C++11: Visual Studio 2015 Update 3 or later needed
-# endif
-
-#elif defined(BOOST_GCC)
-# if(BOOST_GCC < 40801)
-# error Beast requires C++11: gcc version 4.8 or later needed
-# endif
-
-#else
-# if \
- defined(BOOST_NO_CXX11_DECLTYPE) || \
- defined(BOOST_NO_CXX11_HDR_TUPLE) || \
- defined(BOOST_NO_CXX11_TEMPLATE_ALIASES) || \
- defined(BOOST_NO_CXX11_VARIADIC_TEMPLATES)
-# error Beast requires C++11: a conforming compiler is needed
-# endif
-
-#endif
-
-#define BOOST_BEAST_DEPRECATION_STRING \
- "This is a deprecated interface, #define BOOST_BEAST_ALLOW_DEPRECATED to allow it"
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/cpu_info.hpp b/contrib/restricted/boost/boost/beast/core/detail/cpu_info.hpp
deleted file mode 100644
index 579589fa8e..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/cpu_info.hpp
+++ /dev/null
@@ -1,99 +0,0 @@
-//
-// Copyright (c) 2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_DETAIL_CPU_INFO_HPP
-#define BOOST_BEAST_DETAIL_CPU_INFO_HPP
-
-#include <boost/config.hpp>
-
-#ifndef BOOST_BEAST_NO_INTRINSICS
-# if defined(BOOST_MSVC) || ((defined(BOOST_GCC) || defined(BOOST_CLANG)) && defined(__SSE4_2__))
-# define BOOST_BEAST_NO_INTRINSICS 0
-# else
-# define BOOST_BEAST_NO_INTRINSICS 1
-# endif
-#endif
-
-#if ! BOOST_BEAST_NO_INTRINSICS
-
-#ifdef BOOST_MSVC
-#include <intrin.h> // __cpuid
-#else
-#include <cpuid.h> // __get_cpuid
-#endif
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-/* Portions from Boost,
- Copyright Andrey Semashev 2007 - 2015.
-*/
-template<class = void>
-void
-cpuid(
- std::uint32_t id,
- std::uint32_t& eax,
- std::uint32_t& ebx,
- std::uint32_t& ecx,
- std::uint32_t& edx)
-{
-#ifdef BOOST_MSVC
- int regs[4];
- __cpuid(regs, id);
- eax = regs[0];
- ebx = regs[1];
- ecx = regs[2];
- edx = regs[3];
-#else
- __get_cpuid(id, &eax, &ebx, &ecx, &edx);
-#endif
-}
-
-struct cpu_info
-{
- bool sse42 = false;
-
- cpu_info();
-};
-
-inline
-cpu_info::
-cpu_info()
-{
- constexpr std::uint32_t SSE42 = 1 << 20;
-
- std::uint32_t eax = 0;
- std::uint32_t ebx = 0;
- std::uint32_t ecx = 0;
- std::uint32_t edx = 0;
-
- cpuid(0, eax, ebx, ecx, edx);
- if(eax >= 1)
- {
- cpuid(1, eax, ebx, ecx, edx);
- sse42 = (ecx & SSE42) != 0;
- }
-}
-
-template<class = void>
-cpu_info const&
-get_cpu_info()
-{
- static cpu_info const ci;
- return ci;
-}
-
-} // detail
-} // beast
-} // boost
-
-#endif
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/empty_base_optimization.hpp b/contrib/restricted/boost/boost/beast/core/detail/empty_base_optimization.hpp
deleted file mode 100644
index b1e728b674..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/empty_base_optimization.hpp
+++ /dev/null
@@ -1,100 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_DETAIL_EMPTY_BASE_OPTIMIZATION_HPP
-#define BOOST_BEAST_DETAIL_EMPTY_BASE_OPTIMIZATION_HPP
-
-#include <boost/type_traits/is_final.hpp>
-#include <type_traits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-template<class T>
-struct is_empty_base_optimization_derived
- : std::integral_constant<bool,
- std::is_empty<T>::value &&
- ! boost::is_final<T>::value>
-{
-};
-
-template<class T, int UniqueID = 0,
- bool isDerived =
- is_empty_base_optimization_derived<T>::value>
-class empty_base_optimization : private T
-{
-public:
- empty_base_optimization() = default;
- empty_base_optimization(empty_base_optimization&&) = default;
- empty_base_optimization(empty_base_optimization const&) = default;
- empty_base_optimization& operator=(empty_base_optimization&&) = default;
- empty_base_optimization& operator=(empty_base_optimization const&) = default;
-
- template<class Arg1, class... ArgN>
- explicit
- empty_base_optimization(Arg1&& arg1, ArgN&&... argn)
- : T(std::forward<Arg1>(arg1),
- std::forward<ArgN>(argn)...)
- {
- }
-
- T& member() noexcept
- {
- return *this;
- }
-
- T const& member() const noexcept
- {
- return *this;
- }
-};
-
-//------------------------------------------------------------------------------
-
-template<
- class T,
- int UniqueID
->
-class empty_base_optimization <T, UniqueID, false>
-{
- T t_;
-
-public:
- empty_base_optimization() = default;
- empty_base_optimization(empty_base_optimization&&) = default;
- empty_base_optimization(empty_base_optimization const&) = default;
- empty_base_optimization& operator=(empty_base_optimization&&) = default;
- empty_base_optimization& operator=(empty_base_optimization const&) = default;
-
- template<class Arg1, class... ArgN>
- explicit
- empty_base_optimization(Arg1&& arg1, ArgN&&... argn)
- : t_(std::forward<Arg1>(arg1),
- std::forward<ArgN>(argn)...)
- {
- }
-
- T& member() noexcept
- {
- return t_;
- }
-
- T const& member() const noexcept
- {
- return t_;
- }
-};
-
-} // detail
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/integer_sequence.hpp b/contrib/restricted/boost/boost/beast/core/detail/integer_sequence.hpp
deleted file mode 100644
index 71664229af..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/integer_sequence.hpp
+++ /dev/null
@@ -1,143 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_DETAIL_INTEGER_SEQUENCE_HPP
-#define BOOST_BEAST_DETAIL_INTEGER_SEQUENCE_HPP
-
-#include <boost/config.hpp>
-#include <cstddef>
-#include <type_traits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-template<class T, T... Ints>
-struct integer_sequence
-{
- using value_type = T;
- BOOST_STATIC_ASSERT(std::is_integral<T>::value);
-
- static std::size_t constexpr static_size = sizeof...(Ints);
-
- static std::size_t constexpr size()
- {
- return sizeof...(Ints);
- }
-};
-
-template<std::size_t... Ints>
-using index_sequence = integer_sequence<std::size_t, Ints...>;
-
-// This workaround is needed for broken sizeof...
-template<class... Args>
-struct sizeof_workaround
-{
- static std::size_t constexpr size = sizeof... (Args);
-};
-
-#ifdef BOOST_MSVC
-
-// This implementation compiles on real MSVC and clang but not gcc
-
-template<class T, unsigned long long N, class Seq>
-struct make_integer_sequence_unchecked;
-
-template<class T, unsigned long long N, unsigned long long ...Indices>
-struct make_integer_sequence_unchecked<
- T, N, integer_sequence<T, Indices...>>
-{
- using type = typename make_integer_sequence_unchecked<
- T, N-1, integer_sequence<T, N-1, Indices...>>::type;
-};
-
-template<class T, unsigned long long ...Indices>
-struct make_integer_sequence_unchecked<
- T, 0, integer_sequence<T, Indices...>>
-{
- using type = integer_sequence<T, Indices...>;
-};
-
-template<class T, T N>
-struct make_integer_sequence_checked
-{
- BOOST_STATIC_ASSERT(std::is_integral<T>::value);
- BOOST_STATIC_ASSERT(N >= 0);
-
- using type = typename make_integer_sequence_unchecked<
- T, N, integer_sequence<T>>::type;
-};
-
-template<class T, T N>
-using make_integer_sequence =
- typename make_integer_sequence_checked<T, N>::type;
-
-template<std::size_t N>
-using make_index_sequence = make_integer_sequence<std::size_t, N>;
-
-template<class... Args>
-using index_sequence_for =
- make_index_sequence<sizeof_workaround<Args...>::size>;
-
-#else
-
-// This implementation compiles on gcc but not MSVC
-
-template<std::size_t... Ints>
-struct index_tuple
-{
- using next = index_tuple<Ints..., sizeof... (Ints)>;
-
-};
-
-template<std::size_t N>
-struct build_index_tuple
-{
- using type = typename build_index_tuple<N-1>::type::next;
-};
-
-template<>
-struct build_index_tuple<0>
-{
- using type = index_tuple<>;
-};
-
-template<class T, T N,
- class Seq = typename build_index_tuple<N>::type
->
-struct integer_sequence_helper;
-
-template<class T, T N, std::size_t... Ints>
-struct integer_sequence_helper<T, N, index_tuple<Ints...>>
-{
- BOOST_STATIC_ASSERT(std::is_integral<T>::value);
- BOOST_STATIC_ASSERT(N >= 0);
-
- using type = integer_sequence<T, static_cast<T> (Ints)...>;
-};
-
-template<class T, T N>
-using make_integer_sequence =
- typename integer_sequence_helper<T, N>::type;
-
-template<std::size_t N>
-using make_index_sequence = make_integer_sequence<std::size_t, N>;
-
-template<class... Args>
-using index_sequence_for =
- make_index_sequence<sizeof_workaround<Args...>::size>;
-
-#endif
-
-} // detail
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/ostream.hpp b/contrib/restricted/boost/boost/beast/core/detail/ostream.hpp
deleted file mode 100644
index 8d6eb94f51..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/ostream.hpp
+++ /dev/null
@@ -1,319 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_DETAIL_OSTREAM_HPP
-#define BOOST_BEAST_DETAIL_OSTREAM_HPP
-
-#include <boost/beast/core/buffers_prefix.hpp>
-#include <boost/beast/core/read_size.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <memory>
-#include <iosfwd>
-#include <streambuf>
-#include <type_traits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-template<class Buffers>
-class buffers_helper
-{
- Buffers b_;
-
-public:
- explicit
- buffers_helper(Buffers const& b)
- : b_(b)
- {
- }
-
- template<class B>
- friend
- std::ostream&
- operator<<(std::ostream& os,
- buffers_helper<B> const& v);
-};
-
-template<class Buffers>
-std::ostream&
-operator<<(std::ostream& os,
- buffers_helper<Buffers> const& v)
-{
- for(auto b : buffers_range(v.b_))
- os.write(
- reinterpret_cast<char const*>(b.data()),
- b.size());
- return os;
-}
-
-//------------------------------------------------------------------------------
-
-struct basic_streambuf_movable_helper :
- std::basic_streambuf<char, std::char_traits<char>>
-{
- basic_streambuf_movable_helper(
- basic_streambuf_movable_helper&&) = default;
-};
-
-using basic_streambuf_movable =
- std::is_move_constructible<basic_streambuf_movable_helper>;
-
-//------------------------------------------------------------------------------
-
-template<class DynamicBuffer,
- class CharT, class Traits, bool isMovable>
-class ostream_buffer;
-
-template<class DynamicBuffer, class CharT, class Traits>
-class ostream_buffer
- <DynamicBuffer, CharT, Traits, true>
- : public std::basic_streambuf<CharT, Traits>
-{
- using int_type = typename
- std::basic_streambuf<CharT, Traits>::int_type;
-
- using traits_type = typename
- std::basic_streambuf<CharT, Traits>::traits_type;
-
- static std::size_t constexpr max_size = 512;
-
- DynamicBuffer& buf_;
-
-public:
- ostream_buffer(ostream_buffer&&) = default;
- ostream_buffer(ostream_buffer const&) = delete;
-
- ~ostream_buffer() noexcept
- {
- sync();
- }
-
- explicit
- ostream_buffer(DynamicBuffer& buf)
- : buf_(buf)
- {
- prepare();
- }
-
- int_type
- overflow(int_type ch) override
- {
- if(! Traits::eq_int_type(ch, Traits::eof()))
- {
- Traits::assign(*this->pptr(),
- static_cast<CharT>(ch));
- flush(1);
- prepare();
- return ch;
- }
- flush();
- return traits_type::eof();
- }
-
- int
- sync() override
- {
- flush();
- prepare();
- return 0;
- }
-
-private:
- void
- prepare()
- {
- auto bs = buf_.prepare(
- read_size_or_throw(buf_, max_size));
- auto const b = buffers_front(bs);
- auto const p = reinterpret_cast<CharT*>(b.data());
- this->setp(p,
- p + b.size() / sizeof(CharT) - 1);
- }
-
- void
- flush(int extra = 0)
- {
- buf_.commit(
- (this->pptr() - this->pbase() + extra) *
- sizeof(CharT));
- }
-};
-
-// This nonsense is all to work around a glitch in libstdc++
-// where std::basic_streambuf copy constructor is private:
-// https://github.com/gcc-mirror/gcc/blob/gcc-4_8-branch/libstdc%2B%2B-v3/include/std/streambuf#L799
-
-template<class DynamicBuffer, class CharT, class Traits>
-class ostream_buffer
- <DynamicBuffer, CharT, Traits, false>
- : public std::basic_streambuf<CharT, Traits>
-{
- using int_type = typename
- std::basic_streambuf<CharT, Traits>::int_type;
-
- using traits_type = typename
- std::basic_streambuf<CharT, Traits>::traits_type;
-
- static std::size_t constexpr max_size = 512;
-
- DynamicBuffer& buf_;
-
-public:
- ostream_buffer(ostream_buffer&&) = delete;
- ostream_buffer(ostream_buffer const&) = delete;
-
- ~ostream_buffer() noexcept
- {
- sync();
- }
-
- explicit
- ostream_buffer(DynamicBuffer& buf)
- : buf_(buf)
- {
- prepare();
- }
-
- int_type
- overflow(int_type ch) override
- {
- if(! Traits::eq_int_type(ch, Traits::eof()))
- {
- Traits::assign(*this->pptr(),
- static_cast<CharT>(ch));
- flush(1);
- prepare();
- return ch;
- }
- flush();
- return traits_type::eof();
- }
-
- int
- sync() override
- {
- flush();
- prepare();
- return 0;
- }
-
-private:
- void
- prepare()
- {
- auto bs = buf_.prepare(
- read_size_or_throw(buf_, max_size));
- auto const b = buffers_front(bs);
- auto const p = reinterpret_cast<CharT*>(b.data());
- this->setp(p,
- p + b.size() / sizeof(CharT) - 1);
- }
-
- void
- flush(int extra = 0)
- {
- buf_.commit(
- (this->pptr() - this->pbase() + extra) *
- sizeof(CharT));
- }
-};
-
-//------------------------------------------------------------------------------
-
-template<class DynamicBuffer,
- class CharT, class Traits, bool isMovable>
-class ostream_helper;
-
-template<class DynamicBuffer, class CharT, class Traits>
-class ostream_helper<
- DynamicBuffer, CharT, Traits, true>
- : public std::basic_ostream<CharT, Traits>
-{
- ostream_buffer<
- DynamicBuffer, CharT, Traits, true> osb_;
-
-public:
- explicit
- ostream_helper(DynamicBuffer& buf);
-
- ostream_helper(ostream_helper&& other);
-};
-
-template<class DynamicBuffer, class CharT, class Traits>
-ostream_helper<DynamicBuffer, CharT, Traits, true>::
-ostream_helper(DynamicBuffer& buf)
- : std::basic_ostream<CharT, Traits>(
- &this->osb_)
- , osb_(buf)
-{
-}
-
-template<class DynamicBuffer, class CharT, class Traits>
-ostream_helper<DynamicBuffer, CharT, Traits, true>::
-ostream_helper(
- ostream_helper&& other)
- : std::basic_ostream<CharT, Traits>(&osb_)
- , osb_(std::move(other.osb_))
-{
-}
-
-// This work-around is for libstdc++ versions that
-// don't have a movable std::basic_streambuf
-
-template<class T>
-class ostream_helper_base
-{
-protected:
- std::unique_ptr<T> member;
-
- ostream_helper_base(
- ostream_helper_base&&) = default;
-
- explicit
- ostream_helper_base(T* t)
- : member(t)
- {
- }
-};
-
-template<class DynamicBuffer, class CharT, class Traits>
-class ostream_helper<
- DynamicBuffer, CharT, Traits, false>
- : private ostream_helper_base<ostream_buffer<
- DynamicBuffer, CharT, Traits, false>>
- , public std::basic_ostream<CharT, Traits>
-{
-public:
- explicit
- ostream_helper(DynamicBuffer& buf)
- : ostream_helper_base<ostream_buffer<
- DynamicBuffer, CharT, Traits, false>>(
- new ostream_buffer<DynamicBuffer,
- CharT, Traits, false>(buf))
- , std::basic_ostream<CharT, Traits>(this->member.get())
- {
- }
-
- ostream_helper(ostream_helper&& other)
- : ostream_helper_base<ostream_buffer<
- DynamicBuffer, CharT, Traits, false>>(
- std::move(other))
- , std::basic_ostream<CharT, Traits>(this->member.get())
- {
- }
-};
-
-} // detail
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/sha1.hpp b/contrib/restricted/boost/boost/beast/core/detail/sha1.hpp
deleted file mode 100644
index 336da2a0f2..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/sha1.hpp
+++ /dev/null
@@ -1,313 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_DETAIL_SHA1_HPP
-#define BOOST_BEAST_DETAIL_SHA1_HPP
-
-#include <algorithm>
-#include <cstdint>
-#include <cstring>
-
-// Based on https://github.com/vog/sha1
-/*
- Original authors:
- Steve Reid (Original C Code)
- Bruce Guenter (Small changes to fit into bglibs)
- Volker Grabsch (Translation to simpler C++ Code)
- Eugene Hopkinson (Safety improvements)
- Vincent Falco (beast adaptation)
-*/
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-namespace sha1 {
-
-static std::size_t constexpr BLOCK_INTS = 16;
-static std::size_t constexpr BLOCK_BYTES = 64;
-static std::size_t constexpr DIGEST_BYTES = 20;
-
-inline
-std::uint32_t
-rol(std::uint32_t value, std::size_t bits)
-{
- return (value << bits) | (value >> (32 - bits));
-}
-
-inline
-std::uint32_t
-blk(std::uint32_t block[BLOCK_INTS], std::size_t i)
-{
- return rol(
- block[(i+13)&15] ^ block[(i+8)&15] ^
- block[(i+2)&15] ^ block[i], 1);
-}
-
-inline
-void
-R0(std::uint32_t block[BLOCK_INTS], std::uint32_t v,
- std::uint32_t &w, std::uint32_t x, std::uint32_t y,
- std::uint32_t &z, std::size_t i)
-{
- z += ((w&(x^y))^y) + block[i] + 0x5a827999 + rol(v, 5);
- w = rol(w, 30);
-}
-
-
-inline
-void
-R1(std::uint32_t block[BLOCK_INTS], std::uint32_t v,
- std::uint32_t &w, std::uint32_t x, std::uint32_t y,
- std::uint32_t &z, std::size_t i)
-{
- block[i] = blk(block, i);
- z += ((w&(x^y))^y) + block[i] + 0x5a827999 + rol(v, 5);
- w = rol(w, 30);
-}
-
-inline
-void
-R2(std::uint32_t block[BLOCK_INTS], std::uint32_t v,
- std::uint32_t &w, std::uint32_t x, std::uint32_t y,
- std::uint32_t &z, std::size_t i)
-{
- block[i] = blk(block, i);
- z += (w^x^y) + block[i] + 0x6ed9eba1 + rol(v, 5);
- w = rol(w, 30);
-}
-
-inline
-void
-R3(std::uint32_t block[BLOCK_INTS], std::uint32_t v,
- std::uint32_t &w, std::uint32_t x, std::uint32_t y,
- std::uint32_t &z, std::size_t i)
-{
- block[i] = blk(block, i);
- z += (((w|x)&y)|(w&x)) + block[i] + 0x8f1bbcdc + rol(v, 5);
- w = rol(w, 30);
-}
-
-inline
-void
-R4(std::uint32_t block[BLOCK_INTS], std::uint32_t v,
- std::uint32_t &w, std::uint32_t x, std::uint32_t y,
- std::uint32_t &z, std::size_t i)
-{
- block[i] = blk(block, i);
- z += (w^x^y) + block[i] + 0xca62c1d6 + rol(v, 5);
- w = rol(w, 30);
-}
-
-inline
-void
-make_block(std::uint8_t const* p,
- std::uint32_t block[BLOCK_INTS])
-{
- for(std::size_t i = 0; i < BLOCK_INTS; i++)
- block[i] =
- (static_cast<std::uint32_t>(p[4*i+3])) |
- (static_cast<std::uint32_t>(p[4*i+2]))<< 8 |
- (static_cast<std::uint32_t>(p[4*i+1]))<<16 |
- (static_cast<std::uint32_t>(p[4*i+0]))<<24;
-}
-
-template<class = void>
-void
-transform(
- std::uint32_t digest[], std::uint32_t block[BLOCK_INTS])
-{
- std::uint32_t a = digest[0];
- std::uint32_t b = digest[1];
- std::uint32_t c = digest[2];
- std::uint32_t d = digest[3];
- std::uint32_t e = digest[4];
-
- R0(block, a, b, c, d, e, 0);
- R0(block, e, a, b, c, d, 1);
- R0(block, d, e, a, b, c, 2);
- R0(block, c, d, e, a, b, 3);
- R0(block, b, c, d, e, a, 4);
- R0(block, a, b, c, d, e, 5);
- R0(block, e, a, b, c, d, 6);
- R0(block, d, e, a, b, c, 7);
- R0(block, c, d, e, a, b, 8);
- R0(block, b, c, d, e, a, 9);
- R0(block, a, b, c, d, e, 10);
- R0(block, e, a, b, c, d, 11);
- R0(block, d, e, a, b, c, 12);
- R0(block, c, d, e, a, b, 13);
- R0(block, b, c, d, e, a, 14);
- R0(block, a, b, c, d, e, 15);
- R1(block, e, a, b, c, d, 0);
- R1(block, d, e, a, b, c, 1);
- R1(block, c, d, e, a, b, 2);
- R1(block, b, c, d, e, a, 3);
- R2(block, a, b, c, d, e, 4);
- R2(block, e, a, b, c, d, 5);
- R2(block, d, e, a, b, c, 6);
- R2(block, c, d, e, a, b, 7);
- R2(block, b, c, d, e, a, 8);
- R2(block, a, b, c, d, e, 9);
- R2(block, e, a, b, c, d, 10);
- R2(block, d, e, a, b, c, 11);
- R2(block, c, d, e, a, b, 12);
- R2(block, b, c, d, e, a, 13);
- R2(block, a, b, c, d, e, 14);
- R2(block, e, a, b, c, d, 15);
- R2(block, d, e, a, b, c, 0);
- R2(block, c, d, e, a, b, 1);
- R2(block, b, c, d, e, a, 2);
- R2(block, a, b, c, d, e, 3);
- R2(block, e, a, b, c, d, 4);
- R2(block, d, e, a, b, c, 5);
- R2(block, c, d, e, a, b, 6);
- R2(block, b, c, d, e, a, 7);
- R3(block, a, b, c, d, e, 8);
- R3(block, e, a, b, c, d, 9);
- R3(block, d, e, a, b, c, 10);
- R3(block, c, d, e, a, b, 11);
- R3(block, b, c, d, e, a, 12);
- R3(block, a, b, c, d, e, 13);
- R3(block, e, a, b, c, d, 14);
- R3(block, d, e, a, b, c, 15);
- R3(block, c, d, e, a, b, 0);
- R3(block, b, c, d, e, a, 1);
- R3(block, a, b, c, d, e, 2);
- R3(block, e, a, b, c, d, 3);
- R3(block, d, e, a, b, c, 4);
- R3(block, c, d, e, a, b, 5);
- R3(block, b, c, d, e, a, 6);
- R3(block, a, b, c, d, e, 7);
- R3(block, e, a, b, c, d, 8);
- R3(block, d, e, a, b, c, 9);
- R3(block, c, d, e, a, b, 10);
- R3(block, b, c, d, e, a, 11);
- R4(block, a, b, c, d, e, 12);
- R4(block, e, a, b, c, d, 13);
- R4(block, d, e, a, b, c, 14);
- R4(block, c, d, e, a, b, 15);
- R4(block, b, c, d, e, a, 0);
- R4(block, a, b, c, d, e, 1);
- R4(block, e, a, b, c, d, 2);
- R4(block, d, e, a, b, c, 3);
- R4(block, c, d, e, a, b, 4);
- R4(block, b, c, d, e, a, 5);
- R4(block, a, b, c, d, e, 6);
- R4(block, e, a, b, c, d, 7);
- R4(block, d, e, a, b, c, 8);
- R4(block, c, d, e, a, b, 9);
- R4(block, b, c, d, e, a, 10);
- R4(block, a, b, c, d, e, 11);
- R4(block, e, a, b, c, d, 12);
- R4(block, d, e, a, b, c, 13);
- R4(block, c, d, e, a, b, 14);
- R4(block, b, c, d, e, a, 15);
-
- digest[0] += a;
- digest[1] += b;
- digest[2] += c;
- digest[3] += d;
- digest[4] += e;
-}
-
-} // sha1
-
-struct sha1_context
-{
- static unsigned int constexpr block_size = sha1::BLOCK_BYTES;
- static unsigned int constexpr digest_size = 20;
-
- std::size_t buflen;
- std::size_t blocks;
- std::uint32_t digest[5];
- std::uint8_t buf[block_size];
-};
-
-template<class = void>
-void
-init(sha1_context& ctx) noexcept
-{
- ctx.buflen = 0;
- ctx.blocks = 0;
- ctx.digest[0] = 0x67452301;
- ctx.digest[1] = 0xefcdab89;
- ctx.digest[2] = 0x98badcfe;
- ctx.digest[3] = 0x10325476;
- ctx.digest[4] = 0xc3d2e1f0;
-}
-
-template<class = void>
-void
-update(sha1_context& ctx,
- void const* message, std::size_t size) noexcept
-{
- auto p = reinterpret_cast<
- std::uint8_t const*>(message);
- for(;;)
- {
- auto const n = (std::min)(
- size, sizeof(ctx.buf) - ctx.buflen);
- std::memcpy(ctx.buf + ctx.buflen, p, n);
- ctx.buflen += n;
- if(ctx.buflen != 64)
- return;
- p += n;
- size -= n;
- ctx.buflen = 0;
- std::uint32_t block[sha1::BLOCK_INTS];
- sha1::make_block(ctx.buf, block);
- sha1::transform(ctx.digest, block);
- ++ctx.blocks;
- }
-}
-
-template<class = void>
-void
-finish(sha1_context& ctx, void* digest) noexcept
-{
- using sha1::BLOCK_INTS;
- using sha1::BLOCK_BYTES;
-
- std::uint64_t total_bits =
- (ctx.blocks*64 + ctx.buflen) * 8;
- // pad
- ctx.buf[ctx.buflen++] = 0x80;
- auto const buflen = ctx.buflen;
- while(ctx.buflen < 64)
- ctx.buf[ctx.buflen++] = 0x00;
- std::uint32_t block[BLOCK_INTS];
- sha1::make_block(ctx.buf, block);
- if(buflen > BLOCK_BYTES - 8)
- {
- sha1::transform(ctx.digest, block);
- for(size_t i = 0; i < BLOCK_INTS - 2; i++)
- block[i] = 0;
- }
-
- /* Append total_bits, split this uint64_t into two uint32_t */
- block[BLOCK_INTS - 1] = total_bits & 0xffffffff;
- block[BLOCK_INTS - 2] = (total_bits >> 32);
- sha1::transform(ctx.digest, block);
- for(std::size_t i = 0; i < sha1::DIGEST_BYTES/4; i++)
- {
- std::uint8_t* d =
- reinterpret_cast<std::uint8_t*>(digest) + 4 * i;
- d[3] = ctx.digest[i] & 0xff;
- d[2] = (ctx.digest[i] >> 8) & 0xff;
- d[1] = (ctx.digest[i] >> 16) & 0xff;
- d[0] = (ctx.digest[i] >> 24) & 0xff;
- }
-}
-
-} // detail
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/static_ostream.hpp b/contrib/restricted/boost/boost/beast/core/detail/static_ostream.hpp
deleted file mode 100644
index cb5a00b3da..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/static_ostream.hpp
+++ /dev/null
@@ -1,142 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_DETAIL_STATIC_OSTREAM_HPP
-#define BOOST_BEAST_DETAIL_STATIC_OSTREAM_HPP
-
-#include <locale>
-#include <ostream>
-#include <streambuf>
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-// http://www.mr-edd.co.uk/blog/beginners_guide_streambuf
-
-class static_ostream_buffer
- : public std::basic_streambuf<char>
-{
- using CharT = char;
- using Traits = std::char_traits<CharT>;
- using int_type = typename
- std::basic_streambuf<CharT, Traits>::int_type;
- using traits_type = typename
- std::basic_streambuf<CharT, Traits>::traits_type;
-
- char* data_;
- std::size_t size_;
- std::size_t len_ = 0;
- std::string s_;
-
-public:
- static_ostream_buffer(static_ostream_buffer&&) = delete;
- static_ostream_buffer(static_ostream_buffer const&) = delete;
-
- static_ostream_buffer(char* data, std::size_t size)
- : data_(data)
- , size_(size)
- {
- this->setp(data_, data_ + size - 1);
- }
-
- ~static_ostream_buffer() noexcept
- {
- }
-
- string_view
- str() const
- {
- if(! s_.empty())
- return {s_.data(), len_};
- return {data_, len_};
- }
-
- int_type
- overflow(int_type ch) override
- {
- if(! Traits::eq_int_type(ch, Traits::eof()))
- {
- Traits::assign(*this->pptr(),
- static_cast<CharT>(ch));
- flush(1);
- prepare();
- return ch;
- }
- flush();
- return traits_type::eof();
- }
-
- int
- sync() override
- {
- flush();
- prepare();
- return 0;
- }
-
-private:
- void
- prepare()
- {
- static auto const growth_factor = 1.5;
-
- if(len_ < size_ - 1)
- {
- this->setp(
- data_ + len_, data_ + size_ - 2);
- return;
- }
- if(s_.empty())
- {
- s_.resize(static_cast<std::size_t>(
- growth_factor * len_));
- Traits::copy(&s_[0], data_, len_);
- }
- else
- {
- s_.resize(static_cast<std::size_t>(
- growth_factor * len_));
- }
- this->setp(&s_[len_], &s_[len_] +
- s_.size() - len_ - 1);
- }
-
- void
- flush(int extra = 0)
- {
- len_ += static_cast<std::size_t>(
- this->pptr() - this->pbase() + extra);
- }
-};
-
-class static_ostream : public std::basic_ostream<char>
-{
- static_ostream_buffer osb_;
-
-public:
- static_ostream(char* data, std::size_t size)
- : std::basic_ostream<char>(&this->osb_)
- , osb_(data, size)
- {
- imbue(std::locale::classic());
- }
-
- string_view
- str() const
- {
- return osb_.str();
- }
-};
-
-} // detail
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/static_string.hpp b/contrib/restricted/boost/boost/beast/core/detail/static_string.hpp
deleted file mode 100644
index a5384591ff..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/static_string.hpp
+++ /dev/null
@@ -1,135 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_DETAIL_STATIC_STRING_HPP
-#define BOOST_BEAST_DETAIL_STATIC_STRING_HPP
-
-#include <boost/beast/core/string.hpp>
-#include <boost/assert.hpp>
-#include <iterator>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-// Because k-ballo said so
-template<class T>
-using is_input_iterator =
- std::integral_constant<bool,
- ! std::is_integral<T>::value>;
-
-template<class CharT, class Traits>
-int
-lexicographical_compare(
- CharT const* s1, std::size_t n1,
- CharT const* s2, std::size_t n2)
-{
- if(n1 < n2)
- return Traits::compare(
- s1, s2, n1) <= 0 ? -1 : 1;
- if(n1 > n2)
- return Traits::compare(
- s1, s2, n2) >= 0 ? 1 : -1;
- return Traits::compare(s1, s2, n1);
-}
-
-template<class CharT, class Traits>
-inline
-int
-lexicographical_compare(
- basic_string_view<CharT, Traits> s1,
- CharT const* s2, std::size_t n2)
-{
- return lexicographical_compare<CharT, Traits>(
- s1.data(), s1.size(), s2, n2);
-}
-
-template<class CharT, class Traits>
-inline
-int
-lexicographical_compare(
- basic_string_view<CharT, Traits> s1,
- basic_string_view<CharT, Traits> s2)
-{
- return lexicographical_compare<CharT, Traits>(
- s1.data(), s1.size(), s2.data(), s2.size());
-}
-
-// Maximum number of characters in the decimal
-// representation of a binary number. This includes
-// the potential minus sign.
-//
-inline
-std::size_t constexpr
-max_digits(std::size_t bytes)
-{
- return static_cast<std::size_t>(
- bytes * 2.41) + 1 + 1;
-}
-
-template<class CharT, class Integer, class Traits>
-CharT*
-raw_to_string(
- CharT* buf, Integer x, std::true_type)
-{
- if(x == 0)
- {
- Traits::assign(*--buf, '0');
- return buf;
- }
- if(x < 0)
- {
- x = -x;
- for(;x > 0; x /= 10)
- Traits::assign(*--buf ,
- "0123456789"[x % 10]);
- Traits::assign(*--buf, '-');
- return buf;
- }
- for(;x > 0; x /= 10)
- Traits::assign(*--buf ,
- "0123456789"[x % 10]);
- return buf;
-}
-
-template<class CharT, class Integer, class Traits>
-CharT*
-raw_to_string(
- CharT* buf, Integer x, std::false_type)
-{
- if(x == 0)
- {
- *--buf = '0';
- return buf;
- }
- for(;x > 0; x /= 10)
- Traits::assign(*--buf ,
- "0123456789"[x % 10]);
- return buf;
-}
-
-template<
- class CharT,
- class Integer,
- class Traits = std::char_traits<CharT>>
-CharT*
-raw_to_string(CharT* last, std::size_t size, Integer i)
-{
- boost::ignore_unused(size);
- BOOST_ASSERT(size >= max_digits(sizeof(Integer)));
- return raw_to_string<CharT, Integer, Traits>(
- last, i, std::is_signed<Integer>{});
-}
-
-} // detail
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/type_traits.hpp b/contrib/restricted/boost/boost/beast/core/detail/type_traits.hpp
deleted file mode 100644
index 3692b6222b..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/type_traits.hpp
+++ /dev/null
@@ -1,472 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_DETAIL_TYPE_TRAITS_HPP
-#define BOOST_BEAST_DETAIL_TYPE_TRAITS_HPP
-
-#include <boost/beast/core/error.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/type_traits.hpp>
-#include <iterator>
-#include <tuple>
-#include <type_traits>
-#include <string>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-template<class U>
-inline
-std::size_t constexpr
-max_sizeof()
-{
- return sizeof(U);
-}
-
-template<class U0, class U1, class... Us>
-inline
-std::size_t constexpr
-max_sizeof()
-{
- return
- max_sizeof<U0>() > max_sizeof<U1, Us...>() ?
- max_sizeof<U0>() : max_sizeof<U1, Us...>();
-}
-
-template<class U>
-inline
-std::size_t constexpr
-max_alignof()
-{
- return alignof(U);
-}
-
-template<class U0, class U1, class... Us>
-std::size_t constexpr
-max_alignof()
-{
- return
- max_alignof<U0>() > max_alignof<U1, Us...>() ?
- max_alignof<U0>() : max_alignof<U1, Us...>();
-}
-
-// (since C++17)
-template<class... Ts> struct make_void { using type = void; };
-template<class... Ts> using void_t = typename make_void<Ts...>::type;
-
-// (since C++11) missing from g++4.8
-template<std::size_t Len, class... Ts>
-struct aligned_union
-{
- static
- std::size_t constexpr alignment_value =
- max_alignof<Ts...>();
-
- using type = typename std::aligned_storage<
- (Len > max_sizeof<Ts...>()) ? Len : (max_sizeof<Ts...>()),
- alignment_value>::type;
-};
-
-template<std::size_t Len, class... Ts>
-using aligned_union_t =
- typename aligned_union<Len, Ts...>::type;
-
-//------------------------------------------------------------------------------
-
-template<class T>
-inline
-void
-accept_rv(T){}
-
-//------------------------------------------------------------------------------
-
-template<unsigned N, class T, class... Tn>
-struct repeat_tuple_impl
-{
- using type = typename repeat_tuple_impl<
- N - 1, T, T, Tn...>::type;
-};
-
-template<class T, class... Tn>
-struct repeat_tuple_impl<0, T, Tn...>
-{
- using type = std::tuple<T, Tn...>;
-};
-
-template<unsigned N, class T>
-struct repeat_tuple
-{
- using type =
- typename repeat_tuple_impl<N-1, T>::type;
-};
-
-template<class T>
-struct repeat_tuple<0, T>
-{
- using type = std::tuple<>;
-};
-
-//------------------------------------------------------------------------------
-
-template<class R, class C, class ...A>
-auto
-is_invocable_test(C&& c, int, A&& ...a)
- -> decltype(std::is_convertible<
- decltype(c(std::forward<A>(a)...)), R>::value ||
- std::is_same<R, void>::value,
- std::true_type());
-
-template<class R, class C, class ...A>
-std::false_type
-is_invocable_test(C&& c, long, A&& ...a);
-
-/** Metafunction returns `true` if F callable as R(A...)
-
- Example:
-
- @code
- is_invocable<T, void(std::string)>
- @endcode
-*/
-/** @{ */
-template<class C, class F>
-struct is_invocable : std::false_type
-{
-};
-
-template<class C, class R, class ...A>
-struct is_invocable<C, R(A...)>
- : decltype(is_invocable_test<R>(
- std::declval<C>(), 1, std::declval<A>()...))
-{
-};
-/** @} */
-
-//------------------------------------------------------------------------------
-
-// for span
-template<class T, class E, class = void>
-struct is_contiguous_container: std::false_type {};
-
-template<class T, class E>
-struct is_contiguous_container<T, E, void_t<
- decltype(
- std::declval<std::size_t&>() = std::declval<T const&>().size(),
- std::declval<E*&>() = std::declval<T&>().data(),
- (void)0),
- typename std::enable_if<
- std::is_same<
- typename std::remove_cv<E>::type,
- typename std::remove_cv<
- typename std::remove_pointer<
- decltype(std::declval<T&>().data())
- >::type
- >::type
- >::value
- >::type>>: std::true_type
-{};
-
-//------------------------------------------------------------------------------
-
-template<class...>
-struct unwidest_unsigned;
-
-template<class U0>
-struct unwidest_unsigned<U0>
-{
- using type = U0;
-};
-
-template<class U0, class... UN>
-struct unwidest_unsigned<U0, UN...>
-{
- BOOST_STATIC_ASSERT(std::is_unsigned<U0>::value);
- using type = typename std::conditional<
- (sizeof(U0) < sizeof(typename unwidest_unsigned<UN...>::type)),
- U0, typename unwidest_unsigned<UN...>::type>::type;
-};
-
-template<class...>
-struct widest_unsigned;
-
-template<class U0>
-struct widest_unsigned<U0>
-{
- using type = U0;
-};
-
-template<class U0, class... UN>
-struct widest_unsigned<U0, UN...>
-{
- BOOST_STATIC_ASSERT(std::is_unsigned<U0>::value);
- using type = typename std::conditional<
- (sizeof(U0) > sizeof(typename widest_unsigned<UN...>::type)),
- U0, typename widest_unsigned<UN...>::type>::type;
-};
-
-template<class U>
-inline
-constexpr
-U
-min_all(U u)
-{
- BOOST_STATIC_ASSERT(std::is_unsigned<U>::value);
- return u;
-}
-
-template<class U0, class U1, class... UN>
-inline
-constexpr
-typename unwidest_unsigned<U0, U1, UN...>::type
-min_all(U0 u0, U1 u1, UN... un)
-{
- using type =
- typename unwidest_unsigned<U0, U1, UN...>::type;
- return u0 < u1 ?
- static_cast<type>(min_all(u0, un...)) :
- static_cast<type>(min_all(u1, un...));
-}
-
-template<class U>
-inline
-constexpr
-U
-max_all(U u)
-{
- BOOST_STATIC_ASSERT(std::is_unsigned<U>::value);
- return u;
-}
-
-template<class U0, class U1, class... UN>
-inline
-constexpr
-typename widest_unsigned<U0, U1, UN...>::type
-max_all(U0 u0, U1 u1, UN... un)
-{
- return u0 > u1? max_all(u0, un...) : max_all(u1, un...);
-}
-
-//------------------------------------------------------------------------------
-
-template<class T, class = void>
-struct get_lowest_layer_helper
-{
- using type = T;
-};
-
-template<class T>
-struct get_lowest_layer_helper<T,
- void_t<typename T::lowest_layer_type>>
-{
- using type = typename T::lowest_layer_type;
-};
-
-//------------------------------------------------------------------------------
-
-//
-// buffer concepts
-//
-
-// Types that meet the requirements,
-// for use with std::declval only.
-template<class BufferType>
-struct BufferSequence
-{
- using value_type = BufferType;
- using const_iterator = BufferType const*;
- ~BufferSequence();
- BufferSequence(BufferSequence const&) = default;
- const_iterator begin() const noexcept;
- const_iterator end() const noexcept;
-};
-using ConstBufferSequence =
- BufferSequence<boost::asio::const_buffer>;
-using MutableBufferSequence =
- BufferSequence<boost::asio::mutable_buffer>;
-
-template<class B1, class... Bn>
-struct is_all_const_buffer_sequence
- : std::integral_constant<bool,
- boost::asio::is_const_buffer_sequence<B1>::value &&
- is_all_const_buffer_sequence<Bn...>::value>
-{
-};
-
-template<class B>
-struct is_all_const_buffer_sequence<B>
- : boost::asio::is_const_buffer_sequence<B>
-{
-};
-
-template<class... Bn>
-struct common_buffers_type
-{
- using type = typename std::conditional<
- boost::is_convertible<std::tuple<Bn...>,
- typename repeat_tuple<sizeof...(Bn),
- boost::asio::mutable_buffer>::type>::value,
- boost::asio::mutable_buffer,
- boost::asio::const_buffer>::type;
-};
-
-template<class B>
-struct buffer_sequence_iterator
-{
- using type = decltype(
- boost::asio::buffer_sequence_begin(
- std::declval<B const&>()));
-};
-
-// Types that meet the requirements,
-// for use with std::declval only.
-struct StreamHandler
-{
- StreamHandler(StreamHandler const&) = default;
- void operator()(error_code ec, std::size_t);
-};
-using ReadHandler = StreamHandler;
-using WriteHandler = StreamHandler;
-
-template<class Buffers>
-class buffers_range_adaptor
-{
- Buffers const& b_;
-
-public:
- using value_type = typename std::conditional<
- boost::is_convertible<
- typename std::iterator_traits<
- typename buffer_sequence_iterator<
- Buffers>::type>::value_type,
- boost::asio::mutable_buffer>::value,
- boost::asio::mutable_buffer,
- boost::asio::const_buffer>::type;
-
- class const_iterator
- {
- friend class buffers_range_adaptor;
-
- using iter_type = typename
- buffer_sequence_iterator<Buffers>::type;
-
- iter_type it_;
-
- const_iterator(iter_type const& it)
- : it_(it)
- {
- }
-
- public:
- using value_type = typename
- buffers_range_adaptor::value_type;
- using pointer = value_type const*;
- using reference = value_type;
- using difference_type = std::ptrdiff_t;
- using iterator_category =
- std::bidirectional_iterator_tag;
-
- bool
- operator==(const_iterator const& other) const
- {
- return it_ == other.it_;
- }
-
- bool
- operator!=(const_iterator const& other) const
- {
- return ! (*this == other);
- }
-
- reference
- operator*() const
- {
- return *it_;
- }
-
- pointer
- operator->() const = delete;
-
- const_iterator&
- operator++()
- {
- ++it_;
- return *this;
- }
-
- const_iterator
- operator++(int)
- {
- auto temp = *this;
- ++(*this);
- return temp;
- }
-
- // deprecated
- const_iterator&
- operator--()
- {
- --it_;
- return *this;
- }
-
- // deprecated
- const_iterator
- operator--(int)
- {
- auto temp = *this;
- --(*this);
- return temp;
- }
- };
-
- explicit
- buffers_range_adaptor(Buffers const& b)
- : b_(b)
- {
- }
-
- const_iterator
- begin() const noexcept
- {
- return boost::asio::buffer_sequence_begin(b_);
- }
-
- const_iterator
- end() const noexcept
- {
- return boost::asio::buffer_sequence_end(b_);
- }
-};
-
-template<class Buffers>
-buffers_range_adaptor<Buffers>
-buffers_range(Buffers const& buffers)
-{
- return buffers_range_adaptor<Buffers>{buffers};
-}
-
-/* If this static assert goes off, it means that the completion
- handler you provided to an asynchronous initiating function did
- not have the right signature. Check the parameter types for your
- completion handler and make sure they match the list of types
- expected by the initiating function,
-*/
-#define BOOST_BEAST_HANDLER_INIT(type, sig) \
- static_assert(is_completion_handler< \
- BOOST_ASIO_HANDLER_TYPE(type, sig), sig>::value, \
- "CompletionHandler signature requirements not met"); \
- boost::asio::async_completion<type, sig> init{handler}
-
-} // detail
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/variant.hpp b/contrib/restricted/boost/boost/beast/core/detail/variant.hpp
deleted file mode 100644
index 536cb7593f..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/variant.hpp
+++ /dev/null
@@ -1,267 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_DETAIL_VARIANT_HPP
-#define BOOST_BEAST_DETAIL_VARIANT_HPP
-
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/assert.hpp>
-#include <cstddef>
-#include <tuple>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-// This simple variant gets the job done without
-// causing too much trouble with template depth:
-//
-// * Always allows an empty state I==0
-// * emplace() and get() support 1-based indexes only
-// * Basic exception guarantee
-// * Max 255 types
-//
-template<class... TN>
-class variant
-{
- detail::aligned_union_t<1, TN...> buf_;
- unsigned char i_ = 0;
-
- template<std::size_t I>
- using type = typename std::tuple_element<
- I, std::tuple<TN...>>::type;
-
- template<std::size_t I>
- using C = std::integral_constant<std::size_t, I>;
-
-public:
- variant() = default;
-
- ~variant()
- {
- destroy(C<0>{});
- }
-
- bool
- operator==(variant const& other) const
- {
- if(i_ != other.i_)
- return false;
- return equal(other, C<0>{});
- }
-
- // 0 = empty
- unsigned char
- index() const
- {
- return i_;
- }
-
- // moved-from object becomes empty
- variant(variant&& other)
- {
- i_ = other.move(&buf_, C<0>{});
- other.i_ = 0;
- }
-
- variant(variant const& other)
- {
- i_ = other.copy(&buf_, C<0>{});
- }
-
- // moved-from object becomes empty
- variant& operator=(variant&& other)
- {
- if(this != &other)
- {
- destroy(C<0>{});
- i_ = other.move(&buf_, C<0>{});
- other.i_ = 0;
- }
- return *this;
- }
-
- variant& operator=(variant const& other)
- {
- if(this != &other)
- {
- destroy(C<0>{});
- i_ = other.copy(&buf_, C<0>{});
- }
- return *this;
- }
-
- template<std::size_t I, class... Args>
- void
- emplace(Args&&... args)
- {
- destroy(C<0>{});
- new(&buf_) type<I-1>(
- std::forward<Args>(args)...);
- i_ = I;
- }
-
- template<std::size_t I>
- type<I-1>&
- get()
- {
- BOOST_ASSERT(i_ == I);
- return *reinterpret_cast<
- type<I-1>*>(&buf_);
- }
-
- template<std::size_t I>
- type<I-1> const&
- get() const
- {
- BOOST_ASSERT(i_ == I);
- return *reinterpret_cast<
- type<I-1> const*>(&buf_);
- }
-
- void
- reset()
- {
- destroy(C<0>{});
- }
-
-private:
- void
- destroy(C<0>)
- {
- auto const I = 0;
- if(i_ == I)
- return;
- destroy(C<I+1>{});
- i_ = 0;
- }
-
- template<std::size_t I>
- void
- destroy(C<I>)
- {
- if(i_ == I)
- {
- using T = type<I-1>;
- get<I>().~T();
- return;
- }
- destroy(C<I+1>{});
- }
-
- void
- destroy(C<sizeof...(TN)>)
- {
- auto const I = sizeof...(TN);
- BOOST_ASSERT(i_ == I);
- using T = type<I-1>;
- get<I>().~T();
- }
-
- unsigned char
- move(void* dest, C<0>)
- {
- auto const I = 0;
- if(i_ == I)
- return I;
- return move(dest, C<I+1>{});
- }
-
- template<std::size_t I>
- unsigned char
- move(void* dest, C<I>)
- {
- if(i_ == I)
- {
- using T = type<I-1>;
- new(dest) T(std::move(get<I>()));
- get<I>().~T();
- return I;
- }
- return move(dest, C<I+1>{});
- }
-
- unsigned char
- move(void* dest, C<sizeof...(TN)>)
- {
- auto const I = sizeof...(TN);
- BOOST_ASSERT(i_ == I);
- using T = type<I-1>;
- new(dest) T(std::move(get<I>()));
- get<I>().~T();
- return I;
- }
-
- unsigned char
- copy(void* dest, C<0>) const
- {
- auto const I = 0;
- if(i_ == I)
- return I;
- return copy(dest, C<I+1>{});
- }
-
- template<std::size_t I>
- unsigned char
- copy(void* dest, C<I>) const
- {
- if(i_ == I)
- {
- using T = type<I-1>;
- auto const& t = get<I>();
- new(dest) T(t);
- return I;
- }
- return copy(dest, C<I+1>{});
- }
-
- unsigned char
- copy(void* dest, C<sizeof...(TN)>) const
- {
- auto const I = sizeof...(TN);
- BOOST_ASSERT(i_ == I);
- using T = type<I-1>;
- auto const& t = get<I>();
- new(dest) T(t);
- return I;
- }
-
- bool
- equal(variant const& other, C<0>) const
- {
- auto constexpr I = 0;
- if(i_ == I)
- return true;
- return equal(other, C<I+1>{});
- }
-
- template<std::size_t I>
- bool
- equal(variant const& other, C<I>) const
- {
- if(i_ == I)
- return get<I>() == other.get<I>();
- return equal(other, C<I+1>{});
- }
-
- bool
- equal(variant const& other, C<sizeof...(TN)>) const
- {
- auto constexpr I = sizeof...(TN);
- BOOST_ASSERT(i_ == I);
- return get<I>() == other.get<I>();
- }
-};
-
-} // detail
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/detail/varint.hpp b/contrib/restricted/boost/boost/beast/core/detail/varint.hpp
deleted file mode 100644
index 37f0b9d1c1..0000000000
--- a/contrib/restricted/boost/boost/beast/core/detail/varint.hpp
+++ /dev/null
@@ -1,79 +0,0 @@
-//
-// Copyright (c) 2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_DETAIL_VARINT_HPP
-#define BOOST_BEAST_DETAIL_VARINT_HPP
-
-#include <boost/static_assert.hpp>
-#include <cstdlib>
-#include <iterator>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-namespace detail {
-
-// https://developers.google.com/protocol-buffers/docs/encoding#varints
-
-inline
-std::size_t
-varint_size(std::size_t value)
-{
- std::size_t n = 1;
- while(value > 127)
- {
- ++n;
- value /= 128;
- }
- return n;
-}
-
-template<class FwdIt>
-std::size_t
-varint_read(FwdIt& first)
-{
- using value_type = typename
- std::iterator_traits<FwdIt>::value_type;
- BOOST_STATIC_ASSERT(
- std::is_integral<value_type>::value &&
- sizeof(value_type) == 1);
- std::size_t value = 0;
- std::size_t factor = 1;
- while((*first & 0x80) != 0)
- {
- value += (*first++ & 0x7f) * factor;
- factor *= 128;
- }
- value += *first++ * factor;
- return value;
-}
-
-template<class FwdIt>
-void
-varint_write(FwdIt& first, std::size_t value)
-{
- using value_type = typename
- std::iterator_traits<FwdIt>::value_type;
- BOOST_STATIC_ASSERT(
- std::is_integral<value_type>::value &&
- sizeof(value_type) == 1);
- while(value > 127)
- {
- *first++ = static_cast<value_type>(
- 0x80 | value);
- value /= 128;
- }
- *first++ = static_cast<value_type>(value);
-}
-
-} // detail
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/error.hpp b/contrib/restricted/boost/boost/beast/core/error.hpp
deleted file mode 100644
index f034f7a404..0000000000
--- a/contrib/restricted/boost/boost/beast/core/error.hpp
+++ /dev/null
@@ -1,58 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_ERROR_HPP
-#define BOOST_BEAST_ERROR_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/system/error_code.hpp>
-#include <boost/system/system_error.hpp>
-
-namespace boost {
-namespace beast {
-
-/// The type of error code used by the library
-using error_code = boost::system::error_code;
-
-/// The type of system error thrown by the library
-using system_error = boost::system::system_error;
-
-/// The type of error category used by the library
-using error_category = boost::system::error_category;
-
-/// A function to return the generic error category used by the library
-#if BOOST_BEAST_DOXYGEN
-error_category const&
-generic_category();
-#else
-using boost::system::generic_category;
-#endif
-
-/// A function to return the system error category used by the library
-#if BOOST_BEAST_DOXYGEN
-error_category const&
-system_category();
-#else
-using boost::system::system_category;
-#endif
-
-/// The type of error condition used by the library
-using error_condition = boost::system::error_condition;
-
-/// The set of constants used for cross-platform error codes
-#if BOOST_BEAST_DOXYGEN
-enum errc{};
-#else
-namespace errc = boost::system::errc;
-#endif
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/file.hpp b/contrib/restricted/boost/boost/beast/core/file.hpp
deleted file mode 100644
index 09c8e82081..0000000000
--- a/contrib/restricted/boost/boost/beast/core/file.hpp
+++ /dev/null
@@ -1,45 +0,0 @@
-//
-// Copyright (c) 2015-2016 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_CORE_FILE_HPP
-#define BOOST_BEAST_CORE_FILE_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/file_base.hpp>
-#include <boost/beast/core/file_posix.hpp>
-#include <boost/beast/core/file_stdio.hpp>
-#include <boost/beast/core/file_win32.hpp>
-#include <boost/config.hpp>
-
-namespace boost {
-namespace beast {
-
-/** An implementation of File.
-
- This alias is set to the best available implementation
- of @b File given the platform and build settings.
-*/
-#if BOOST_BEAST_DOXYGEN
-struct file : file_stdio
-{
-};
-#else
-#if BOOST_BEAST_USE_WIN32_FILE
-using file = file_win32;
-#elif BOOST_BEAST_USE_POSIX_FILE
-using file = file_posix;
-#else
-using file = file_stdio;
-#endif
-#endif
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/file_base.hpp b/contrib/restricted/boost/boost/beast/core/file_base.hpp
deleted file mode 100644
index c2b3c53a53..0000000000
--- a/contrib/restricted/boost/boost/beast/core/file_base.hpp
+++ /dev/null
@@ -1,89 +0,0 @@
-//
-// Copyright (c) 2015-2016 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_CORE_FILE_BASE_HPP
-#define BOOST_BEAST_CORE_FILE_BASE_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/string.hpp>
-
-namespace boost {
-namespace beast {
-
-/** File open modes
-
- These modes are used when opening files using
- instances of the @b File concept.
-
- @see file_stdio
-*/
-enum class file_mode
-{
- /// Random reading
- read,
-
- /// Sequential reading
- scan,
-
- /** Random writing to a new or truncated file
-
- @li If the file does not exist, it is created.
-
- @li If the file exists, it is truncated to
- zero size upon opening.
- */
- write,
-
- /** Random writing to new file only
-
- If the file exists, an error is generated.
- */
- write_new,
-
- /** Random writing to existing file
-
- If the file does not exist, an error is generated.
- */
- write_existing,
-
- /** Appending to a new or truncated file
-
- The current file position shall be set to the end of
- the file prior to each write.
-
- @li If the file does not exist, it is created.
-
- @li If the file exists, it is truncated to
- zero size upon opening.
- */
- append,
-
- /** Appending to a new file only
-
- The current file position shall be set to the end of
- the file prior to each write.
-
- If the file exists, an error is generated.
- */
- append_new,
-
- /** Appending to an existing file
-
- The current file position shall be set to the end of
- the file prior to each write.
-
- If the file does not exist, an error is generated.
- */
- append_existing
-};
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/file_posix.hpp b/contrib/restricted/boost/boost/beast/core/file_posix.hpp
deleted file mode 100644
index 65bac2065d..0000000000
--- a/contrib/restricted/boost/boost/beast/core/file_posix.hpp
+++ /dev/null
@@ -1,175 +0,0 @@
-//
-// Copyright (c) 2015-2016 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_CORE_FILE_POSIX_HPP
-#define BOOST_BEAST_CORE_FILE_POSIX_HPP
-
-#include <boost/config.hpp>
-
-#if ! defined(BOOST_BEAST_NO_POSIX_FILE)
-# if ! defined(__APPLE__) && ! defined(__linux__)
-# define BOOST_BEAST_NO_POSIX_FILE
-# endif
-#endif
-
-#if ! defined(BOOST_BEAST_USE_POSIX_FILE)
-# if ! defined(BOOST_BEAST_NO_POSIX_FILE)
-# define BOOST_BEAST_USE_POSIX_FILE 1
-# else
-# define BOOST_BEAST_USE_POSIX_FILE 0
-# endif
-#endif
-
-#if BOOST_BEAST_USE_POSIX_FILE
-
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/core/file_base.hpp>
-#include <cstdint>
-
-namespace boost {
-namespace beast {
-
-/** An implementation of File for POSIX systems.
-
- This class implements a @b File using POSIX interfaces.
-*/
-class file_posix
-{
- int fd_ = -1;
-
-public:
- /** The type of the underlying file handle.
-
- This is platform-specific.
- */
- using native_handle_type = int;
-
- /** Destructor
-
- If the file is open it is first closed.
- */
- ~file_posix();
-
- /** Constructor
-
- There is no open file initially.
- */
- file_posix() = default;
-
- /** Constructor
-
- The moved-from object behaves as if default constructed.
- */
- file_posix(file_posix&& other);
-
- /** Assignment
-
- The moved-from object behaves as if default constructed.
- */
- file_posix& operator=(file_posix&& other);
-
- /// Returns the native handle associated with the file.
- native_handle_type
- native_handle() const
- {
- return fd_;
- }
-
- /** Set the native handle associated with the file.
-
- If the file is open it is first closed.
-
- @param fd The native file handle to assign.
- */
- void
- native_handle(native_handle_type fd);
-
- /// Returns `true` if the file is open
- bool
- is_open() const
- {
- return fd_ != -1;
- }
-
- /** Close the file if open
-
- @param ec Set to the error, if any occurred.
- */
- void
- close(error_code& ec);
-
- /** Open a file at the given path with the specified mode
-
- @param path The utf-8 encoded path to the file
-
- @param mode The file mode to use
-
- @param ec Set to the error, if any occurred
- */
- void
- open(char const* path, file_mode mode, error_code& ec);
-
- /** Return the size of the open file
-
- @param ec Set to the error, if any occurred
-
- @return The size in bytes
- */
- std::uint64_t
- size(error_code& ec) const;
-
- /** Return the current position in the open file
-
- @param ec Set to the error, if any occurred
-
- @return The offset in bytes from the beginning of the file
- */
- std::uint64_t
- pos(error_code& ec) const;
-
- /** Adjust the current position in the open file
-
- @param offset The offset in bytes from the beginning of the file
-
- @param ec Set to the error, if any occurred
- */
- void
- seek(std::uint64_t offset, error_code& ec);
-
- /** Read from the open file
-
- @param buffer The buffer for storing the result of the read
-
- @param n The number of bytes to read
-
- @param ec Set to the error, if any occurred
- */
- std::size_t
- read(void* buffer, std::size_t n, error_code& ec) const;
-
- /** Write to the open file
-
- @param buffer The buffer holding the data to write
-
- @param n The number of bytes to write
-
- @param ec Set to the error, if any occurred
- */
- std::size_t
- write(void const* buffer, std::size_t n, error_code& ec);
-};
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/file_posix.ipp>
-
-#endif
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/file_stdio.hpp b/contrib/restricted/boost/boost/beast/core/file_stdio.hpp
deleted file mode 100644
index 09ca0c42de..0000000000
--- a/contrib/restricted/boost/boost/beast/core/file_stdio.hpp
+++ /dev/null
@@ -1,158 +0,0 @@
-//
-// Copyright (c) 2015-2016 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_CORE_FILE_STDIO_HPP
-#define BOOST_BEAST_CORE_FILE_STDIO_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/core/file_base.hpp>
-#include <cstdio>
-#include <cstdint>
-
-namespace boost {
-namespace beast {
-
-/** An implementation of File which uses cstdio.
-
- This class implements a file using the interfaces present
- in the C++ Standard Library, in `<stdio>`.
-*/
-class file_stdio
-{
- FILE* f_ = nullptr;
-
-public:
- /** The type of the underlying file handle.
-
- This is platform-specific.
- */
- using native_handle_type = FILE*;
-
- /** Destructor
-
- If the file is open it is first closed.
- */
- ~file_stdio();
-
- /** Constructor
-
- There is no open file initially.
- */
- file_stdio() = default;
-
- /** Constructor
-
- The moved-from object behaves as if default constructed.
- */
- file_stdio(file_stdio&& other);
-
- /** Assignment
-
- The moved-from object behaves as if default constructed.
- */
- file_stdio& operator=(file_stdio&& other);
-
- /// Returns the native handle associated with the file.
- FILE*
- native_handle() const
- {
- return f_;
- }
-
- /** Set the native handle associated with the file.
-
- If the file is open it is first closed.
-
- @param f The native file handle to assign.
- */
- void
- native_handle(FILE* f);
-
- /// Returns `true` if the file is open
- bool
- is_open() const
- {
- return f_ != nullptr;
- }
-
- /** Close the file if open
-
- @param ec Set to the error, if any occurred.
- */
- void
- close(error_code& ec);
-
- /** Open a file at the given path with the specified mode
-
- @param path The utf-8 encoded path to the file
-
- @param mode The file mode to use
-
- @param ec Set to the error, if any occurred
- */
- void
- open(char const* path, file_mode mode, error_code& ec);
-
- /** Return the size of the open file
-
- @param ec Set to the error, if any occurred
-
- @return The size in bytes
- */
- std::uint64_t
- size(error_code& ec) const;
-
- /** Return the current position in the open file
-
- @param ec Set to the error, if any occurred
-
- @return The offset in bytes from the beginning of the file
- */
- std::uint64_t
- pos(error_code& ec) const;
-
- /** Adjust the current position in the open file
-
- @param offset The offset in bytes from the beginning of the file
-
- @param ec Set to the error, if any occurred
- */
- void
- seek(std::uint64_t offset, error_code& ec);
-
- /** Read from the open file
-
- @param buffer The buffer for storing the result of the read
-
- @param n The number of bytes to read
-
- @param ec Set to the error, if any occurred
- */
- std::size_t
- read(void* buffer, std::size_t n, error_code& ec) const;
-
- /** Write to the open file
-
- @param buffer The buffer holding the data to write
-
- @param n The number of bytes to write
-
- @param ec Set to the error, if any occurred
- */
- std::size_t
- write(void const* buffer, std::size_t n, error_code& ec);
-};
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/file_stdio.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/file_win32.hpp b/contrib/restricted/boost/boost/beast/core/file_win32.hpp
deleted file mode 100644
index 3e9a18abaa..0000000000
--- a/contrib/restricted/boost/boost/beast/core/file_win32.hpp
+++ /dev/null
@@ -1,177 +0,0 @@
-//
-// Copyright (c) 2015-2016 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_CORE_FILE_WIN32_HPP
-#define BOOST_BEAST_CORE_FILE_WIN32_HPP
-
-#include <boost/config.hpp>
-
-#if ! defined(BOOST_BEAST_USE_WIN32_FILE)
-# ifdef BOOST_MSVC
-# define BOOST_BEAST_USE_WIN32_FILE 1
-# else
-# define BOOST_BEAST_USE_WIN32_FILE 0
-# endif
-#endif
-
-#if BOOST_BEAST_USE_WIN32_FILE
-
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/core/file_base.hpp>
-#include <boost/winapi/basic_types.hpp>
-#include <boost/winapi/handles.hpp>
-#include <cstdio>
-#include <cstdint>
-
-namespace boost {
-namespace beast {
-
-/** An implementation of File for Win32.
-
- This class implements a @b File using Win32 native interfaces.
-*/
-class file_win32
-{
- boost::winapi::HANDLE_ h_ =
- boost::winapi::INVALID_HANDLE_VALUE_;
-
-public:
- /** The type of the underlying file handle.
-
- This is platform-specific.
- */
-#if BOOST_BEAST_DOXYGEN
- using native_handle_type = HANDLE;
-#else
- using native_handle_type = boost::winapi::HANDLE_;
-#endif
-
- /** Destructor
-
- If the file is open it is first closed.
- */
- ~file_win32();
-
- /** Constructor
-
- There is no open file initially.
- */
- file_win32() = default;
-
- /** Constructor
-
- The moved-from object behaves as if default constructed.
- */
- file_win32(file_win32&& other);
-
- /** Assignment
-
- The moved-from object behaves as if default constructed.
- */
- file_win32& operator=(file_win32&& other);
-
- /// Returns the native handle associated with the file.
- native_handle_type
- native_handle()
- {
- return h_;
- }
-
- /** Set the native handle associated with the file.
-
- If the file is open it is first closed.
-
- @param h The native file handle to assign.
- */
- void
- native_handle(native_handle_type h);
-
- /// Returns `true` if the file is open
- bool
- is_open() const
- {
- return h_ != boost::winapi::INVALID_HANDLE_VALUE_;
- }
-
- /** Close the file if open
-
- @param ec Set to the error, if any occurred.
- */
- void
- close(error_code& ec);
-
- /** Open a file at the given path with the specified mode
-
- @param path The utf-8 encoded path to the file
-
- @param mode The file mode to use
-
- @param ec Set to the error, if any occurred
- */
- void
- open(char const* path, file_mode mode, error_code& ec);
-
- /** Return the size of the open file
-
- @param ec Set to the error, if any occurred
-
- @return The size in bytes
- */
- std::uint64_t
- size(error_code& ec) const;
-
- /** Return the current position in the open file
-
- @param ec Set to the error, if any occurred
-
- @return The offset in bytes from the beginning of the file
- */
- std::uint64_t
- pos(error_code& ec);
-
- /** Adjust the current position in the open file
-
- @param offset The offset in bytes from the beginning of the file
-
- @param ec Set to the error, if any occurred
- */
- void
- seek(std::uint64_t offset, error_code& ec);
-
- /** Read from the open file
-
- @param buffer The buffer for storing the result of the read
-
- @param n The number of bytes to read
-
- @param ec Set to the error, if any occurred
- */
- std::size_t
- read(void* buffer, std::size_t n, error_code& ec);
-
- /** Write to the open file
-
- @param buffer The buffer holding the data to write
-
- @param n The number of bytes to write
-
- @param ec Set to the error, if any occurred
- */
- std::size_t
- write(void const* buffer, std::size_t n, error_code& ec);
-};
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/file_win32.ipp>
-
-#endif
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/flat_buffer.hpp b/contrib/restricted/boost/boost/beast/core/flat_buffer.hpp
deleted file mode 100644
index 11a18fdcb4..0000000000
--- a/contrib/restricted/boost/boost/beast/core/flat_buffer.hpp
+++ /dev/null
@@ -1,342 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_FLAT_BUFFER_HPP
-#define BOOST_BEAST_FLAT_BUFFER_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/detail/allocator.hpp>
-#include <boost/beast/core/detail/empty_base_optimization.hpp>
-#include <boost/asio/buffer.hpp>
-#include <limits>
-#include <memory>
-
-namespace boost {
-namespace beast {
-
-/** A linear dynamic buffer.
-
- Objects of this type meet the requirements of @b DynamicBuffer
- and offer additional invariants:
-
- @li Buffer sequences returned by @ref data and @ref prepare
- will always be of length one.
-
- @li A configurable maximum buffer size may be set upon
- construction. Attempts to exceed the buffer size will throw
- `std::length_error`.
-
- Upon construction, a maximum size for the buffer may be
- specified. If this limit is exceeded, the `std::length_error`
- exception will be thrown.
-
- @note This class is designed for use with algorithms that
- take dynamic buffers as parameters, and are optimized
- for the case where the input sequence or output sequence
- is stored in a single contiguous buffer.
-*/
-template<class Allocator>
-class basic_flat_buffer
-#if ! BOOST_BEAST_DOXYGEN
- : private detail::empty_base_optimization<
- typename detail::allocator_traits<Allocator>::
- template rebind_alloc<char>>
-#endif
-{
- enum
- {
- min_size = 512
- };
-
- template<class OtherAlloc>
- friend class basic_flat_buffer;
-
- using base_alloc_type = typename
- detail::allocator_traits<Allocator>::
- template rebind_alloc<char>;
-
- using alloc_traits =
- detail::allocator_traits<base_alloc_type>;
-
- static
- inline
- std::size_t
- dist(char const* first, char const* last)
- {
- return static_cast<std::size_t>(last - first);
- }
-
- char* begin_;
- char* in_;
- char* out_;
- char* last_;
- char* end_;
- std::size_t max_;
-
-public:
- /// The type of allocator used.
- using allocator_type = Allocator;
-
- /// The type used to represent the input sequence as a list of buffers.
- using const_buffers_type = boost::asio::const_buffer;
-
- /// The type used to represent the output sequence as a list of buffers.
- using mutable_buffers_type = boost::asio::mutable_buffer;
-
- /// Destructor
- ~basic_flat_buffer();
-
- /** Constructor
-
- Upon construction, capacity will be zero.
- */
- basic_flat_buffer();
-
- /** Constructor
-
- Upon construction, capacity will be zero.
-
- @param limit The setting for @ref max_size.
- */
- explicit
- basic_flat_buffer(std::size_t limit);
-
- /** Constructor
-
- Upon construction, capacity will be zero.
-
- @param alloc The allocator to construct with.
- */
- explicit
- basic_flat_buffer(Allocator const& alloc);
-
- /** Constructor
-
- Upon construction, capacity will be zero.
-
- @param limit The setting for @ref max_size.
-
- @param alloc The allocator to use.
- */
- basic_flat_buffer(
- std::size_t limit, Allocator const& alloc);
-
- /** Constructor
-
- After the move, `*this` will have an empty output sequence.
-
- @param other The object to move from. After the move,
- The object's state will be as if constructed using
- its current allocator and limit.
- */
- basic_flat_buffer(basic_flat_buffer&& other);
-
- /** Constructor
-
- After the move, `*this` will have an empty output sequence.
-
- @param other The object to move from. After the move,
- The object's state will be as if constructed using
- its current allocator and limit.
-
- @param alloc The allocator to use.
- */
- basic_flat_buffer(
- basic_flat_buffer&& other, Allocator const& alloc);
-
- /** Constructor
-
- @param other The object to copy from.
- */
- basic_flat_buffer(basic_flat_buffer const& other);
-
- /** Constructor
-
- @param other The object to copy from.
-
- @param alloc The allocator to use.
- */
- basic_flat_buffer(basic_flat_buffer const& other,
- Allocator const& alloc);
-
- /** Constructor
-
- @param other The object to copy from.
- */
- template<class OtherAlloc>
- basic_flat_buffer(
- basic_flat_buffer<OtherAlloc> const& other);
-
- /** Constructor
-
- @param other The object to copy from.
-
- @param alloc The allocator to use.
- */
- template<class OtherAlloc>
- basic_flat_buffer(
- basic_flat_buffer<OtherAlloc> const& other,
- Allocator const& alloc);
-
- /** Assignment
-
- After the move, `*this` will have an empty output sequence.
-
- @param other The object to move from. After the move,
- the object's state will be as if constructed using
- its current allocator and limit.
- */
- basic_flat_buffer&
- operator=(basic_flat_buffer&& other);
-
- /** Assignment
-
- After the copy, `*this` will have an empty output sequence.
-
- @param other The object to copy from.
- */
- basic_flat_buffer&
- operator=(basic_flat_buffer const& other);
-
- /** Copy assignment
-
- After the copy, `*this` will have an empty output sequence.
-
- @param other The object to copy from.
- */
- template<class OtherAlloc>
- basic_flat_buffer&
- operator=(basic_flat_buffer<OtherAlloc> const& other);
-
- /// Returns a copy of the associated allocator.
- allocator_type
- get_allocator() const
- {
- return this->member();
- }
-
- /// Returns the size of the input sequence.
- std::size_t
- size() const
- {
- return dist(in_, out_);
- }
-
- /// Return the maximum sum of the input and output sequence sizes.
- std::size_t
- max_size() const
- {
- return max_;
- }
-
- /// Return the maximum sum of input and output sizes that can be held without an allocation.
- std::size_t
- capacity() const
- {
- return dist(begin_, end_);
- }
-
- /// Get a list of buffers that represent the input sequence.
- const_buffers_type
- data() const
- {
- return {in_, dist(in_, out_)};
- }
-
- /** Get a list of buffers that represent the output sequence, with the given size.
-
- @throws std::length_error if `size() + n` exceeds `max_size()`.
-
- @note All previous buffers sequences obtained from
- calls to @ref data or @ref prepare are invalidated.
- */
- mutable_buffers_type
- prepare(std::size_t n);
-
- /** Move bytes from the output sequence to the input sequence.
-
- @param n The number of bytes to move. If this is larger than
- the number of bytes in the output sequences, then the entire
- output sequences is moved.
-
- @note All previous buffers sequences obtained from
- calls to @ref data or @ref prepare are invalidated.
- */
- void
- commit(std::size_t n)
- {
- out_ += (std::min)(n, dist(out_, last_));
- }
-
- /** Remove bytes from the input sequence.
-
- If `n` is greater than the number of bytes in the input
- sequence, all bytes in the input sequence are removed.
-
- @note All previous buffers sequences obtained from
- calls to @ref data or @ref prepare are invalidated.
- */
- void
- consume(std::size_t n);
-
- /** Reallocate the buffer to fit the input sequence.
-
- @note All previous buffers sequences obtained from
- calls to @ref data or @ref prepare are invalidated.
- */
- void
- shrink_to_fit();
-
- /// Exchange two flat buffers
- template<class Alloc>
- friend
- void
- swap(
- basic_flat_buffer<Alloc>& lhs,
- basic_flat_buffer<Alloc>& rhs);
-
-private:
- void
- reset();
-
- template<class DynamicBuffer>
- void
- copy_from(DynamicBuffer const& other);
-
- void
- move_assign(basic_flat_buffer&, std::true_type);
-
- void
- move_assign(basic_flat_buffer&, std::false_type);
-
- void
- copy_assign(basic_flat_buffer const&, std::true_type);
-
- void
- copy_assign(basic_flat_buffer const&, std::false_type);
-
- void
- swap(basic_flat_buffer&);
-
- void
- swap(basic_flat_buffer&, std::true_type);
-
- void
- swap(basic_flat_buffer&, std::false_type);
-};
-
-using flat_buffer =
- basic_flat_buffer<std::allocator<char>>;
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/flat_buffer.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/flat_static_buffer.hpp b/contrib/restricted/boost/boost/beast/core/flat_static_buffer.hpp
deleted file mode 100644
index c8eae90945..0000000000
--- a/contrib/restricted/boost/boost/beast/core/flat_static_buffer.hpp
+++ /dev/null
@@ -1,254 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_FLAT_STATIC_BUFFER_HPP
-#define BOOST_BEAST_FLAT_STATIC_BUFFER_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/asio/buffer.hpp>
-#include <algorithm>
-#include <cstddef>
-#include <cstring>
-
-namespace boost {
-namespace beast {
-
-/** A flat @b DynamicBuffer with a fixed size internal buffer.
-
- Buffer sequences returned by @ref data and @ref prepare
- will always be of length one.
- Ownership of the underlying storage belongs to the derived class.
-
- @note Variables are usually declared using the template class
- @ref flat_static_buffer; however, to reduce the number of instantiations
- of template functions receiving static stream buffer arguments in a
- deduced context, the signature of the receiving function should use
- @ref flat_static_buffer_base.
-
- When used with @ref flat_static_buffer this implements a dynamic
- buffer using no memory allocations.
-
- @see @ref flat_static_buffer
-*/
-class flat_static_buffer_base
-{
- char* begin_;
- char* in_;
- char* out_;
- char* last_;
- char* end_;
-
- flat_static_buffer_base(flat_static_buffer_base const& other) = delete;
- flat_static_buffer_base& operator=(flat_static_buffer_base const&) = delete;
-
-public:
- /** The type used to represent the input sequence as a list of buffers.
-
- This buffer sequence is guaranteed to have length 1.
- */
- using const_buffers_type = boost::asio::const_buffer;
-
- /** The type used to represent the output sequence as a list of buffers.
-
- This buffer sequence is guaranteed to have length 1.
- */
- using mutable_buffers_type = boost::asio::mutable_buffer;
-
- /** Constructor
-
- This creates a dynamic buffer using the provided storage area.
-
- @param p A pointer to valid storage of at least `n` bytes.
-
- @param n The number of valid bytes pointed to by `p`.
- */
- flat_static_buffer_base(void* p, std::size_t n)
- {
- reset_impl(p, n);
- }
-
- /// Return the size of the input sequence.
- std::size_t
- size() const
- {
- return out_ - in_;
- }
-
- /// Return the maximum sum of the input and output sequence sizes.
- std::size_t
- max_size() const
- {
- return dist(begin_, end_);
- }
-
- /// Return the maximum sum of input and output sizes that can be held without an allocation.
- std::size_t
- capacity() const
- {
- return max_size();
- }
-
- /** Get a list of buffers that represent the input sequence.
-
- @note These buffers remain valid across subsequent calls to `prepare`.
- */
- const_buffers_type
- data() const;
-
- /// Set the input and output sequences to size 0
- void
- reset();
-
- /** Get a list of buffers that represent the output sequence, with the given size.
-
- @throws std::length_error if the size would exceed the limit
- imposed by the underlying mutable buffer sequence.
-
- @note Buffers representing the input sequence acquired prior to
- this call remain valid.
- */
- mutable_buffers_type
- prepare(std::size_t n);
-
- /** Move bytes from the output sequence to the input sequence.
-
- @note Buffers representing the input sequence acquired prior to
- this call remain valid.
- */
- void
- commit(std::size_t n)
- {
- out_ += (std::min<std::size_t>)(n, last_ - out_);
- }
-
- /// Remove bytes from the input sequence.
- void
- consume(std::size_t n)
- {
- consume_impl(n);
- }
-
-protected:
- /** Constructor
-
- The buffer will be in an undefined state. It is necessary
- for the derived class to call @ref reset with a pointer
- and size in order to initialize the object.
- */
- flat_static_buffer_base() = default;
-
- /** Reset the pointed-to buffer.
-
- This function resets the internal state to the buffer provided.
- All input and output sequences are invalidated. This function
- allows the derived class to construct its members before
- initializing the static buffer.
-
- @param p A pointer to valid storage of at least `n` bytes.
-
- @param n The number of valid bytes pointed to by `p`.
- */
- void
- reset(void* p, std::size_t n);
-
-private:
- static
- inline
- std::size_t
- dist(char const* first, char const* last)
- {
- return static_cast<std::size_t>(last - first);
- }
-
- template<class = void>
- void
- reset_impl();
-
- template<class = void>
- void
- reset_impl(void* p, std::size_t n);
-
- template<class = void>
- mutable_buffers_type
- prepare_impl(std::size_t n);
-
- template<class = void>
- void
- consume_impl(std::size_t n);
-};
-
-//------------------------------------------------------------------------------
-
-/** A @b DynamicBuffer with a fixed size internal buffer.
-
- Buffer sequences returned by @ref data and @ref prepare
- will always be of length one.
- This implements a dynamic buffer using no memory allocations.
-
- @tparam N The number of bytes in the internal buffer.
-
- @note To reduce the number of template instantiations when passing
- objects of this type in a deduced context, the signature of the
- receiving function should use @ref flat_static_buffer_base instead.
-
- @see @ref flat_static_buffer_base
-*/
-template<std::size_t N>
-class flat_static_buffer : public flat_static_buffer_base
-{
- char buf_[N];
-
-public:
- /// Constructor
- flat_static_buffer(flat_static_buffer const&);
-
- /// Constructor
- flat_static_buffer()
- : flat_static_buffer_base(buf_, N)
- {
- }
-
- /// Assignment
- flat_static_buffer& operator=(flat_static_buffer const&);
-
- /// Returns the @ref flat_static_buffer_base portion of this object
- flat_static_buffer_base&
- base()
- {
- return *this;
- }
-
- /// Returns the @ref flat_static_buffer_base portion of this object
- flat_static_buffer_base const&
- base() const
- {
- return *this;
- }
-
- /// Return the maximum sum of the input and output sequence sizes.
- std::size_t constexpr
- max_size() const
- {
- return N;
- }
-
- /// Return the maximum sum of input and output sizes that can be held without an allocation.
- std::size_t constexpr
- capacity() const
- {
- return N;
- }
-};
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/flat_static_buffer.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/handler_ptr.hpp b/contrib/restricted/boost/boost/beast/core/handler_ptr.hpp
deleted file mode 100644
index 559c0c1559..0000000000
--- a/contrib/restricted/boost/boost/beast/core/handler_ptr.hpp
+++ /dev/null
@@ -1,191 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HANDLER_PTR_HPP
-#define BOOST_BEAST_HANDLER_PTR_HPP
-
-#include <boost/beast/core/detail/allocator.hpp>
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <type_traits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-
-/** A smart pointer container with associated completion handler.
-
- This is a smart pointer that retains unique ownership of an
- object through a pointer. Memory is managed using the allocator
- associated with a completion handler stored in the object. The
- managed object is destroyed and its memory deallocated when one
- of the following occurs:
-
- @li The function @ref invoke is called.
-
- @li The function @ref release_handler is called.
-
- @li The container is destroyed.
-
- Objects of this type are used in the implementation of composed
- operations with states that are expensive or impossible to move.
- This container manages that non-trivial state on behalf of the
- composed operation.
-
- @par Thread Safety
- @e Distinct @e objects: Safe.@n
- @e Shared @e objects: Unsafe.
-
- @tparam T The type of the owned object. Must be noexcept destructible.
-
- @tparam Handler The type of the completion handler.
-*/
-template<class T, class Handler>
-class handler_ptr
-{
- using handler_storage_t = typename detail::aligned_union<1, Handler>::type;
-
- T* t_ = nullptr;
- handler_storage_t h_;
-
- void clear();
-
-public:
- static_assert(std::is_nothrow_destructible<T>::value,
- "T must be nothrow destructible");
-
- /// The type of element stored
- using element_type = T;
-
- /// The type of handler stored
- using handler_type = Handler;
-
- /// Default constructor (deleted).
- handler_ptr() = delete;
-
- /// Copy assignment (deleted).
- handler_ptr& operator=(handler_ptr const&) = delete;
-
- /// Move assignment (deleted).
- handler_ptr& operator=(handler_ptr &&) = delete;
-
- /** Destructor
-
- If `*this` owns an object the object is destroyed and
- the memory deallocated using the allocator associated
- with the handler.
- */
- ~handler_ptr();
-
- /** Move constructor.
-
- When this call returns, the moved-from container
- will have no owned object.
- */
- handler_ptr(handler_ptr&& other);
-
- /// Copy constructor (deleted).
- handler_ptr(handler_ptr const& other) = delete;
-
- /** Constructor
-
- This creates a new container with an owned object of
- type `T`. The allocator associated with the handler will
- be used to allocate memory for the owned object. The
- constructor for the owned object will be called with the
- following equivalent signature:
-
- @code
- T::T(Handler const&, Args&&...)
- @endcode
-
- @par Exception Safety
- Strong guarantee.
-
- @param handler The handler to associate with the owned
- object. The argument will be moved if it is an xvalue.
-
- @param args Optional arguments forwarded to
- the owned object's constructor.
- */
- template<class DeducedHandler, class... Args>
- explicit handler_ptr(DeducedHandler&& handler, Args&&... args);
-
- /// Returns a const reference to the handler
- handler_type const&
- handler() const
- {
- return *reinterpret_cast<Handler const*>(&h_);
- }
-
- /// Returns a reference to the handler
- handler_type&
- handler()
- {
- return *reinterpret_cast<Handler*>(&h_);
- }
-
- /** Returns a pointer to the owned object.
- */
- T*
- get() const
- {
- return t_;
- }
-
- /// Return a reference to the owned object.
- T&
- operator*() const
- {
- return *t_;
- }
-
- /// Return a pointer to the owned object.
- T*
- operator->() const
- {
- return t_;
- }
-
- /** Release ownership of the handler
-
- Requires: `*this` owns an object
-
- Before this function returns, the owned object is
- destroyed, satisfying the deallocation-before-invocation
- Asio guarantee.
-
- @return The released handler.
- */
- handler_type
- release_handler();
-
- /** Invoke the handler in the owned object.
-
- This function invokes the handler in the owned object
- with a forwarded argument list. Before the invocation,
- the owned object is destroyed, satisfying the
- deallocation-before-invocation Asio guarantee.
-
- @note Care must be taken when the arguments are themselves
- stored in the owned object. Such arguments must first be
- moved to the stack or elsewhere, and then passed, or else
- undefined behavior will result.
- */
- template<class... Args>
- void
- invoke(Args&&... args);
-};
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/handler_ptr.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/buffered_read_stream.ipp b/contrib/restricted/boost/boost/beast/core/impl/buffered_read_stream.ipp
deleted file mode 100644
index 1ae76b4d34..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/buffered_read_stream.ipp
+++ /dev/null
@@ -1,257 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_IMPL_BUFFERED_READ_STREAM_IPP
-#define BOOST_BEAST_IMPL_BUFFERED_READ_STREAM_IPP
-
-#include <boost/beast/core/bind_handler.hpp>
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/core/handler_ptr.hpp>
-#include <boost/beast/core/read_size.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/asio/associated_allocator.hpp>
-#include <boost/asio/associated_executor.hpp>
-#include <boost/asio/handler_continuation_hook.hpp>
-#include <boost/asio/handler_invoke_hook.hpp>
-#include <boost/asio/post.hpp>
-#include <boost/throw_exception.hpp>
-
-namespace boost {
-namespace beast {
-
-template<class Stream, class DynamicBuffer>
-template<class MutableBufferSequence, class Handler>
-class buffered_read_stream<
- Stream, DynamicBuffer>::read_some_op
-{
- int step_ = 0;
- buffered_read_stream& s_;
- MutableBufferSequence b_;
- Handler h_;
-
-public:
- read_some_op(read_some_op&&) = default;
- read_some_op(read_some_op const&) = delete;
-
- template<class DeducedHandler, class... Args>
- read_some_op(DeducedHandler&& h,
- buffered_read_stream& s,
- MutableBufferSequence const& b)
- : s_(s)
- , b_(b)
- , h_(std::forward<DeducedHandler>(h))
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(h_);
- }
-
- using executor_type =
- boost::asio::associated_executor_t<Handler, decltype(
- std::declval<buffered_read_stream&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- h_, s_.get_executor());
- }
-
- void
- operator()(error_code const& ec,
- std::size_t bytes_transferred);
-
- friend
- bool asio_handler_is_continuation(read_some_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return asio_handler_is_continuation(
- std::addressof(op->h_));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, read_some_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f, std::addressof(op->h_));
- }
-};
-
-template<class Stream, class DynamicBuffer>
-template<class MutableBufferSequence, class Handler>
-void
-buffered_read_stream<Stream, DynamicBuffer>::
-read_some_op<MutableBufferSequence, Handler>::operator()(
- error_code const& ec, std::size_t bytes_transferred)
-{
- switch(step_)
- {
- case 0:
- if(s_.buffer_.size() == 0)
- {
- if(s_.capacity_ == 0)
- {
- // read (unbuffered)
- step_ = 1;
- return s_.next_layer_.async_read_some(
- b_, std::move(*this));
- }
-
- // read
- step_ = 2;
- return s_.next_layer_.async_read_some(
- s_.buffer_.prepare(read_size(
- s_.buffer_, s_.capacity_)),
- std::move(*this));
-
- }
- step_ = 3;
- return boost::asio::post(
- s_.get_executor(),
- bind_handler(std::move(*this), ec, 0));
-
- case 1:
- // upcall
- break;
-
- case 2:
- s_.buffer_.commit(bytes_transferred);
- BOOST_FALLTHROUGH;
-
- case 3:
- bytes_transferred =
- boost::asio::buffer_copy(b_, s_.buffer_.data());
- s_.buffer_.consume(bytes_transferred);
- break;
- }
- h_(ec, bytes_transferred);
-}
-
-//------------------------------------------------------------------------------
-
-template<class Stream, class DynamicBuffer>
-template<class... Args>
-buffered_read_stream<Stream, DynamicBuffer>::
-buffered_read_stream(Args&&... args)
- : next_layer_(std::forward<Args>(args)...)
-{
-}
-
-template<class Stream, class DynamicBuffer>
-template<class ConstBufferSequence, class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
-buffered_read_stream<Stream, DynamicBuffer>::
-async_write_some(
- ConstBufferSequence const& buffers,
- WriteHandler&& handler)
-{
- static_assert(is_async_write_stream<next_layer_type>::value,
- "AsyncWriteStream requirements not met");
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- static_assert(is_completion_handler<WriteHandler,
- void(error_code, std::size_t)>::value,
- "WriteHandler requirements not met");
- return next_layer_.async_write_some(buffers,
- std::forward<WriteHandler>(handler));
-}
-
-template<class Stream, class DynamicBuffer>
-template<class MutableBufferSequence>
-std::size_t
-buffered_read_stream<Stream, DynamicBuffer>::
-read_some(
- MutableBufferSequence const& buffers)
-{
- static_assert(is_sync_read_stream<next_layer_type>::value,
- "SyncReadStream requirements not met");
- static_assert(boost::asio::is_mutable_buffer_sequence<
- MutableBufferSequence>::value,
- "MutableBufferSequence requirements not met");
- error_code ec;
- auto n = read_some(buffers, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
- return n;
-}
-
-template<class Stream, class DynamicBuffer>
-template<class MutableBufferSequence>
-std::size_t
-buffered_read_stream<Stream, DynamicBuffer>::
-read_some(MutableBufferSequence const& buffers,
- error_code& ec)
-{
- static_assert(is_sync_read_stream<next_layer_type>::value,
- "SyncReadStream requirements not met");
- static_assert(boost::asio::is_mutable_buffer_sequence<
- MutableBufferSequence>::value,
- "MutableBufferSequence requirements not met");
- using boost::asio::buffer_size;
- using boost::asio::buffer_copy;
- if(buffer_.size() == 0)
- {
- if(capacity_ == 0)
- return next_layer_.read_some(buffers, ec);
- buffer_.commit(next_layer_.read_some(
- buffer_.prepare(read_size(buffer_,
- capacity_)), ec));
- if(ec)
- return 0;
- }
- else
- {
- ec.assign(0, ec.category());
- }
- auto bytes_transferred =
- buffer_copy(buffers, buffer_.data());
- buffer_.consume(bytes_transferred);
- return bytes_transferred;
-}
-
-template<class Stream, class DynamicBuffer>
-template<class MutableBufferSequence, class ReadHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
-buffered_read_stream<Stream, DynamicBuffer>::
-async_read_some(
- MutableBufferSequence const& buffers,
- ReadHandler&& handler)
-{
- static_assert(is_async_read_stream<next_layer_type>::value,
- "AsyncReadStream requirements not met");
- static_assert(boost::asio::is_mutable_buffer_sequence<
- MutableBufferSequence>::value,
- "MutableBufferSequence requirements not met");
- if(buffer_.size() == 0 && capacity_ == 0)
- return next_layer_.async_read_some(buffers,
- std::forward<ReadHandler>(handler));
- BOOST_BEAST_HANDLER_INIT(
- ReadHandler, void(error_code, std::size_t));
- read_some_op<MutableBufferSequence, BOOST_ASIO_HANDLER_TYPE(
- ReadHandler, void(error_code, std::size_t))>{
- std::move(init.completion_handler), *this, buffers}(
- error_code{}, 0);
- return init.result.get();
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/buffers_adapter.ipp b/contrib/restricted/boost/boost/beast/core/impl/buffers_adapter.ipp
deleted file mode 100644
index e16d2a9b32..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/buffers_adapter.ipp
+++ /dev/null
@@ -1,517 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_IMPL_BUFFERS_ADAPTER_IPP
-#define BOOST_BEAST_IMPL_BUFFERS_ADAPTER_IPP
-
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/throw_exception.hpp>
-#include <algorithm>
-#include <cstring>
-#include <iterator>
-#include <stdexcept>
-
-namespace boost {
-namespace beast {
-
-template<class MutableBufferSequence>
-class buffers_adapter<MutableBufferSequence>::
- const_buffers_type
-{
- buffers_adapter const* ba_;
-
-public:
- using value_type = boost::asio::mutable_buffer;
-
- class const_iterator;
-
- const_buffers_type() = delete;
- const_buffers_type(
- const_buffers_type const&) = default;
- const_buffers_type& operator=(
- const_buffers_type const&) = default;
-
- const_iterator
- begin() const;
-
- const_iterator
- end() const;
-
-private:
- friend class buffers_adapter;
-
- const_buffers_type(buffers_adapter const& ba)
- : ba_(&ba)
- {
- }
-};
-
-template<class MutableBufferSequence>
-class buffers_adapter<MutableBufferSequence>::
- const_buffers_type::const_iterator
-{
- iter_type it_;
- buffers_adapter const* ba_ = nullptr;
-
-public:
- using value_type = boost::asio::const_buffer;
- using pointer = value_type const*;
- using reference = value_type;
- using difference_type = std::ptrdiff_t;
- using iterator_category =
- std::bidirectional_iterator_tag;
-
- const_iterator() = default;
- const_iterator(const_iterator&& other) = default;
- const_iterator(const_iterator const& other) = default;
- const_iterator& operator=(const_iterator&& other) = default;
- const_iterator& operator=(const_iterator const& other) = default;
-
- bool
- operator==(const_iterator const& other) const
- {
- return ba_ == other.ba_ &&
- it_ == other.it_;
- }
-
- bool
- operator!=(const_iterator const& other) const
- {
- return !(*this == other);
- }
-
- reference
- operator*() const
- {
- value_type const b = *it_;
- return value_type{b.data(),
- (ba_->out_ == boost::asio::buffer_sequence_end(ba_->bs_) ||
- it_ != ba_->out_) ? b.size() : ba_->out_pos_} +
- (it_ == ba_->begin_ ? ba_->in_pos_ : 0);
- }
-
- pointer
- operator->() const = delete;
-
- const_iterator&
- operator++()
- {
- ++it_;
- return *this;
- }
-
- const_iterator
- operator++(int)
- {
- auto temp = *this;
- ++(*this);
- return temp;
- }
-
- const_iterator&
- operator--()
- {
- --it_;
- return *this;
- }
-
- const_iterator
- operator--(int)
- {
- auto temp = *this;
- --(*this);
- return temp;
- }
-
-private:
- friend class const_buffers_type;
-
- const_iterator(buffers_adapter const& ba,
- iter_type iter)
- : it_(iter)
- , ba_(&ba)
- {
- }
-};
-
-template<class MutableBufferSequence>
-inline
-auto
-buffers_adapter<MutableBufferSequence>::const_buffers_type::begin() const ->
- const_iterator
-{
- return const_iterator{*ba_, ba_->begin_};
-}
-
-template<class MutableBufferSequence>
-inline
-auto
-buffers_adapter<MutableBufferSequence>::const_buffers_type::end() const ->
- const_iterator
-{
- return const_iterator{*ba_, ba_->out_ ==
- ba_->end_ ? ba_->end_ : std::next(ba_->out_)};
-}
-
-//------------------------------------------------------------------------------
-
-template<class MutableBufferSequence>
-class buffers_adapter<MutableBufferSequence>::
-mutable_buffers_type
-{
- buffers_adapter const* ba_;
-
-public:
- using value_type = boost::asio::mutable_buffer;
-
- class const_iterator;
-
- mutable_buffers_type() = delete;
- mutable_buffers_type(
- mutable_buffers_type const&) = default;
- mutable_buffers_type& operator=(
- mutable_buffers_type const&) = default;
-
- const_iterator
- begin() const;
-
- const_iterator
- end() const;
-
-private:
- friend class buffers_adapter;
-
- mutable_buffers_type(
- buffers_adapter const& ba)
- : ba_(&ba)
- {
- }
-};
-
-template<class MutableBufferSequence>
-class buffers_adapter<MutableBufferSequence>::
-mutable_buffers_type::const_iterator
-{
- iter_type it_;
- buffers_adapter const* ba_ = nullptr;
-
-public:
- using value_type = boost::asio::mutable_buffer;
- using pointer = value_type const*;
- using reference = value_type;
- using difference_type = std::ptrdiff_t;
- using iterator_category =
- std::bidirectional_iterator_tag;
-
- const_iterator() = default;
- const_iterator(const_iterator&& other) = default;
- const_iterator(const_iterator const& other) = default;
- const_iterator& operator=(const_iterator&& other) = default;
- const_iterator& operator=(const_iterator const& other) = default;
-
- bool
- operator==(const_iterator const& other) const
- {
- return ba_ == other.ba_ &&
- it_ == other.it_;
- }
-
- bool
- operator!=(const_iterator const& other) const
- {
- return !(*this == other);
- }
-
- reference
- operator*() const
- {
- value_type const b = *it_;
- return value_type{b.data(),
- it_ == std::prev(ba_->end_) ?
- ba_->out_end_ : b.size()} +
- (it_ == ba_->out_ ? ba_->out_pos_ : 0);
- }
-
- pointer
- operator->() const = delete;
-
- const_iterator&
- operator++()
- {
- ++it_;
- return *this;
- }
-
- const_iterator
- operator++(int)
- {
- auto temp = *this;
- ++(*this);
- return temp;
- }
-
- const_iterator&
- operator--()
- {
- --it_;
- return *this;
- }
-
- const_iterator
- operator--(int)
- {
- auto temp = *this;
- --(*this);
- return temp;
- }
-
-private:
- friend class mutable_buffers_type;
-
- const_iterator(buffers_adapter const& ba,
- iter_type iter)
- : it_(iter)
- , ba_(&ba)
- {
- }
-};
-
-template<class MutableBufferSequence>
-inline
-auto
-buffers_adapter<MutableBufferSequence>::
-mutable_buffers_type::
-begin() const ->
- const_iterator
-{
- return const_iterator{*ba_, ba_->out_};
-}
-
-template<class MutableBufferSequence>
-inline
-auto
-buffers_adapter<MutableBufferSequence>::
-mutable_buffers_type::
-end() const ->
- const_iterator
-{
- return const_iterator{*ba_, ba_->end_};
-}
-
-//------------------------------------------------------------------------------
-
-template<class MutableBufferSequence>
-buffers_adapter<MutableBufferSequence>::buffers_adapter(
- buffers_adapter&& other)
- : buffers_adapter(std::move(other),
- std::distance<iter_type>(boost::asio::buffer_sequence_begin(other.bs_), other.begin_),
- std::distance<iter_type>(boost::asio::buffer_sequence_begin(other.bs_), other.out_),
- std::distance<iter_type>(boost::asio::buffer_sequence_begin(other.bs_), other.end_))
-{
-}
-
-template<class MutableBufferSequence>
-buffers_adapter<MutableBufferSequence>::buffers_adapter(
- buffers_adapter const& other)
- : buffers_adapter(other,
- std::distance<iter_type>(boost::asio::buffer_sequence_begin(other.bs_), other.begin_),
- std::distance<iter_type>(boost::asio::buffer_sequence_begin(other.bs_), other.out_),
- std::distance<iter_type>(boost::asio::buffer_sequence_begin(other.bs_), other.end_))
-{
-}
-
-template<class MutableBufferSequence>
-auto
-buffers_adapter<MutableBufferSequence>::operator=(
- buffers_adapter&& other) -> buffers_adapter&
-{
- auto const nbegin = std::distance<iter_type>(
- boost::asio::buffer_sequence_begin(other.bs_),
- other.begin_);
- auto const nout = std::distance<iter_type>(
- boost::asio::buffer_sequence_begin(other.bs_),
- other.out_);
- auto const nend = std::distance<iter_type>(
- boost::asio::buffer_sequence_begin(other.bs_),
- other.end_);
- bs_ = std::move(other.bs_);
- begin_ = std::next(boost::asio::buffer_sequence_begin(bs_), nbegin);
- out_ = std::next(boost::asio::buffer_sequence_begin(bs_), nout);
- end_ = std::next(boost::asio::buffer_sequence_begin(bs_), nend);
- max_size_ = other.max_size_;
- in_pos_ = other.in_pos_;
- in_size_ = other.in_size_;
- out_pos_ = other.out_pos_;
- out_end_ = other.out_end_;
- return *this;
-}
-
-template<class MutableBufferSequence>
-auto
-buffers_adapter<MutableBufferSequence>::operator=(
- buffers_adapter const& other) -> buffers_adapter&
-{
- auto const nbegin = std::distance<iter_type>(
- boost::asio::buffer_sequence_begin(other.bs_),
- other.begin_);
- auto const nout = std::distance<iter_type>(
- boost::asio::buffer_sequence_begin(other.bs_),
- other.out_);
- auto const nend = std::distance<iter_type>(
- boost::asio::buffer_sequence_begin(other.bs_),
- other.end_);
- bs_ = other.bs_;
- begin_ = std::next(boost::asio::buffer_sequence_begin(bs_), nbegin);
- out_ = std::next(boost::asio::buffer_sequence_begin(bs_), nout);
- end_ = std::next(boost::asio::buffer_sequence_begin(bs_), nend);
- max_size_ = other.max_size_;
- in_pos_ = other.in_pos_;
- in_size_ = other.in_size_;
- out_pos_ = other.out_pos_;
- out_end_ = other.out_end_;
- return *this;
-}
-
-template<class MutableBufferSequence>
-buffers_adapter<MutableBufferSequence>::buffers_adapter(
- MutableBufferSequence const& bs)
- : bs_(bs)
- , begin_(boost::asio::buffer_sequence_begin(bs_))
- , out_ (boost::asio::buffer_sequence_begin(bs_))
- , end_ (boost::asio::buffer_sequence_begin(bs_))
- , max_size_(boost::asio::buffer_size(bs_))
-{
-}
-
-template<class MutableBufferSequence>
-auto
-buffers_adapter<MutableBufferSequence>::prepare(std::size_t n) ->
- mutable_buffers_type
-{
- using boost::asio::buffer_size;
- end_ = out_;
- if(end_ != boost::asio::buffer_sequence_end(bs_))
- {
- auto size = buffer_size(*end_) - out_pos_;
- if(n > size)
- {
- n -= size;
- while(++end_ !=
- boost::asio::buffer_sequence_end(bs_))
- {
- size = buffer_size(*end_);
- if(n < size)
- {
- out_end_ = n;
- n = 0;
- ++end_;
- break;
- }
- n -= size;
- out_end_ = size;
- }
- }
- else
- {
- ++end_;
- out_end_ = out_pos_ + n;
- n = 0;
- }
- }
- if(n > 0)
- BOOST_THROW_EXCEPTION(std::length_error{
- "buffer overflow"});
- return mutable_buffers_type{*this};
-}
-
-template<class MutableBufferSequence>
-void
-buffers_adapter<MutableBufferSequence>::commit(std::size_t n)
-{
- using boost::asio::buffer_size;
- if(out_ == end_)
- return;
- auto const last = std::prev(end_);
- while(out_ != last)
- {
- auto const avail =
- buffer_size(*out_) - out_pos_;
- if(n < avail)
- {
- out_pos_ += n;
- in_size_ += n;
- max_size_ -= n;
- return;
- }
- ++out_;
- n -= avail;
- out_pos_ = 0;
- in_size_ += avail;
- max_size_ -= avail;
- }
-
- n = (std::min)(n, out_end_ - out_pos_);
- out_pos_ += n;
- in_size_ += n;
- max_size_ -= n;
- if(out_pos_ == buffer_size(*out_))
- {
- ++out_;
- out_pos_ = 0;
- out_end_ = 0;
- }
-}
-
-template<class MutableBufferSequence>
-inline
-auto
-buffers_adapter<MutableBufferSequence>::data() const ->
- const_buffers_type
-{
- return const_buffers_type{*this};
-}
-
-template<class MutableBufferSequence>
-void
-buffers_adapter<MutableBufferSequence>::consume(std::size_t n)
-{
- using boost::asio::buffer_size;
- while(begin_ != out_)
- {
- auto const avail =
- buffer_size(*begin_) - in_pos_;
- if(n < avail)
- {
- in_size_ -= n;
- in_pos_ += n;
- return;
- }
- n -= avail;
- in_size_ -= avail;
- in_pos_ = 0;
- ++begin_;
- }
- auto const avail = out_pos_ - in_pos_;
- if(n < avail)
- {
- in_size_ -= n;
- in_pos_ += n;
- }
- else
- {
- in_size_ -= avail;
- in_pos_ = out_pos_;
- }
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/buffers_cat.ipp b/contrib/restricted/boost/boost/beast/core/impl/buffers_cat.ipp
deleted file mode 100644
index 2e82e887fc..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/buffers_cat.ipp
+++ /dev/null
@@ -1,376 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_IMPL_BUFFERS_CAT_IPP
-#define BOOST_BEAST_IMPL_BUFFERS_CAT_IPP
-
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/beast/core/detail/variant.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/throw_exception.hpp>
-#include <cstdint>
-#include <iterator>
-#include <new>
-#include <stdexcept>
-#include <tuple>
-#include <utility>
-
-namespace boost {
-namespace beast {
-
-template<class... Bn>
-class buffers_cat_view<Bn...>::const_iterator
-{
- // VFALCO The logic to skip empty sequences fails
- // if there is just one buffer in the list.
- static_assert(sizeof...(Bn) >= 2,
- "A minimum of two sequences are required");
-
- struct past_end
- {
- operator bool() const noexcept
- {
- return true;
- }
- };
-
- std::tuple<Bn...> const* bn_ = nullptr;
- detail::variant<typename
- detail::buffer_sequence_iterator<Bn>::type...,
- past_end> it_;
-
- friend class buffers_cat_view<Bn...>;
-
- template<std::size_t I>
- using C = std::integral_constant<std::size_t, I>;
-
-public:
- using value_type = typename
- detail::common_buffers_type<Bn...>::type;
- using pointer = value_type const*;
- using reference = value_type;
- using difference_type = std::ptrdiff_t;
- using iterator_category =
- std::bidirectional_iterator_tag;
-
- const_iterator() = default;
- const_iterator(const_iterator&& other) = default;
- const_iterator(const_iterator const& other) = default;
- const_iterator& operator=(const_iterator&& other) = default;
- const_iterator& operator=(const_iterator const& other) = default;
-
- bool
- operator==(const_iterator const& other) const;
-
- bool
- operator!=(const_iterator const& other) const
- {
- return ! (*this == other);
- }
-
- reference
- operator*() const;
-
- pointer
- operator->() const = delete;
-
- const_iterator&
- operator++();
-
- const_iterator
- operator++(int);
-
- // deprecated
- const_iterator&
- operator--();
-
- // deprecated
- const_iterator
- operator--(int);
-
-private:
- const_iterator(
- std::tuple<Bn...> const& bn, bool at_end);
-
- template<std::size_t I>
- void
- construct(C<I> const&)
- {
- if(boost::asio::buffer_size(
- std::get<I>(*bn_)) != 0)
- {
- it_.template emplace<I+1>(
- boost::asio::buffer_sequence_begin(
- std::get<I>(*bn_)));
- return;
- }
- construct(C<I+1>{});
- }
-
- void
- construct(C<sizeof...(Bn)-1> const&)
- {
- auto constexpr I = sizeof...(Bn)-1;
- it_.template emplace<I+1>(
- boost::asio::buffer_sequence_begin(
- std::get<I>(*bn_)));
- }
-
- void
- construct(C<sizeof...(Bn)> const&)
- {
- // end
- auto constexpr I = sizeof...(Bn);
- it_.template emplace<I+1>();
- }
-
- template<std::size_t I>
- void
- next(C<I> const&)
- {
- if(boost::asio::buffer_size(
- std::get<I>(*bn_)) != 0)
- {
- it_.template emplace<I+1>(
- boost::asio::buffer_sequence_begin(
- std::get<I>(*bn_)));
- return;
- }
- next(C<I+1>{});
- }
-
- void
- next(C<sizeof...(Bn)> const&)
- {
- // end
- auto constexpr I = sizeof...(Bn);
- it_.template emplace<I+1>();
- }
-
- template<std::size_t I>
- void
- prev(C<I> const&)
- {
- if(boost::asio::buffer_size(
- std::get<I>(*bn_)) != 0)
- {
- it_.template emplace<I+1>(
- boost::asio::buffer_sequence_end(
- std::get<I>(*bn_)));
- return;
- }
- prev(C<I-1>{});
- }
-
- void
- prev(C<0> const&)
- {
- auto constexpr I = 0;
- it_.template emplace<I+1>(
- boost::asio::buffer_sequence_end(
- std::get<I>(*bn_)));
- }
-
- template<std::size_t I>
- reference
- dereference(C<I> const&) const
- {
- if(it_.index() == I+1)
- return *it_.template get<I+1>();
- return dereference(C<I+1>{});
- }
-
- [[noreturn]]
- reference
- dereference(C<sizeof...(Bn)> const&) const
- {
- BOOST_THROW_EXCEPTION(std::logic_error{
- "invalid iterator"});
- }
-
- template<std::size_t I>
- void
- increment(C<I> const&)
- {
- if(it_.index() == I+1)
- {
- if(++it_.template get<I+1>() !=
- boost::asio::buffer_sequence_end(
- std::get<I>(*bn_)))
- return;
- return next(C<I+1>{});
- }
- increment(C<I+1>{});
- }
-
- [[noreturn]]
- void
- increment(C<sizeof...(Bn)> const&)
- {
- BOOST_THROW_EXCEPTION(std::logic_error{
- "invalid iterator"});
- }
-
- void
- decrement(C<sizeof...(Bn)> const&)
- {
- auto constexpr I = sizeof...(Bn);
- if(it_.index() == I+1)
- prev(C<I-1>{});
- decrement(C<I-1>{});
- }
-
- template<std::size_t I>
- void
- decrement(C<I> const&)
- {
- if(it_.index() == I+1)
- {
- if(it_.template get<I+1>() !=
- boost::asio::buffer_sequence_begin(
- std::get<I>(*bn_)))
- {
- --it_.template get<I+1>();
- return;
- }
- prev(C<I-1>{});
- }
- decrement(C<I-1>{});
- }
-
- void
- decrement(C<0> const&)
- {
- auto constexpr I = 0;
- if(it_.template get<I+1>() !=
- boost::asio::buffer_sequence_begin(
- std::get<I>(*bn_)))
- {
- --it_.template get<I+1>();
- return;
- }
- BOOST_THROW_EXCEPTION(std::logic_error{
- "invalid iterator"});
- }
-};
-
-//------------------------------------------------------------------------------
-
-template<class... Bn>
-buffers_cat_view<Bn...>::
-const_iterator::
-const_iterator(
- std::tuple<Bn...> const& bn, bool at_end)
- : bn_(&bn)
-{
- if(! at_end)
- construct(C<0>{});
- else
- construct(C<sizeof...(Bn)>{});
-}
-
-template<class... Bn>
-bool
-buffers_cat_view<Bn...>::
-const_iterator::
-operator==(const_iterator const& other) const
-{
- if(bn_ != other.bn_)
- return false;
- return it_ == other.it_;
-}
-
-template<class... Bn>
-auto
-buffers_cat_view<Bn...>::
-const_iterator::
-operator*() const ->
- reference
-{
- return dereference(C<0>{});
-}
-
-template<class... Bn>
-auto
-buffers_cat_view<Bn...>::
-const_iterator::
-operator++() ->
- const_iterator&
-{
- increment(C<0>{});
- return *this;
-}
-
-template<class... Bn>
-auto
-buffers_cat_view<Bn...>::
-const_iterator::
-operator++(int) ->
- const_iterator
-{
- auto temp = *this;
- ++(*this);
- return temp;
-}
-
-template<class... Bn>
-auto
-buffers_cat_view<Bn...>::
-const_iterator::
-operator--() ->
- const_iterator&
-{
- decrement(C<sizeof...(Bn)>{});
- return *this;
-}
-
-template<class... Bn>
-auto
-buffers_cat_view<Bn...>::
-const_iterator::
-operator--(int) ->
- const_iterator
-{
- auto temp = *this;
- --(*this);
- return temp;
-}
-
-//------------------------------------------------------------------------------
-
-template<class... Bn>
-buffers_cat_view<Bn...>::
-buffers_cat_view(Bn const&... bn)
- : bn_(bn...)
-{
-}
-
-
-template<class... Bn>
-inline
-auto
-buffers_cat_view<Bn...>::begin() const ->
- const_iterator
-{
- return const_iterator{bn_, false};
-}
-
-template<class... Bn>
-inline
-auto
-buffers_cat_view<Bn...>::end() const ->
- const_iterator
-{
- return const_iterator{bn_, true};
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/buffers_prefix.ipp b/contrib/restricted/boost/boost/beast/core/impl/buffers_prefix.ipp
deleted file mode 100644
index a45483854f..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/buffers_prefix.ipp
+++ /dev/null
@@ -1,258 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_IMPL_BUFFERS_PREFIX_IPP
-#define BOOST_BEAST_IMPL_BUFFERS_PREFIX_IPP
-
-#include <algorithm>
-#include <cstdint>
-#include <iterator>
-#include <stdexcept>
-#include <type_traits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-
-namespace detail {
-
-inline
-boost::asio::const_buffer
-buffers_prefix(std::size_t size,
- boost::asio::const_buffer buffer)
-{
- return {buffer.data(),
- (std::min)(size, buffer.size())};
-}
-
-inline
-boost::asio::mutable_buffer
-buffers_prefix(std::size_t size,
- boost::asio::mutable_buffer buffer)
-{
- return {buffer.data(),
- (std::min)(size, buffer.size())};
-}
-
-} // detail
-
-template<class BufferSequence>
-class buffers_prefix_view<BufferSequence>::const_iterator
-{
- friend class buffers_prefix_view<BufferSequence>;
-
- buffers_prefix_view const* b_ = nullptr;
- std::size_t remain_;
- iter_type it_;
-
-public:
- using value_type = typename std::conditional<
- boost::is_convertible<typename
- std::iterator_traits<iter_type>::value_type,
- boost::asio::mutable_buffer>::value,
- boost::asio::mutable_buffer,
- boost::asio::const_buffer>::type;
- using pointer = value_type const*;
- using reference = value_type;
- using difference_type = std::ptrdiff_t;
- using iterator_category =
- std::bidirectional_iterator_tag;
-
- const_iterator() = default;
- const_iterator(const_iterator&& other) = default;
- const_iterator(const_iterator const& other) = default;
- const_iterator& operator=(const_iterator&& other) = default;
- const_iterator& operator=(const_iterator const& other) = default;
-
- bool
- operator==(const_iterator const& other) const
- {
- return b_ == other.b_ && it_ == other.it_;
- }
-
- bool
- operator!=(const_iterator const& other) const
- {
- return !(*this == other);
- }
-
- reference
- operator*() const
- {
- return detail::buffers_prefix(remain_, *it_);
- }
-
- pointer
- operator->() const = delete;
-
- const_iterator&
- operator++()
- {
- remain_ -= boost::asio::buffer_size(*it_++);
- return *this;
- }
-
- const_iterator
- operator++(int)
- {
- auto temp = *this;
- remain_ -= boost::asio::buffer_size(*it_++);
- return temp;
- }
-
- const_iterator&
- operator--()
- {
- remain_ += boost::asio::buffer_size(*--it_);
- return *this;
- }
-
- const_iterator
- operator--(int)
- {
- auto temp = *this;
- remain_ += boost::asio::buffer_size(*--it_);
- return temp;
- }
-
-private:
- const_iterator(buffers_prefix_view const& b,
- std::true_type)
- : b_(&b)
- , remain_(0)
- , it_(b_->end_)
- {
- }
-
- const_iterator(buffers_prefix_view const& b,
- std::false_type)
- : b_(&b)
- , remain_(b_->size_)
- , it_(boost::asio::buffer_sequence_begin(b_->bs_))
- {
- }
-};
-
-template<class BufferSequence>
-void
-buffers_prefix_view<BufferSequence>::
-setup(std::size_t size)
-{
- size_ = 0;
- end_ = boost::asio::buffer_sequence_begin(bs_);
- auto const last = bs_.end();
- while(end_ != last)
- {
- auto const len =
- boost::asio::buffer_size(*end_++);
- if(len >= size)
- {
- size_ += size;
- break;
- }
- size -= len;
- size_ += len;
- }
-}
-
-template<class BufferSequence>
-buffers_prefix_view<BufferSequence>::
-buffers_prefix_view(buffers_prefix_view&& other)
- : buffers_prefix_view(std::move(other),
- std::distance<iter_type>(
- boost::asio::buffer_sequence_begin(other.bs_),
- other.end_))
-{
-}
-
-template<class BufferSequence>
-buffers_prefix_view<BufferSequence>::
-buffers_prefix_view(buffers_prefix_view const& other)
- : buffers_prefix_view(other,
- std::distance<iter_type>(
- boost::asio::buffer_sequence_begin(other.bs_),
- other.end_))
-{
-}
-
-template<class BufferSequence>
-auto
-buffers_prefix_view<BufferSequence>::
-operator=(buffers_prefix_view&& other) ->
- buffers_prefix_view&
-{
- auto const dist = std::distance<iter_type>(
- boost::asio::buffer_sequence_begin(other.bs_),
- other.end_);
- bs_ = std::move(other.bs_);
- size_ = other.size_;
- end_ = std::next(
- boost::asio::buffer_sequence_begin(bs_),
- dist);
- return *this;
-}
-
-template<class BufferSequence>
-auto
-buffers_prefix_view<BufferSequence>::
-operator=(buffers_prefix_view const& other) ->
- buffers_prefix_view&
-{
- auto const dist = std::distance<iter_type>(
- boost::asio::buffer_sequence_begin(other.bs_),
- other.end_);
- bs_ = other.bs_;
- size_ = other.size_;
- end_ = std::next(
- boost::asio::buffer_sequence_begin(bs_),
- dist);
- return *this;
-}
-
-template<class BufferSequence>
-buffers_prefix_view<BufferSequence>::
-buffers_prefix_view(std::size_t size,
- BufferSequence const& bs)
- : bs_(bs)
-{
- setup(size);
-}
-
-template<class BufferSequence>
-template<class... Args>
-buffers_prefix_view<BufferSequence>::
-buffers_prefix_view(std::size_t size,
- boost::in_place_init_t, Args&&... args)
- : bs_(std::forward<Args>(args)...)
-{
- setup(size);
-}
-
-template<class BufferSequence>
-inline
-auto
-buffers_prefix_view<BufferSequence>::begin() const ->
- const_iterator
-{
- return const_iterator{*this, std::false_type{}};
-}
-
-template<class BufferSequence>
-inline
-auto
-buffers_prefix_view<BufferSequence>::end() const ->
- const_iterator
-{
- return const_iterator{*this, std::true_type{}};
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/buffers_suffix.ipp b/contrib/restricted/boost/boost/beast/core/impl/buffers_suffix.ipp
deleted file mode 100644
index 4385fe500d..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/buffers_suffix.ipp
+++ /dev/null
@@ -1,250 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_IMPL_BUFFERS_SUFFIX_IPP
-#define BOOST_BEAST_IMPL_BUFFERS_SUFFIX_IPP
-
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/type_traits.hpp>
-#include <algorithm>
-#include <cstdint>
-#include <iterator>
-#include <type_traits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-
-template<class Buffers>
-class buffers_suffix<Buffers>::const_iterator
-{
- friend class buffers_suffix<Buffers>;
-
- using iter_type = typename
- detail::buffer_sequence_iterator<Buffers>::type;
-
- iter_type it_;
- buffers_suffix const* b_ = nullptr;
-
-public:
- using value_type = typename std::conditional<
- boost::is_convertible<typename
- std::iterator_traits<iter_type>::value_type,
- boost::asio::mutable_buffer>::value,
- boost::asio::mutable_buffer,
- boost::asio::const_buffer>::type;
- using pointer = value_type const*;
- using reference = value_type;
- using difference_type = std::ptrdiff_t;
- using iterator_category =
- std::bidirectional_iterator_tag;
-
- const_iterator() = default;
- const_iterator(const_iterator&& other) = default;
- const_iterator(const_iterator const& other) = default;
- const_iterator& operator=(const_iterator&& other) = default;
- const_iterator& operator=(const_iterator const& other) = default;
-
- bool
- operator==(const_iterator const& other) const
- {
- return b_ == other.b_ && it_ == other.it_;
- }
-
- bool
- operator!=(const_iterator const& other) const
- {
- return !(*this == other);
- }
-
- reference
- operator*() const
- {
- return it_ == b_->begin_
- ? value_type{*it_} + b_->skip_
- : *it_;
- }
-
- pointer
- operator->() const = delete;
-
- const_iterator&
- operator++()
- {
- ++it_;
- return *this;
- }
-
- const_iterator
- operator++(int)
- {
- auto temp = *this;
- ++(*this);
- return temp;
- }
-
- const_iterator&
- operator--()
- {
- --it_;
- return *this;
- }
-
- const_iterator
- operator--(int)
- {
- auto temp = *this;
- --(*this);
- return temp;
- }
-
-private:
- const_iterator(buffers_suffix const& b,
- iter_type it)
- : it_(it)
- , b_(&b)
- {
- }
-};
-
-//------------------------------------------------------------------------------
-
-template<class Buffers>
-buffers_suffix<Buffers>::
-buffers_suffix()
- : begin_(boost::asio::buffer_sequence_begin(bs_))
-{
-}
-
-template<class Buffers>
-buffers_suffix<Buffers>::
-buffers_suffix(buffers_suffix&& other)
- : buffers_suffix(std::move(other),
- std::distance<iter_type>(
- boost::asio::buffer_sequence_begin(
- other.bs_), other.begin_))
-{
-}
-
-template<class Buffers>
-buffers_suffix<Buffers>::
-buffers_suffix(buffers_suffix const& other)
- : buffers_suffix(other,
- std::distance<iter_type>(
- boost::asio::buffer_sequence_begin(
- other.bs_), other.begin_))
-{
-}
-
-template<class Buffers>
-buffers_suffix<Buffers>::
-buffers_suffix(Buffers const& bs)
- : bs_(bs)
- , begin_(boost::asio::buffer_sequence_begin(bs_))
-{
- static_assert(
- boost::asio::is_const_buffer_sequence<Buffers>::value||
- boost::asio::is_mutable_buffer_sequence<Buffers>::value,
- "BufferSequence requirements not met");
-}
-
-template<class Buffers>
-template<class... Args>
-buffers_suffix<Buffers>::
-buffers_suffix(boost::in_place_init_t, Args&&... args)
- : bs_(std::forward<Args>(args)...)
- , begin_(boost::asio::buffer_sequence_begin(bs_))
-{
- static_assert(sizeof...(Args) > 0,
- "Missing constructor arguments");
- static_assert(
- std::is_constructible<Buffers, Args...>::value,
- "Buffers not constructible from arguments");
-}
-
-template<class Buffers>
-auto
-buffers_suffix<Buffers>::
-operator=(buffers_suffix&& other) ->
- buffers_suffix&
-{
- auto const dist = std::distance<iter_type>(
- boost::asio::buffer_sequence_begin(other.bs_),
- other.begin_);
- bs_ = std::move(other.bs_);
- begin_ = std::next(
- boost::asio::buffer_sequence_begin(bs_),
- dist);
- skip_ = other.skip_;
- return *this;
-}
-
-template<class Buffers>
-auto
-buffers_suffix<Buffers>::
-operator=(buffers_suffix const& other) ->
- buffers_suffix&
-{
- auto const dist = std::distance<iter_type>(
- boost::asio::buffer_sequence_begin(other.bs_),
- other.begin_);
- bs_ = other.bs_;
- begin_ = std::next(
- boost::asio::buffer_sequence_begin(bs_), dist);
- skip_ = other.skip_;
- return *this;
-}
-
-template<class Buffers>
-inline
-auto
-buffers_suffix<Buffers>::
-begin() const ->
- const_iterator
-{
- return const_iterator{*this, begin_};
-}
-
-template<class Buffers>
-inline
-auto
-buffers_suffix<Buffers>::
-end() const ->
- const_iterator
-{
- return const_iterator{*this,
- boost::asio::buffer_sequence_end(bs_)};
-}
-
-template<class Buffers>
-void
-buffers_suffix<Buffers>::
-consume(std::size_t amount)
-{
- using boost::asio::buffer_size;
- auto const end =
- boost::asio::buffer_sequence_end(bs_);
- for(;amount > 0 && begin_ != end; ++begin_)
- {
- auto const len =
- buffer_size(*begin_) - skip_;
- if(amount < len)
- {
- skip_ += amount;
- break;
- }
- amount -= len;
- skip_ = 0;
- }
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/file_posix.ipp b/contrib/restricted/boost/boost/beast/core/impl/file_posix.ipp
deleted file mode 100644
index c30a7d020f..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/file_posix.ipp
+++ /dev/null
@@ -1,349 +0,0 @@
-//
-// Copyright (c) 2015-2016 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_CORE_IMPL_FILE_POSIX_IPP
-#define BOOST_BEAST_CORE_IMPL_FILE_POSIX_IPP
-
-#if ! defined(BOOST_BEAST_NO_POSIX_FADVISE)
-# if defined(__APPLE__) || (defined(ANDROID) && (__ANDROID_API__ < 21))
-# define BOOST_BEAST_NO_POSIX_FADVISE
-# endif
-#endif
-
-#if ! defined(BOOST_BEAST_USE_POSIX_FADVISE)
-# if ! defined(BOOST_BEAST_NO_POSIX_FADVISE)
-# define BOOST_BEAST_USE_POSIX_FADVISE 1
-# else
-# define BOOST_BEAST_USE_POSIX_FADVISE 0
-# endif
-#endif
-
-#include <limits>
-#include <fcntl.h>
-#include <sys/types.h>
-#include <sys/uio.h>
-#include <sys/stat.h>
-#include <unistd.h>
-#include <limits.h>
-
-namespace boost {
-namespace beast {
-
-namespace detail {
-
-inline
-int
-file_posix_close(int fd)
-{
- for(;;)
- {
- if(! ::close(fd))
- break;
- int const ev = errno;
- if(errno != EINTR)
- return ev;
- }
- return 0;
-}
-
-} // detail
-
-inline
-file_posix::
-~file_posix()
-{
- if(fd_ != -1)
- detail::file_posix_close(fd_);
-}
-
-inline
-file_posix::
-file_posix(file_posix&& other)
- : fd_(other.fd_)
-{
- other.fd_ = -1;
-}
-
-inline
-file_posix&
-file_posix::
-operator=(file_posix&& other)
-{
- if(&other == this)
- return *this;
- if(fd_ != -1)
- detail::file_posix_close(fd_);
- fd_ = other.fd_;
- other.fd_ = -1;
- return *this;
-}
-
-inline
-void
-file_posix::
-native_handle(native_handle_type fd)
-{
- if(fd_ != -1)
- detail::file_posix_close(fd_);
- fd_ = fd;
-}
-
-inline
-void
-file_posix::
-close(error_code& ec)
-{
- if(fd_ != -1)
- {
- auto const ev =
- detail::file_posix_close(fd_);
- if(ev)
- ec.assign(ev, generic_category());
- else
- ec.assign(0, ec.category());
- fd_ = -1;
- }
- else
- {
- ec.assign(0, ec.category());
- }
-}
-
-inline
-void
-file_posix::
-open(char const* path, file_mode mode, error_code& ec)
-{
- if(fd_ != -1)
- {
- auto const ev =
- detail::file_posix_close(fd_);
- if(ev)
- ec.assign(ev, generic_category());
- else
- ec.assign(0, ec.category());
- fd_ = -1;
- }
- int f = 0;
-#if BOOST_BEAST_USE_POSIX_FADVISE
- int advise = 0;
-#endif
- switch(mode)
- {
- default:
- case file_mode::read:
- f = O_RDONLY;
- #if BOOST_BEAST_USE_POSIX_FADVISE
- advise = POSIX_FADV_RANDOM;
- #endif
- break;
- case file_mode::scan:
- f = O_RDONLY;
- #if BOOST_BEAST_USE_POSIX_FADVISE
- advise = POSIX_FADV_SEQUENTIAL;
- #endif
- break;
-
- case file_mode::write:
- f = O_RDWR | O_CREAT | O_TRUNC;
- #if BOOST_BEAST_USE_POSIX_FADVISE
- advise = POSIX_FADV_RANDOM;
- #endif
- break;
-
- case file_mode::write_new:
- f = O_RDWR | O_CREAT | O_EXCL;
- #if BOOST_BEAST_USE_POSIX_FADVISE
- advise = POSIX_FADV_RANDOM;
- #endif
- break;
-
- case file_mode::write_existing:
- f = O_RDWR | O_EXCL;
- #if BOOST_BEAST_USE_POSIX_FADVISE
- advise = POSIX_FADV_RANDOM;
- #endif
- break;
-
- case file_mode::append:
- f = O_RDWR | O_CREAT | O_TRUNC;
- #if BOOST_BEAST_USE_POSIX_FADVISE
- advise = POSIX_FADV_SEQUENTIAL;
- #endif
- break;
-
- case file_mode::append_new:
- f = O_RDWR | O_CREAT | O_EXCL;
- #if BOOST_BEAST_USE_POSIX_FADVISE
- advise = POSIX_FADV_SEQUENTIAL;
- #endif
- break;
-
- case file_mode::append_existing:
- f = O_RDWR | O_EXCL;
- #if BOOST_BEAST_USE_POSIX_FADVISE
- advise = POSIX_FADV_SEQUENTIAL;
- #endif
- break;
- }
- for(;;)
- {
- fd_ = ::open(path, f, 0644);
- if(fd_ != -1)
- break;
- auto const ev = errno;
- if(ev != EINTR)
- {
- ec.assign(ev, generic_category());
- return;
- }
- }
-#if BOOST_BEAST_USE_POSIX_FADVISE
- if(::posix_fadvise(fd_, 0, 0, advise))
- {
- auto const ev = errno;
- detail::file_posix_close(fd_);
- fd_ = -1;
- ec.assign(ev, generic_category());
- return;
- }
-#endif
- ec.assign(0, ec.category());
-}
-
-inline
-std::uint64_t
-file_posix::
-size(error_code& ec) const
-{
- if(fd_ == -1)
- {
- ec = make_error_code(errc::invalid_argument);
- return 0;
- }
- struct stat st;
- if(::fstat(fd_, &st) != 0)
- {
- ec.assign(errno, generic_category());
- return 0;
- }
- ec.assign(0, ec.category());
- return st.st_size;
-}
-
-inline
-std::uint64_t
-file_posix::
-pos(error_code& ec) const
-{
- if(fd_ == -1)
- {
- ec = make_error_code(errc::invalid_argument);
- return 0;
- }
- auto const result = ::lseek(fd_, 0, SEEK_CUR);
- if(result == (off_t)-1)
- {
- ec.assign(errno, generic_category());
- return 0;
- }
- ec.assign(0, ec.category());
- return result;
-}
-
-inline
-void
-file_posix::
-seek(std::uint64_t offset, error_code& ec)
-{
- if(fd_ == -1)
- {
- ec = make_error_code(errc::invalid_argument);
- return;
- }
- auto const result = ::lseek(fd_, offset, SEEK_SET);
- if(result == static_cast<off_t>(-1))
- {
- ec.assign(errno, generic_category());
- return;
- }
- ec.assign(0, ec.category());
-}
-
-inline
-std::size_t
-file_posix::
-read(void* buffer, std::size_t n, error_code& ec) const
-{
- if(fd_ == -1)
- {
- ec = make_error_code(errc::invalid_argument);
- return 0;
- }
- std::size_t nread = 0;
- while(n > 0)
- {
- auto const amount = static_cast<ssize_t>((std::min)(
- n, static_cast<std::size_t>(SSIZE_MAX)));
- auto const result = ::read(fd_, buffer, amount);
- if(result == -1)
- {
- auto const ev = errno;
- if(ev == EINTR)
- continue;
- ec.assign(ev, generic_category());
- return nread;
- }
- if(result == 0)
- {
- // short read
- return nread;
- }
- n -= result;
- nread += result;
- buffer = reinterpret_cast<char*>(buffer) + result;
- }
- return nread;
-}
-
-inline
-std::size_t
-file_posix::
-write(void const* buffer, std::size_t n, error_code& ec)
-{
- if(fd_ == -1)
- {
- ec = make_error_code(errc::invalid_argument);
- return 0;
- }
- std::size_t nwritten = 0;
- while(n > 0)
- {
- auto const amount = static_cast<ssize_t>((std::min)(
- n, static_cast<std::size_t>(SSIZE_MAX)));
- auto const result = ::write(fd_, buffer, amount);
- if(result == -1)
- {
- auto const ev = errno;
- if(ev == EINTR)
- continue;
- ec.assign(ev, generic_category());
- return nwritten;
- }
- n -= result;
- nwritten += result;
- buffer = reinterpret_cast<char const*>(buffer) + result;
- }
- return nwritten;
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/file_stdio.ipp b/contrib/restricted/boost/boost/beast/core/impl/file_stdio.ipp
deleted file mode 100644
index 60a0f3fc0e..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/file_stdio.ipp
+++ /dev/null
@@ -1,239 +0,0 @@
-//
-// Copyright (c) 2015-2016 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_CORE_IMPL_FILE_STDIO_IPP
-#define BOOST_BEAST_CORE_IMPL_FILE_STDIO_IPP
-
-#include <limits>
-
-namespace boost {
-namespace beast {
-
-inline
-file_stdio::
-~file_stdio()
-{
- if(f_)
- fclose(f_);
-}
-
-inline
-file_stdio::
-file_stdio(file_stdio&& other)
- : f_(other.f_)
-{
- other.f_ = nullptr;
-}
-
-inline
-file_stdio&
-file_stdio::
-operator=(file_stdio&& other)
-{
- if(&other == this)
- return *this;
- if(f_)
- fclose(f_);
- f_ = other.f_;
- other.f_ = nullptr;
- return *this;
-}
-
-inline
-void
-file_stdio::
-native_handle(FILE* f)
-{
- if(f_)
- fclose(f_);
- f_ = f;
-}
-
-inline
-void
-file_stdio::
-close(error_code& ec)
-{
- if(f_)
- {
- int failed = fclose(f_);
- f_ = nullptr;
- if(failed)
- {
- ec.assign(errno, generic_category());
- return;
- }
- }
- ec.assign(0, ec.category());
-}
-
-inline
-void
-file_stdio::
-open(char const* path, file_mode mode, error_code& ec)
-{
- if(f_)
- {
- fclose(f_);
- f_ = nullptr;
- }
- char const* s;
- switch(mode)
- {
- default:
- case file_mode::read: s = "rb"; break;
- case file_mode::scan: s = "rb"; break;
- case file_mode::write: s = "wb"; break;
- case file_mode::write_new: s = "wbx"; break;
- case file_mode::write_existing: s = "wb"; break;
- case file_mode::append: s = "ab"; break;
- case file_mode::append_new: s = "abx"; break;
- case file_mode::append_existing: s = "ab"; break;
- }
-#if BOOST_MSVC
- auto const ev = fopen_s(&f_, path, s);
- if(ev)
- {
- f_ = nullptr;
- ec.assign(ev, generic_category());
- return;
- }
-#else
- f_ = std::fopen(path, s);
- if(! f_)
- {
- ec.assign(errno, generic_category());
- return;
- }
-#endif
- ec.assign(0, ec.category());
-}
-
-inline
-std::uint64_t
-file_stdio::
-size(error_code& ec) const
-{
- if(! f_)
- {
- ec = make_error_code(errc::invalid_argument);
- return 0;
- }
- long pos = std::ftell(f_);
- if(pos == -1L)
- {
- ec.assign(errno, generic_category());
- return 0;
- }
- int result = std::fseek(f_, 0, SEEK_END);
- if(result != 0)
- {
- ec.assign(errno, generic_category());
- return 0;
- }
- long size = std::ftell(f_);
- if(size == -1L)
- {
- ec.assign(errno, generic_category());
- std::fseek(f_, pos, SEEK_SET);
- return 0;
- }
- result = std::fseek(f_, pos, SEEK_SET);
- if(result != 0)
- ec.assign(errno, generic_category());
- else
- ec.assign(0, ec.category());
- return size;
-}
-
-inline
-std::uint64_t
-file_stdio::
-pos(error_code& ec) const
-{
- if(! f_)
- {
- ec = make_error_code(errc::invalid_argument);
- return 0;
- }
- long pos = std::ftell(f_);
- if(pos == -1L)
- {
- ec.assign(errno, generic_category());
- return 0;
- }
- ec.assign(0, ec.category());
- return pos;
-}
-
-inline
-void
-file_stdio::
-seek(std::uint64_t offset, error_code& ec)
-{
- if(! f_)
- {
- ec = make_error_code(errc::invalid_argument);
- return;
- }
- if(offset > (std::numeric_limits<long>::max)())
- {
- ec = make_error_code(errc::invalid_seek);
- return;
- }
- int result = std::fseek(f_,
- static_cast<long>(offset), SEEK_SET);
- if(result != 0)
- ec.assign(errno, generic_category());
- else
- ec.assign(0, ec.category());
-}
-
-inline
-std::size_t
-file_stdio::
-read(void* buffer, std::size_t n, error_code& ec) const
-{
- if(! f_)
- {
- ec = make_error_code(errc::invalid_argument);
- return 0;
- }
- auto nread = std::fread(buffer, 1, n, f_);
- if(std::ferror(f_))
- {
- ec.assign(errno, generic_category());
- return 0;
- }
- return nread;
-}
-
-inline
-std::size_t
-file_stdio::
-write(void const* buffer, std::size_t n, error_code& ec)
-{
- if(! f_)
- {
- ec = make_error_code(errc::invalid_argument);
- return 0;
- }
- auto nwritten = std::fwrite(buffer, 1, n, f_);
- if(std::ferror(f_))
- {
- ec.assign(errno, generic_category());
- return 0;
- }
- return nwritten;
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/file_win32.ipp b/contrib/restricted/boost/boost/beast/core/impl/file_win32.ipp
deleted file mode 100644
index c1b4cc6c7d..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/file_win32.ipp
+++ /dev/null
@@ -1,364 +0,0 @@
-//
-// Copyright (c) 2015-2016 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_CORE_IMPL_FILE_WIN32_IPP
-#define BOOST_BEAST_CORE_IMPL_FILE_WIN32_IPP
-
-#include <boost/winapi/access_rights.hpp>
-#include <boost/winapi/error_codes.hpp>
-#include <boost/winapi/file_management.hpp>
-#include <boost/winapi/get_last_error.hpp>
-#include <limits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-
-namespace detail {
-
-// VFALCO Can't seem to get boost/detail/winapi to work with
-// this so use the non-Ex version for now.
-inline
-boost::winapi::BOOL_
-set_file_pointer_ex(
- boost::winapi::HANDLE_ hFile,
- boost::winapi::LARGE_INTEGER_ lpDistanceToMove,
- boost::winapi::PLARGE_INTEGER_ lpNewFilePointer,
- boost::winapi::DWORD_ dwMoveMethod)
-{
- auto dwHighPart = lpDistanceToMove.u.HighPart;
- auto dwLowPart = boost::winapi::SetFilePointer(
- hFile,
- lpDistanceToMove.u.LowPart,
- &dwHighPart,
- dwMoveMethod);
- if(dwLowPart == boost::winapi::INVALID_SET_FILE_POINTER_)
- return 0;
- if(lpNewFilePointer)
- {
- lpNewFilePointer->u.LowPart = dwLowPart;
- lpNewFilePointer->u.HighPart = dwHighPart;
- }
- return 1;
-}
-
-} // detail
-
-inline
-file_win32::
-~file_win32()
-{
- if(h_ != boost::winapi::INVALID_HANDLE_VALUE_)
- boost::winapi::CloseHandle(h_);
-}
-
-inline
-file_win32::
-file_win32(file_win32&& other)
- : h_(other.h_)
-{
- other.h_ = boost::winapi::INVALID_HANDLE_VALUE_;
-}
-
-inline
-file_win32&
-file_win32::
-operator=(file_win32&& other)
-{
- if(&other == this)
- return *this;
- if(h_)
- boost::winapi::CloseHandle(h_);
- h_ = other.h_;
- other.h_ = boost::winapi::INVALID_HANDLE_VALUE_;
- return *this;
-}
-
-inline
-void
-file_win32::
-native_handle(native_handle_type h)
-{
- if(h_ != boost::winapi::INVALID_HANDLE_VALUE_)
- boost::winapi::CloseHandle(h_);
- h_ = h;
-}
-
-inline
-void
-file_win32::
-close(error_code& ec)
-{
- if(h_ != boost::winapi::INVALID_HANDLE_VALUE_)
- {
- if(! boost::winapi::CloseHandle(h_))
- ec.assign(boost::winapi::GetLastError(),
- system_category());
- else
- ec.assign(0, ec.category());
- h_ = boost::winapi::INVALID_HANDLE_VALUE_;
- }
- else
- {
- ec.assign(0, ec.category());
- }
-}
-
-inline
-void
-file_win32::
-open(char const* path, file_mode mode, error_code& ec)
-{
- if(h_ != boost::winapi::INVALID_HANDLE_VALUE_)
- {
- boost::winapi::CloseHandle(h_);
- h_ = boost::winapi::INVALID_HANDLE_VALUE_;
- }
- boost::winapi::DWORD_ share_mode = 0;
- boost::winapi::DWORD_ desired_access = 0;
- boost::winapi::DWORD_ creation_disposition = 0;
- boost::winapi::DWORD_ flags_and_attributes = 0;
-/*
- | When the file...
- This argument: | Exists Does not exist
- -------------------------+------------------------------------------------------
- CREATE_ALWAYS | Truncates Creates
- CREATE_NEW +-----------+ Fails Creates
- OPEN_ALWAYS ===| does this |===> Opens Creates
- OPEN_EXISTING +-----------+ Opens Fails
- TRUNCATE_EXISTING | Truncates Fails
-*/
- switch(mode)
- {
- default:
- case file_mode::read:
- desired_access = boost::winapi::GENERIC_READ_;
- share_mode = boost::winapi::FILE_SHARE_READ_;
- creation_disposition = boost::winapi::OPEN_EXISTING_;
- flags_and_attributes = 0x10000000; // FILE_FLAG_RANDOM_ACCESS
- break;
-
- case file_mode::scan:
- desired_access = boost::winapi::GENERIC_READ_;
- share_mode = boost::winapi::FILE_SHARE_READ_;
- creation_disposition = boost::winapi::OPEN_EXISTING_;
- flags_and_attributes = 0x08000000; // FILE_FLAG_SEQUENTIAL_SCAN
- break;
-
- case file_mode::write:
- desired_access = boost::winapi::GENERIC_READ_ |
- boost::winapi::GENERIC_WRITE_;
- creation_disposition = boost::winapi::CREATE_ALWAYS_;
- flags_and_attributes = 0x10000000; // FILE_FLAG_RANDOM_ACCESS
- break;
-
- case file_mode::write_new:
- desired_access = boost::winapi::GENERIC_READ_ |
- boost::winapi::GENERIC_WRITE_;
- creation_disposition = boost::winapi::CREATE_NEW_;
- flags_and_attributes = 0x10000000; // FILE_FLAG_RANDOM_ACCESS
- break;
-
- case file_mode::write_existing:
- desired_access = boost::winapi::GENERIC_READ_ |
- boost::winapi::GENERIC_WRITE_;
- creation_disposition = boost::winapi::OPEN_EXISTING_;
- flags_and_attributes = 0x10000000; // FILE_FLAG_RANDOM_ACCESS
- break;
-
- case file_mode::append:
- desired_access = boost::winapi::GENERIC_READ_ |
- boost::winapi::GENERIC_WRITE_;
-
- creation_disposition = boost::winapi::CREATE_ALWAYS_;
- flags_and_attributes = 0x08000000; // FILE_FLAG_SEQUENTIAL_SCAN
- break;
-
- case file_mode::append_new:
- desired_access = boost::winapi::GENERIC_READ_ |
- boost::winapi::GENERIC_WRITE_;
- creation_disposition = boost::winapi::CREATE_NEW_;
- flags_and_attributes = 0x08000000; // FILE_FLAG_SEQUENTIAL_SCAN
- break;
-
- case file_mode::append_existing:
- desired_access = boost::winapi::GENERIC_READ_ |
- boost::winapi::GENERIC_WRITE_;
- creation_disposition = boost::winapi::OPEN_EXISTING_;
- flags_and_attributes = 0x08000000; // FILE_FLAG_SEQUENTIAL_SCAN
- break;
- }
- h_ = ::CreateFileA(
- path,
- desired_access,
- share_mode,
- NULL,
- creation_disposition,
- flags_and_attributes,
- NULL);
- if(h_ == boost::winapi::INVALID_HANDLE_VALUE_)
- ec.assign(boost::winapi::GetLastError(),
- system_category());
- else
- ec.assign(0, ec.category());
-}
-
-inline
-std::uint64_t
-file_win32::
-size(error_code& ec) const
-{
- if(h_ == boost::winapi::INVALID_HANDLE_VALUE_)
- {
- ec = make_error_code(errc::invalid_argument);
- return 0;
- }
- boost::winapi::LARGE_INTEGER_ fileSize;
- if(! boost::winapi::GetFileSizeEx(h_, &fileSize))
- {
- ec.assign(boost::winapi::GetLastError(),
- system_category());
- return 0;
- }
- ec.assign(0, ec.category());
- return fileSize.QuadPart;
-}
-
-inline
-std::uint64_t
-file_win32::
-pos(error_code& ec)
-{
- if(h_ == boost::winapi::INVALID_HANDLE_VALUE_)
- {
- ec = make_error_code(errc::invalid_argument);
- return 0;
- }
- boost::winapi::LARGE_INTEGER_ in;
- boost::winapi::LARGE_INTEGER_ out;
- in.QuadPart = 0;
- if(! detail::set_file_pointer_ex(h_, in, &out,
- boost::winapi::FILE_CURRENT_))
- {
- ec.assign(boost::winapi::GetLastError(),
- system_category());
- return 0;
- }
- ec.assign(0, ec.category());
- return out.QuadPart;
-}
-
-inline
-void
-file_win32::
-seek(std::uint64_t offset, error_code& ec)
-{
- if(h_ == boost::winapi::INVALID_HANDLE_VALUE_)
- {
- ec = make_error_code(errc::invalid_argument);
- return;
- }
- boost::winapi::LARGE_INTEGER_ in;
- in.QuadPart = offset;
- if(! detail::set_file_pointer_ex(h_, in, 0,
- boost::winapi::FILE_BEGIN_))
- {
- ec.assign(boost::winapi::GetLastError(),
- system_category());
- return;
- }
- ec.assign(0, ec.category());
-}
-
-inline
-std::size_t
-file_win32::
-read(void* buffer, std::size_t n, error_code& ec)
-{
- if(h_ == boost::winapi::INVALID_HANDLE_VALUE_)
- {
- ec = make_error_code(errc::invalid_argument);
- return 0;
- }
- std::size_t nread = 0;
- while(n > 0)
- {
- boost::winapi::DWORD_ amount;
- if(n > (std::numeric_limits<
- boost::winapi::DWORD_>::max)())
- amount = (std::numeric_limits<
- boost::winapi::DWORD_>::max)();
- else
- amount = static_cast<
- boost::winapi::DWORD_>(n);
- boost::winapi::DWORD_ bytesRead;
- if(! ::ReadFile(h_, buffer, amount, &bytesRead, 0))
- {
- auto const dwError = boost::winapi::GetLastError();
- if(dwError != boost::winapi::ERROR_HANDLE_EOF_)
- ec.assign(dwError, system_category());
- else
- ec.assign(0, ec.category());
- return nread;
- }
- if(bytesRead == 0)
- return nread;
- n -= bytesRead;
- nread += bytesRead;
- buffer = reinterpret_cast<char*>(buffer) + bytesRead;
- }
- ec.assign(0, ec.category());
- return nread;
-}
-
-inline
-std::size_t
-file_win32::
-write(void const* buffer, std::size_t n, error_code& ec)
-{
- if(h_ == boost::winapi::INVALID_HANDLE_VALUE_)
- {
- ec = make_error_code(errc::invalid_argument);
- return 0;
- }
- std::size_t nwritten = 0;
- while(n > 0)
- {
- boost::winapi::DWORD_ amount;
- if(n > (std::numeric_limits<
- boost::winapi::DWORD_>::max)())
- amount = (std::numeric_limits<
- boost::winapi::DWORD_>::max)();
- else
- amount = static_cast<
- boost::winapi::DWORD_>(n);
- boost::winapi::DWORD_ bytesWritten;
- if(! ::WriteFile(h_, buffer, amount, &bytesWritten, 0))
- {
- auto const dwError = boost::winapi::GetLastError();
- if(dwError != boost::winapi::ERROR_HANDLE_EOF_)
- ec.assign(dwError, system_category());
- else
- ec.assign(0, ec.category());
- return nwritten;
- }
- if(bytesWritten == 0)
- return nwritten;
- n -= bytesWritten;
- nwritten += bytesWritten;
- buffer = reinterpret_cast<char const*>(buffer) + bytesWritten;
- }
- ec.assign(0, ec.category());
- return nwritten;
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/flat_buffer.ipp b/contrib/restricted/boost/boost/beast/core/impl/flat_buffer.ipp
deleted file mode 100644
index ffca651cc9..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/flat_buffer.ipp
+++ /dev/null
@@ -1,475 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_IMPL_FLAT_BUFFER_HPP
-#define BOOST_BEAST_IMPL_FLAT_BUFFER_HPP
-
-#include <boost/assert.hpp>
-#include <boost/throw_exception.hpp>
-#include <stdexcept>
-
-namespace boost {
-namespace beast {
-
-/* Memory is laid out thusly:
-
- begin_ ..|.. in_ ..|.. out_ ..|.. last_ ..|.. end_
-*/
-
-template<class Allocator>
-basic_flat_buffer<Allocator>::
-~basic_flat_buffer()
-{
- if(begin_)
- alloc_traits::deallocate(
- this->member(), begin_, dist(begin_, end_));
-}
-
-template<class Allocator>
-basic_flat_buffer<Allocator>::
-basic_flat_buffer()
- : begin_(nullptr)
- , in_(nullptr)
- , out_(nullptr)
- , last_(nullptr)
- , end_(nullptr)
- , max_((std::numeric_limits<std::size_t>::max)())
-{
-}
-
-template<class Allocator>
-basic_flat_buffer<Allocator>::
-basic_flat_buffer(std::size_t limit)
- : begin_(nullptr)
- , in_(nullptr)
- , out_(nullptr)
- , last_(nullptr)
- , end_(nullptr)
- , max_(limit)
-{
-}
-
-template<class Allocator>
-basic_flat_buffer<Allocator>::
-basic_flat_buffer(Allocator const& alloc)
- : detail::empty_base_optimization<base_alloc_type>(alloc)
- , begin_(nullptr)
- , in_(nullptr)
- , out_(nullptr)
- , last_(nullptr)
- , end_(nullptr)
- , max_((std::numeric_limits<std::size_t>::max)())
-{
-}
-
-template<class Allocator>
-basic_flat_buffer<Allocator>::
-basic_flat_buffer(std::size_t limit, Allocator const& alloc)
- : detail::empty_base_optimization<base_alloc_type>(alloc)
- , begin_(nullptr)
- , in_(nullptr)
- , out_(nullptr)
- , last_(nullptr)
- , end_(nullptr)
- , max_(limit)
-{
-}
-
-template<class Allocator>
-basic_flat_buffer<Allocator>::
-basic_flat_buffer(basic_flat_buffer&& other)
- : detail::empty_base_optimization<base_alloc_type>(
- std::move(other.member()))
- , begin_(other.begin_)
- , in_(other.in_)
- , out_(other.out_)
- , last_(out_)
- , end_(other.end_)
- , max_(other.max_)
-{
- other.begin_ = nullptr;
- other.in_ = nullptr;
- other.out_ = nullptr;
- other.last_ = nullptr;
- other.end_ = nullptr;
-}
-
-template<class Allocator>
-basic_flat_buffer<Allocator>::
-basic_flat_buffer(basic_flat_buffer&& other,
- Allocator const& alloc)
- : detail::empty_base_optimization<base_alloc_type>(alloc)
-{
- if(this->member() != other.member())
- {
- begin_ = nullptr;
- in_ = nullptr;
- out_ = nullptr;
- last_ = nullptr;
- end_ = nullptr;
- max_ = other.max_;
- copy_from(other);
- other.reset();
- }
- else
- {
- begin_ = other.begin_;
- in_ = other.in_;
- out_ = other.out_;
- last_ = out_;
- end_ = other.end_;
- max_ = other.max_;
- other.begin_ = nullptr;
- other.in_ = nullptr;
- other.out_ = nullptr;
- other.last_ = nullptr;
- other.end_ = nullptr;
- }
-}
-
-template<class Allocator>
-basic_flat_buffer<Allocator>::
-basic_flat_buffer(basic_flat_buffer const& other)
- : detail::empty_base_optimization<base_alloc_type>(
- alloc_traits::select_on_container_copy_construction(
- other.member()))
- , begin_(nullptr)
- , in_(nullptr)
- , out_(nullptr)
- , last_(nullptr)
- , end_(nullptr)
- , max_(other.max_)
-{
- copy_from(other);
-}
-
-template<class Allocator>
-basic_flat_buffer<Allocator>::
-basic_flat_buffer(basic_flat_buffer const& other,
- Allocator const& alloc)
- : detail::empty_base_optimization<base_alloc_type>(alloc)
- , begin_(nullptr)
- , in_(nullptr)
- , out_(nullptr)
- , last_(nullptr)
- , end_(nullptr)
- , max_(other.max_)
-{
- copy_from(other);
-}
-
-template<class Allocator>
-template<class OtherAlloc>
-basic_flat_buffer<Allocator>::
-basic_flat_buffer(
- basic_flat_buffer<OtherAlloc> const& other)
- : begin_(nullptr)
- , in_(nullptr)
- , out_(nullptr)
- , last_(nullptr)
- , end_(nullptr)
- , max_(other.max_)
-{
- copy_from(other);
-}
-
-template<class Allocator>
-template<class OtherAlloc>
-basic_flat_buffer<Allocator>::
-basic_flat_buffer(basic_flat_buffer<OtherAlloc> const& other,
- Allocator const& alloc)
- : detail::empty_base_optimization<base_alloc_type>(alloc)
- , begin_(nullptr)
- , in_(nullptr)
- , out_(nullptr)
- , last_(nullptr)
- , end_(nullptr)
- , max_(other.max_)
-{
- copy_from(other);
-}
-
-template<class Allocator>
-auto
-basic_flat_buffer<Allocator>::
-operator=(basic_flat_buffer&& other) ->
- basic_flat_buffer&
-{
- if(this != &other)
- move_assign(other, std::integral_constant<bool,
- alloc_traits::propagate_on_container_move_assignment::value>{});
- return *this;
-}
-
-template<class Allocator>
-auto
-basic_flat_buffer<Allocator>::
-operator=(basic_flat_buffer const& other) ->
- basic_flat_buffer&
-{
- if(this != &other)
- copy_assign(other, std::integral_constant<bool,
- alloc_traits::propagate_on_container_copy_assignment::value>{});
- return *this;
-}
-
-template<class Allocator>
-template<class OtherAlloc>
-auto
-basic_flat_buffer<Allocator>::
-operator=(basic_flat_buffer<OtherAlloc> const& other) ->
- basic_flat_buffer&
-{
- reset();
- max_ = other.max_;
- copy_from(other);
- return *this;
-}
-
-//------------------------------------------------------------------------------
-
-template<class Allocator>
-auto
-basic_flat_buffer<Allocator>::
-prepare(std::size_t n) ->
- mutable_buffers_type
-{
- if(n <= dist(out_, end_))
- {
- // existing capacity is sufficient
- last_ = out_ + n;
- return{out_, n};
- }
- auto const len = size();
- if(n <= capacity() - len)
- {
- // after a memmove,
- // existing capacity is sufficient
- if(len > 0)
- std::memmove(begin_, in_, len);
- in_ = begin_;
- out_ = in_ + len;
- last_ = out_ + n;
- return {out_, n};
- }
- // enforce maximum capacity
- if(n > max_ - len)
- BOOST_THROW_EXCEPTION(std::length_error{
- "basic_flat_buffer overflow"});
- // allocate a new buffer
- auto const new_size = (std::min<std::size_t>)(
- max_,
- (std::max<std::size_t>)(2 * len, len + n));
- auto const p = alloc_traits::allocate(
- this->member(), new_size);
- if(begin_)
- {
- BOOST_ASSERT(p);
- BOOST_ASSERT(in_);
- std::memcpy(p, in_, len);
- alloc_traits::deallocate(
- this->member(), begin_, capacity());
- }
- begin_ = p;
- in_ = begin_;
- out_ = in_ + len;
- last_ = out_ + n;
- end_ = begin_ + new_size;
- return {out_, n};
-}
-
-template<class Allocator>
-void
-basic_flat_buffer<Allocator>::
-consume(std::size_t n)
-{
- if(n >= dist(in_, out_))
- {
- in_ = begin_;
- out_ = begin_;
- return;
- }
- in_ += n;
-}
-
-template<class Allocator>
-void
-basic_flat_buffer<Allocator>::
-shrink_to_fit()
-{
- auto const len = size();
- if(len == capacity())
- return;
- char* p;
- if(len > 0)
- {
- BOOST_ASSERT(begin_);
- BOOST_ASSERT(in_);
- p = alloc_traits::allocate(
- this->member(), len);
- std::memcpy(p, in_, len);
- }
- else
- {
- p = nullptr;
- }
- alloc_traits::deallocate(
- this->member(), begin_, dist(begin_, end_));
- begin_ = p;
- in_ = begin_;
- out_ = begin_ + len;
- last_ = out_;
- end_ = out_;
-}
-
-//------------------------------------------------------------------------------
-
-template<class Allocator>
-inline
-void
-basic_flat_buffer<Allocator>::
-reset()
-{
- consume(size());
- shrink_to_fit();
-}
-
-template<class Allocator>
-template<class DynamicBuffer>
-inline
-void
-basic_flat_buffer<Allocator>::
-copy_from(DynamicBuffer const& buffer)
-{
- if(buffer.size() == 0)
- return;
- using boost::asio::buffer_copy;
- commit(buffer_copy(
- prepare(buffer.size()), buffer.data()));
-}
-
-template<class Allocator>
-inline
-void
-basic_flat_buffer<Allocator>::
-move_assign(basic_flat_buffer& other, std::true_type)
-{
- reset();
- this->member() = std::move(other.member());
- begin_ = other.begin_;
- in_ = other.in_;
- out_ = other.out_;
- last_ = out_;
- end_ = other.end_;
- max_ = other.max_;
- other.begin_ = nullptr;
- other.in_ = nullptr;
- other.out_ = nullptr;
- other.last_ = nullptr;
- other.end_ = nullptr;
-}
-
-template<class Allocator>
-inline
-void
-basic_flat_buffer<Allocator>::
-move_assign(basic_flat_buffer& other, std::false_type)
-{
- reset();
- if(this->member() != other.member())
- {
- copy_from(other);
- other.reset();
- }
- else
- {
- move_assign(other, std::true_type{});
- }
-}
-
-template<class Allocator>
-inline
-void
-basic_flat_buffer<Allocator>::
-copy_assign(basic_flat_buffer const& other, std::true_type)
-{
- reset();
- max_ = other.max_;
- this->member() = other.member();
- copy_from(other);
-}
-
-template<class Allocator>
-inline
-void
-basic_flat_buffer<Allocator>::
-copy_assign(basic_flat_buffer const& other, std::false_type)
-{
- reset();
- max_ = other.max_;
- copy_from(other);
-}
-
-template<class Allocator>
-inline
-void
-basic_flat_buffer<Allocator>::
-swap(basic_flat_buffer& other)
-{
- swap(other, typename
- alloc_traits::propagate_on_container_swap{});
-}
-
-template<class Allocator>
-inline
-void
-basic_flat_buffer<Allocator>::
-swap(basic_flat_buffer& other, std::true_type)
-{
- using std::swap;
- swap(this->member(), other.member());
- swap(max_, other.max_);
- swap(begin_, other.begin_);
- swap(in_, other.in_);
- swap(out_, other.out_);
- last_ = this->out_;
- other.last_ = other.out_;
- swap(end_, other.end_);
-}
-
-template<class Allocator>
-inline
-void
-basic_flat_buffer<Allocator>::
-swap(basic_flat_buffer& other, std::false_type)
-{
- BOOST_ASSERT(this->member() == other.member());
- using std::swap;
- swap(max_, other.max_);
- swap(begin_, other.begin_);
- swap(in_, other.in_);
- swap(out_, other.out_);
- last_ = this->out_;
- other.last_ = other.out_;
- swap(end_, other.end_);
-}
-
-template<class Allocator>
-void
-swap(
- basic_flat_buffer<Allocator>& lhs,
- basic_flat_buffer<Allocator>& rhs)
-{
- lhs.swap(rhs);
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/flat_static_buffer.ipp b/contrib/restricted/boost/boost/beast/core/impl/flat_static_buffer.ipp
deleted file mode 100644
index 3d38b92958..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/flat_static_buffer.ipp
+++ /dev/null
@@ -1,151 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_IMPL_FLAT_STATIC_BUFFER_IPP
-#define BOOST_BEAST_IMPL_FLAT_STATIC_BUFFER_IPP
-
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/throw_exception.hpp>
-#include <algorithm>
-#include <cstring>
-#include <iterator>
-#include <stdexcept>
-
-namespace boost {
-namespace beast {
-
-/* Memory is laid out thusly:
-
- begin_ ..|.. in_ ..|.. out_ ..|.. last_ ..|.. end_
-*/
-
-inline
-auto
-flat_static_buffer_base::
-data() const ->
- const_buffers_type
-{
- return {in_, dist(in_, out_)};
-}
-
-inline
-void
-flat_static_buffer_base::
-reset()
-{
- reset_impl();
-}
-
-inline
-auto
-flat_static_buffer_base::
-prepare(std::size_t n) ->
- mutable_buffers_type
-{
- return prepare_impl(n);
-}
-
-inline
-void
-flat_static_buffer_base::
-reset(void* p, std::size_t n)
-{
- reset_impl(p, n);
-}
-
-template<class>
-void
-flat_static_buffer_base::
-reset_impl()
-{
- in_ = begin_;
- out_ = begin_;
- last_ = begin_;
-}
-
-template<class>
-void
-flat_static_buffer_base::
-reset_impl(void* p, std::size_t n)
-{
- begin_ =
- reinterpret_cast<char*>(p);
- in_ = begin_;
- out_ = begin_;
- last_ = begin_;
- end_ = begin_ + n;
-}
-
-template<class>
-auto
-flat_static_buffer_base::
-prepare_impl(std::size_t n) ->
- mutable_buffers_type
-{
- if(n <= dist(out_, end_))
- {
- last_ = out_ + n;
- return {out_, n};
- }
- auto const len = size();
- if(n > capacity() - len)
- BOOST_THROW_EXCEPTION(std::length_error{
- "buffer overflow"});
- if(len > 0)
- std::memmove(begin_, in_, len);
- in_ = begin_;
- out_ = in_ + len;
- last_ = out_ + n;
- return {out_, n};
-}
-
-template<class>
-void
-flat_static_buffer_base::
-consume_impl(std::size_t n)
-{
- if(n >= size())
- {
- in_ = begin_;
- out_ = in_;
- return;
- }
- in_ += n;
-}
-
-//------------------------------------------------------------------------------
-
-template<std::size_t N>
-flat_static_buffer<N>::
-flat_static_buffer(flat_static_buffer const& other)
- : flat_static_buffer_base(buf_, N)
-{
- using boost::asio::buffer_copy;
- this->commit(buffer_copy(
- this->prepare(other.size()), other.data()));
-}
-
-template<std::size_t N>
-auto
-flat_static_buffer<N>::
-operator=(flat_static_buffer const& other) ->
- flat_static_buffer<N>&
-{
- using boost::asio::buffer_copy;
- this->consume(this->size());
- this->commit(buffer_copy(
- this->prepare(other.size()), other.data()));
- return *this;
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/handler_ptr.ipp b/contrib/restricted/boost/boost/beast/core/impl/handler_ptr.ipp
deleted file mode 100644
index 99d1a894d5..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/handler_ptr.ipp
+++ /dev/null
@@ -1,128 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_IMPL_HANDLER_PTR_HPP
-#define BOOST_BEAST_IMPL_HANDLER_PTR_HPP
-
-#include <boost/asio/associated_allocator.hpp>
-#include <boost/assert.hpp>
-#include <memory>
-
-namespace boost {
-namespace beast {
-
-template<class T, class Handler>
-void
-handler_ptr<T, Handler>::
-clear()
-{
- typename beast::detail::allocator_traits<
- boost::asio::associated_allocator_t<
- Handler>>::template rebind_alloc<T> alloc(
- boost::asio::get_associated_allocator(
- handler()));
- beast::detail::allocator_traits<
- decltype(alloc)>::destroy(alloc, t_);
- beast::detail::allocator_traits<
- decltype(alloc)>::deallocate(alloc, t_, 1);
- t_ = nullptr;
-}
-
-template<class T, class Handler>
-handler_ptr<T, Handler>::
-~handler_ptr()
-{
- if(t_)
- {
- clear();
- handler().~Handler();
- }
-}
-
-template<class T, class Handler>
-handler_ptr<T, Handler>::
-handler_ptr(handler_ptr&& other)
- : t_(other.t_)
-{
- if(other.t_)
- {
- new(&h_) Handler(std::move(other.handler()));
- other.handler().~Handler();
- other.t_ = nullptr;
- }
-}
-
-template<class T, class Handler>
-template<class DeducedHandler, class... Args>
-handler_ptr<T, Handler>::
-handler_ptr(DeducedHandler&& h, Args&&... args)
-{
- BOOST_STATIC_ASSERT(! std::is_array<T>::value);
- typename beast::detail::allocator_traits<
- boost::asio::associated_allocator_t<
- Handler>>::template rebind_alloc<T> alloc{
- boost::asio::get_associated_allocator(h)};
- using A = decltype(alloc);
- bool destroy = false;
- auto deleter = [&alloc, &destroy](T* p)
- {
- if(destroy)
- beast::detail::allocator_traits<A>::destroy(alloc, p);
- beast::detail::allocator_traits<A>::deallocate(alloc, p, 1);
- };
- std::unique_ptr<T, decltype(deleter)> t{
- beast::detail::allocator_traits<A>::allocate(alloc, 1), deleter};
- beast::detail::allocator_traits<A>::construct(alloc, t.get(),
- static_cast<DeducedHandler const&>(h),
- std::forward<Args>(args)...);
- destroy = true;
- new(&h_) Handler(std::forward<DeducedHandler>(h));
- t_ = t.release();
-}
-
-template<class T, class Handler>
-auto
-handler_ptr<T, Handler>::
-release_handler() ->
- handler_type
-{
- BOOST_ASSERT(t_);
- clear();
- auto deleter = [](Handler* h)
- {
- h->~Handler();
- };
- std::unique_ptr<
- Handler, decltype(deleter)> destroyer{
- &handler(), deleter};
- return std::move(handler());
-}
-
-template<class T, class Handler>
-template<class... Args>
-void
-handler_ptr<T, Handler>::
-invoke(Args&&... args)
-{
- BOOST_ASSERT(t_);
- clear();
- auto deleter = [](Handler* h)
- {
- h->~Handler();
- };
- std::unique_ptr<
- Handler, decltype(deleter)> destroyer{
- &handler(), deleter};
- handler()(std::forward<Args>(args)...);
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/multi_buffer.ipp b/contrib/restricted/boost/boost/beast/core/impl/multi_buffer.ipp
deleted file mode 100644
index e7ae541f9c..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/multi_buffer.ipp
+++ /dev/null
@@ -1,1063 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_IMPL_MULTI_BUFFER_IPP
-#define BOOST_BEAST_IMPL_MULTI_BUFFER_IPP
-
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/assert.hpp>
-#include <boost/throw_exception.hpp>
-#include <algorithm>
-#include <exception>
-#include <sstream>
-#include <string>
-#include <utility>
-
-namespace boost {
-namespace beast {
-
-/* These diagrams illustrate the layout and state variables.
-
-1 Input and output contained entirely in one element:
-
- 0 out_
- |<-------------+------------------------------------------->|
- in_pos_ out_pos_ out_end_
-
-
-2 Output contained in first and second elements:
-
- out_
- |<------+----------+------->| |<----------+-------------->|
- in_pos_ out_pos_ out_end_
-
-
-3 Output contained in the second element:
-
- out_
- |<------------+------------>| |<----+-------------------->|
- in_pos_ out_pos_ out_end_
-
-
-4 Output contained in second and third elements:
-
- out_
- |<-----+-------->| |<-------+------>| |<--------------->|
- in_pos_ out_pos_ out_end_
-
-
-5 Input sequence is empty:
-
- out_
- |<------+------------------>| |<-----------+------------->|
- out_pos_ out_end_
- in_pos_
-
-
-6 Output sequence is empty:
-
- out_
- |<------+------------------>| |<------+------------------>|
- in_pos_ out_pos_
- out_end_
-
-
-7 The end of output can point to the end of an element.
- But out_pos_ should never point to the end:
-
- out_
- |<------+------------------>| |<------+------------------>|
- in_pos_ out_pos_ out_end_
-
-
-8 When the input sequence entirely fills the last element and
- the output sequence is empty, out_ will point to the end of
- the list of buffers, and out_pos_ and out_end_ will be 0:
-
-
- |<------+------------------>| out_ == list_.end()
- in_pos_ out_pos_ == 0
- out_end_ == 0
-*/
-
-template<class Allocator>
-class basic_multi_buffer<Allocator>::element
- : public boost::intrusive::list_base_hook<
- boost::intrusive::link_mode<
- boost::intrusive::normal_link>>
-{
- using size_type =
- typename detail::allocator_traits<Allocator>::size_type;
-
- size_type const size_;
-
-public:
- element(element const&) = delete;
- element& operator=(element const&) = delete;
-
- explicit
- element(size_type n)
- : size_(n)
- {
- }
-
- size_type
- size() const
- {
- return size_;
- }
-
- char*
- data() const
- {
- return const_cast<char*>(
- reinterpret_cast<char const*>(this+1));
- }
-};
-
-template<class Allocator>
-class basic_multi_buffer<Allocator>::const_buffers_type
-{
- basic_multi_buffer const* b_;
-
- friend class basic_multi_buffer;
-
- explicit
- const_buffers_type(basic_multi_buffer const& b);
-
-public:
- using value_type = boost::asio::const_buffer;
-
- class const_iterator;
-
- const_buffers_type() = delete;
- const_buffers_type(const_buffers_type const&) = default;
- const_buffers_type& operator=(const_buffers_type const&) = default;
-
- const_iterator
- begin() const;
-
- const_iterator
- end() const;
-
- friend
- std::size_t
- buffer_size(const_buffers_type const& buffers)
- {
- return buffers.b_->size();
- }
-};
-
-template<class Allocator>
-class basic_multi_buffer<Allocator>::mutable_buffers_type
-{
- basic_multi_buffer const* b_;
-
- friend class basic_multi_buffer;
-
- explicit
- mutable_buffers_type(basic_multi_buffer const& b);
-
-public:
- using value_type = mutable_buffer;
-
- class const_iterator;
-
- mutable_buffers_type() = delete;
- mutable_buffers_type(mutable_buffers_type const&) = default;
- mutable_buffers_type& operator=(mutable_buffers_type const&) = default;
-
- const_iterator
- begin() const;
-
- const_iterator
- end() const;
-};
-
-//------------------------------------------------------------------------------
-
-template<class Allocator>
-class basic_multi_buffer<Allocator>::const_buffers_type::const_iterator
-{
- basic_multi_buffer const* b_ = nullptr;
- typename list_type::const_iterator it_;
-
-public:
- using value_type =
- typename const_buffers_type::value_type;
- using pointer = value_type const*;
- using reference = value_type;
- using difference_type = std::ptrdiff_t;
- using iterator_category =
- std::bidirectional_iterator_tag;
-
- const_iterator() = default;
- const_iterator(const_iterator&& other) = default;
- const_iterator(const_iterator const& other) = default;
- const_iterator& operator=(const_iterator&& other) = default;
- const_iterator& operator=(const_iterator const& other) = default;
-
- const_iterator(basic_multi_buffer const& b,
- typename list_type::const_iterator const& it)
- : b_(&b)
- , it_(it)
- {
- }
-
- bool
- operator==(const_iterator const& other) const
- {
- return b_ == other.b_ && it_ == other.it_;
- }
-
- bool
- operator!=(const_iterator const& other) const
- {
- return !(*this == other);
- }
-
- reference
- operator*() const
- {
- auto const& e = *it_;
- return value_type{e.data(),
- (b_->out_ == b_->list_.end() ||
- &e != &*b_->out_) ? e.size() : b_->out_pos_} +
- (&e == &*b_->list_.begin() ? b_->in_pos_ : 0);
- }
-
- pointer
- operator->() const = delete;
-
- const_iterator&
- operator++()
- {
- ++it_;
- return *this;
- }
-
- const_iterator
- operator++(int)
- {
- auto temp = *this;
- ++(*this);
- return temp;
- }
-
- const_iterator&
- operator--()
- {
- --it_;
- return *this;
- }
-
- const_iterator
- operator--(int)
- {
- auto temp = *this;
- --(*this);
- return temp;
- }
-};
-
-template<class Allocator>
-basic_multi_buffer<Allocator>::
-const_buffers_type::
-const_buffers_type(
- basic_multi_buffer const& b)
- : b_(&b)
-{
-}
-
-template<class Allocator>
-auto
-basic_multi_buffer<Allocator>::
-const_buffers_type::
-begin() const ->
- const_iterator
-{
- return const_iterator{*b_, b_->list_.begin()};
-}
-
-template<class Allocator>
-auto
-basic_multi_buffer<Allocator>::
-const_buffers_type::
-end() const ->
- const_iterator
-{
- return const_iterator{*b_, b_->out_ ==
- b_->list_.end() ? b_->list_.end() :
- std::next(b_->out_)};
-}
-
-//------------------------------------------------------------------------------
-
-template<class Allocator>
-class basic_multi_buffer<Allocator>::mutable_buffers_type::const_iterator
-{
- basic_multi_buffer const* b_ = nullptr;
- typename list_type::const_iterator it_;
-
-public:
- using value_type =
- typename mutable_buffers_type::value_type;
- using pointer = value_type const*;
- using reference = value_type;
- using difference_type = std::ptrdiff_t;
- using iterator_category =
- std::bidirectional_iterator_tag;
-
- const_iterator() = default;
- const_iterator(const_iterator&& other) = default;
- const_iterator(const_iterator const& other) = default;
- const_iterator& operator=(const_iterator&& other) = default;
- const_iterator& operator=(const_iterator const& other) = default;
-
- const_iterator(basic_multi_buffer const& b,
- typename list_type::const_iterator const& it)
- : b_(&b)
- , it_(it)
- {
- }
-
- bool
- operator==(const_iterator const& other) const
- {
- return b_ == other.b_ && it_ == other.it_;
- }
-
- bool
- operator!=(const_iterator const& other) const
- {
- return !(*this == other);
- }
-
- reference
- operator*() const
- {
- auto const& e = *it_;
- return value_type{e.data(),
- &e == &*std::prev(b_->list_.end()) ?
- b_->out_end_ : e.size()} +
- (&e == &*b_->out_ ? b_->out_pos_ : 0);
- }
-
- pointer
- operator->() const = delete;
-
- const_iterator&
- operator++()
- {
- ++it_;
- return *this;
- }
-
- const_iterator
- operator++(int)
- {
- auto temp = *this;
- ++(*this);
- return temp;
- }
-
- const_iterator&
- operator--()
- {
- --it_;
- return *this;
- }
-
- const_iterator
- operator--(int)
- {
- auto temp = *this;
- --(*this);
- return temp;
- }
-};
-
-template<class Allocator>
-basic_multi_buffer<Allocator>::
-mutable_buffers_type::
-mutable_buffers_type(
- basic_multi_buffer const& b)
- : b_(&b)
-{
-}
-
-template<class Allocator>
-auto
-basic_multi_buffer<Allocator>::
-mutable_buffers_type::
-begin() const ->
- const_iterator
-{
- return const_iterator{*b_, b_->out_};
-}
-
-template<class Allocator>
-auto
-basic_multi_buffer<Allocator>::
-mutable_buffers_type::
-end() const ->
- const_iterator
-{
- return const_iterator{*b_, b_->list_.end()};
-}
-
-//------------------------------------------------------------------------------
-
-template<class Allocator>
-basic_multi_buffer<Allocator>::
-~basic_multi_buffer()
-{
- delete_list();
-}
-
-template<class Allocator>
-basic_multi_buffer<Allocator>::
-basic_multi_buffer()
- : out_(list_.end())
-{
-}
-
-template<class Allocator>
-basic_multi_buffer<Allocator>::
-basic_multi_buffer(std::size_t limit)
- : max_(limit)
- , out_(list_.end())
-{
-}
-
-template<class Allocator>
-basic_multi_buffer<Allocator>::
-basic_multi_buffer(Allocator const& alloc)
- : detail::empty_base_optimization<
- base_alloc_type>(alloc)
- , out_(list_.end())
-{
-}
-
-template<class Allocator>
-basic_multi_buffer<Allocator>::
-basic_multi_buffer(std::size_t limit,
- Allocator const& alloc)
- : detail::empty_base_optimization<
- base_alloc_type>(alloc)
- , max_(limit)
- , out_(list_.end())
-{
-}
-
-template<class Allocator>
-basic_multi_buffer<Allocator>::
-basic_multi_buffer(basic_multi_buffer&& other)
- : detail::empty_base_optimization<
- base_alloc_type>(std::move(other.member()))
- , max_(other.max_)
- , in_size_(other.in_size_)
- , in_pos_(other.in_pos_)
- , out_pos_(other.out_pos_)
- , out_end_(other.out_end_)
-{
- auto const at_end =
- other.out_ == other.list_.end();
- list_ = std::move(other.list_);
- out_ = at_end ? list_.end() : other.out_;
- other.in_size_ = 0;
- other.out_ = other.list_.end();
- other.in_pos_ = 0;
- other.out_pos_ = 0;
- other.out_end_ = 0;
-}
-
-template<class Allocator>
-basic_multi_buffer<Allocator>::
-basic_multi_buffer(basic_multi_buffer&& other,
- Allocator const& alloc)
- : detail::empty_base_optimization<
- base_alloc_type>(alloc)
- , max_(other.max_)
-{
- if(this->member() != other.member())
- {
- out_ = list_.end();
- copy_from(other);
- other.reset();
- }
- else
- {
- auto const at_end =
- other.out_ == other.list_.end();
- list_ = std::move(other.list_);
- out_ = at_end ? list_.end() : other.out_;
- in_size_ = other.in_size_;
- in_pos_ = other.in_pos_;
- out_pos_ = other.out_pos_;
- out_end_ = other.out_end_;
- other.in_size_ = 0;
- other.out_ = other.list_.end();
- other.in_pos_ = 0;
- other.out_pos_ = 0;
- other.out_end_ = 0;
- }
-}
-
-template<class Allocator>
-basic_multi_buffer<Allocator>::
-basic_multi_buffer(basic_multi_buffer const& other)
- : detail::empty_base_optimization<
- base_alloc_type>(alloc_traits::
- select_on_container_copy_construction(
- other.member()))
- , max_(other.max_)
- , out_(list_.end())
-{
- copy_from(other);
-}
-
-template<class Allocator>
-basic_multi_buffer<Allocator>::
-basic_multi_buffer(basic_multi_buffer const& other,
- Allocator const& alloc)
- : detail::empty_base_optimization<
- base_alloc_type>(alloc)
- , max_(other.max_)
- , out_(list_.end())
-{
- copy_from(other);
-}
-
-template<class Allocator>
-template<class OtherAlloc>
-basic_multi_buffer<Allocator>::
-basic_multi_buffer(
- basic_multi_buffer<OtherAlloc> const& other)
- : out_(list_.end())
-{
- copy_from(other);
-}
-
-template<class Allocator>
-template<class OtherAlloc>
-basic_multi_buffer<Allocator>::
-basic_multi_buffer(
- basic_multi_buffer<OtherAlloc> const& other,
- allocator_type const& alloc)
- : detail::empty_base_optimization<
- base_alloc_type>(alloc)
- , max_(other.max_)
- , out_(list_.end())
-{
- copy_from(other);
-}
-
-template<class Allocator>
-auto
-basic_multi_buffer<Allocator>::
-operator=(basic_multi_buffer&& other) ->
- basic_multi_buffer&
-{
- if(this == &other)
- return *this;
- reset();
- max_ = other.max_;
- move_assign(other, std::integral_constant<bool,
- alloc_traits::propagate_on_container_move_assignment::value>{});
- return *this;
-}
-
-template<class Allocator>
-auto
-basic_multi_buffer<Allocator>::
-operator=(basic_multi_buffer const& other) ->
-basic_multi_buffer&
-{
- if(this == &other)
- return *this;
- copy_assign(other, std::integral_constant<bool,
- alloc_traits::propagate_on_container_copy_assignment::value>{});
- return *this;
-}
-
-template<class Allocator>
-template<class OtherAlloc>
-auto
-basic_multi_buffer<Allocator>::
-operator=(
- basic_multi_buffer<OtherAlloc> const& other) ->
- basic_multi_buffer&
-{
- reset();
- max_ = other.max_;
- copy_from(other);
- return *this;
-}
-
-template<class Allocator>
-std::size_t
-basic_multi_buffer<Allocator>::
-capacity() const
-{
- auto pos = out_;
- if(pos == list_.end())
- return in_size_;
- auto n = pos->size() - out_pos_;
- while(++pos != list_.end())
- n += pos->size();
- return in_size_ + n;
-}
-
-template<class Allocator>
-auto
-basic_multi_buffer<Allocator>::
-data() const ->
- const_buffers_type
-{
- return const_buffers_type(*this);
-}
-
-template<class Allocator>
-auto
-basic_multi_buffer<Allocator>::
-prepare(size_type n) ->
- mutable_buffers_type
-{
- if(in_size_ + n > max_)
- BOOST_THROW_EXCEPTION(std::length_error{
- "dynamic buffer overflow"});
- list_type reuse;
- std::size_t total = in_size_;
- // put all empty buffers on reuse list
- if(out_ != list_.end())
- {
- total += out_->size() - out_pos_;
- if(out_ != list_.iterator_to(list_.back()))
- {
- out_end_ = out_->size();
- reuse.splice(reuse.end(), list_,
- std::next(out_), list_.end());
- #if BOOST_BEAST_MULTI_BUFFER_DEBUG_CHECK
- debug_check();
- #endif
- }
- auto const avail = out_->size() - out_pos_;
- if(n > avail)
- {
- out_end_ = out_->size();
- n -= avail;
- }
- else
- {
- out_end_ = out_pos_ + n;
- n = 0;
- }
- #if BOOST_BEAST_MULTI_BUFFER_DEBUG_CHECK
- debug_check();
- #endif
- }
- // get space from reuse buffers
- while(n > 0 && ! reuse.empty())
- {
- auto& e = reuse.front();
- reuse.erase(reuse.iterator_to(e));
- list_.push_back(e);
- total += e.size();
- if(n > e.size())
- {
- out_end_ = e.size();
- n -= e.size();
- }
- else
- {
- out_end_ = n;
- n = 0;
- }
- #if BOOST_BEAST_MULTI_BUFFER_DEBUG_CHECK
- debug_check();
- #endif
- }
- BOOST_ASSERT(total <= max_);
- if(! reuse.empty() || n > 0)
- {
- for(auto it = reuse.begin(); it != reuse.end();)
- {
- auto& e = *it++;
- reuse.erase(list_.iterator_to(e));
- auto const len = sizeof(e) + e.size();
- alloc_traits::destroy(this->member(), &e);
- alloc_traits::deallocate(this->member(),
- reinterpret_cast<char*>(&e), len);
- }
- if(n > 0)
- {
- static auto const growth_factor = 2.0f;
- auto const size =
- (std::min<std::size_t>)(
- max_ - total,
- (std::max<std::size_t>)({
- static_cast<std::size_t>(
- in_size_ * growth_factor - in_size_),
- 512,
- n}));
- auto& e = *reinterpret_cast<element*>(static_cast<
- void*>(alloc_traits::allocate(this->member(),
- sizeof(element) + size)));
- alloc_traits::construct(this->member(), &e, size);
- list_.push_back(e);
- if(out_ == list_.end())
- out_ = list_.iterator_to(e);
- out_end_ = n;
- #if BOOST_BEAST_MULTI_BUFFER_DEBUG_CHECK
- debug_check();
- #endif
- }
- }
- return mutable_buffers_type(*this);
-}
-
-template<class Allocator>
-void
-basic_multi_buffer<Allocator>::
-commit(size_type n)
-{
- if(list_.empty())
- return;
- if(out_ == list_.end())
- return;
- auto const back =
- list_.iterator_to(list_.back());
- while(out_ != back)
- {
- auto const avail =
- out_->size() - out_pos_;
- if(n < avail)
- {
- out_pos_ += n;
- in_size_ += n;
- #if BOOST_BEAST_MULTI_BUFFER_DEBUG_CHECK
- debug_check();
- #endif
- return;
- }
- ++out_;
- n -= avail;
- out_pos_ = 0;
- in_size_ += avail;
- #if BOOST_BEAST_MULTI_BUFFER_DEBUG_CHECK
- debug_check();
- #endif
- }
-
- n = (std::min)(n, out_end_ - out_pos_);
- out_pos_ += n;
- in_size_ += n;
- if(out_pos_ == out_->size())
- {
- ++out_;
- out_pos_ = 0;
- out_end_ = 0;
- }
-#if BOOST_BEAST_MULTI_BUFFER_DEBUG_CHECK
- debug_check();
-#endif
-}
-
-template<class Allocator>
-void
-basic_multi_buffer<Allocator>::
-consume(size_type n)
-{
- if(list_.empty())
- return;
- for(;;)
- {
- if(list_.begin() != out_)
- {
- auto const avail =
- list_.front().size() - in_pos_;
- if(n < avail)
- {
- in_size_ -= n;
- in_pos_ += n;
- #if BOOST_BEAST_MULTI_BUFFER_DEBUG_CHECK
- debug_check();
- #endif
- break;
- }
- n -= avail;
- in_size_ -= avail;
- in_pos_ = 0;
- auto& e = list_.front();
- list_.erase(list_.iterator_to(e));
- auto const len = sizeof(e) + e.size();
- alloc_traits::destroy(this->member(), &e);
- alloc_traits::deallocate(this->member(),
- reinterpret_cast<char*>(&e), len);
- #if BOOST_BEAST_MULTI_BUFFER_DEBUG_CHECK
- debug_check();
- #endif
- }
- else
- {
- auto const avail = out_pos_ - in_pos_;
- if(n < avail)
- {
- in_size_ -= n;
- in_pos_ += n;
- }
- else
- {
- in_size_ = 0;
- if(out_ != list_.iterator_to(list_.back()) ||
- out_pos_ != out_end_)
- {
- in_pos_ = out_pos_;
- }
- else
- {
- // Input and output sequences are empty, reuse buffer.
- // Alternatively we could deallocate it.
- in_pos_ = 0;
- out_pos_ = 0;
- out_end_ = 0;
- }
- }
- #if BOOST_BEAST_MULTI_BUFFER_DEBUG_CHECK
- debug_check();
- #endif
- break;
- }
- }
-}
-
-template<class Allocator>
-inline
-void
-basic_multi_buffer<Allocator>::
-delete_list()
-{
- for(auto iter = list_.begin(); iter != list_.end();)
- {
- auto& e = *iter++;
- auto const len = sizeof(e) + e.size();
- alloc_traits::destroy(this->member(), &e);
- alloc_traits::deallocate(this->member(),
- reinterpret_cast<char*>(&e), len);
- }
-}
-
-template<class Allocator>
-inline
-void
-basic_multi_buffer<Allocator>::
-reset()
-{
- delete_list();
- list_.clear();
- out_ = list_.end();
- in_size_ = 0;
- in_pos_ = 0;
- out_pos_ = 0;
- out_end_ = 0;
-}
-
-template<class Allocator>
-template<class DynamicBuffer>
-inline
-void
-basic_multi_buffer<Allocator>::
-copy_from(DynamicBuffer const& buffer)
-{
- if(buffer.size() == 0)
- return;
- using boost::asio::buffer_copy;
- commit(buffer_copy(
- prepare(buffer.size()), buffer.data()));
-}
-
-template<class Allocator>
-inline
-void
-basic_multi_buffer<Allocator>::
-move_assign(basic_multi_buffer& other, std::false_type)
-{
- if(this->member() != other.member())
- {
- copy_from(other);
- other.reset();
- }
- else
- {
- move_assign(other, std::true_type{});
- }
-}
-
-template<class Allocator>
-inline
-void
-basic_multi_buffer<Allocator>::
-move_assign(basic_multi_buffer& other, std::true_type)
-{
- this->member() = std::move(other.member());
- auto const at_end =
- other.out_ == other.list_.end();
- list_ = std::move(other.list_);
- out_ = at_end ? list_.end() : other.out_;
-
- in_size_ = other.in_size_;
- in_pos_ = other.in_pos_;
- out_pos_ = other.out_pos_;
- out_end_ = other.out_end_;
-
- other.in_size_ = 0;
- other.out_ = other.list_.end();
- other.in_pos_ = 0;
- other.out_pos_ = 0;
- other.out_end_ = 0;
-}
-
-template<class Allocator>
-inline
-void
-basic_multi_buffer<Allocator>::
-copy_assign(
- basic_multi_buffer const& other, std::false_type)
-{
- reset();
- max_ = other.max_;
- copy_from(other);
-}
-
-template<class Allocator>
-inline
-void
-basic_multi_buffer<Allocator>::
-copy_assign(
- basic_multi_buffer const& other, std::true_type)
-{
- reset();
- max_ = other.max_;
- this->member() = other.member();
- copy_from(other);
-}
-
-template<class Allocator>
-inline
-void
-basic_multi_buffer<Allocator>::
-swap(basic_multi_buffer& other)
-{
- swap(other, typename
- alloc_traits::propagate_on_container_swap{});
-}
-
-template<class Allocator>
-inline
-void
-basic_multi_buffer<Allocator>::
-swap(basic_multi_buffer& other, std::true_type)
-{
- using std::swap;
- auto const at_end0 =
- out_ == list_.end();
- auto const at_end1 =
- other.out_ == other.list_.end();
- swap(this->member(), other.member());
- swap(list_, other.list_);
- swap(out_, other.out_);
- if(at_end1)
- out_ = list_.end();
- if(at_end0)
- other.out_ = other.list_.end();
- swap(in_size_, other.in_size_);
- swap(in_pos_, other.in_pos_);
- swap(out_pos_, other.out_pos_);
- swap(out_end_, other.out_end_);
-}
-
-template<class Allocator>
-inline
-void
-basic_multi_buffer<Allocator>::
-swap(basic_multi_buffer& other, std::false_type)
-{
- BOOST_ASSERT(this->member() == other.member());
- using std::swap;
- auto const at_end0 =
- out_ == list_.end();
- auto const at_end1 =
- other.out_ == other.list_.end();
- swap(list_, other.list_);
- swap(out_, other.out_);
- if(at_end1)
- out_ = list_.end();
- if(at_end0)
- other.out_ = other.list_.end();
- swap(in_size_, other.in_size_);
- swap(in_pos_, other.in_pos_);
- swap(out_pos_, other.out_pos_);
- swap(out_end_, other.out_end_);
-}
-
-template<class Allocator>
-void
-swap(
- basic_multi_buffer<Allocator>& lhs,
- basic_multi_buffer<Allocator>& rhs)
-{
- lhs.swap(rhs);
-}
-
-template<class Allocator>
-void
-basic_multi_buffer<Allocator>::
-debug_check() const
-{
-#ifndef NDEBUG
- using boost::asio::buffer_size;
- BOOST_ASSERT(buffer_size(data()) == in_size_);
- if(list_.empty())
- {
- BOOST_ASSERT(in_pos_ == 0);
- BOOST_ASSERT(in_size_ == 0);
- BOOST_ASSERT(out_pos_ == 0);
- BOOST_ASSERT(out_end_ == 0);
- BOOST_ASSERT(out_ == list_.end());
- return;
- }
-
- auto const& front = list_.front();
-
- BOOST_ASSERT(in_pos_ < front.size());
-
- if(out_ == list_.end())
- {
- BOOST_ASSERT(out_pos_ == 0);
- BOOST_ASSERT(out_end_ == 0);
- }
- else
- {
- auto const& out = *out_;
- auto const& back = list_.back();
-
- BOOST_ASSERT(out_end_ <= back.size());
- BOOST_ASSERT(out_pos_ < out.size());
- BOOST_ASSERT(&out != &front || out_pos_ >= in_pos_);
- BOOST_ASSERT(&out != &front || out_pos_ - in_pos_ == in_size_);
- BOOST_ASSERT(&out != &back || out_pos_ <= out_end_);
- }
-#endif
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/read_size.ipp b/contrib/restricted/boost/boost/beast/core/impl/read_size.ipp
deleted file mode 100644
index ddcaf397a9..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/read_size.ipp
+++ /dev/null
@@ -1,80 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_IMPL_READ_SIZE_IPP
-#define BOOST_BEAST_IMPL_READ_SIZE_IPP
-
-namespace boost {
-namespace beast {
-
-namespace detail {
-
-template<class T, class = void>
-struct has_read_size_helper : std::false_type {};
-
-template<class T>
-struct has_read_size_helper<T, decltype(
- read_size_helper(std::declval<T&>(), 512),
- (void)0)> : std::true_type
-{
-};
-
-template<class DynamicBuffer>
-std::size_t
-read_size(DynamicBuffer& buffer,
- std::size_t max_size, std::true_type)
-{
- return read_size_helper(buffer, max_size);
-}
-
-template<class DynamicBuffer>
-std::size_t
-read_size(DynamicBuffer& buffer,
- std::size_t max_size, std::false_type)
-{
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- BOOST_ASSERT(max_size >= 1);
- auto const size = buffer.size();
- auto const limit = buffer.max_size() - size;
- BOOST_ASSERT(size <= buffer.max_size());
- return (std::min<std::size_t>)(
- (std::max<std::size_t>)(512, buffer.capacity() - size),
- (std::min<std::size_t>)(max_size, limit));
-}
-
-} // detail
-
-template<class DynamicBuffer>
-inline
-std::size_t
-read_size(
- DynamicBuffer& buffer, std::size_t max_size)
-{
- return detail::read_size(buffer, max_size,
- detail::has_read_size_helper<DynamicBuffer>{});
-}
-
-template<class DynamicBuffer>
-std::size_t
-read_size_or_throw(
- DynamicBuffer& buffer, std::size_t max_size)
-{
- auto const n = read_size(buffer, max_size);
- if(n == 0)
- BOOST_THROW_EXCEPTION(std::length_error{
- "buffer overflow"});
- return n;
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/static_buffer.ipp b/contrib/restricted/boost/boost/beast/core/impl/static_buffer.ipp
deleted file mode 100644
index 2fdb2d9a8a..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/static_buffer.ipp
+++ /dev/null
@@ -1,169 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_IMPL_STATIC_BUFFER_IPP
-#define BOOST_BEAST_IMPL_STATIC_BUFFER_IPP
-
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/throw_exception.hpp>
-#include <algorithm>
-#include <cstring>
-#include <iterator>
-#include <stdexcept>
-
-namespace boost {
-namespace beast {
-
-inline
-static_buffer_base::
-static_buffer_base(void* p, std::size_t size)
- : begin_(reinterpret_cast<char*>(p))
- , capacity_(size)
-{
-}
-
-inline
-auto
-static_buffer_base::
-data() const ->
- const_buffers_type
-{
- using boost::asio::const_buffer;
- const_buffers_type result;
- if(in_off_ + in_size_ <= capacity_)
- {
- result[0] = const_buffer{begin_ + in_off_, in_size_};
- result[1] = const_buffer{begin_, 0};
- }
- else
- {
- result[0] = const_buffer{begin_ + in_off_, capacity_ - in_off_};
- result[1] = const_buffer{begin_, in_size_ - (capacity_ - in_off_)};
- }
- return result;
-}
-
-inline
-auto
-static_buffer_base::
-mutable_data() ->
- mutable_buffers_type
-{
- using boost::asio::mutable_buffer;
- mutable_buffers_type result;
- if(in_off_ + in_size_ <= capacity_)
- {
- result[0] = mutable_buffer{begin_ + in_off_, in_size_};
- result[1] = mutable_buffer{begin_, 0};
- }
- else
- {
- result[0] = mutable_buffer{begin_ + in_off_, capacity_ - in_off_};
- result[1] = mutable_buffer{begin_, in_size_ - (capacity_ - in_off_)};
- }
- return result;
-}
-
-inline
-auto
-static_buffer_base::
-prepare(std::size_t size) ->
- mutable_buffers_type
-{
- using boost::asio::mutable_buffer;
- if(size > capacity_ - in_size_)
- BOOST_THROW_EXCEPTION(std::length_error{
- "buffer overflow"});
- out_size_ = size;
- auto const out_off = (in_off_ + in_size_) % capacity_;
- mutable_buffers_type result;
- if(out_off + out_size_ <= capacity_ )
- {
- result[0] = mutable_buffer{begin_ + out_off, out_size_};
- result[1] = mutable_buffer{begin_, 0};
- }
- else
- {
- result[0] = mutable_buffer{begin_ + out_off, capacity_ - out_off};
- result[1] = mutable_buffer{begin_, out_size_ - (capacity_ - out_off)};
- }
- return result;
-}
-
-inline
-void
-static_buffer_base::
-commit(std::size_t size)
-{
- in_size_ += (std::min)(size, out_size_);
- out_size_ = 0;
-}
-
-inline
-void
-static_buffer_base::
-consume(std::size_t size)
-{
- if(size < in_size_)
- {
- in_off_ = (in_off_ + size) % capacity_;
- in_size_ -= size;
- }
- else
- {
- // rewind the offset, so the next call to prepare
- // can have a longer continguous segment. this helps
- // algorithms optimized for larger buffesr.
- in_off_ = 0;
- in_size_ = 0;
- }
-}
-
-inline
-void
-static_buffer_base::
-reset(void* p, std::size_t size)
-{
- begin_ = reinterpret_cast<char*>(p);
- capacity_ = size;
- in_off_ = 0;
- in_size_ = 0;
- out_size_ = 0;
-}
-
-//------------------------------------------------------------------------------
-
-template<std::size_t N>
-static_buffer<N>::
-static_buffer(static_buffer const& other)
- : static_buffer_base(buf_, N)
-{
- using boost::asio::buffer_copy;
- this->commit(buffer_copy(
- this->prepare(other.size()), other.data()));
-}
-
-template<std::size_t N>
-auto
-static_buffer<N>::
-operator=(static_buffer const& other) ->
- static_buffer<N>&
-{
- using boost::asio::buffer_copy;
- this->consume(this->size());
- this->commit(buffer_copy(
- this->prepare(other.size()), other.data()));
- return *this;
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/static_string.ipp b/contrib/restricted/boost/boost/beast/core/impl/static_string.ipp
deleted file mode 100644
index 29571dfeee..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/static_string.ipp
+++ /dev/null
@@ -1,618 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_IMPL_STATIC_STRING_IPP
-#define BOOST_BEAST_IMPL_STATIC_STRING_IPP
-
-#include <boost/beast/core/detail/static_string.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/throw_exception.hpp>
-
-namespace boost {
-namespace beast {
-
-//
-// (constructor)
-//
-
-template<std::size_t N, class CharT, class Traits>
-static_string<N, CharT, Traits>::
-static_string()
-{
- n_ = 0;
- term();
-}
-
-template<std::size_t N, class CharT, class Traits>
-static_string<N, CharT, Traits>::
-static_string(size_type count, CharT ch)
-{
- assign(count, ch);
-}
-
-template<std::size_t N, class CharT, class Traits>
-template<std::size_t M>
-static_string<N, CharT, Traits>::
-static_string(static_string<M, CharT, Traits> const& other,
- size_type pos)
-{
- assign(other, pos);
-}
-
-template<std::size_t N, class CharT, class Traits>
-template<std::size_t M>
-static_string<N, CharT, Traits>::
-static_string(static_string<M, CharT, Traits> const& other,
- size_type pos, size_type count)
-{
- assign(other, pos, count);
-}
-
-template<std::size_t N, class CharT, class Traits>
-static_string<N, CharT, Traits>::
-static_string(CharT const* s, size_type count)
-{
- assign(s, count);
-}
-
-template<std::size_t N, class CharT, class Traits>
-static_string<N, CharT, Traits>::
-static_string(CharT const* s)
-{
- assign(s);
-}
-
-template<std::size_t N, class CharT, class Traits>
-template<class InputIt>
-static_string<N, CharT, Traits>::
-static_string(InputIt first, InputIt last)
-{
- assign(first, last);
-}
-
-template<std::size_t N, class CharT, class Traits>
-static_string<N, CharT, Traits>::
-static_string(static_string const& s)
-{
- assign(s);
-}
-
-template<std::size_t N, class CharT, class Traits>
-template<std::size_t M>
-static_string<N, CharT, Traits>::
-static_string(static_string<M, CharT, Traits> const& s)
-{
- assign(s);
-}
-
-template<std::size_t N, class CharT, class Traits>
-static_string<N, CharT, Traits>::
-static_string(std::initializer_list<CharT> init)
-{
- assign(init.begin(), init.end());
-}
-
-template<std::size_t N, class CharT, class Traits>
-static_string<N, CharT, Traits>::
-static_string(string_view_type sv)
-{
- assign(sv);
-}
-
-template<std::size_t N, class CharT, class Traits>
-template<class T, class>
-static_string<N, CharT, Traits>::
-static_string(T const& t, size_type pos, size_type n)
-{
- assign(t, pos, n);
-}
-
-//
-// (assignment)
-//
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-assign(size_type count, CharT ch) ->
- static_string&
-{
- if(count > max_size())
- BOOST_THROW_EXCEPTION(std::length_error{
- "count > max_size()"});
- n_ = count;
- Traits::assign(&s_[0], n_, ch);
- term();
- return *this;
-}
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-assign(static_string const& str) ->
- static_string&
-{
- n_ = str.n_;
- Traits::copy(&s_[0], &str.s_[0], n_ + 1);
- return *this;
-}
-
-template<std::size_t N, class CharT, class Traits>
-template<std::size_t M>
-auto
-static_string<N, CharT, Traits>::
-assign(static_string<M, CharT, Traits> const& str,
- size_type pos, size_type count) ->
- static_string&
-{
- auto const ss = str.substr(pos, count);
- return assign(ss.data(), ss.size());
-}
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-assign(CharT const* s, size_type count) ->
- static_string&
-{
- if(count > max_size())
- BOOST_THROW_EXCEPTION(std::length_error{
- "count > max_size()"});
- n_ = count;
- Traits::copy(&s_[0], s, n_);
- term();
- return *this;
-}
-
-template<std::size_t N, class CharT, class Traits>
-template<class InputIt>
-auto
-static_string<N, CharT, Traits>::
-assign(InputIt first, InputIt last) ->
- static_string&
-{
- std::size_t const n = std::distance(first, last);
- if(n > max_size())
- BOOST_THROW_EXCEPTION(std::length_error{
- "n > max_size()"});
- n_ = n;
- for(auto it = &s_[0]; first != last; ++it, ++first)
- Traits::assign(*it, *first);
- term();
- return *this;
-}
-
-template<std::size_t N, class CharT, class Traits>
-template<class T>
-auto
-static_string<N, CharT, Traits>::
-assign(T const& t, size_type pos, size_type count) ->
- typename std::enable_if<std::is_convertible<T,
- string_view_type>::value, static_string&>::type
-{
- auto const sv = string_view_type(t).substr(pos, count);
- if(sv.size() > max_size())
- BOOST_THROW_EXCEPTION(std::length_error{
- "sv.size() > max_size()"});
- n_ = sv.size();
- Traits::copy(&s_[0], &sv[0], n_);
- term();
- return *this;
-}
-
-//
-// Element access
-//
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-at(size_type pos) ->
- reference
-{
- if(pos >= size())
- BOOST_THROW_EXCEPTION(std::out_of_range{
- "pos >= size()"});
- return s_[pos];
-}
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-at(size_type pos) const ->
- const_reference
-{
- if(pos >= size())
- BOOST_THROW_EXCEPTION(std::out_of_range{
- "pos >= size()"});
- return s_[pos];
-}
-
-//
-// Capacity
-//
-
-template<std::size_t N, class CharT, class Traits>
-void
-static_string<N, CharT, Traits>::
-reserve(std::size_t n)
-{
- if(n > max_size())
- BOOST_THROW_EXCEPTION(std::length_error{
- "n > max_size()"});
-}
-
-//
-// Operations
-//
-
-template<std::size_t N, class CharT, class Traits>
-void
-static_string<N, CharT, Traits>::
-clear()
-{
- n_ = 0;
- term();
-}
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-insert(size_type index, size_type count, CharT ch) ->
- static_string&
-{
- if(index > size())
- BOOST_THROW_EXCEPTION(std::out_of_range{
- "index > size()"});
- insert(begin() + index, count, ch);
- return *this;
-}
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-insert(size_type index, CharT const* s, size_type count) ->
- static_string&
-{
- if(index > size())
- BOOST_THROW_EXCEPTION(std::out_of_range{
- "index > size()"});
- if(size() + count > max_size())
- BOOST_THROW_EXCEPTION(std::length_error{
- "size() + count > max_size()"});
- Traits::move(
- &s_[index + count], &s_[index], size() - index);
- n_ += count;
- Traits::copy(&s_[index], s, count);
- term();
- return *this;
-}
-
-template<std::size_t N, class CharT, class Traits>
-template<std::size_t M>
-auto
-static_string<N, CharT, Traits>::
-insert(size_type index,
- static_string<M, CharT, Traits> const& str,
- size_type index_str, size_type count) ->
- static_string&
-{
- auto const ss = str.substr(index_str, count);
- return insert(index, ss.data(), ss.size());
-}
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-insert(const_iterator pos, size_type count, CharT ch) ->
- iterator
-{
- if(size() + count > max_size())
- BOOST_THROW_EXCEPTION(std::length_error{
- "size() + count() > max_size()"});
- auto const index = pos - &s_[0];
- Traits::move(
- &s_[index + count], &s_[index], size() - index);
- n_ += count;
- Traits::assign(&s_[index], count, ch);
- term();
- return &s_[index];
-}
-
-template<std::size_t N, class CharT, class Traits>
-template<class InputIt>
-auto
-static_string<N, CharT, Traits>::
-insert(const_iterator pos, InputIt first, InputIt last) ->
- typename std::enable_if<
- detail::is_input_iterator<InputIt>::value,
- iterator>::type
-{
- std::size_t const count = std::distance(first, last);
- if(size() + count > max_size())
- BOOST_THROW_EXCEPTION(std::length_error{
- "size() + count > max_size()"});
- std::size_t const index = pos - begin();
- Traits::move(
- &s_[index + count], &s_[index], size() - index);
- n_ += count;
- for(auto it = begin() + index;
- first != last; ++it, ++first)
- Traits::assign(*it, *first);
- term();
- return begin() + index;
-}
-
-template<std::size_t N, class CharT, class Traits>
-template<class T>
-auto
-static_string<N, CharT, Traits>::
-insert(size_type index, const T& t,
- size_type index_str, size_type count) ->
- typename std::enable_if<std::is_convertible<
- T const&, string_view_type>::value &&
- ! std::is_convertible<T const&, CharT const*>::value,
- static_string&>::type
-{
- auto const str =
- string_view_type(t).substr(index_str, count);
- return insert(index, str.data(), str.size());
-}
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-erase(size_type index, size_type count) ->
- static_string&
-{
- if(index > size())
- BOOST_THROW_EXCEPTION(std::out_of_range{
- "index > size()"});
- auto const n = (std::min)(count, size() - index);
- Traits::move(
- &s_[index], &s_[index + n], size() - (index + n) + 1);
- n_ -= n;
- return *this;
-}
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-erase(const_iterator pos) ->
- iterator
-{
- erase(pos - begin(), 1);
- return begin() + (pos - begin());
-}
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-erase(const_iterator first, const_iterator last) ->
- iterator
-{
- erase(first - begin(),
- std::distance(first, last));
- return begin() + (first - begin());
-}
-
-template<std::size_t N, class CharT, class Traits>
-void
-static_string<N, CharT, Traits>::
-push_back(CharT ch)
-{
- if(size() >= max_size())
- BOOST_THROW_EXCEPTION(std::length_error{
- "size() >= max_size()"});
- Traits::assign(s_[n_++], ch);
- term();
-}
-
-template<std::size_t N, class CharT, class Traits>
-template<std::size_t M>
-auto
-static_string<N, CharT, Traits>::
-append(static_string<M, CharT, Traits> const& str,
- size_type pos, size_type count) ->
- static_string&
-{
- // Valid range is [0, size)
- if(pos >= str.size())
- BOOST_THROW_EXCEPTION(std::out_of_range{
- "pos > str.size()"});
- string_view_type const ss{&str.s_[pos],
- (std::min)(count, str.size() - pos)};
- insert(size(), ss.data(), ss.size());
- return *this;
-}
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-substr(size_type pos, size_type count) const ->
- string_view_type
-{
- if(pos > size())
- BOOST_THROW_EXCEPTION(std::out_of_range{
- "pos > size()"});
- return{&s_[pos], (std::min)(count, size() - pos)};
-}
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-copy(CharT* dest, size_type count, size_type pos) const ->
- size_type
-{
- auto const str = substr(pos, count);
- Traits::copy(dest, str.data(), str.size());
- return str.size();
-}
-
-template<std::size_t N, class CharT, class Traits>
-void
-static_string<N, CharT, Traits>::
-resize(std::size_t n)
-{
- if(n > max_size())
- BOOST_THROW_EXCEPTION(std::length_error{
- "n > max_size()"});
- n_ = n;
- term();
-}
-
-template<std::size_t N, class CharT, class Traits>
-void
-static_string<N, CharT, Traits>::
-resize(std::size_t n, CharT c)
-{
- if(n > max_size())
- BOOST_THROW_EXCEPTION(std::length_error{
- "n > max_size()"});
- if(n > n_)
- Traits::assign(&s_[n_], n - n_, c);
- n_ = n;
- term();
-}
-
-template<std::size_t N, class CharT, class Traits>
-void
-static_string<N, CharT, Traits>::
-swap(static_string& str)
-{
- static_string tmp(str);
- str.n_ = n_;
- Traits::copy(&str.s_[0], &s_[0], n_ + 1);
- n_ = tmp.n_;
- Traits::copy(&s_[0], &tmp.s_[0], n_ + 1);
-}
-
-template<std::size_t N, class CharT, class Traits>
-template<std::size_t M>
-void
-static_string<N, CharT, Traits>::
-swap(static_string<M, CharT, Traits>& str)
-{
- if(size() > str.max_size())
- BOOST_THROW_EXCEPTION(std::length_error{
- "size() > str.max_size()"});
- if(str.size() > max_size())
- BOOST_THROW_EXCEPTION(std::length_error{
- "str.size() > max_size()"});
- static_string tmp(str);
- str.n_ = n_;
- Traits::copy(&str.s_[0], &s_[0], n_ + 1);
- n_ = tmp.n_;
- Traits::copy(&s_[0], &tmp.s_[0], n_ + 1);
-}
-
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-assign_char(CharT ch, std::true_type) ->
- static_string&
-{
- n_ = 1;
- Traits::assign(s_[0], ch);
- term();
- return *this;
-}
-
-template<std::size_t N, class CharT, class Traits>
-auto
-static_string<N, CharT, Traits>::
-assign_char(CharT, std::false_type) ->
- static_string&
-{
- BOOST_THROW_EXCEPTION(std::length_error{
- "max_size() == 0"});
-}
-
-namespace detail {
-
-template<class Integer>
-static_string<max_digits(sizeof(Integer))>
-to_static_string(Integer x, std::true_type)
-{
- if(x == 0)
- return {'0'};
- static_string<detail::max_digits(
- sizeof(Integer))> s;
- if(x < 0)
- {
- x = -x;
- char buf[max_digits(sizeof(x))];
- char* p = buf;
- for(;x > 0; x /= 10)
- *p++ = "0123456789"[x % 10];
- s.resize(1 + p - buf);
- s[0] = '-';
- auto d = &s[1];
- while(p > buf)
- *d++ = *--p;
- }
- else
- {
- char buf[max_digits(sizeof(x))];
- char* p = buf;
- for(;x > 0; x /= 10)
- *p++ = "0123456789"[x % 10];
- s.resize(p - buf);
- auto d = &s[0];
- while(p > buf)
- *d++ = *--p;
- }
- return s;
-}
-
-template<class Integer>
-static_string<max_digits(sizeof(Integer))>
-to_static_string(Integer x, std::false_type)
-{
- if(x == 0)
- return {'0'};
- char buf[max_digits(sizeof(x))];
- char* p = buf;
- for(;x > 0; x /= 10)
- *p++ = "0123456789"[x % 10];
- static_string<detail::max_digits(
- sizeof(Integer))> s;
- s.resize(p - buf);
- auto d = &s[0];
- while(p > buf)
- *d++ = *--p;
- return s;
-}
-
-} // detail
-
-template<class Integer>
-static_string<detail::max_digits(sizeof(Integer))>
-to_static_string(Integer x)
-{
- using CharT = char;
- using Traits = std::char_traits<CharT>;
- BOOST_STATIC_ASSERT(std::is_integral<Integer>::value);
- char buf[detail::max_digits(sizeof(Integer))];
- auto last = buf + sizeof(buf);
- auto it = detail::raw_to_string<
- CharT, Integer, Traits>(last, sizeof(buf), x);
- static_string<detail::max_digits(sizeof(Integer))> s;
- s.resize(static_cast<std::size_t>(last - it));
- auto p = s.data();
- while(it < last)
- Traits::assign(*p++, *it++);
- return s;
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/impl/string_param.ipp b/contrib/restricted/boost/boost/beast/core/impl/string_param.ipp
deleted file mode 100644
index a60771cc12..0000000000
--- a/contrib/restricted/boost/boost/beast/core/impl/string_param.ipp
+++ /dev/null
@@ -1,108 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_IMPL_STRING_PARAM_IPP
-#define BOOST_BEAST_IMPL_STRING_PARAM_IPP
-
-namespace boost {
-namespace beast {
-
-template<class T>
-typename std::enable_if<
- std::is_integral<T>::value>::type
-string_param::
-print(T const& t)
-{
- auto const last = buf_ + sizeof(buf_);
- auto const it = detail::raw_to_string<
- char, T, std::char_traits<char>>(
- last, sizeof(buf_), t);
- sv_ = {it, static_cast<std::size_t>(
- last - it)};
-}
-
-template<class T>
-typename std::enable_if<
- ! std::is_integral<T>::value &&
- ! std::is_convertible<T, string_view>::value
->::type
-string_param::
-print(T const& t)
-{
- os_.emplace(buf_, sizeof(buf_));
- *os_ << t;
- os_->flush();
- sv_ = os_->str();
-}
-
-inline
-void
-string_param::
-print(string_view sv)
-{
- sv_ = sv;
-}
-
-template<class T>
-typename std::enable_if<
- std::is_integral<T>::value>::type
-string_param::
-print_1(T const& t)
-{
- char buf[detail::max_digits(sizeof(T))];
- auto const last = buf + sizeof(buf);
- auto const it = detail::raw_to_string<
- char, T, std::char_traits<char>>(
- last, sizeof(buf), t);
- *os_ << string_view{it,
- static_cast<std::size_t>(last - it)};
-}
-
-template<class T>
-typename std::enable_if<
- ! std::is_integral<T>::value>::type
-string_param::
-print_1(T const& t)
-{
- *os_ << t;
-}
-
-template<class T0, class... TN>
-void
-string_param::
-print_n(T0 const& t0, TN const&... tn)
-{
- print_1(t0);
- print_n(tn...);
-}
-
-template<class T0, class T1, class... TN>
-void
-string_param::
-print(T0 const& t0, T1 const& t1, TN const&... tn)
-{
- os_.emplace(buf_, sizeof(buf_));
- print_1(t0);
- print_1(t1);
- print_n(tn...);
- os_->flush();
- sv_ = os_->str();
-}
-
-template<class... Args>
-string_param::
-string_param(Args const&... args)
-{
- print(args...);
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/multi_buffer.hpp b/contrib/restricted/boost/boost/beast/core/multi_buffer.hpp
deleted file mode 100644
index ee14b419a5..0000000000
--- a/contrib/restricted/boost/boost/beast/core/multi_buffer.hpp
+++ /dev/null
@@ -1,322 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_MULTI_BUFFER_HPP
-#define BOOST_BEAST_MULTI_BUFFER_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/detail/allocator.hpp>
-#include <boost/beast/core/detail/empty_base_optimization.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/intrusive/list.hpp>
-#include <iterator>
-#include <limits>
-#include <memory>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-
-/** A @b DynamicBuffer that uses multiple buffers internally.
-
- The implementation uses a sequence of one or more character arrays
- of varying sizes. Additional character array objects are appended to
- the sequence to accommodate changes in the size of the character
- sequence.
-
- @note Meets the requirements of @b DynamicBuffer.
-
- @tparam Allocator The allocator to use for managing memory.
-*/
-template<class Allocator>
-class basic_multi_buffer
-#if ! BOOST_BEAST_DOXYGEN
- : private detail::empty_base_optimization<
- typename detail::allocator_traits<Allocator>::
- template rebind_alloc<char>>
-#endif
-{
- using base_alloc_type = typename
- detail::allocator_traits<Allocator>::
- template rebind_alloc<char>;
-
- // Storage for the list of buffers representing the input
- // and output sequences. The allocation for each element
- // contains `element` followed by raw storage bytes.
- class element;
-
- using alloc_traits = detail::allocator_traits<base_alloc_type>;
- using list_type = typename boost::intrusive::make_list<element,
- boost::intrusive::constant_time_size<true>>::type;
- using iter = typename list_type::iterator;
- using const_iter = typename list_type::const_iterator;
-
- using size_type = typename alloc_traits::size_type;
- using const_buffer = boost::asio::const_buffer;
- using mutable_buffer = boost::asio::mutable_buffer;
-
- static_assert(std::is_base_of<std::bidirectional_iterator_tag,
- typename std::iterator_traits<iter>::iterator_category>::value,
- "BidirectionalIterator requirements not met");
-
- static_assert(std::is_base_of<std::bidirectional_iterator_tag,
- typename std::iterator_traits<const_iter>::iterator_category>::value,
- "BidirectionalIterator requirements not met");
-
- std::size_t max_ =
- (std::numeric_limits<std::size_t>::max)();
- list_type list_; // list of allocated buffers
- iter out_; // element that contains out_pos_
- size_type in_size_ = 0; // size of the input sequence
- size_type in_pos_ = 0; // input offset in list_.front()
- size_type out_pos_ = 0; // output offset in *out_
- size_type out_end_ = 0; // output end offset in list_.back()
-
-public:
- /// The type of allocator used.
- using allocator_type = Allocator;
-
-#if BOOST_BEAST_DOXYGEN
- /// The type used to represent the input sequence as a list of buffers.
- using const_buffers_type = implementation_defined;
-
- /// The type used to represent the output sequence as a list of buffers.
- using mutable_buffers_type = implementation_defined;
-
-#else
- class const_buffers_type;
-
- class mutable_buffers_type;
-
-#endif
-
- /// Destructor
- ~basic_multi_buffer();
-
- /** Constructor
-
- Upon construction, capacity will be zero.
- */
- basic_multi_buffer();
-
- /** Constructor.
-
- @param limit The setting for @ref max_size.
- */
- explicit
- basic_multi_buffer(std::size_t limit);
-
- /** Constructor.
-
- @param alloc The allocator to use.
- */
- explicit
- basic_multi_buffer(Allocator const& alloc);
-
- /** Constructor.
-
- @param limit The setting for @ref max_size.
-
- @param alloc The allocator to use.
- */
- basic_multi_buffer(
- std::size_t limit, Allocator const& alloc);
-
- /** Move constructor
-
- After the move, `*this` will have an empty output sequence.
-
- @param other The object to move from. After the move,
- The object's state will be as if constructed using
- its current allocator and limit.
- */
- basic_multi_buffer(basic_multi_buffer&& other);
-
- /** Move constructor
-
- After the move, `*this` will have an empty output sequence.
-
- @param other The object to move from. After the move,
- The object's state will be as if constructed using
- its current allocator and limit.
-
- @param alloc The allocator to use.
- */
- basic_multi_buffer(basic_multi_buffer&& other,
- Allocator const& alloc);
-
- /** Copy constructor.
-
- @param other The object to copy from.
- */
- basic_multi_buffer(basic_multi_buffer const& other);
-
- /** Copy constructor
-
- @param other The object to copy from.
-
- @param alloc The allocator to use.
- */
- basic_multi_buffer(basic_multi_buffer const& other,
- Allocator const& alloc);
-
- /** Copy constructor.
-
- @param other The object to copy from.
- */
- template<class OtherAlloc>
- basic_multi_buffer(basic_multi_buffer<
- OtherAlloc> const& other);
-
- /** Copy constructor.
-
- @param other The object to copy from.
-
- @param alloc The allocator to use.
- */
- template<class OtherAlloc>
- basic_multi_buffer(basic_multi_buffer<
- OtherAlloc> const& other, allocator_type const& alloc);
-
- /** Move assignment
-
- After the move, `*this` will have an empty output sequence.
-
- @param other The object to move from. After the move,
- The object's state will be as if constructed using
- its current allocator and limit.
- */
- basic_multi_buffer&
- operator=(basic_multi_buffer&& other);
-
- /** Copy assignment
-
- After the copy, `*this` will have an empty output sequence.
-
- @param other The object to copy from.
- */
- basic_multi_buffer& operator=(basic_multi_buffer const& other);
-
- /** Copy assignment
-
- After the copy, `*this` will have an empty output sequence.
-
- @param other The object to copy from.
- */
- template<class OtherAlloc>
- basic_multi_buffer& operator=(
- basic_multi_buffer<OtherAlloc> const& other);
-
- /// Returns a copy of the associated allocator.
- allocator_type
- get_allocator() const
- {
- return this->member();
- }
-
- /// Returns the size of the input sequence.
- size_type
- size() const
- {
- return in_size_;
- }
-
- /// Returns the permitted maximum sum of the sizes of the input and output sequence.
- size_type
- max_size() const
- {
- return max_;
- }
-
- /// Returns the maximum sum of the sizes of the input sequence and output sequence the buffer can hold without requiring reallocation.
- std::size_t
- capacity() const;
-
- /** Get a list of buffers that represents the input sequence.
-
- @note These buffers remain valid across subsequent calls to `prepare`.
- */
- const_buffers_type
- data() const;
-
- /** Get a list of buffers that represents the output sequence, with the given size.
-
- @note Buffers representing the input sequence acquired prior to
- this call remain valid.
- */
- mutable_buffers_type
- prepare(size_type n);
-
- /** Move bytes from the output sequence to the input sequence.
-
- @note Buffers representing the input sequence acquired prior to
- this call remain valid.
- */
- void
- commit(size_type n);
-
- /// Remove bytes from the input sequence.
- void
- consume(size_type n);
-
- template<class Alloc>
- friend
- void
- swap(
- basic_multi_buffer<Alloc>& lhs,
- basic_multi_buffer<Alloc>& rhs);
-
-private:
- template<class OtherAlloc>
- friend class basic_multi_buffer;
-
- void
- delete_list();
-
- void
- reset();
-
- template<class DynamicBuffer>
- void
- copy_from(DynamicBuffer const& other);
-
- void
- move_assign(basic_multi_buffer& other, std::false_type);
-
- void
- move_assign(basic_multi_buffer& other, std::true_type);
-
- void
- copy_assign(basic_multi_buffer const& other, std::false_type);
-
- void
- copy_assign(basic_multi_buffer const& other, std::true_type);
-
- void
- swap(basic_multi_buffer&);
-
- void
- swap(basic_multi_buffer&, std::true_type);
-
- void
- swap(basic_multi_buffer&, std::false_type);
-
- void
- debug_check() const;
-};
-
-/// A typical multi buffer
-using multi_buffer = basic_multi_buffer<std::allocator<char>>;
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/multi_buffer.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/ostream.hpp b/contrib/restricted/boost/boost/beast/core/ostream.hpp
deleted file mode 100644
index 1f00289bd1..0000000000
--- a/contrib/restricted/boost/boost/beast/core/ostream.hpp
+++ /dev/null
@@ -1,104 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WRITE_OSTREAM_HPP
-#define BOOST_BEAST_WRITE_OSTREAM_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/core/detail/ostream.hpp>
-#include <type_traits>
-#include <streambuf>
-#include <utility>
-
-namespace boost {
-namespace beast {
-
-/** Return an object representing a @b ConstBufferSequence.
-
- This function wraps a reference to a buffer sequence and permits
- the following operation:
-
- @li `operator<<` to `std::ostream`. No character translation is
- performed; unprintable and null characters will be transferred
- as-is to the output stream.
-
- @par Example
- @code
- multi_buffer b;
- ...
- std::cout << buffers(b.data()) << std::endl;
- @endcode
-
- @param b An object meeting the requirements of @b ConstBufferSequence
- to be streamed. The implementation will make a copy of this object.
- Ownership of the underlying memory is not transferred, the application
- is still responsible for managing its lifetime.
-*/
-template<class ConstBufferSequence>
-#if BOOST_BEAST_DOXYGEN
-implementation_defined
-#else
-detail::buffers_helper<ConstBufferSequence>
-#endif
-buffers(ConstBufferSequence const& b)
-{
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- return detail::buffers_helper<
- ConstBufferSequence>{b};
-}
-
-/** Return an output stream that formats values into a @b DynamicBuffer.
-
- This function wraps the caller provided @b DynamicBuffer into
- a `std::ostream` derived class, to allow `operator<<` stream style
- formatting operations.
-
- @par Example
- @code
- ostream(buffer) << "Hello, world!" << std::endl;
- @endcode
-
- @note Calling members of the underlying buffer before the output
- stream is destroyed results in undefined behavior.
-
- @param buffer An object meeting the requirements of @b DynamicBuffer
- into which the formatted output will be placed.
-
- @return An object derived from `std::ostream` which redirects output
- The wrapped dynamic buffer is not modified, a copy is made instead.
- Ownership of the underlying memory is not transferred, the application
- is still responsible for managing its lifetime. The caller is
- responsible for ensuring the dynamic buffer is not destroyed for the
- lifetime of the output stream.
-*/
-template<class DynamicBuffer>
-#if BOOST_BEAST_DOXYGEN
-implementation_defined
-#else
-detail::ostream_helper<
- DynamicBuffer, char, std::char_traits<char>,
- detail::basic_streambuf_movable::value>
-#endif
-ostream(DynamicBuffer& buffer)
-{
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- return detail::ostream_helper<
- DynamicBuffer, char, std::char_traits<char>,
- detail::basic_streambuf_movable::value>{buffer};
-}
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/read_size.hpp b/contrib/restricted/boost/boost/beast/core/read_size.hpp
deleted file mode 100644
index d9aaaa61ab..0000000000
--- a/contrib/restricted/boost/boost/beast/core/read_size.hpp
+++ /dev/null
@@ -1,64 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_READ_SIZE_HELPER_HPP
-#define BOOST_BEAST_READ_SIZE_HELPER_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/throw_exception.hpp>
-
-namespace boost {
-namespace beast {
-
-/** Returns a natural read size.
-
- This function inspects the capacity, size, and maximum
- size of the dynamic buffer. Then it computes a natural
- read size given the passed-in upper limit. It favors
- a read size that does not require a reallocation, subject
- to a reasonable minimum to avoid tiny reads.
-
- @param buffer The dynamic buffer to inspect.
-
- @param max_size An upper limit on the returned value.
-
- @note If the buffer is already at its maximum size, zero
- is returned.
-*/
-template<class DynamicBuffer>
-std::size_t
-read_size(DynamicBuffer& buffer, std::size_t max_size);
-
-/** Returns a natural read size or throw if the buffer is full.
-
- This function inspects the capacity, size, and maximum
- size of the dynamic buffer. Then it computes a natural
- read size given the passed-in upper limit. It favors
- a read size that does not require a reallocation, subject
- to a reasonable minimum to avoid tiny reads.
-
- @param buffer The dynamic buffer to inspect.
-
- @param max_size An upper limit on the returned value.
-
- @throws std::length_error if `max_size > 0` and the buffer
- is full.
-*/
-template<class DynamicBuffer>
-std::size_t
-read_size_or_throw(DynamicBuffer& buffer,
- std::size_t max_size);
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/read_size.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/span.hpp b/contrib/restricted/boost/boost/beast/core/span.hpp
deleted file mode 100644
index 4aa7788501..0000000000
--- a/contrib/restricted/boost/boost/beast/core/span.hpp
+++ /dev/null
@@ -1,215 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_CORE_SPAN_HPP
-#define BOOST_BEAST_CORE_SPAN_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <algorithm>
-#include <iterator>
-#include <string>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-
-/** A range of bytes expressed as a ContiguousContainer
-
- This class implements a non-owning reference to a storage
- area of a certain size and having an underlying integral
- type with size of 1.
-
- @tparam T The type pointed to by span iterators
-*/
-template<class T>
-class span
-{
- T* data_ = nullptr;
- std::size_t size_ = 0;
-
-public:
- /// The type of value, including cv qualifiers
- using element_type = T;
-
- /// The type of value of each span element
- using value_type = typename std::remove_const<T>::type;
-
- /// The type of integer used to index the span
- using index_type = std::ptrdiff_t;
-
- /// A pointer to a span element
- using pointer = T*;
-
- /// A reference to a span element
- using reference = T&;
-
- /// The iterator used by the container
- using iterator = pointer;
-
- /// The const pointer used by the container
- using const_pointer = T const*;
-
- /// The const reference used by the container
- using const_reference = T const&;
-
- /// The const iterator used by the container
- using const_iterator = const_pointer;
-
- /// Constructor
- span() = default;
-
- /// Constructor
- span(span const&) = default;
-
- /// Assignment
- span& operator=(span const&) = default;
-
- /** Constructor
-
- @param data A pointer to the beginning of the range of elements
-
- @param size The number of elements pointed to by `data`
- */
- span(T* data, std::size_t size)
- : data_(data), size_(size)
- {
- }
-
- /** Constructor
-
- @param container The container to construct from
- */
- template<class ContiguousContainer
-#if ! BOOST_BEAST_DOXYGEN
- , class = typename std::enable_if<
- detail::is_contiguous_container<
- ContiguousContainer, T>::value>::type
-#endif
- >
- explicit
- span(ContiguousContainer&& container)
- : data_(container.data())
- , size_(container.size())
- {
- }
-
-#if ! BOOST_BEAST_DOXYGEN
- template<class CharT, class Traits, class Allocator>
- explicit
- span(std::basic_string<CharT, Traits, Allocator>& s)
- : data_(&s[0])
- , size_(s.size())
- {
- }
-
- template<class CharT, class Traits, class Allocator>
- explicit
- span(std::basic_string<CharT, Traits, Allocator> const& s)
- : data_(s.data())
- , size_(s.size())
- {
- }
-#endif
-
- /** Assignment
-
- @param container The container to assign from
- */
- template<class ContiguousContainer>
-#if BOOST_BEAST_DOXYGEN
- span&
-#else
- typename std::enable_if<detail::is_contiguous_container<
- ContiguousContainer, T>::value,
- span&>::type
-#endif
- operator=(ContiguousContainer&& container)
- {
- data_ = container.data();
- size_ = container.size();
- return *this;
- }
-
-#if ! BOOST_BEAST_DOXYGEN
- template<class CharT, class Traits, class Allocator>
- span&
- operator=(std::basic_string<
- CharT, Traits, Allocator>& s)
- {
- data_ = &s[0];
- size_ = s.size();
- return *this;
- }
-
- template<class CharT, class Traits, class Allocator>
- span&
- operator=(std::basic_string<
- CharT, Traits, Allocator> const& s)
- {
- data_ = s.data();
- size_ = s.size();
- return *this;
- }
-#endif
-
- /// Returns `true` if the span is empty
- bool
- empty() const
- {
- return size_ == 0;
- }
-
- /// Returns a pointer to the beginning of the span
- T*
- data() const
- {
- return data_;
- }
-
- /// Returns the number of elements in the span
- std::size_t
- size() const
- {
- return size_;
- }
-
- /// Returns an iterator to the beginning of the span
- const_iterator
- begin() const
- {
- return data_;
- }
-
- /// Returns an iterator to the beginning of the span
- const_iterator
- cbegin() const
- {
- return data_;
- }
-
- /// Returns an iterator to one past the end of the span
- const_iterator
- end() const
- {
- return data_ + size_;
- }
-
- /// Returns an iterator to one past the end of the span
- const_iterator
- cend() const
- {
- return data_ + size_;
- }
-};
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/static_buffer.hpp b/contrib/restricted/boost/boost/beast/core/static_buffer.hpp
deleted file mode 100644
index 86f06b1efd..0000000000
--- a/contrib/restricted/boost/boost/beast/core/static_buffer.hpp
+++ /dev/null
@@ -1,222 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_STATIC_BUFFER_HPP
-#define BOOST_BEAST_STATIC_BUFFER_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/asio/buffer.hpp>
-#include <algorithm>
-#include <array>
-#include <cstddef>
-#include <cstring>
-
-namespace boost {
-namespace beast {
-
-/** A circular @b DynamicBuffer with a fixed size internal buffer.
-
- This implements a circular dynamic buffer. Calls to @ref prepare
- never require moving memory. The buffer sequences returned may
- be up to length two.
- Ownership of the underlying storage belongs to the derived class.
-
- @note Variables are usually declared using the template class
- @ref static_buffer; however, to reduce the number of instantiations
- of template functions receiving static stream buffer arguments in a
- deduced context, the signature of the receiving function should use
- @ref static_buffer_base.
-
- When used with @ref static_buffer this implements a dynamic
- buffer using no memory allocations.
-
- @see @ref static_buffer
-*/
-class static_buffer_base
-{
- char* begin_;
- std::size_t in_off_ = 0;
- std::size_t in_size_ = 0;
- std::size_t out_size_ = 0;
- std::size_t capacity_;
-
- static_buffer_base(static_buffer_base const& other) = delete;
- static_buffer_base& operator=(static_buffer_base const&) = delete;
-
-public:
- /// The type used to represent the input sequence as a list of buffers.
- using const_buffers_type =
- std::array<boost::asio::const_buffer, 2>;
-
- /// The type used to represent the output sequence as a list of buffers.
- using mutable_buffers_type =
- std::array<boost::asio::mutable_buffer, 2>;
-
- /** Constructor
-
- This creates a dynamic buffer using the provided storage area.
-
- @param p A pointer to valid storage of at least `n` bytes.
-
- @param size The number of valid bytes pointed to by `p`.
- */
- static_buffer_base(void* p, std::size_t size);
-
- /// Return the size of the input sequence.
- std::size_t
- size() const
- {
- return in_size_;
- }
-
- /// Return the maximum sum of the input and output sequence sizes.
- std::size_t
- max_size() const
- {
- return capacity_;
- }
-
- /// Return the maximum sum of input and output sizes that can be held without an allocation.
- std::size_t
- capacity() const
- {
- return capacity_;
- }
-
- /** Get a list of buffers that represent the input sequence.
- */
- const_buffers_type
- data() const;
-
- /** Get a mutable list of buffers that represent the input sequence.
- */
- mutable_buffers_type
- mutable_data();
-
- /** Get a list of buffers that represent the output sequence, with the given size.
-
- @param size The number of bytes to request.
-
- @throws std::length_error if the size would exceed the capacity.
- */
- mutable_buffers_type
- prepare(std::size_t size);
-
- /** Move bytes from the output sequence to the input sequence.
-
- @param size The nubmer of bytes to commit. If this is greater
- than the size of the output sequence, the entire output
- sequence is committed.
- */
- void
- commit(std::size_t size);
-
- /** Remove bytes from the input sequence.
-
- @param size The number of bytes to consume. If this is greater
- than the size of the input sequence, the entire input sequence
- is consumed.
- */
- void
- consume(std::size_t size);
-
-protected:
- /** Constructor
-
- The buffer will be in an undefined state. It is necessary
- for the derived class to call @ref reset in order to
- initialize the object.
- */
- static_buffer_base() = default;
-
- /** Reset the pointed-to buffer.
-
- This function resets the internal state to the buffer provided.
- All input and output sequences are invalidated. This function
- allows the derived class to construct its members before
- initializing the static buffer.
-
- @param p A pointer to valid storage of at least `n` bytes.
-
- @param size The number of valid bytes pointed to by `p`.
- */
- void
- reset(void* p, std::size_t size);
-};
-
-//------------------------------------------------------------------------------
-
-/** A circular @b DynamicBuffer with a fixed size internal buffer.
-
- This implements a circular dynamic buffer. Calls to @ref prepare
- never require moving memory. The buffer sequences returned may
- be up to length two.
- Ownership of the underlying storage belongs to the derived class.
-
- @tparam N The number of bytes in the internal buffer.
-
- @note To reduce the number of template instantiations when passing
- objects of this type in a deduced context, the signature of the
- receiving function should use @ref static_buffer_base instead.
-
- @see @ref static_buffer_base
-*/
-template<std::size_t N>
-class static_buffer : public static_buffer_base
-{
- char buf_[N];
-
-public:
- /// Constructor
- static_buffer(static_buffer const&);
-
- /// Constructor
- static_buffer()
- : static_buffer_base(buf_, N)
- {
- }
-
- /// Assignment
- static_buffer& operator=(static_buffer const&);
-
- /// Returns the @ref static_buffer_base portion of this object
- static_buffer_base&
- base()
- {
- return *this;
- }
-
- /// Returns the @ref static_buffer_base portion of this object
- static_buffer_base const&
- base() const
- {
- return *this;
- }
-
- /// Return the maximum sum of the input and output sequence sizes.
- std::size_t constexpr
- max_size() const
- {
- return N;
- }
-
- /// Return the maximum sum of input and output sizes that can be held without an allocation.
- std::size_t constexpr
- capacity() const
- {
- return N;
- }
-};
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/static_buffer.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/static_string.hpp b/contrib/restricted/boost/boost/beast/core/static_string.hpp
deleted file mode 100644
index 991c2e64a5..0000000000
--- a/contrib/restricted/boost/boost/beast/core/static_string.hpp
+++ /dev/null
@@ -1,1112 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_STATIC_STRING_HPP
-#define BOOST_BEAST_STATIC_STRING_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/core/detail/static_string.hpp>
-#include <algorithm>
-#include <cstdint>
-#include <initializer_list>
-#include <iterator>
-#include <ostream>
-#include <stdexcept>
-#include <string>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-
-/** A modifiable string with a fixed-size storage area.
-
- These objects behave like `std::string` except that the storage
- is not dynamically allocated but rather fixed in size.
-
- These strings offer performance advantages when a protocol
- imposes a natural small upper limit on the size of a value.
-
- @note The stored string is always null-terminated.
-
- @see @ref to_static_string
-*/
-template<
- std::size_t N,
- class CharT = char,
- class Traits = std::char_traits<CharT>>
-class static_string
-{
- template<std::size_t, class, class>
- friend class static_string;
-
- void
- term()
- {
- Traits::assign(s_[n_], 0);
- }
-
- std::size_t n_;
- CharT s_[N+1];
-
-public:
- //
- // Member types
- //
-
- using traits_type = Traits;
- using value_type = typename Traits::char_type;
- using size_type = std::size_t;
- using difference_type = std::ptrdiff_t;
- using pointer = value_type*;
- using reference = value_type&;
- using const_pointer = value_type const*;
- using const_reference = value_type const&;
- using iterator = value_type*;
- using const_iterator = value_type const*;
- using reverse_iterator =
- std::reverse_iterator<iterator>;
- using const_reverse_iterator =
- std::reverse_iterator<const_iterator>;
-
- /// The type of `string_view` returned by the interface
- using string_view_type =
- basic_string_view<CharT, Traits>;
-
- //
- // Constants
- //
-
- /// Maximum size of the string excluding the null terminator
- static std::size_t constexpr max_size_n = N;
-
- /// A special index
- static constexpr size_type npos = size_type(-1);
-
- //
- // (constructor)
- //
-
- /// Default constructor (empty string).
- static_string();
-
- /** Construct with count copies of character `ch`.
-
- The behavior is undefined if `count >= npos`
- */
- static_string(size_type count, CharT ch);
-
- /// Construct with a substring (pos, other.size()) of `other`.
- template<std::size_t M>
- static_string(static_string<M, CharT, Traits> const& other,
- size_type pos);
-
- /// Construct with a substring (pos, count) of `other`.
- template<std::size_t M>
- static_string(static_string<M, CharT, Traits> const& other,
- size_type pos, size_type count);
-
- /// Construct with the first `count` characters of `s`, including nulls.
- static_string(CharT const* s, size_type count);
-
- /// Construct from a null terminated string.
- static_string(CharT const* s);
-
- /// Construct from a range of characters
- template<class InputIt>
- static_string(InputIt first, InputIt last);
-
- /// Copy constructor.
- static_string(static_string const& other);
-
- /// Copy constructor.
- template<std::size_t M>
- static_string(static_string<M, CharT, Traits> const& other);
-
- /// Construct from an initializer list
- static_string(std::initializer_list<CharT> init);
-
- /// Construct from a `string_view`
- explicit
- static_string(string_view_type sv);
-
- /** Construct from any object convertible to `string_view_type`.
-
- The range (pos, n) is extracted from the value
- obtained by converting `t` to `string_view_type`,
- and used to construct the string.
- */
-#if BOOST_BEAST_DOXYGEN
- template<class T>
-#else
- template<class T, class = typename std::enable_if<
- std::is_convertible<T, string_view_type>::value>::type>
-#endif
- static_string(T const& t, size_type pos, size_type n);
-
- //
- // (assignment)
- //
-
- /// Copy assignment.
- static_string&
- operator=(static_string const& str)
- {
- return assign(str);
- }
-
- /// Copy assignment.
- template<std::size_t M>
- static_string&
- operator=(static_string<M, CharT, Traits> const& str)
- {
- return assign(str);
- }
-
- /// Assign from null-terminated string.
- static_string&
- operator=(CharT const* s)
- {
- return assign(s);
- }
-
- /// Assign from single character.
- static_string&
- operator=(CharT ch)
- {
- return assign_char(ch,
- std::integral_constant<bool, (N>0)>{});
- }
-
- /// Assign from initializer list.
- static_string&
- operator=(std::initializer_list<CharT> init)
- {
- return assign(init);
- }
-
- /// Assign from `string_view_type`.
- static_string&
- operator=(string_view_type sv)
- {
- return assign(sv);
- }
-
- /// Assign `count` copies of `ch`.
- static_string&
- assign(size_type count, CharT ch);
-
- /// Assign from another `static_string`
- static_string&
- assign(static_string const& str);
-
- // VFALCO NOTE this could come in two flavors,
- // N>M and N<M, and skip the exception
- // check when N>M
-
- /// Assign from another `static_string`
- template<std::size_t M>
- static_string&
- assign(static_string<M, CharT, Traits> const& str)
- {
- return assign(str.data(), str.size());
- }
-
- /// Assign `count` characterss starting at `npos` from `other`.
- template<std::size_t M>
- static_string&
- assign(static_string<M, CharT, Traits> const& str,
- size_type pos, size_type count = npos);
-
- /// Assign the first `count` characters of `s`, including nulls.
- static_string&
- assign(CharT const* s, size_type count);
-
- /// Assign a null terminated string.
- static_string&
- assign(CharT const* s)
- {
- return assign(s, Traits::length(s));
- }
-
- /// Assign from an iterator range of characters.
- template<class InputIt>
- static_string&
- assign(InputIt first, InputIt last);
-
- /// Assign from initializer list.
- static_string&
- assign(std::initializer_list<CharT> init)
- {
- return assign(init.begin(), init.end());
- }
-
- /// Assign from `string_view_type`.
- static_string&
- assign(string_view_type str)
- {
- return assign(str.data(), str.size());
- }
-
- /** Assign from any object convertible to `string_view_type`.
-
- The range (pos, n) is extracted from the value
- obtained by converting `t` to `string_view_type`,
- and used to assign the string.
- */
- template<class T>
-#if BOOST_BEAST_DOXYGEN
- static_string&
-#else
- typename std::enable_if<std::is_convertible<T,
- string_view_type>::value, static_string&>::type
-#endif
- assign(T const& t,
- size_type pos, size_type count = npos);
-
- //
- // Element access
- //
-
- /// Access specified character with bounds checking.
- reference
- at(size_type pos);
-
- /// Access specified character with bounds checking.
- const_reference
- at(size_type pos) const;
-
- /// Access specified character.
- reference
- operator[](size_type pos)
- {
- return s_[pos];
- }
-
- /// Access specified character.
- const_reference
- operator[](size_type pos) const
- {
- return s_[pos];
- }
-
- /// Accesses the first character.
- CharT&
- front()
- {
- return s_[0];
- }
-
- /// Accesses the first character.
- CharT const&
- front() const
- {
- return s_[0];
- }
-
- /// Accesses the last character.
- CharT&
- back()
- {
- return s_[n_-1];
- }
-
- /// Accesses the last character.
- CharT const&
- back() const
- {
- return s_[n_-1];
- }
-
- /// Returns a pointer to the first character of a string.
- CharT*
- data()
- {
- return &s_[0];
- }
-
- /// Returns a pointer to the first character of a string.
- CharT const*
- data() const
- {
- return &s_[0];
- }
-
- /// Returns a non-modifiable standard C character array version of the string.
- CharT const*
- c_str() const
- {
- return data();
- }
-
- /// Convert a static string to a `string_view_type`
- operator string_view_type() const
- {
- return basic_string_view<
- CharT, Traits>{data(), size()};
- }
-
- //
- // Iterators
- //
-
- /// Returns an iterator to the beginning.
- iterator
- begin()
- {
- return &s_[0];
- }
-
- /// Returns an iterator to the beginning.
- const_iterator
- begin() const
- {
- return &s_[0];
- }
-
- /// Returns an iterator to the beginning.
- const_iterator
- cbegin() const
- {
- return &s_[0];
- }
-
- /// Returns an iterator to the end.
- iterator
- end()
- {
- return &s_[n_];
- }
-
- /// Returns an iterator to the end.
- const_iterator
- end() const
- {
- return &s_[n_];
- }
-
- /// Returns an iterator to the end.
- const_iterator
- cend() const
- {
- return &s_[n_];
- }
-
- /// Returns a reverse iterator to the beginning.
- reverse_iterator
- rbegin()
- {
- return reverse_iterator{end()};
- }
-
- /// Returns a reverse iterator to the beginning.
- const_reverse_iterator
- rbegin() const
- {
- return const_reverse_iterator{cend()};
- }
-
- /// Returns a reverse iterator to the beginning.
- const_reverse_iterator
- crbegin() const
- {
- return const_reverse_iterator{cend()};
- }
-
- /// Returns a reverse iterator to the end.
- reverse_iterator
- rend()
- {
- return reverse_iterator{begin()};
- }
-
- /// Returns a reverse iterator to the end.
- const_reverse_iterator
- rend() const
- {
- return const_reverse_iterator{cbegin()};
- }
-
- /// Returns a reverse iterator to the end.
- const_reverse_iterator
- crend() const
- {
- return const_reverse_iterator{cbegin()};
- }
-
- //
- // Capacity
- //
-
- /// Returns `true` if the string is empty.
- bool
- empty() const
- {
- return n_ == 0;
- }
-
- /// Returns the number of characters, excluding the null terminator.
- size_type
- size() const
- {
- return n_;
- }
-
- /// Returns the number of characters, excluding the null terminator.
- size_type
- length() const
- {
- return size();
- }
-
- /// Returns the maximum number of characters that can be stored, excluding the null terminator.
- size_type constexpr
- max_size() const
- {
- return N;
- }
-
- /** Reserves storage.
-
- This actually just throws an exception if `n > N`,
- otherwise does nothing since the storage is fixed.
- */
- void
- reserve(std::size_t n);
-
- /// Returns the number of characters that can be held in currently allocated storage.
- size_type constexpr
- capacity() const
- {
- return max_size();
- }
-
- /** Reduces memory usage by freeing unused memory.
-
- This actually does nothing, since the storage is fixed.
- */
- void
- shrink_to_fit()
- {
- }
-
- //
- // Operations
- //
-
- /// Clears the contents.
- void
- clear();
-
- static_string&
- insert(size_type index, size_type count, CharT ch);
-
- static_string&
- insert(size_type index, CharT const* s)
- {
- return insert(index, s, Traits::length(s));
- }
-
- static_string&
- insert(size_type index, CharT const* s, size_type count);
-
- template<std::size_t M>
- static_string&
- insert(size_type index,
- static_string<M, CharT, Traits> const& str)
- {
- return insert(index, str.data(), str.size());
- }
-
- template<std::size_t M>
- static_string&
- insert(size_type index,
- static_string<M, CharT, Traits> const& str,
- size_type index_str, size_type count = npos);
-
- iterator
- insert(const_iterator pos, CharT ch)
- {
- return insert(pos, 1, ch);
- }
-
- iterator
- insert(const_iterator pos, size_type count, CharT ch);
-
- template<class InputIt>
-#if BOOST_BEAST_DOXYGEN
- iterator
-#else
- typename std::enable_if<
- detail::is_input_iterator<InputIt>::value,
- iterator>::type
-#endif
- insert(const_iterator pos, InputIt first, InputIt last);
-
- iterator
- insert(const_iterator pos, std::initializer_list<CharT> init)
- {
- return insert(pos, init.begin(), init.end());
- }
-
- static_string&
- insert(size_type index, string_view_type str)
- {
- return insert(index, str.data(), str.size());
- }
-
- template<class T>
-#if BOOST_BEAST_DOXYGEN
- static_string&
-#else
- typename std::enable_if<
- std::is_convertible<T const&, string_view_type>::value &&
- ! std::is_convertible<T const&, CharT const*>::value,
- static_string&>::type
-#endif
- insert(size_type index, T const& t,
- size_type index_str, size_type count = npos);
-
- static_string&
- erase(size_type index = 0, size_type count = npos);
-
- iterator
- erase(const_iterator pos);
-
- iterator
- erase(const_iterator first, const_iterator last);
-
- void
- push_back(CharT ch);
-
- void
- pop_back()
- {
- Traits::assign(s_[--n_], 0);
- }
-
- static_string&
- append(size_type count, CharT ch)
- {
- insert(end(), count, ch);
- return *this;
- }
-
- template<std::size_t M>
- static_string&
- append(static_string<M, CharT, Traits> const& str)
- {
- insert(size(), str);
- return *this;
- }
-
- template<std::size_t M>
- static_string&
- append(static_string<M, CharT, Traits> const& str,
- size_type pos, size_type count = npos);
-
- static_string&
- append(CharT const* s, size_type count)
- {
- insert(size(), s, count);
- return *this;
- }
-
- static_string&
- append(CharT const* s)
- {
- insert(size(), s);
- return *this;
- }
-
- template<class InputIt>
-#if BOOST_BEAST_DOXYGEN
- static_string&
-#else
- typename std::enable_if<
- detail::is_input_iterator<InputIt>::value,
- static_string&>::type
-#endif
- append(InputIt first, InputIt last)
- {
- insert(end(), first, last);
- return *this;
- }
-
- static_string&
- append(std::initializer_list<CharT> init)
- {
- insert(end(), init);
- return *this;
- }
-
- static_string&
- append(string_view_type sv)
- {
- insert(size(), sv);
- return *this;
- }
-
- template<class T>
- typename std::enable_if<
- std::is_convertible<T const&, string_view_type>::value &&
- ! std::is_convertible<T const&, CharT const*>::value,
- static_string&>::type
- append(T const& t, size_type pos, size_type count = npos)
- {
- insert(size(), t, pos, count);
- return *this;
- }
-
- template<std::size_t M>
- static_string&
- operator+=(static_string<M, CharT, Traits> const& str)
- {
- return append(str.data(), str.size());
- }
-
- static_string&
- operator+=(CharT ch)
- {
- push_back(ch);
- return *this;
- }
-
- static_string&
- operator+=(CharT const* s)
- {
- return append(s);
- }
-
- static_string&
- operator+=(std::initializer_list<CharT> init)
- {
- return append(init);
- }
-
- static_string&
- operator+=(string_view_type const& str)
- {
- return append(str);
- }
-
- template<std::size_t M>
- int
- compare(static_string<M, CharT, Traits> const& str) const
- {
- return detail::lexicographical_compare<CharT, Traits>(
- &s_[0], n_, &str.s_[0], str.n_);
- }
-
- template<std::size_t M>
- int
- compare(size_type pos1, size_type count1,
- static_string<M, CharT, Traits> const& str) const
- {
- return detail::lexicographical_compare<CharT, Traits>(
- substr(pos1, count1), str.data(), str.size());
- }
-
- template<std::size_t M>
- int
- compare(size_type pos1, size_type count1,
- static_string<M, CharT, Traits> const& str,
- size_type pos2, size_type count2 = npos) const
- {
- return detail::lexicographical_compare(
- substr(pos1, count1), str.substr(pos2, count2));
- }
-
- int
- compare(CharT const* s) const
- {
- return detail::lexicographical_compare<CharT, Traits>(
- &s_[0], n_, s, Traits::length(s));
- }
-
- int
- compare(size_type pos1, size_type count1,
- CharT const* s) const
- {
- return detail::lexicographical_compare<CharT, Traits>(
- substr(pos1, count1), s, Traits::length(s));
- }
-
- int
- compare(size_type pos1, size_type count1,
- CharT const*s, size_type count2) const
- {
- return detail::lexicographical_compare<CharT, Traits>(
- substr(pos1, count1), s, count2);
- }
-
- int
- compare(string_view_type str) const
- {
- return detail::lexicographical_compare<CharT, Traits>(
- &s_[0], n_, str.data(), str.size());
- }
-
- int
- compare(size_type pos1, size_type count1,
- string_view_type str) const
- {
- return detail::lexicographical_compare<CharT, Traits>(
- substr(pos1, count1), str);
- }
-
- template<class T>
-#if BOOST_BEAST_DOXYGEN
- int
-#else
- typename std::enable_if<
- std::is_convertible<T const&, string_view_type>::value &&
- ! std::is_convertible<T const&, CharT const*>::value,
- int>::type
-#endif
- compare(size_type pos1, size_type count1,
- T const& t, size_type pos2,
- size_type count2 = npos) const
- {
- return compare(pos1, count1,
- string_view_type(t).substr(pos2, count2));
- }
-
- string_view_type
- substr(size_type pos = 0, size_type count = npos) const;
-
- /// Copy a substring (pos, pos+count) to character string pointed to by `dest`.
- size_type
- copy(CharT* dest, size_type count, size_type pos = 0) const;
-
- /** Changes the number of characters stored.
-
- If the resulting string is larger, the new
- characters are uninitialized.
- */
- void
- resize(std::size_t n);
-
- /** Changes the number of characters stored.
-
- If the resulting string is larger, the new
- characters are initialized to the value of `c`.
- */
- void
- resize(std::size_t n, CharT c);
-
- /// Exchange the contents of this string with another.
- void
- swap(static_string& str);
-
- /// Exchange the contents of this string with another.
- template<std::size_t M>
- void
- swap(static_string<M, CharT, Traits>& str);
-
- //
- // Search
- //
-
-private:
- static_string&
- assign_char(CharT ch, std::true_type);
-
- static_string&
- assign_char(CharT ch, std::false_type);
-};
-
-//
-// Disallowed operations
-//
-
-// These operations are explicitly deleted since
-// there is no reasonable implementation possible.
-
-template<std::size_t N, std::size_t M, class CharT, class Traits>
-void
-operator+(
- static_string<N, CharT, Traits>const& lhs,
- static_string<M, CharT, Traits>const& rhs) = delete;
-
-template<std::size_t N, class CharT, class Traits>
-void
-operator+(CharT const* lhs,
- static_string<N, CharT, Traits>const& rhs) = delete;
-
-template<std::size_t N, class CharT, class Traits>
-void
-operator+(CharT lhs,
- static_string<N, CharT, Traits> const& rhs) = delete;
-
-template<std::size_t N, class CharT, class Traits>
-void
-operator+(static_string<N, CharT, Traits> const& lhs,
- CharT const* rhs) = delete;
-
-template<std::size_t N, class CharT, class Traits>
-void
-operator+(static_string<N, CharT, Traits> const& lhs,
- CharT rhs) = delete;
-
-//
-// Non-member functions
-//
-
-template<std::size_t N, std::size_t M,
- class CharT, class Traits>
-bool
-operator==(
- static_string<N, CharT, Traits> const& lhs,
- static_string<M, CharT, Traits> const& rhs)
-{
- return lhs.compare(rhs) == 0;
-}
-
-template<std::size_t N, std::size_t M,
- class CharT, class Traits>
-bool
-operator!=(
- static_string<N, CharT, Traits> const& lhs,
- static_string<M, CharT, Traits> const& rhs)
-{
- return lhs.compare(rhs) != 0;
-}
-
-template<std::size_t N, std::size_t M,
- class CharT, class Traits>
-bool
-operator<(
- static_string<N, CharT, Traits> const& lhs,
- static_string<M, CharT, Traits> const& rhs)
-{
- return lhs.compare(rhs) < 0;
-}
-
-template<std::size_t N, std::size_t M,
- class CharT, class Traits>
-bool
-operator<=(
- static_string<N, CharT, Traits> const& lhs,
- static_string<M, CharT, Traits> const& rhs)
-{
- return lhs.compare(rhs) <= 0;
-}
-
-template<std::size_t N, std::size_t M,
- class CharT, class Traits>
-bool
-operator>(
- static_string<N, CharT, Traits> const& lhs,
- static_string<M, CharT, Traits> const& rhs)
-{
- return lhs.compare(rhs) > 0;
-}
-
-template<std::size_t N, std::size_t M,
- class CharT, class Traits>
-bool
-operator>=(
- static_string<N, CharT, Traits> const& lhs,
- static_string<M, CharT, Traits> const& rhs)
-{
- return lhs.compare(rhs) >= 0;
-}
-
-template<std::size_t N, class CharT, class Traits>
-bool
-operator==(
- CharT const* lhs,
- static_string<N, CharT, Traits> const& rhs)
-{
- return detail::lexicographical_compare<CharT, Traits>(
- lhs, Traits::length(lhs),
- rhs.data(), rhs.size()) == 0;
-}
-
-template<std::size_t N, class CharT, class Traits>
-bool
-operator==(
- static_string<N, CharT, Traits> const& lhs,
- CharT const* rhs)
-{
- return detail::lexicographical_compare<CharT, Traits>(
- lhs.data(), lhs.size(),
- rhs, Traits::length(rhs)) == 0;
-}
-
-template<std::size_t N, class CharT, class Traits>
-bool
-operator!=(
- CharT const* lhs,
- static_string<N, CharT, Traits> const& rhs)
-{
- return detail::lexicographical_compare<CharT, Traits>(
- lhs, Traits::length(lhs),
- rhs.data(), rhs.size()) != 0;
-}
-
-template<std::size_t N, class CharT, class Traits>
-bool
-operator!=(
- static_string<N, CharT, Traits> const& lhs,
- CharT const* rhs)
-{
- return detail::lexicographical_compare<CharT, Traits>(
- lhs.data(), lhs.size(),
- rhs, Traits::length(rhs)) != 0;
-}
-
-template<std::size_t N, class CharT, class Traits>
-bool
-operator<(
- CharT const* lhs,
- static_string<N, CharT, Traits> const& rhs)
-{
- return detail::lexicographical_compare<CharT, Traits>(
- lhs, Traits::length(lhs),
- rhs.data(), rhs.size()) < 0;
-}
-
-template<std::size_t N, class CharT, class Traits>
-bool
-operator<(
- static_string<N, CharT, Traits> const& lhs,
- CharT const* rhs)
-{
- return detail::lexicographical_compare<CharT, Traits>(
- lhs.data(), lhs.size(),
- rhs, Traits::length(rhs)) < 0;
-}
-
-template<std::size_t N, class CharT, class Traits>
-bool
-operator<=(
- CharT const* lhs,
- static_string<N, CharT, Traits> const& rhs)
-{
- return detail::lexicographical_compare<CharT, Traits>(
- lhs, Traits::length(lhs),
- rhs.data(), rhs.size()) <= 0;
-}
-
-template<std::size_t N, class CharT, class Traits>
-bool
-operator<=(
- static_string<N, CharT, Traits> const& lhs,
- CharT const* rhs)
-{
- return detail::lexicographical_compare<CharT, Traits>(
- lhs.data(), lhs.size(),
- rhs, Traits::length(rhs)) <= 0;
-}
-
-template<std::size_t N, class CharT, class Traits>
-bool
-operator>(
- CharT const* lhs,
- static_string<N, CharT, Traits> const& rhs)
-{
- return detail::lexicographical_compare<CharT, Traits>(
- lhs, Traits::length(lhs),
- rhs.data(), rhs.size()) > 0;
-}
-
-template<std::size_t N, class CharT, class Traits>
-bool
-operator>(
- static_string<N, CharT, Traits> const& lhs,
- CharT const* rhs)
-{
- return detail::lexicographical_compare<CharT, Traits>(
- lhs.data(), lhs.size(),
- rhs, Traits::length(rhs)) > 0;
-}
-
-template<std::size_t N, class CharT, class Traits>
-bool
-operator>=(
- CharT const* lhs,
- static_string<N, CharT, Traits> const& rhs)
-{
- return detail::lexicographical_compare<CharT, Traits>(
- lhs, Traits::length(lhs),
- rhs.data(), rhs.size()) >= 0;
-}
-
-template<std::size_t N, class CharT, class Traits>
-bool
-operator>=(
- static_string<N, CharT, Traits> const& lhs,
- CharT const* rhs)
-{
- return detail::lexicographical_compare<CharT, Traits>(
- lhs.data(), lhs.size(),
- rhs, Traits::length(rhs)) >= 0;
-}
-
-//
-// swap
-//
-
-template<std::size_t N, class CharT, class Traits>
-void
-swap(
- static_string<N, CharT, Traits>& lhs,
- static_string<N, CharT, Traits>& rhs)
-{
- lhs.swap(rhs);
-}
-
-template<std::size_t N, std::size_t M,
- class CharT, class Traits>
-void
-swap(
- static_string<N, CharT, Traits>& lhs,
- static_string<M, CharT, Traits>& rhs)
-{
- lhs.swap(rhs);
-}
-
-//
-// Input/Output
-//
-
-template<std::size_t N, class CharT, class Traits>
-std::basic_ostream<CharT, Traits>&
-operator<<(std::basic_ostream<CharT, Traits>& os,
- static_string<N, CharT, Traits> const& str)
-{
- return os << static_cast<
- beast::basic_string_view<CharT, Traits>>(str);
-}
-
-//
-// Numeric conversions
-//
-
-/** Returns a static string representing an integer as a decimal.
-
- @param x The signed or unsigned integer to convert.
- This must be an integral type.
-
- @return A @ref static_string with an implementation defined
- maximum size large enough to hold the longest possible decimal
- representation of any integer of the given type.
-*/
-template<class Integer>
-static_string<detail::max_digits(sizeof(Integer))>
-to_static_string(Integer x);
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/static_string.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/string.hpp b/contrib/restricted/boost/boost/beast/core/string.hpp
deleted file mode 100644
index 27bfa57165..0000000000
--- a/contrib/restricted/boost/boost/beast/core/string.hpp
+++ /dev/null
@@ -1,132 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_STRING_HPP
-#define BOOST_BEAST_STRING_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/version.hpp>
-#include <boost/utility/string_view.hpp>
-#include <algorithm>
-
-namespace boost {
-namespace beast {
-
-/// The type of string view used by the library
-using string_view = boost::string_view;
-
-/// The type of basic string view used by the library
-template<class CharT, class Traits>
-using basic_string_view =
- boost::basic_string_view<CharT, Traits>;
-
-namespace detail {
-
-inline
-char
-ascii_tolower(char c)
-{
- return ((static_cast<unsigned>(c) - 65U) < 26) ?
- c + 'a' - 'A' : c;
-}
-
-template<class = void>
-bool
-iequals(
- beast::string_view lhs,
- beast::string_view rhs)
-{
- auto n = lhs.size();
- if(rhs.size() != n)
- return false;
- auto p1 = lhs.data();
- auto p2 = rhs.data();
- char a, b;
- while(n--)
- {
- a = *p1++;
- b = *p2++;
- if(a != b)
- {
- // slow loop
- do
- {
- if(ascii_tolower(a) != ascii_tolower(b))
- return false;
- a = *p1++;
- b = *p2++;
- }
- while(n--);
- return true;
- }
- }
- return true;
-}
-
-} // detail
-
-/** Returns `true` if two strings are equal, using a case-insensitive comparison.
-
- The case-comparison operation is defined only for low-ASCII characters.
-
- @param lhs The string on the left side of the equality
-
- @param rhs The string on the right side of the equality
-*/
-inline
-bool
-iequals(
- beast::string_view lhs,
- beast::string_view rhs)
-{
- return detail::iequals(lhs, rhs);
-}
-
-/** A case-insensitive less predicate for strings.
-
- The case-comparison operation is defined only for low-ASCII characters.
-*/
-struct iless
-{
- bool
- operator()(
- string_view lhs,
- string_view rhs) const
- {
- using std::begin;
- using std::end;
- return std::lexicographical_compare(
- begin(lhs), end(lhs), begin(rhs), end(rhs),
- [](char c1, char c2)
- {
- return detail::ascii_tolower(c1) < detail::ascii_tolower(c2);
- }
- );
- }
-};
-
-/** A case-insensitive equality predicate for strings.
-
- The case-comparison operation is defined only for low-ASCII characters.
-*/
-struct iequal
-{
- bool
- operator()(
- string_view lhs,
- string_view rhs) const
- {
- return iequals(lhs, rhs);
- }
-};
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/string_param.hpp b/contrib/restricted/boost/boost/beast/core/string_param.hpp
deleted file mode 100644
index a068cc4091..0000000000
--- a/contrib/restricted/boost/boost/beast/core/string_param.hpp
+++ /dev/null
@@ -1,130 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_STRING_PARAM_HPP
-#define BOOST_BEAST_STRING_PARAM_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/core/static_string.hpp>
-#include <boost/beast/core/detail/static_ostream.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/optional.hpp>
-
-namespace boost {
-namespace beast {
-
-/** A function parameter which efficiently converts to string.
-
- This is used as a function parameter type to allow callers
- notational convenience: objects other than strings may be
- passed in contexts where a string is expected. The conversion
- to string is made using `operator<<` to a non-dynamically
- allocated static buffer if possible, else to a `std::string`
- on overflow.
-
- To use it, modify your function signature to accept
- `string_param` and then extract the string inside the
- function:
- @code
- void print(string_param s)
- {
- std::cout << s.str();
- }
- @endcode
-*/
-class string_param
-{
- string_view sv_;
- char buf_[128];
- boost::optional<detail::static_ostream> os_;
-
- template<class T>
- typename std::enable_if<
- std::is_integral<T>::value>::type
- print(T const&);
-
- template<class T>
- typename std::enable_if<
- ! std::is_integral<T>::value &&
- ! std::is_convertible<T, string_view>::value
- >::type
- print(T const&);
-
- void
- print(string_view);
-
- template<class T>
- typename std::enable_if<
- std::is_integral<T>::value>::type
- print_1(T const&);
-
- template<class T>
- typename std::enable_if<
- ! std::is_integral<T>::value>::type
- print_1(T const&);
-
- void
- print_n()
- {
- }
-
- template<class T0, class... TN>
- void
- print_n(T0 const&, TN const&...);
-
- template<class T0, class T1, class... TN>
- void
- print(T0 const&, T1 const&, TN const&...);
-
-public:
- /// Copy constructor (disallowed)
- string_param(string_param const&) = delete;
-
- /// Copy assignment (disallowed)
- string_param& operator=(string_param const&) = delete;
-
- /** Constructor
-
- This function constructs a string as if by concatenating
- the result of streaming each argument in order into an
- output stream. It is used as a notational convenience
- at call sites which expect a parameter with the semantics
- of a @ref string_view.
-
- The implementation uses a small, internal static buffer
- to avoid memory allocations especially for the case where
- the list of arguments to be converted consists of a single
- integral type.
-
- @param args One or more arguments to convert
- */
- template<class... Args>
- string_param(Args const&... args);
-
- /// Returns the contained string
- string_view
- str() const
- {
- return sv_;
- }
-
- /// Implicit conversion to @ref string_view
- operator string_view const() const
- {
- return sv_;
- }
-};
-
-} // beast
-} // boost
-
-#include <boost/beast/core/impl/string_param.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/core/type_traits.hpp b/contrib/restricted/boost/boost/beast/core/type_traits.hpp
deleted file mode 100644
index f5e466a759..0000000000
--- a/contrib/restricted/boost/boost/beast/core/type_traits.hpp
+++ /dev/null
@@ -1,480 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_TYPE_TRAITS_HPP
-#define BOOST_BEAST_TYPE_TRAITS_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/file_base.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-
-//------------------------------------------------------------------------------
-//
-// Handler concepts
-//
-//------------------------------------------------------------------------------
-
-/** Determine if `T` meets the requirements of @b CompletionHandler.
-
- This trait checks whether a type meets the requirements for a completion
- handler, and is also callable with the specified signature.
- Metafunctions are used to perform compile time checking of template
- types. This type will be `std::true_type` if `T` meets the requirements,
- else the type will be `std::false_type`.
-
- @par Example
-
- Use with `static_assert`:
-
- @code
- struct handler
- {
- void operator()(error_code&);
- };
-
- static_assert(is_completion_handler<handler, void(error_code&)>::value,
- "Not a completion handler");
- @endcode
-*/
-template<class T, class Signature>
-#if BOOST_BEAST_DOXYGEN
-using is_completion_handler = std::integral_constant<bool, ...>;
-#else
-using is_completion_handler = std::integral_constant<bool,
- std::is_move_constructible<typename std::decay<T>::type>::value &&
- detail::is_invocable<T, Signature>::value>;
-#endif
-
-//------------------------------------------------------------------------------
-//
-// Stream concepts
-//
-//------------------------------------------------------------------------------
-
-/** Determine if `T` has the `get_executor` member function.
-
- Metafunctions are used to perform compile time checking of template
- types. This type will be `std::true_type` if `T` has the member
- function with the correct signature, else type will be `std::false_type`.
-
- @par Example
-
- Use with tag dispatching:
-
- @code
- template<class T>
- void maybe_hello(T& t, std::true_type)
- {
- boost::asio::post(
- t.get_executor(),
- []
- {
- std::cout << "Hello, world!" << std::endl;
- });
- }
-
- template<class T>
- void maybe_hello(T&, std::false_type)
- {
- // T does not have get_executor
- }
-
- template<class T>
- void maybe_hello(T& t)
- {
- maybe_hello(t, has_get_executor<T>{});
- }
- @endcode
-
- Use with `static_assert`:
-
- @code
- struct stream
- {
- using executor_type = boost::asio::io_context::executor_type;
- executor_type get_executor() noexcept;
- };
-
- static_assert(has_get_executor<stream>::value, "Missing get_executor member");
- @endcode
-*/
-#if BOOST_BEAST_DOXYGEN
-template<class T>
-struct has_get_executor : std::integral_constant<bool, ...>{};
-#else
-template<class T, class = void>
-struct has_get_executor : std::false_type {};
-
-template<class T>
-struct has_get_executor<T, beast::detail::void_t<decltype(
- std::declval<T&>().get_executor(),
- (void)0)>> : std::true_type {};
-#endif
-
-/** Alias for `T::lowest_layer_type` if it exists, else `T`
-
- This will be a type alias for `T::lowest_layer_type`
- if it exists, else it will be an alias for `T`.
-
- @par Example
-
- Declaring a wrapper:
-
- @code
- template<class Stream>
- struct stream_wrapper
- {
- using next_layer_type = typename std::remove_reference<Stream>::type;
- using lowest_layer_type = get_lowest_layer<stream_type>;
- };
- @endcode
-
- Defining a metafunction:
-
- @code
- /// Alias for `std::true_type` if `T` wraps another stream
- template<class T>
- using is_stream_wrapper : std::integral_constant<bool,
- ! std::is_same<T, get_lowest_layer<T>>::value> {};
- @endcode
-*/
-#if BOOST_BEAST_DOXYGEN
-template<class T>
-struct get_lowest_layer;
-#else
-template<class T>
-using get_lowest_layer = typename detail::get_lowest_layer_helper<T>::type;
-#endif
-
-/** Determine if `T` meets the requirements of @b AsyncReadStream.
-
- Metafunctions are used to perform compile time checking of template
- types. This type will be `std::true_type` if `T` meets the requirements,
- else the type will be `std::false_type`.
-
- @par Example
-
- Use with `static_assert`:
-
- @code
- template<class AsyncReadStream>
- void f(AsyncReadStream& stream)
- {
- static_assert(is_async_read_stream<AsyncReadStream>::value,
- "AsyncReadStream requirements not met");
- ...
- @endcode
-
- Use with `std::enable_if` (SFINAE):
-
- @code
- template<class AsyncReadStream>
- typename std::enable_if<is_async_read_stream<AsyncReadStream>::value>::type
- f(AsyncReadStream& stream);
- @endcode
-*/
-#if BOOST_BEAST_DOXYGEN
-template<class T>
-struct is_async_read_stream : std::integral_constant<bool, ...>{};
-#else
-template<class T, class = void>
-struct is_async_read_stream : std::false_type {};
-
-template<class T>
-struct is_async_read_stream<T, detail::void_t<decltype(
- std::declval<T>().async_read_some(
- std::declval<detail::MutableBufferSequence>(),
- std::declval<detail::ReadHandler>()),
- (void)0)>> : std::integral_constant<bool,
- has_get_executor<T>::value
- > {};
-#endif
-
-/** Determine if `T` meets the requirements of @b AsyncWriteStream.
-
- Metafunctions are used to perform compile time checking of template
- types. This type will be `std::true_type` if `T` meets the requirements,
- else the type will be `std::false_type`.
-
- @par Example
-
- Use with `static_assert`:
-
- @code
- template<class AsyncWriteStream>
- void f(AsyncWriteStream& stream)
- {
- static_assert(is_async_write_stream<AsyncWriteStream>::value,
- "AsyncWriteStream requirements not met");
- ...
- @endcode
-
- Use with `std::enable_if` (SFINAE):
-
- @code
- template<class AsyncWriteStream>
- typename std::enable_if<is_async_write_stream<AsyncWriteStream>::value>::type
- f(AsyncWriteStream& stream);
- @endcode
-*/
-#if BOOST_BEAST_DOXYGEN
-template<class T>
-struct is_async_write_stream : std::integral_constant<bool, ...>{};
-#else
-template<class T, class = void>
-struct is_async_write_stream : std::false_type {};
-
-template<class T>
-struct is_async_write_stream<T, detail::void_t<decltype(
- std::declval<T>().async_write_some(
- std::declval<detail::ConstBufferSequence>(),
- std::declval<detail::WriteHandler>()),
- (void)0)>> : std::integral_constant<bool,
- has_get_executor<T>::value
- > {};
-#endif
-
-/** Determine if `T` meets the requirements of @b SyncReadStream.
-
- Metafunctions are used to perform compile time checking of template
- types. This type will be `std::true_type` if `T` meets the requirements,
- else the type will be `std::false_type`.
-
- @par Example
-
- Use with `static_assert`:
-
- @code
- template<class SyncReadStream>
- void f(SyncReadStream& stream)
- {
- static_assert(is_sync_read_stream<SyncReadStream>::value,
- "SyncReadStream requirements not met");
- ...
- @endcode
-
- Use with `std::enable_if` (SFINAE):
-
- @code
- template<class SyncReadStream>
- typename std::enable_if<is_sync_read_stream<SyncReadStream>::value>::type
- f(SyncReadStream& stream);
- @endcode
-*/
-#if BOOST_BEAST_DOXYGEN
-template<class T>
-struct is_sync_read_stream : std::integral_constant<bool, ...>{};
-#else
-template<class T, class = void>
-struct is_sync_read_stream : std::false_type {};
-
-template<class T>
-struct is_sync_read_stream<T, detail::void_t<decltype(
- std::declval<std::size_t&>() = std::declval<T>().read_some(
- std::declval<detail::MutableBufferSequence>()),
- std::declval<std::size_t&>() = std::declval<T>().read_some(
- std::declval<detail::MutableBufferSequence>(),
- std::declval<boost::system::error_code&>()),
- (void)0)>> : std::true_type {};
-#endif
-
-/** Determine if `T` meets the requirements of @b SyncWriteStream.
-
- Metafunctions are used to perform compile time checking of template
- types. This type will be `std::true_type` if `T` meets the requirements,
- else the type will be `std::false_type`.
-
- @par Example
-
- Use with `static_assert`:
-
- @code
- template<class SyncReadStream>
- void f(SyncReadStream& stream)
- {
- static_assert(is_sync_read_stream<SyncReadStream>::value,
- "SyncReadStream requirements not met");
- ...
- @endcode
-
- Use with `std::enable_if` (SFINAE):
-
- @code
- template<class SyncReadStream>
- typename std::enable_if<is_sync_read_stream<SyncReadStream>::value>::type
- f(SyncReadStream& stream);
- @endcode
-*/
-#if BOOST_BEAST_DOXYGEN
-template<class T>
-struct is_sync_write_stream : std::integral_constant<bool, ...>{};
-#else
-template<class T, class = void>
-struct is_sync_write_stream : std::false_type {};
-
-template<class T>
-struct is_sync_write_stream<T, detail::void_t<decltype(
- std::declval<std::size_t&>() = std::declval<T&>().write_some(
- std::declval<detail::ConstBufferSequence>()),
- std::declval<std::size_t&>() = std::declval<T&>().write_some(
- std::declval<detail::ConstBufferSequence>(),
- std::declval<boost::system::error_code&>()),
- (void)0)>> : std::true_type {};
-#endif
-
-/** Determine if `T` meets the requirements of @b AsyncStream.
-
- Metafunctions are used to perform compile time checking of template
- types. This type will be `std::true_type` if `T` meets the requirements,
- else the type will be `std::false_type`.
-
- @par Example
-
- Use with `static_assert`:
-
- @code
- template<class AsyncStream>
- void f(AsyncStream& stream)
- {
- static_assert(is_async_stream<AsyncStream>::value,
- "AsyncStream requirements not met");
- ...
- @endcode
-
- Use with `std::enable_if` (SFINAE):
-
- @code
- template<class AsyncStream>
- typename std::enable_if<is_async_stream<AsyncStream>::value>::type
- f(AsyncStream& stream);
- @endcode
-*/
-#if BOOST_BEAST_DOXYGEN
-template<class T>
-struct is_async_stream : std::integral_constant<bool, ...>{};
-#else
-template<class T>
-using is_async_stream = std::integral_constant<bool,
- is_async_read_stream<T>::value && is_async_write_stream<T>::value>;
-#endif
-
-/** Determine if `T` meets the requirements of @b SyncStream.
-
- Metafunctions are used to perform compile time checking of template
- types. This type will be `std::true_type` if `T` meets the requirements,
- else the type will be `std::false_type`.
-
- @par Example
-
- Use with `static_assert`:
-
- @code
- template<class SyncStream>
- void f(SyncStream& stream)
- {
- static_assert(is_sync_stream<SyncStream>::value,
- "SyncStream requirements not met");
- ...
- @endcode
-
- Use with `std::enable_if` (SFINAE):
-
- @code
- template<class SyncStream>
- typename std::enable_if<is_sync_stream<SyncStream>::value>::type
- f(SyncStream& stream);
- @endcode
-*/
-#if BOOST_BEAST_DOXYGEN
-template<class T>
-struct is_sync_stream : std::integral_constant<bool, ...>{};
-#else
-template<class T>
-using is_sync_stream = std::integral_constant<bool,
- is_sync_read_stream<T>::value && is_sync_write_stream<T>::value>;
-#endif
-
-//------------------------------------------------------------------------------
-//
-// File concepts
-//
-//------------------------------------------------------------------------------
-
-/** Determine if `T` meets the requirements of @b File.
-
- Metafunctions are used to perform compile time checking of template
- types. This type will be `std::true_type` if `T` meets the requirements,
- else the type will be `std::false_type`.
-
- @par Example
-
- Use with `static_assert`:
-
- @code
- template<class File>
- void f(File& file)
- {
- static_assert(is_file<File>::value,
- "File requirements not met");
- ...
- @endcode
-
- Use with `std::enable_if` (SFINAE):
-
- @code
- template<class File>
- typename std::enable_if<is_file<File>::value>::type
- f(File& file);
- @endcode
-*/
-#if BOOST_BEAST_DOXYGEN
-template<class T>
-struct is_file : std::integral_constant<bool, ...>{};
-#else
-template<class T, class = void>
-struct is_file : std::false_type {};
-
-template<class T>
-struct is_file<T, detail::void_t<decltype(
- std::declval<bool&>() = std::declval<T const&>().is_open(),
- std::declval<T&>().close(std::declval<error_code&>()),
- std::declval<T&>().open(
- std::declval<char const*>(),
- std::declval<file_mode>(),
- std::declval<error_code&>()),
- std::declval<std::uint64_t&>() = std::declval<T&>().size(
- std::declval<error_code&>()),
- std::declval<std::uint64_t&>() = std::declval<T&>().pos(
- std::declval<error_code&>()),
- std::declval<T&>().seek(
- std::declval<std::uint64_t>(),
- std::declval<error_code&>()),
- std::declval<std::size_t&>() = std::declval<T&>().read(
- std::declval<void*>(),
- std::declval<std::size_t>(),
- std::declval<error_code&>()),
- std::declval<std::size_t&>() = std::declval<T&>().write(
- std::declval<void const*>(),
- std::declval<std::size_t>(),
- std::declval<error_code&>()),
- (void)0)>> : std::integral_constant<bool,
- std::is_default_constructible<T>::value &&
- std::is_destructible<T>::value
- > {};
-#endif
-
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http.hpp b/contrib/restricted/boost/boost/beast/http.hpp
deleted file mode 100644
index c419724db2..0000000000
--- a/contrib/restricted/boost/boost/beast/http.hpp
+++ /dev/null
@@ -1,38 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_HPP
-#define BOOST_BEAST_HTTP_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-
-#include <boost/beast/http/basic_dynamic_body.hpp>
-#include <boost/beast/http/basic_parser.hpp>
-#include <boost/beast/http/buffer_body.hpp>
-#include <boost/beast/http/chunk_encode.hpp>
-#include <boost/beast/http/dynamic_body.hpp>
-#include <boost/beast/http/empty_body.hpp>
-#include <boost/beast/http/error.hpp>
-#include <boost/beast/http/field.hpp>
-#include <boost/beast/http/fields.hpp>
-#include <boost/beast/http/file_body.hpp>
-#include <boost/beast/http/message.hpp>
-#include <boost/beast/http/parser.hpp>
-#include <boost/beast/http/read.hpp>
-#include <boost/beast/http/rfc7230.hpp>
-#include <boost/beast/http/serializer.hpp>
-#include <boost/beast/http/span_body.hpp>
-#include <boost/beast/http/status.hpp>
-#include <boost/beast/http/string_body.hpp>
-#include <boost/beast/http/type_traits.hpp>
-#include <boost/beast/http/vector_body.hpp>
-#include <boost/beast/http/verb.hpp>
-#include <boost/beast/http/write.hpp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/basic_dynamic_body.hpp b/contrib/restricted/boost/boost/beast/http/basic_dynamic_body.hpp
deleted file mode 100644
index 7d850d76f3..0000000000
--- a/contrib/restricted/boost/boost/beast/http/basic_dynamic_body.hpp
+++ /dev/null
@@ -1,167 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_BASIC_DYNAMIC_BODY_HPP
-#define BOOST_BEAST_HTTP_BASIC_DYNAMIC_BODY_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/http/error.hpp>
-#include <boost/beast/http/message.hpp>
-#include <boost/optional.hpp>
-#include <algorithm>
-#include <cstdint>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** A @b Body using a @b DynamicBuffer
-
- This body uses a @b DynamicBuffer as a memory-based container
- for holding message payloads. Messages using this body type
- may be serialized and parsed.
-*/
-template<class DynamicBuffer>
-struct basic_dynamic_body
-{
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
-
- /** The type of container used for the body
-
- This determines the type of @ref message::body
- when this body type is used with a message container.
- */
- using value_type = DynamicBuffer;
-
- /** Returns the payload size of the body
-
- When this body is used with @ref message::prepare_payload,
- the Content-Length will be set to the payload size, and
- any chunked Transfer-Encoding will be removed.
- */
- static
- std::uint64_t
- size(value_type const& v)
- {
- return v.size();
- }
-
- /** The algorithm for parsing the body
-
- Meets the requirements of @b BodyReader.
- */
-#if BOOST_BEAST_DOXYGEN
- using reader = implementation_defined;
-#else
- class reader
- {
- value_type& body_;
-
- public:
- template<bool isRequest, class Fields>
- explicit
- reader(header<isRequest, Fields>&, value_type& b)
- : body_(b)
- {
- }
-
- void
- init(boost::optional<
- std::uint64_t> const&, error_code& ec)
- {
- ec.assign(0, ec.category());
- }
-
- template<class ConstBufferSequence>
- std::size_t
- put(ConstBufferSequence const& buffers,
- error_code& ec)
- {
- using boost::asio::buffer_copy;
- using boost::asio::buffer_size;
- auto const n = buffer_size(buffers);
- if(body_.size() > body_.max_size() - n)
- {
- ec = error::buffer_overflow;
- return 0;
- }
- boost::optional<typename
- DynamicBuffer::mutable_buffers_type> b;
- try
- {
- b.emplace(body_.prepare((std::min)(n,
- body_.max_size() - body_.size())));
- }
- catch(std::length_error const&)
- {
- ec = error::buffer_overflow;
- return 0;
- }
- ec.assign(0, ec.category());
- auto const bytes_transferred =
- buffer_copy(*b, buffers);
- body_.commit(bytes_transferred);
- return bytes_transferred;
- }
-
- void
- finish(error_code& ec)
- {
- ec.assign(0, ec.category());
- }
- };
-#endif
-
- /** The algorithm for serializing the body
-
- Meets the requirements of @b BodyWriter.
- */
-#if BOOST_BEAST_DOXYGEN
- using writer = implementation_defined;
-#else
- class writer
- {
- DynamicBuffer const& body_;
-
- public:
- using const_buffers_type =
- typename DynamicBuffer::const_buffers_type;
-
- template<bool isRequest, class Fields>
- explicit
- writer(header<isRequest, Fields> const&, value_type const& b)
- : body_(b)
- {
- }
-
- void
- init(error_code& ec)
- {
- ec.assign(0, ec.category());
- }
-
- boost::optional<std::pair<const_buffers_type, bool>>
- get(error_code& ec)
- {
- ec.assign(0, ec.category());
- return {{body_.data(), false}};
- }
- };
-#endif
-};
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/basic_file_body.hpp b/contrib/restricted/boost/boost/beast/http/basic_file_body.hpp
deleted file mode 100644
index 6d1de9a3b8..0000000000
--- a/contrib/restricted/boost/boost/beast/http/basic_file_body.hpp
+++ /dev/null
@@ -1,539 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_BASIC_FILE_BODY_HPP
-#define BOOST_BEAST_HTTP_BASIC_FILE_BODY_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/core/file_base.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/http/message.hpp>
-#include <boost/assert.hpp>
-#include <boost/optional.hpp>
-#include <algorithm>
-#include <cstdio>
-#include <cstdint>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-//[example_http_file_body_1
-
-/** A message body represented by a file on the filesystem.
-
- Messages with this type have bodies represented by a
- file on the file system. When parsing a message using
- this body type, the data is stored in the file pointed
- to by the path, which must be writable. When serializing,
- the implementation will read the file and present those
- octets as the body content. This may be used to serve
- content from a directory as part of a web service.
-
- @tparam File The implementation to use for accessing files.
- This type must meet the requirements of @b File.
-*/
-template<class File>
-struct basic_file_body
-{
- // Make sure the type meets the requirements
- static_assert(is_file<File>::value,
- "File requirements not met");
-
- /// The type of File this body uses
- using file_type = File;
-
- // Algorithm for storing buffers when parsing.
- class reader;
-
- // Algorithm for retrieving buffers when serializing.
- class writer;
-
- // The type of the @ref message::body member.
- class value_type;
-
- /** Returns the size of the body
-
- @param body The file body to use
- */
- static
- std::uint64_t
- size(value_type const& body);
-};
-
-//]
-
-//[example_http_file_body_2
-
-/** The type of the @ref message::body member.
-
- Messages declared using `basic_file_body` will have this type for
- the body member. This rich class interface allow the file to be
- opened with the file handle maintained directly in the object,
- which is attached to the message.
-*/
-template<class File>
-class basic_file_body<File>::value_type
-{
- // This body container holds a handle to the file
- // when it is open, and also caches the size when set.
-
- friend class reader;
- friend class writer;
- friend struct basic_file_body;
-
- // This represents the open file
- File file_;
-
- // The cached file size
- std::uint64_t file_size_ = 0;
-
-public:
- /** Destructor.
-
- If the file is open, it is closed first.
- */
- ~value_type() = default;
-
- /// Constructor
- value_type() = default;
-
- /// Constructor
- value_type(value_type&& other) = default;
-
- /// Move assignment
- value_type& operator=(value_type&& other) = default;
-
- /// Returns `true` if the file is open
- bool
- is_open() const
- {
- return file_.is_open();
- }
-
- /// Returns the size of the file if open
- std::uint64_t
- size() const
- {
- return file_size_;
- }
-
- /// Close the file if open
- void
- close();
-
- /** Open a file at the given path with the specified mode
-
- @param path The utf-8 encoded path to the file
-
- @param mode The file mode to use
-
- @param ec Set to the error, if any occurred
- */
- void
- open(char const* path, file_mode mode, error_code& ec);
-
- /** Set the open file
-
- This function is used to set the open file. Any previously
- set file will be closed.
-
- @param file The file to set. The file must be open or else
- an error occurs
-
- @param ec Set to the error, if any occurred
- */
- void
- reset(File&& file, error_code& ec);
-};
-
-template<class File>
-void
-basic_file_body<File>::
-value_type::
-close()
-{
- error_code ignored;
- file_.close(ignored);
-}
-
-template<class File>
-void
-basic_file_body<File>::
-value_type::
-open(char const* path, file_mode mode, error_code& ec)
-{
- // Open the file
- file_.open(path, mode, ec);
- if(ec)
- return;
-
- // Cache the size
- file_size_ = file_.size(ec);
- if(ec)
- {
- close();
- return;
- }
-}
-
-template<class File>
-void
-basic_file_body<File>::
-value_type::
-reset(File&& file, error_code& ec)
-{
- // First close the file if open
- if(file_.is_open())
- {
- error_code ignored;
- file_.close(ignored);
- }
-
- // Take ownership of the new file
- file_ = std::move(file);
-
- // Cache the size
- file_size_ = file_.size(ec);
-}
-
-// This is called from message::payload_size
-template<class File>
-std::uint64_t
-basic_file_body<File>::
-size(value_type const& body)
-{
- // Forward the call to the body
- return body.size();
-}
-
-//]
-
-//[example_http_file_body_3
-
-/** Algorithm for retrieving buffers when serializing.
-
- Objects of this type are created during serialization
- to extract the buffers representing the body.
-*/
-template<class File>
-class basic_file_body<File>::writer
-{
- value_type& body_; // The body we are reading from
- std::uint64_t remain_; // The number of unread bytes
- char buf_[4096]; // Small buffer for reading
-
-public:
- // The type of buffer sequence returned by `get`.
- //
- using const_buffers_type =
- boost::asio::const_buffer;
-
- // Constructor.
- //
- // `h` holds the headers of the message we are
- // serializing, while `b` holds the body.
- //
- // Note that the message is passed by non-const reference.
- // This is intentional, because reading from the file
- // changes its "current position" which counts makes the
- // operation logically not-const (although it is bitwise
- // const).
- //
- // The BodyWriter concept allows the writer to choose
- // whether to take the message by const reference or
- // non-const reference. Depending on the choice, a
- // serializer constructed using that body type will
- // require the same const or non-const reference to
- // construct.
- //
- // Readers which accept const messages usually allow
- // the same body to be serialized by multiple threads
- // concurrently, while readers accepting non-const
- // messages may only be serialized by one thread at
- // a time.
- //
- template<bool isRequest, class Fields>
- writer(header<isRequest, Fields>& h, value_type& b);
-
- // Initializer
- //
- // This is called before the body is serialized and
- // gives the writer a chance to do something that might
- // need to return an error code.
- //
- void
- init(error_code& ec);
-
- // This function is called zero or more times to
- // retrieve buffers. A return value of `boost::none`
- // means there are no more buffers. Otherwise,
- // the contained pair will have the next buffer
- // to serialize, and a `bool` indicating whether
- // or not there may be additional buffers.
- boost::optional<std::pair<const_buffers_type, bool>>
- get(error_code& ec);
-};
-
-//]
-
-//[example_http_file_body_4
-
-// Here we just stash a reference to the path for later.
-// Rather than dealing with messy constructor exceptions,
-// we save the things that might fail for the call to `init`.
-//
-template<class File>
-template<bool isRequest, class Fields>
-basic_file_body<File>::
-writer::
-writer(header<isRequest, Fields>& h, value_type& b)
- : body_(b)
-{
- boost::ignore_unused(h);
-
- // The file must already be open
- BOOST_ASSERT(body_.file_.is_open());
-
- // Get the size of the file
- remain_ = body_.file_size_;
-}
-
-// Initializer
-template<class File>
-void
-basic_file_body<File>::
-writer::
-init(error_code& ec)
-{
- // The error_code specification requires that we
- // either set the error to some value, or set it
- // to indicate no error.
- //
- // We don't do anything fancy so set "no error"
- ec.assign(0, ec.category());
-}
-
-// This function is called repeatedly by the serializer to
-// retrieve the buffers representing the body. Our strategy
-// is to read into our buffer and return it until we have
-// read through the whole file.
-//
-template<class File>
-auto
-basic_file_body<File>::
-writer::
-get(error_code& ec) ->
- boost::optional<std::pair<const_buffers_type, bool>>
-{
- // Calculate the smaller of our buffer size,
- // or the amount of unread data in the file.
- auto const amount = remain_ > sizeof(buf_) ?
- sizeof(buf_) : static_cast<std::size_t>(remain_);
-
- // Handle the case where the file is zero length
- if(amount == 0)
- {
- // Modify the error code to indicate success
- // This is required by the error_code specification.
- //
- // NOTE We use the existing category instead of calling
- // into the library to get the generic category because
- // that saves us a possibly expensive atomic operation.
- //
- ec.assign(0, ec.category());
- return boost::none;
- }
-
- // Now read the next buffer
- auto const nread = body_.file_.read(buf_, amount, ec);
- if(ec)
- return boost::none;
-
- // Make sure there is forward progress
- BOOST_ASSERT(nread != 0);
- BOOST_ASSERT(nread <= remain_);
-
- // Update the amount remaining based on what we got
- remain_ -= nread;
-
- // Return the buffer to the caller.
- //
- // The second element of the pair indicates whether or
- // not there is more data. As long as there is some
- // unread bytes, there will be more data. Otherwise,
- // we set this bool to `false` so we will not be called
- // again.
- //
- ec.assign(0, ec.category());
- return {{
- const_buffers_type{buf_, nread}, // buffer to return.
- remain_ > 0 // `true` if there are more buffers.
- }};
-}
-
-//]
-
-//[example_http_file_body_5
-
-/** Algorithm for storing buffers when parsing.
-
- Objects of this type are created during parsing
- to store incoming buffers representing the body.
-*/
-template<class File>
-class basic_file_body<File>::reader
-{
- value_type& body_; // The body we are writing to
-
-public:
- // Constructor.
- //
- // This is called after the header is parsed and
- // indicates that a non-zero sized body may be present.
- // `h` holds the received message headers.
- // `b` is an instance of `basic_file_body`.
- //
- template<bool isRequest, class Fields>
- explicit
- reader(header<isRequest, Fields>&h, value_type& b);
-
- // Initializer
- //
- // This is called before the body is parsed and
- // gives the reader a chance to do something that might
- // need to return an error code. It informs us of
- // the payload size (`content_length`) which we can
- // optionally use for optimization.
- //
- void
- init(boost::optional<std::uint64_t> const&, error_code& ec);
-
- // This function is called one or more times to store
- // buffer sequences corresponding to the incoming body.
- //
- template<class ConstBufferSequence>
- std::size_t
- put(ConstBufferSequence const& buffers,
- error_code& ec);
-
- // This function is called when writing is complete.
- // It is an opportunity to perform any final actions
- // which might fail, in order to return an error code.
- // Operations that might fail should not be attemped in
- // destructors, since an exception thrown from there
- // would terminate the program.
- //
- void
- finish(error_code& ec);
-};
-
-//]
-
-//[example_http_file_body_6
-
-// We don't do much in the reader constructor since the
-// file is already open.
-//
-template<class File>
-template<bool isRequest, class Fields>
-basic_file_body<File>::
-reader::
-reader(header<isRequest, Fields>& h, value_type& body)
- : body_(body)
-{
- boost::ignore_unused(h);
-}
-
-template<class File>
-void
-basic_file_body<File>::
-reader::
-init(
- boost::optional<std::uint64_t> const& content_length,
- error_code& ec)
-{
- // The file must already be open for writing
- BOOST_ASSERT(body_.file_.is_open());
-
- // We don't do anything with this but a sophisticated
- // application might check available space on the device
- // to see if there is enough room to store the body.
- boost::ignore_unused(content_length);
-
- // The error_code specification requires that we
- // either set the error to some value, or set it
- // to indicate no error.
- //
- // We don't do anything fancy so set "no error"
- ec.assign(0, ec.category());
-}
-
-// This will get called one or more times with body buffers
-//
-template<class File>
-template<class ConstBufferSequence>
-std::size_t
-basic_file_body<File>::
-reader::
-put(ConstBufferSequence const& buffers, error_code& ec)
-{
- // This function must return the total number of
- // bytes transferred from the input buffers.
- std::size_t nwritten = 0;
-
- // Loop over all the buffers in the sequence,
- // and write each one to the file.
- for(auto it = boost::asio::buffer_sequence_begin(buffers);
- it != boost::asio::buffer_sequence_end(buffers); ++it)
- {
- // Write this buffer to the file
- boost::asio::const_buffer buffer = *it;
- nwritten += body_.file_.write(
- buffer.data(), buffer.size(), ec);
- if(ec)
- return nwritten;
- }
-
- // Indicate success
- // This is required by the error_code specification
- ec.assign(0, ec.category());
-
- return nwritten;
-}
-
-// Called after writing is done when there's no error.
-template<class File>
-void
-basic_file_body<File>::
-reader::
-finish(error_code& ec)
-{
- // This has to be cleared before returning, to
- // indicate no error. The specification requires it.
- ec.assign(0, ec.category());
-}
-
-//]
-
-#if ! BOOST_BEAST_DOXYGEN
-// operator<< is not supported for file_body
-template<bool isRequest, class File, class Fields>
-std::ostream&
-operator<<(std::ostream& os, message<
- isRequest, basic_file_body<File>, Fields> const& msg) = delete;
-#endif
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/basic_parser.hpp b/contrib/restricted/boost/boost/beast/http/basic_parser.hpp
deleted file mode 100644
index 552adec7e4..0000000000
--- a/contrib/restricted/boost/boost/beast/http/basic_parser.hpp
+++ /dev/null
@@ -1,621 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_BASIC_PARSER_HPP
-#define BOOST_BEAST_HTTP_BASIC_PARSER_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/http/field.hpp>
-#include <boost/beast/http/verb.hpp>
-#include <boost/beast/http/detail/basic_parser.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/optional.hpp>
-#include <boost/assert.hpp>
-#include <limits>
-#include <memory>
-#include <type_traits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** A parser for decoding HTTP/1 wire format messages.
-
- This parser is designed to efficiently parse messages in the
- HTTP/1 wire format. It allocates no memory when input is
- presented as a single contiguous buffer, and uses minimal
- state. It will handle chunked encoding and it understands
- the semantics of the Connection, Content-Length, and Upgrade
- fields.
- The parser is optimized for the case where the input buffer
- sequence consists of a single contiguous buffer. The
- @ref flat_buffer class is provided, which guarantees
- that the input sequence of the stream buffer will be represented
- by exactly one contiguous buffer. To ensure the optimum performance
- of the parser, use @ref flat_buffer with HTTP algorithms
- such as @ref read, @ref read_some, @ref async_read, and @ref async_read_some.
- Alternatively, the caller may use custom techniques to ensure that
- the structured portion of the HTTP message (header or chunk header)
- is contained in a linear buffer.
-
- The interface uses CRTP (Curiously Recurring Template Pattern).
- To use this class directly, derive from @ref basic_parser. When
- bytes are presented, the implementation will make a series of zero
- or more calls to derived class members functions (termed "callbacks"
- in this context) matching a specific signature.
-
- Every callback must be provided by the derived class, or else
- a compilation error will be generated. This exemplar shows
- the signature and description of the callbacks required in
- the derived class.
- For each callback, the function will ensure that `!ec` is `true`
- if there was no error or set to the appropriate error code if
- there was one. If an error is set, the value is propagated to
- the caller of the parser.
-
- @par Derived Class Requirements
- @code
- template<bool isRequest>
- class derived
- : public basic_parser<isRequest, derived<isRequest>>
- {
- private:
- // The friend declaration is needed,
- // otherwise the callbacks must be made public.
- friend class basic_parser<isRequest, derived>;
-
- /// Called after receiving the request-line (isRequest == true).
- void
- on_request_impl(
- verb method, // The method verb, verb::unknown if no match
- string_view method_str, // The method as a string
- string_view target, // The request-target
- int version, // The HTTP-version
- error_code& ec); // The error returned to the caller, if any
-
- /// Called after receiving the start-line (isRequest == false).
- void
- on_response_impl(
- int code, // The status-code
- string_view reason, // The obsolete reason-phrase
- int version, // The HTTP-version
- error_code& ec); // The error returned to the caller, if any
-
- /// Called after receiving a header field.
- void
- on_field_impl(
- field f, // The known-field enumeration constant
- string_view name, // The field name string.
- string_view value, // The field value
- error_code& ec); // The error returned to the caller, if any
-
- /// Called after the complete header is received.
- void
- on_header_impl(
- error_code& ec); // The error returned to the caller, if any
-
- /// Called just before processing the body, if a body exists.
- void
- on_body_init_impl(
- boost::optional<
- std::uint64_t> const&
- content_length, // Content length if known, else `boost::none`
- error_code& ec); // The error returned to the caller, if any
-
- /// Called for each piece of the body, if a body exists.
- //!
- //! This is used when there is no chunked transfer coding.
- //!
- //! The function returns the number of bytes consumed from the
- //! input buffer. Any input octets not consumed will be will be
- //! presented on subsequent calls.
- //!
- std::size_t
- on_body_impl(
- string_view s, // A portion of the body
- error_code& ec); // The error returned to the caller, if any
-
- /// Called for each chunk header.
- void
- on_chunk_header_impl(
- std::uint64_t size, // The size of the upcoming chunk,
- // or zero for the last chunk
- string_view extension, // The chunk extensions (may be empty)
- error_code& ec); // The error returned to the caller, if any
-
- /// Called to deliver the chunk body.
- //!
- //! This is used when there is a chunked transfer coding. The
- //! implementation will automatically remove the encoding before
- //! calling this function.
- //!
- //! The function returns the number of bytes consumed from the
- //! input buffer. Any input octets not consumed will be will be
- //! presented on subsequent calls.
- //!
- std::size_t
- on_chunk_body_impl(
- std::uint64_t remain, // The number of bytes remaining in the chunk,
- // including what is being passed here.
- // or zero for the last chunk
- string_view body, // The next piece of the chunk body
- error_code& ec); // The error returned to the caller, if any
-
- /// Called when the complete message is parsed.
- void
- on_finish_impl(error_code& ec);
-
- public:
- derived() = default;
- };
- @endcode
-
- @tparam isRequest A `bool` indicating whether the parser will be
- presented with request or response message.
-
- @tparam Derived The derived class type. This is part of the
- Curiously Recurring Template Pattern interface.
-
- @note If the parser encounters a field value with obs-fold
- longer than 4 kilobytes in length, an error is generated.
-*/
-template<bool isRequest, class Derived>
-class basic_parser
- : private detail::basic_parser_base
-{
- template<bool OtherIsRequest, class OtherDerived>
- friend class basic_parser;
-
- // limit on the size of the stack flat buffer
- static std::size_t constexpr max_stack_buffer = 8192;
-
- // Message will be complete after reading header
- static unsigned constexpr flagSkipBody = 1<< 0;
-
- // Consume input buffers across semantic boundaries
- static unsigned constexpr flagEager = 1<< 1;
-
- // The parser has read at least one byte
- static unsigned constexpr flagGotSome = 1<< 2;
-
- // Message semantics indicate a body is expected.
- // cleared if flagSkipBody set
- //
- static unsigned constexpr flagHasBody = 1<< 3;
-
- static unsigned constexpr flagHTTP11 = 1<< 4;
- static unsigned constexpr flagNeedEOF = 1<< 5;
- static unsigned constexpr flagExpectCRLF = 1<< 6;
- static unsigned constexpr flagConnectionClose = 1<< 7;
- static unsigned constexpr flagConnectionUpgrade = 1<< 8;
- static unsigned constexpr flagConnectionKeepAlive = 1<< 9;
- static unsigned constexpr flagContentLength = 1<< 10;
- static unsigned constexpr flagChunked = 1<< 11;
- static unsigned constexpr flagUpgrade = 1<< 12;
- static unsigned constexpr flagFinalChunk = 1<< 13;
-
- static constexpr
- std::uint64_t
- default_body_limit(std::true_type)
- {
- // limit for requests
- return 1 * 1024 * 1024; // 1MB
- }
-
- static constexpr
- std::uint64_t
- default_body_limit(std::false_type)
- {
- // limit for responses
- return 8 * 1024 * 1024; // 8MB
- }
-
- std::uint64_t body_limit_ =
- default_body_limit(is_request{}); // max payload body
- std::uint64_t len_ = 0; // size of chunk or body
- std::unique_ptr<char[]> buf_; // temp storage
- std::size_t buf_len_ = 0; // size of buf_
- std::size_t skip_ = 0; // resume search here
- std::uint32_t header_limit_ = 8192; // max header size
- unsigned short status_ = 0; // response status
- state state_ = state::nothing_yet; // initial state
- unsigned f_ = 0; // flags
-
-protected:
- /// Default constructor
- basic_parser() = default;
-
- /// Move constructor
- basic_parser(basic_parser &&) = default;
-
- /// Move assignment
- basic_parser& operator=(basic_parser &&) = default;
-
- /** Move constructor
-
- @note
-
- After the move, the only valid operation on the
- moved-from object is destruction.
- */
- template<class OtherDerived>
- basic_parser(basic_parser<isRequest, OtherDerived>&&);
-
-public:
- /// `true` if this parser parses requests, `false` for responses.
- using is_request =
- std::integral_constant<bool, isRequest>;
-
- /// Destructor
- ~basic_parser() = default;
-
- /// Copy constructor
- basic_parser(basic_parser const&) = delete;
-
- /// Copy assignment
- basic_parser& operator=(basic_parser const&) = delete;
-
- /** Returns a reference to this object as a @ref basic_parser.
-
- This is used to pass a derived class where a base class is
- expected, to choose a correct function overload when the
- resolution would be ambiguous.
- */
- basic_parser&
- base()
- {
- return *this;
- }
-
- /** Returns a constant reference to this object as a @ref basic_parser.
-
- This is used to pass a derived class where a base class is
- expected, to choose a correct function overload when the
- resolution would be ambiguous.
- */
- basic_parser const&
- base() const
- {
- return *this;
- }
-
- /// Returns `true` if the parser has received at least one byte of input.
- bool
- got_some() const
- {
- return state_ != state::nothing_yet;
- }
-
- /** Returns `true` if the message is complete.
-
- The message is complete after the full header is prduced
- and one of the following is true:
-
- @li The skip body option was set.
-
- @li The semantics of the message indicate there is no body.
-
- @li The semantics of the message indicate a body is expected,
- and the entire body was parsed.
- */
- bool
- is_done() const
- {
- return state_ == state::complete;
- }
-
- /** Returns `true` if a the parser has produced the full header.
- */
- bool
- is_header_done() const
- {
- return state_ > state::fields;
- }
-
- /** Returns `true` if the message is an upgrade message.
-
- @note The return value is undefined unless
- @ref is_header_done would return `true`.
- */
- bool
- upgrade() const
- {
- return (f_ & flagConnectionUpgrade) != 0;
- }
-
- /** Returns `true` if the last value for Transfer-Encoding is "chunked".
-
- @note The return value is undefined unless
- @ref is_header_done would return `true`.
- */
- bool
- chunked() const
- {
- return (f_ & flagChunked) != 0;
- }
-
- /** Returns `true` if the message has keep-alive connection semantics.
-
- This function always returns `false` if @ref need_eof would return
- `false`.
-
- @note The return value is undefined unless
- @ref is_header_done would return `true`.
- */
- bool
- keep_alive() const;
-
- /** Returns the optional value of Content-Length if known.
-
- @note The return value is undefined unless
- @ref is_header_done would return `true`.
- */
- boost::optional<std::uint64_t>
- content_length() const;
-
- /** Returns `true` if the message semantics require an end of file.
-
- Depending on the contents of the header, the parser may
- require and end of file notification to know where the end
- of the body lies. If this function returns `true` it will be
- necessary to call @ref put_eof when there will never be additional
- data from the input.
- */
- bool
- need_eof() const
- {
- return (f_ & flagNeedEOF) != 0;
- }
-
- /** Set the limit on the payload body.
-
- This function sets the maximum allowed size of the payload body,
- before any encodings except chunked have been removed. Depending
- on the message semantics, one of these cases will apply:
-
- @li The Content-Length is specified and exceeds the limit. In
- this case the result @ref error::body_limit is returned
- immediately after the header is parsed.
-
- @li The Content-Length is unspecified and the chunked encoding
- is not specified as the last encoding. In this case the end of
- message is determined by the end of file indicator on the
- associated stream or input source. If a sufficient number of
- body payload octets are presented to the parser to exceed the
- configured limit, the parse fails with the result
- @ref error::body_limit
-
- @li The Transfer-Encoding specifies the chunked encoding as the
- last encoding. In this case, when the number of payload body
- octets produced by removing the chunked encoding exceeds
- the configured limit, the parse fails with the result
- @ref error::body_limit.
-
- Setting the limit after any body octets have been parsed
- results in undefined behavior.
-
- The default limit is 1MB for requests and 8MB for responses.
-
- @param v The payload body limit to set
- */
- void
- body_limit(std::uint64_t v)
- {
- body_limit_ = v;
- }
-
- /** Set a limit on the total size of the header.
-
- This function sets the maximum allowed size of the header
- including all field name, value, and delimiter characters
- and also including the CRLF sequences in the serialized
- input. If the end of the header is not found within the
- limit of the header size, the error @ref error::header_limit
- is returned by @ref put.
-
- Setting the limit after any header octets have been parsed
- results in undefined behavior.
- */
- void
- header_limit(std::uint32_t v)
- {
- header_limit_ = v;
- }
-
- /// Returns `true` if the eager parse option is set.
- bool
- eager() const
- {
- return (f_ & flagEager) != 0;
- }
-
- /** Set the eager parse option.
-
- Normally the parser returns after successfully parsing a structured
- element (header, chunk header, or chunk body) even if there are octets
- remaining in the input. This is necessary when attempting to parse the
- header first, or when the caller wants to inspect information which may
- be invalidated by subsequent parsing, such as a chunk extension. The
- `eager` option controls whether the parser keeps going after parsing
- structured element if there are octets remaining in the buffer and no
- error occurs. This option is automatically set or cleared during certain
- stream operations to improve performance with no change in functionality.
-
- The default setting is `false`.
-
- @param v `true` to set the eager parse option or `false` to disable it.
- */
- void
- eager(bool v)
- {
- if(v)
- f_ |= flagEager;
- else
- f_ &= ~flagEager;
- }
-
- /// Returns `true` if the skip parse option is set.
- bool
- skip() const
- {
- return (f_ & flagSkipBody) != 0;
- }
-
- /** Set the skip parse option.
-
- This option controls whether or not the parser expects to see an HTTP
- body, regardless of the presence or absence of certain fields such as
- Content-Length or a chunked Transfer-Encoding. Depending on the request,
- some responses do not carry a body. For example, a 200 response to a
- CONNECT request from a tunneling proxy, or a response to a HEAD request.
- In these cases, callers may use this function inform the parser that
- no body is expected. The parser will consider the message complete
- after the header has been received.
-
- @param v `true` to set the skip body option or `false` to disable it.
-
- @note This function must called before any bytes are processed.
- */
- void
- skip(bool v);
-
- /** Write a buffer sequence to the parser.
-
- This function attempts to incrementally parse the HTTP
- message data stored in the caller provided buffers. Upon
- success, a positive return value indicates that the parser
- made forward progress, consuming that number of
- bytes.
-
- In some cases there may be an insufficient number of octets
- in the input buffer in order to make forward progress. This
- is indicated by the code @ref error::need_more. When
- this happens, the caller should place additional bytes into
- the buffer sequence and call @ref put again.
-
- The error code @ref error::need_more is special. When this
- error is returned, a subsequent call to @ref put may succeed
- if the buffers have been updated. Otherwise, upon error
- the parser may not be restarted.
-
- @param buffers An object meeting the requirements of
- @b ConstBufferSequence that represents the next chunk of
- message data. If the length of this buffer sequence is
- one, the implementation will not allocate additional memory.
- The class @ref beast::flat_buffer is provided as one way to
- meet this requirement
-
- @param ec Set to the error, if any occurred.
-
- @return The number of octets consumed in the buffer
- sequence. The caller should remove these octets even if the
- error is set.
- */
- template<class ConstBufferSequence>
- std::size_t
- put(ConstBufferSequence const& buffers, error_code& ec);
-
-#if ! BOOST_BEAST_DOXYGEN
- std::size_t
- put(boost::asio::const_buffer const& buffer,
- error_code& ec);
-#endif
-
- /** Inform the parser that the end of stream was reached.
-
- In certain cases, HTTP needs to know where the end of
- the stream is. For example, sometimes servers send
- responses without Content-Length and expect the client
- to consume input (for the body) until EOF. Callbacks
- and errors will still be processed as usual.
-
- This is typically called when a read from the
- underlying stream object sets the error code to
- `boost::asio::error::eof`.
-
- @note Only valid after parsing a complete header.
-
- @param ec Set to the error, if any occurred.
- */
- void
- put_eof(error_code& ec);
-
-private:
- inline
- Derived&
- impl()
- {
- return *static_cast<Derived*>(this);
- }
-
- template<class ConstBufferSequence>
- std::size_t
- put_from_stack(std::size_t size,
- ConstBufferSequence const& buffers,
- error_code& ec);
-
- void
- maybe_need_more(
- char const* p, std::size_t n,
- error_code& ec);
-
- void
- parse_start_line(
- char const*& p, char const* last,
- error_code& ec, std::true_type);
-
- void
- parse_start_line(
- char const*& p, char const* last,
- error_code& ec, std::false_type);
-
- void
- parse_fields(
- char const*& p, char const* last,
- error_code& ec);
-
- void
- finish_header(
- error_code& ec, std::true_type);
-
- void
- finish_header(
- error_code& ec, std::false_type);
-
- void
- parse_body(char const*& p,
- std::size_t n, error_code& ec);
-
- void
- parse_body_to_eof(char const*& p,
- std::size_t n, error_code& ec);
-
- void
- parse_chunk_header(char const*& p,
- std::size_t n, error_code& ec);
-
- void
- parse_chunk_body(char const*& p,
- std::size_t n, error_code& ec);
-
- void
- do_field(field f,
- string_view value, error_code& ec);
-};
-
-} // http
-} // beast
-} // boost
-
-#include <boost/beast/http/impl/basic_parser.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/buffer_body.hpp b/contrib/restricted/boost/boost/beast/http/buffer_body.hpp
deleted file mode 100644
index 3ffe0a002a..0000000000
--- a/contrib/restricted/boost/boost/beast/http/buffer_body.hpp
+++ /dev/null
@@ -1,227 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_BUFFER_BODY_HPP
-#define BOOST_BEAST_HTTP_BUFFER_BODY_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/http/error.hpp>
-#include <boost/beast/http/message.hpp>
-#include <boost/beast/http/type_traits.hpp>
-#include <boost/optional.hpp>
-#include <type_traits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** A @b Body using a caller provided buffer
-
- Messages using this body type may be serialized and parsed.
- To use this class, the caller must initialize the members
- of @ref buffer_body::value_type to appropriate values before
- each call to read or write during a stream operation.
-*/
-struct buffer_body
-{
- /// The type of the body member when used in a message.
- struct value_type
- {
- /** A pointer to a contiguous area of memory of @ref size octets, else `nullptr`.
-
- @par When Serializing
-
- If this is `nullptr` and `more` is `true`, the error
- @ref error::need_buffer will be returned from @ref serializer::get
- Otherwise, the serializer will use the memory pointed to
- by `data` having `size` octets of valid storage as the
- next buffer representing the body.
-
- @par When Parsing
-
- If this is `nullptr`, the error @ref error::need_buffer
- will be returned from @ref parser::put. Otherwise, the
- parser will store body octets into the memory pointed to
- by `data` having `size` octets of valid storage. After
- octets are stored, the `data` and `size` members are
- adjusted: `data` is incremented to point to the next
- octet after the data written, while `size` is decremented
- to reflect the remaining space at the memory location
- pointed to by `data`.
- */
- void* data = nullptr;
-
- /** The number of octets in the buffer pointed to by @ref data.
-
- @par When Serializing
-
- If `data` is `nullptr` during serialization, this value
- is ignored. Otherwise, it represents the number of valid
- body octets pointed to by `data`.
-
- @par When Parsing
-
- The value of this field will be decremented during parsing
- to indicate the number of remaining free octets in the
- buffer pointed to by `data`. When it reaches zero, the
- parser will return @ref error::need_buffer, indicating to
- the caller that the values of `data` and `size` should be
- updated to point to a new memory buffer.
- */
- std::size_t size = 0;
-
- /** `true` if this is not the last buffer.
-
- @par When Serializing
-
- If this is `true` and `data` is `nullptr`, the error
- @ref error::need_buffer will be returned from @ref serializer::get
-
- @par When Parsing
-
- This field is not used during parsing.
- */
- bool more = true;
- };
-
- /** The algorithm for parsing the body
-
- Meets the requirements of @b BodyReader.
- */
-#if BOOST_BEAST_DOXYGEN
- using reader = implementation_defined;
-#else
- class reader
- {
- value_type& body_;
-
- public:
- template<bool isRequest, class Fields>
- explicit
- reader(header<isRequest, Fields>&, value_type& b)
- : body_(b)
- {
- }
-
- void
- init(boost::optional<std::uint64_t> const&, error_code& ec)
- {
- ec.assign(0, ec.category());
- }
-
- template<class ConstBufferSequence>
- std::size_t
- put(ConstBufferSequence const& buffers,
- error_code& ec)
- {
- using boost::asio::buffer_size;
- using boost::asio::buffer_copy;
- if(! body_.data)
- {
- ec = error::need_buffer;
- return 0;
- }
- auto const bytes_transferred =
- buffer_copy(boost::asio::buffer(
- body_.data, body_.size), buffers);
- body_.data = reinterpret_cast<char*>(
- body_.data) + bytes_transferred;
- body_.size -= bytes_transferred;
- if(bytes_transferred == buffer_size(buffers))
- ec.assign(0, ec.category());
- else
- ec = error::need_buffer;
- return bytes_transferred;
- }
-
- void
- finish(error_code& ec)
- {
- ec.assign(0, ec.category());
- }
- };
-#endif
-
- /** The algorithm for serializing the body
-
- Meets the requirements of @b BodyWriter.
- */
-#if BOOST_BEAST_DOXYGEN
- using writer = implementation_defined;
-#else
- class writer
- {
- bool toggle_ = false;
- value_type const& body_;
-
- public:
- using const_buffers_type =
- boost::asio::const_buffer;
-
- template<bool isRequest, class Fields>
- explicit
- writer(header<isRequest, Fields> const&, value_type const& b)
- : body_(b)
- {
- }
-
- void
- init(error_code& ec)
- {
- ec.assign(0, ec.category());
- }
-
- boost::optional<
- std::pair<const_buffers_type, bool>>
- get(error_code& ec)
- {
- if(toggle_)
- {
- if(body_.more)
- {
- toggle_ = false;
- ec = error::need_buffer;
- }
- else
- {
- ec.assign(0, ec.category());
- }
- return boost::none;
- }
- if(body_.data)
- {
- ec.assign(0, ec.category());
- toggle_ = true;
- return {{const_buffers_type{
- body_.data, body_.size}, body_.more}};
- }
- if(body_.more)
- ec = error::need_buffer;
- else
- ec.assign(0, ec.category());
- return boost::none;
- }
- };
-#endif
-};
-
-#if ! BOOST_BEAST_DOXYGEN
-// operator<< is not supported for buffer_body
-template<bool isRequest, class Fields>
-std::ostream&
-operator<<(std::ostream& os, message<isRequest,
- buffer_body, Fields> const& msg) = delete;
-#endif
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/chunk_encode.hpp b/contrib/restricted/boost/boost/beast/http/chunk_encode.hpp
deleted file mode 100644
index 4994765fc8..0000000000
--- a/contrib/restricted/boost/boost/beast/http/chunk_encode.hpp
+++ /dev/null
@@ -1,736 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_CHUNK_ENCODE_HPP
-#define BOOST_BEAST_HTTP_CHUNK_ENCODE_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/buffers_cat.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/http/type_traits.hpp>
-#include <boost/beast/http/detail/chunk_encode.hpp>
-#include <boost/asio/buffer.hpp>
-#include <memory>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** A chunked encoding crlf
-
- This implements a @b ConstBufferSequence holding the CRLF
- (`"\r\n"`) used as a delimiter in a @em chunk.
-
- To use this class, pass an instance of it to a
- stream algorithm as the buffer sequence:
- @code
- // writes "\r\n"
- boost::asio::write(stream, chunk_crlf{});
- @endcode
-
- @see https://tools.ietf.org/html/rfc7230#section-4.1
-*/
-struct chunk_crlf
-{
- /// Constructor
- chunk_crlf() = default;
-
- //-----
-
- /// Required for @b ConstBufferSequence
-#if BOOST_BEAST_DOXYGEN
- using value_type = implementation_defined;
-#else
- using value_type = detail::chunk_crlf_iter::value_type;
-#endif
-
- /// Required for @b ConstBufferSequence
- using const_iterator = value_type const*;
-
- /// Required for @b ConstBufferSequence
- chunk_crlf(chunk_crlf const&) = default;
-
- /// Required for @b ConstBufferSequence
- const_iterator
- begin() const
- {
- return &detail::chunk_crlf_iter::value;
- }
-
- /// Required for @b ConstBufferSequence
- const_iterator
- end() const
- {
- return begin() + 1;
- }
-};
-
-//------------------------------------------------------------------------------
-
-/** A @em chunk header
-
- This implements a @b ConstBufferSequence representing the
- header of a @em chunk. The serialized format is as follows:
- @code
- chunk-header = 1*HEXDIG chunk-ext CRLF
- chunk-ext = *( ";" chunk-ext-name [ "=" chunk-ext-val ] )
- chunk-ext-name = token
- chunk-ext-val = token / quoted-string
- @endcode
- The chunk extension is optional. After the header and
- chunk body have been serialized, it is the callers
- responsibility to also serialize the final CRLF (`"\r\n"`).
-
- This class allows the caller to emit piecewise chunk bodies,
- by first serializing the chunk header using this class and then
- serializing the chunk body in a series of one or more calls to
- a stream write operation.
-
- To use this class, pass an instance of it to a
- stream algorithm as the buffer sequence:
- @code
- // writes "400;x\r\n"
- boost::asio::write(stream, chunk_header{1024, "x"});
- @endcode
-
- @see https://tools.ietf.org/html/rfc7230#section-4.1
-*/
-class chunk_header
-{
- using view_type = buffers_cat_view<
- detail::chunk_size, // chunk-size
- boost::asio::const_buffer, // chunk-extensions
- chunk_crlf>; // CRLF
-
- std::shared_ptr<
- detail::chunk_extensions> exts_;
- view_type view_;
-
-public:
- /** Constructor
-
- This constructs a buffer sequence representing a
- @em chunked-body size and terminating CRLF (`"\r\n"`)
- with no chunk extensions.
-
- @param size The size of the chunk body that follows.
- The value must be greater than zero.
-
- @see https://tools.ietf.org/html/rfc7230#section-4.1
- */
- explicit
- chunk_header(std::size_t size);
-
- /** Constructor
-
- This constructs a buffer sequence representing a
- @em chunked-body size and terminating CRLF (`"\r\n"`)
- with provided chunk extensions.
-
- @param size The size of the chunk body that follows.
- The value must be greater than zero.
-
- @param extensions The chunk extensions string. This
- string must be formatted correctly as per rfc7230,
- using this BNF syntax:
- @code
- chunk-ext = *( ";" chunk-ext-name [ "=" chunk-ext-val ] )
- chunk-ext-name = token
- chunk-ext-val = token / quoted-string
- @endcode
- The data pointed to by this string view must remain
- valid for the lifetime of any operations performed on
- the object.
-
- @see https://tools.ietf.org/html/rfc7230#section-4.1.1
- */
- chunk_header(
- std::size_t size,
- string_view extensions);
-
- /** Constructor
-
- This constructs a buffer sequence representing a
- @em chunked-body size and terminating CRLF (`"\r\n"`)
- with provided chunk extensions.
- The default allocator is used to provide storage for the
- extensions object.
-
- @param size The size of the chunk body that follows.
- The value must be greater than zero.
-
- @param extensions The chunk extensions object. The expression
- `extensions.str()` must be valid, and the return type must
- be convertible to @ref string_view. This object will be copied
- or moved as needed to ensure that the chunk header object retains
- ownership of the buffers provided by the chunk extensions object.
-
- @note This function participates in overload resolution only
- if @b ChunkExtensions meets the requirements stated above.
-
- @see https://tools.ietf.org/html/rfc7230#section-4.1
- */
- template<class ChunkExtensions
-#if ! BOOST_BEAST_DOXYGEN
- , class = typename std::enable_if<
- detail::is_chunk_extensions<
- ChunkExtensions>::value>::type
-#endif
- >
- chunk_header(
- std::size_t size,
- ChunkExtensions&& extensions);
-
- /** Constructor
-
- This constructs a buffer sequence representing a
- @em chunked-body size and terminating CRLF (`"\r\n"`)
- with provided chunk extensions.
- The specified allocator is used to provide storage for the
- extensions object.
-
- @param size The size of the chunk body that follows.
- The value be greater than zero.
-
- @param extensions The chunk extensions object. The expression
- `extensions.str()` must be valid, and the return type must
- be convertible to @ref string_view. This object will be copied
- or moved as needed to ensure that the chunk header object retains
- ownership of the buffers provided by the chunk extensions object.
-
- @param allocator The allocator to provide storage for the moved
- or copied extensions object.
-
- @note This function participates in overload resolution only
- if @b ChunkExtensions meets the requirements stated above.
-
- @see https://tools.ietf.org/html/rfc7230#section-4.1
- */
- template<class ChunkExtensions, class Allocator
-#if ! BOOST_BEAST_DOXYGEN
- , class = typename std::enable_if<
- detail::is_chunk_extensions<
- ChunkExtensions>::value>::type
-#endif
- >
- chunk_header(
- std::size_t size,
- ChunkExtensions&& extensions,
- Allocator const& allocator);
-
- //-----
-
- /// Required for @b ConstBufferSequence
-#if BOOST_BEAST_DOXYGEN
- using value_type = implementation_defined;
-#else
- using value_type = typename view_type::value_type;
-#endif
-
- /// Required for @b ConstBufferSequence
-#if BOOST_BEAST_DOXYGEN
- using const_iterator = implementation_defined;
-#else
- using const_iterator = typename view_type::const_iterator;
-#endif
-
- /// Required for @b ConstBufferSequence
- chunk_header(chunk_header const&) = default;
-
- /// Required for @b ConstBufferSequence
- const_iterator
- begin() const
- {
- return view_.begin();
- }
-
- /// Required for @b ConstBufferSequence
- const_iterator
- end() const
- {
- return view_.end();
- }
-};
-
-//------------------------------------------------------------------------------
-
-/** A @em chunk
-
- This implements a @b ConstBufferSequence representing
- a @em chunk. The serialized format is as follows:
- @code
- chunk = chunk-size [ chunk-ext ] CRLF chunk-data CRLF
- chunk-size = 1*HEXDIG
- chunk-ext = *( ";" chunk-ext-name [ "=" chunk-ext-val ] )
- chunk-ext-name = token
- chunk-ext-val = token / quoted-string
- chunk-data = 1*OCTET ; a sequence of chunk-size octets
- @endcode
- The chunk extension is optional.
-
- To use this class, pass an instance of it to a
- stream algorithm as the buffer sequence.
-
- @see https://tools.ietf.org/html/rfc7230#section-4.1
-*/
-template<class ConstBufferSequence>
-class chunk_body
-{
- using view_type = buffers_cat_view<
- detail::chunk_size, // chunk-size
- boost::asio::const_buffer, // chunk-extensions
- chunk_crlf, // CRLF
- ConstBufferSequence, // chunk-body
- chunk_crlf>; // CRLF
-
- std::shared_ptr<
- detail::chunk_extensions> exts_;
- view_type view_;
-
-public:
- /** Constructor
-
- This constructs buffers representing a complete @em chunk
- with no chunk extensions and having the size and contents
- of the specified buffer sequence.
-
- @param buffers A buffer sequence representing the chunk
- body. Although the buffers object may be copied as necessary,
- ownership of the underlying memory blocks is retained by the
- caller, which must guarantee that they remain valid while this
- object is in use.
-
- @see https://tools.ietf.org/html/rfc7230#section-4.1
- */
- explicit
- chunk_body(
- ConstBufferSequence const& buffers);
-
- /** Constructor
-
- This constructs buffers representing a complete @em chunk
- with the passed chunk extensions and having the size and
- contents of the specified buffer sequence.
-
- @param buffers A buffer sequence representing the chunk
- body. Although the buffers object may be copied as necessary,
- ownership of the underlying memory blocks is retained by the
- caller, which must guarantee that they remain valid while this
- object is in use.
-
- @param extensions The chunk extensions string. This
- string must be formatted correctly as per rfc7230,
- using this BNF syntax:
- @code
- chunk-ext = *( ";" chunk-ext-name [ "=" chunk-ext-val ] )
- chunk-ext-name = token
- chunk-ext-val = token / quoted-string
- @endcode
- The data pointed to by this string view must remain
- valid for the lifetime of any operations performed on
- the object.
-
- @see https://tools.ietf.org/html/rfc7230#section-4.1.1
- */
- chunk_body(
- ConstBufferSequence const& buffers,
- string_view extensions);
-
- /** Constructor
-
- This constructs buffers representing a complete @em chunk
- with the passed chunk extensions and having the size and
- contents of the specified buffer sequence.
- The default allocator is used to provide storage for the
- extensions object.
-
- @param buffers A buffer sequence representing the chunk
- body. Although the buffers object may be copied as necessary,
- ownership of the underlying memory blocks is retained by the
- caller, which must guarantee that they remain valid while this
- object is in use.
-
- @param extensions The chunk extensions object. The expression
- `extensions.str()` must be valid, and the return type must
- be convertible to @ref string_view. This object will be copied
- or moved as needed to ensure that the chunk header object retains
- ownership of the buffers provided by the chunk extensions object.
-
- @note This function participates in overload resolution only
- if @b ChunkExtensions meets the requirements stated above.
-
- @see https://tools.ietf.org/html/rfc7230#section-4.1
- */
- template<class ChunkExtensions
-#if ! BOOST_BEAST_DOXYGEN
- , class = typename std::enable_if<
- ! std::is_convertible<typename std::decay<
- ChunkExtensions>::type, string_view>::value>::type
-#endif
- >
- chunk_body(
- ConstBufferSequence const& buffers,
- ChunkExtensions&& extensions);
-
- /** Constructor
-
- This constructs buffers representing a complete @em chunk
- with the passed chunk extensions and having the size and
- contents of the specified buffer sequence.
- The specified allocator is used to provide storage for the
- extensions object.
-
- @param buffers A buffer sequence representing the chunk
- body. Although the buffers object may be copied as necessary,
- ownership of the underlying memory blocks is retained by the
- caller, which must guarantee that they remain valid while this
- object is in use.
-
- @param extensions The chunk extensions object. The expression
- `extensions.str()` must be valid, and the return type must
- be convertible to @ref string_view. This object will be copied
- or moved as needed to ensure that the chunk header object retains
- ownership of the buffers provided by the chunk extensions object.
-
- @param allocator The allocator to provide storage for the moved
- or copied extensions object.
-
- @note This function participates in overload resolution only
- if @b ChunkExtensions meets the requirements stated above.
-
- @see https://tools.ietf.org/html/rfc7230#section-4.1
- */
- template<class ChunkExtensions, class Allocator
-#if ! BOOST_BEAST_DOXYGEN
- , class = typename std::enable_if<
- ! std::is_convertible<typename std::decay<
- ChunkExtensions>::type, string_view>::value>::type
-#endif
- >
- chunk_body(
- ConstBufferSequence const& buffers,
- ChunkExtensions&& extensions,
- Allocator const& allocator);
-
- //-----
-
- /// Required for @b ConstBufferSequence
-#if BOOST_BEAST_DOXYGEN
- using value_type = implementation_defined;
-#else
- using value_type = typename view_type::value_type;
-#endif
-
- /// Required for @b ConstBufferSequence
-#if BOOST_BEAST_DOXYGEN
- using const_iterator = implementation_defined;
-#else
- using const_iterator = typename view_type::const_iterator;
-#endif
-
- /// Required for @b ConstBufferSequence
- const_iterator
- begin() const
- {
- return view_.begin();
- }
-
- /// Required for @b ConstBufferSequence
- const_iterator
- end() const
- {
- return view_.end();
- }
-};
-
-//------------------------------------------------------------------------------
-
-/** A chunked-encoding last chunk
-*/
-template<class Trailer = chunk_crlf>
-class chunk_last
-{
- static_assert(
- is_fields<Trailer>::value ||
- boost::asio::is_const_buffer_sequence<Trailer>::value,
- "Trailer requirements not met");
-
- using buffers_type = typename
- detail::buffers_or_fields<Trailer>::type;
-
- using view_type =
- buffers_cat_view<
- detail::chunk_size0, // "0\r\n"
- buffers_type>; // Trailer (includes CRLF)
-
- template<class Allocator>
- buffers_type
- prepare(Trailer const& trailer, Allocator const& alloc);
-
- buffers_type
- prepare(Trailer const& trailer, std::true_type);
-
- buffers_type
- prepare(Trailer const& trailer, std::false_type);
-
- std::shared_ptr<void> sp_;
- view_type view_;
-
-public:
- /** Constructor
-
- The last chunk will have an empty trailer
- */
- chunk_last();
-
- /** Constructor
-
- @param trailer The trailer to use. This may be
- a type meeting the requirements of either Fields
- or ConstBufferSequence. If it is a ConstBufferSequence,
- the trailer must be formatted correctly as per rfc7230
- including a CRLF on its own line to denote the end
- of the trailer.
- */
- explicit
- chunk_last(Trailer const& trailer);
-
- /** Constructor
-
- @param trailer The trailer to use. This type must
- meet the requirements of Fields.
-
- @param allocator The allocator to use for storing temporary
- data associated with the serialized trailer buffers.
- */
-#if BOOST_BEAST_DOXYGEN
- template<class Allocator>
- chunk_last(Trailer const& trailer, Allocator const& allocator);
-#else
- template<class DeducedTrailer, class Allocator,
- class = typename std::enable_if<
- is_fields<DeducedTrailer>::value>::type>
- chunk_last(
- DeducedTrailer const& trailer, Allocator const& allocator);
-#endif
-
- //-----
-
- /// Required for @b ConstBufferSequence
- chunk_last(chunk_last const&) = default;
-
- /// Required for @b ConstBufferSequence
-#if BOOST_BEAST_DOXYGEN
- using value_type = implementation_defined;
-#else
- using value_type =
- typename view_type::value_type;
-#endif
-
- /// Required for @b ConstBufferSequence
-#if BOOST_BEAST_DOXYGEN
- using const_iterator = implementation_defined;
-#else
- using const_iterator =
- typename view_type::const_iterator;
-#endif
-
- /// Required for @b ConstBufferSequence
- const_iterator
- begin() const
- {
- return view_.begin();
- }
-
- /// Required for @b ConstBufferSequence
- const_iterator
- end() const
- {
- return view_.end();
- }
-};
-
-//------------------------------------------------------------------------------
-
-/** A set of chunk extensions
-
- This container stores a set of chunk extensions suited for use with
- @ref chunk_header and @ref chunk_body. The container may be iterated
- to access the extensions in their structured form.
-
- Meets the requirements of ChunkExtensions
-*/
-template<class Allocator>
-class basic_chunk_extensions
-{
- std::basic_string<char,
- std::char_traits<char>, Allocator> s_;
-
- std::basic_string<char,
- std::char_traits<char>, Allocator> range_;
-
- template<class FwdIt>
- FwdIt
- do_parse(FwdIt it, FwdIt last, error_code& ec);
-
- void
- do_insert(string_view name, string_view value);
-
-public:
- /** The type of value when iterating.
-
- The first element of the pair is the name, and the second
- element is the value which may be empty. The value is
- stored in its raw representation, without quotes or escapes.
- */
- using value_type = std::pair<string_view, string_view>;
-
- class const_iterator;
-
- /// Constructor
- basic_chunk_extensions() = default;
-
- /// Constructor
- basic_chunk_extensions(basic_chunk_extensions&&) = default;
-
- /// Constructor
- basic_chunk_extensions(basic_chunk_extensions const&) = default;
-
- /** Constructor
-
- @param allocator The allocator to use for storing the serialized extension
- */
- explicit
- basic_chunk_extensions(Allocator const& allocator)
- : s_(allocator)
- {
- }
-
- /** Clear the chunk extensions
-
- This preserves the capacity of the internal string
- used to hold the serialized representation.
- */
- void
- clear()
- {
- s_.clear();
- }
-
- /** Parse a set of chunk extensions
-
- Any previous extensions will be cleared
- */
- void
- parse(string_view s, error_code& ec);
-
- /** Insert an extension name with an empty value
-
- @param name The name of the extension
- */
- void
- insert(string_view name);
-
- /** Insert an extension value
-
- @param name The name of the extension
-
- @param value The value to insert. Depending on the
- contents, the serialized extension may use a quoted string.
- */
- void
- insert(string_view name, string_view value);
-
- /// Return the serialized representation of the chunk extension
- string_view
- str() const
- {
- return s_;
- }
-
- const_iterator
- begin() const;
-
- const_iterator
- end() const;
-};
-
-//------------------------------------------------------------------------------
-
-/// A set of chunk extensions
-using chunk_extensions =
- basic_chunk_extensions<std::allocator<char>>;
-
-/** Returns a @ref chunk_body
-
- This functions constructs and returns a complete
- @ref chunk_body for a chunk body represented by the
- specified buffer sequence.
-
- @param buffers The buffers representing the chunk body.
-
- @param args Optional arguments passed to the @ref chunk_body constructor.
-
- @note This function is provided as a notational convenience
- to omit specification of the class template arguments.
-*/
-template<class ConstBufferSequence, class... Args>
-auto
-make_chunk(
- ConstBufferSequence const& buffers,
- Args&&... args) ->
- chunk_body<ConstBufferSequence>
-{
- return chunk_body<ConstBufferSequence>(
- buffers, std::forward<Args>(args)...);
-}
-
-/** Returns a @ref chunk_last
-
- @note This function is provided as a notational convenience
- to omit specification of the class template arguments.
-*/
-inline
-chunk_last<chunk_crlf>
-make_chunk_last()
-{
- return chunk_last<chunk_crlf>{};
-}
-
-/** Returns a @ref chunk_last
-
- This function construct and returns a complete
- @ref chunk_last for a last chunk containing the
- specified trailers.
-
- @param trailer A ConstBufferSequence or
- @note This function is provided as a notational convenience
- to omit specification of the class template arguments.
-
- @param args Optional arguments passed to the @ref chunk_last
- constructor.
-*/
-template<class Trailer, class... Args>
-chunk_last<Trailer>
-make_chunk_last(
- Trailer const& trailer,
- Args&&... args)
-{
- return chunk_last<Trailer>{
- trailer, std::forward<Args>(args)...};
-}
-
-} // http
-} // beast
-} // boost
-
-#include <boost/beast/http/impl/chunk_encode.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/detail/basic_parsed_list.hpp b/contrib/restricted/boost/boost/beast/http/detail/basic_parsed_list.hpp
deleted file mode 100644
index d1e1565252..0000000000
--- a/contrib/restricted/boost/boost/beast/http/detail/basic_parsed_list.hpp
+++ /dev/null
@@ -1,198 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_DETAIL_BASIC_PARSED_LIST_HPP
-#define BOOST_BEAST_HTTP_DETAIL_BASIC_PARSED_LIST_HPP
-
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/core/detail/empty_base_optimization.hpp>
-#include <cstddef>
-#include <iterator>
-
-namespace boost {
-namespace beast {
-namespace http {
-namespace detail {
-
-/** A list parser which presents the sequence as a container.
-*/
-template<class Policy>
-class basic_parsed_list
-{
- string_view s_;
-
-public:
- /// The type of policy this list uses for parsing.
- using policy_type = Policy;
-
- /// The type of each element in the list.
- using value_type = typename Policy::value_type;
-
- /// A constant iterator to a list element.
-#if BOOST_BEAST_DOXYGEN
- using const_iterator = implementation_defined;
-#else
- class const_iterator;
-#endif
-
- class const_iterator
- : private beast::detail::
- empty_base_optimization<Policy>
- {
- basic_parsed_list const* list_ = nullptr;
- char const* it_ = nullptr;
- typename Policy::value_type v_;
- bool error_ = false;
-
- public:
- using value_type =
- typename Policy::value_type;
- using reference = value_type const&;
- using pointer = value_type const*;
- using difference_type = std::ptrdiff_t;
- using iterator_category =
- std::forward_iterator_tag;
-
- const_iterator() = default;
-
- bool
- operator==(
- const_iterator const& other) const
- {
- return
- other.list_ == list_ &&
- other.it_ == it_;
- }
-
- bool
- operator!=(
- const_iterator const& other) const
- {
- return ! (*this == other);
- }
-
- reference
- operator*() const
- {
- return v_;
- }
-
- const_iterator&
- operator++()
- {
- increment();
- return *this;
- }
-
- const_iterator
- operator++(int)
- {
- auto temp = *this;
- ++(*this);
- return temp;
- }
-
- bool
- error() const
- {
- return error_;
- }
-
- private:
- friend class basic_parsed_list;
-
- const_iterator(
- basic_parsed_list const& list, bool at_end)
- : list_(&list)
- , it_(at_end ? nullptr :
- list.s_.begin())
- {
- if(! at_end)
- increment();
- }
-
- void
- increment()
- {
- if(! this->member()(
- v_, it_, list_->s_))
- {
- it_ = nullptr;
- error_ = true;
- }
- }
- };
-
- /// Construct a list from a string
- explicit
- basic_parsed_list(string_view s)
- : s_(s)
- {
- }
-
- /// Return a const iterator to the beginning of the list
- const_iterator begin() const;
-
- /// Return a const iterator to the end of the list
- const_iterator end() const;
-
- /// Return a const iterator to the beginning of the list
- const_iterator cbegin() const;
-
- /// Return a const iterator to the end of the list
- const_iterator cend() const;
-};
-
-template<class Policy>
-inline
-auto
-basic_parsed_list<Policy>::
-begin() const ->
- const_iterator
-{
- return const_iterator{*this, false};
-}
-
-template<class Policy>
-inline
-auto
-basic_parsed_list<Policy>::
-end() const ->
- const_iterator
-{
- return const_iterator{*this, true};
-}
-
-template<class Policy>
-inline
-auto
-basic_parsed_list<Policy>::
-cbegin() const ->
- const_iterator
-{
- return const_iterator{*this, false};
-}
-
-template<class Policy>
-inline
-auto
-basic_parsed_list<Policy>::
-cend() const ->
- const_iterator
-{
- return const_iterator{*this, true};
-}
-
-} // detail
-} // http
-} // beast
-} // boost
-
-#endif
-
diff --git a/contrib/restricted/boost/boost/beast/http/detail/basic_parser.hpp b/contrib/restricted/boost/boost/beast/http/detail/basic_parser.hpp
deleted file mode 100644
index 0936862add..0000000000
--- a/contrib/restricted/boost/boost/beast/http/detail/basic_parser.hpp
+++ /dev/null
@@ -1,896 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_DETAIL_BASIC_PARSER_HPP
-#define BOOST_BEAST_HTTP_DETAIL_BASIC_PARSER_HPP
-
-#include <boost/beast/core/static_string.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/core/detail/cpu_info.hpp>
-#include <boost/beast/http/error.hpp>
-#include <boost/beast/http/detail/rfc7230.hpp>
-#include <boost/config.hpp>
-#include <boost/version.hpp>
-#include <algorithm>
-#include <cstddef>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-namespace detail {
-
-class basic_parser_base
-{
-protected:
- // limit on the size of the obs-fold buffer
- //
- // https://stackoverflow.com/questions/686217/maximum-on-http-header-values
- //
- static std::size_t constexpr max_obs_fold = 4096;
-
- enum class state
- {
- nothing_yet = 0,
- start_line,
- fields,
- body0,
- body,
- body_to_eof0,
- body_to_eof,
- chunk_header0,
- chunk_header,
- chunk_body,
- complete
- };
-
- static
- bool
- is_pathchar(char c)
- {
- // VFALCO This looks the same as the one below...
-
- // TEXT = <any OCTET except CTLs, and excluding LWS>
- static bool constexpr tab[256] = {
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 0
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 16
- 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 32
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 48
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 64
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 80
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 96
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, // 112
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 128
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 144
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 160
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 176
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 192
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 208
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 224
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 // 240
- };
- return tab[static_cast<unsigned char>(c)];
- }
-
- static
- inline
- bool
- unhex(unsigned char& d, char c)
- {
- static signed char constexpr tab[256] = {
- -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, // 0
- -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, // 16
- -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, // 32
- 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,-1,-1,-1,-1,-1,-1, // 48
- -1,10,11,12,13,14,15,-1,-1,-1,-1,-1,-1,-1,-1,-1, // 64
- -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, // 80
- -1,10,11,12,13,14,15,-1,-1,-1,-1,-1,-1,-1,-1,-1, // 96
- -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 // 112
-
- -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 // 128
- -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 // 144
- -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 // 160
- -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 // 176
- -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 // 192
- -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 // 208
- -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 // 224
- -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1 // 240
- };
- d = static_cast<unsigned char>(
- tab[static_cast<unsigned char>(c)]);
- return d != static_cast<unsigned char>(-1);
- }
-
- static
- bool
- is_digit(char c)
- {
- return static_cast<unsigned char>(c-'0') < 10;
- }
-
- static
- bool
- is_print(char c)
- {
- return static_cast<unsigned char>(c-32) < 95;
- }
-
- template<class FwdIt>
- static
- FwdIt
- trim_front(FwdIt it, FwdIt const& end)
- {
- while(it != end)
- {
- if(*it != ' ' && *it != '\t')
- break;
- ++it;
- }
- return it;
- }
-
- template<class RanIt>
- static
- RanIt
- trim_back(
- RanIt it, RanIt const& first)
- {
- while(it != first)
- {
- auto const c = it[-1];
- if(c != ' ' && c != '\t')
- break;
- --it;
- }
- return it;
- }
-
- static
- string_view
- make_string(char const* first, char const* last)
- {
- return {first, static_cast<
- std::size_t>(last - first)};
- }
-
- //--------------------------------------------------------------------------
-
- static
- std::pair<char const*, bool>
- find_fast(
- char const* buf,
- char const* buf_end,
- char const* ranges,
- size_t ranges_size)
- {
- bool found = false;
- boost::ignore_unused(buf_end, ranges, ranges_size);
- return {buf, found};
- }
-
- // VFALCO Can SIMD help this?
- static
- char const*
- find_eol(
- char const* it, char const* last,
- error_code& ec)
- {
- for(;;)
- {
- if(it == last)
- {
- ec.assign(0, ec.category());
- return nullptr;
- }
- if(*it == '\r')
- {
- if(++it == last)
- {
- ec.assign(0, ec.category());
- return nullptr;
- }
- if(*it != '\n')
- {
- ec = error::bad_line_ending;
- return nullptr;
- }
- ec.assign(0, ec.category());
- return ++it;
- }
- // VFALCO Should we handle the legacy case
- // for lines terminated with a single '\n'?
- ++it;
- }
- }
-
- static
- char const*
- find_eom(char const* p, char const* last)
- {
- for(;;)
- {
- if(p + 4 > last)
- return nullptr;
- if(p[3] != '\n')
- {
- if(p[3] == '\r')
- ++p;
- else
- p += 4;
- }
- else if(p[2] != '\r')
- {
- p += 4;
- }
- else if(p[1] != '\n')
- {
- p += 2;
- }
- else if(p[0] != '\r')
- {
- p += 2;
- }
- else
- {
- return p + 4;
- }
- }
- }
-
- //--------------------------------------------------------------------------
-
- static
- char const*
- parse_token_to_eol(
- char const* p,
- char const* last,
- char const*& token_last,
- error_code& ec)
- {
- for(;; ++p)
- {
- if(p >= last)
- {
- ec = error::need_more;
- return p;
- }
- if(BOOST_UNLIKELY(! is_print(*p)))
- if((BOOST_LIKELY(static_cast<
- unsigned char>(*p) < '\040') &&
- BOOST_LIKELY(*p != '\011')) ||
- BOOST_UNLIKELY(*p == '\177'))
- goto found_control;
- }
- found_control:
- if(BOOST_LIKELY(*p == '\r'))
- {
- if(++p >= last)
- {
- ec = error::need_more;
- return last;
- }
- if(*p++ != '\n')
- {
- ec = error::bad_line_ending;
- return last;
- }
- token_last = p - 2;
- }
- #if 0
- // VFALCO This allows `\n` by itself
- // to terminate a line
- else if(*p == '\n')
- {
- token_last = p;
- ++p;
- }
- #endif
- else
- {
- // invalid character
- return nullptr;
- }
- return p;
- }
-
- template<class Iter, class Unsigned>
- static
- bool
- parse_dec(Iter it, Iter last, Unsigned& v)
- {
- if(! is_digit(*it))
- return false;
- v = *it - '0';
- for(;;)
- {
- if(! is_digit(*++it))
- break;
- auto const d = *it - '0';
- if(v > ((std::numeric_limits<
- Unsigned>::max)() - 10) / 10)
- return false;
- v = 10 * v + d;
- }
- return it == last;
- }
-
- template<class Iter, class Unsigned>
- static
- bool
- parse_hex(Iter& it, Unsigned& v)
- {
- unsigned char d;
- if(! unhex(d, *it))
- return false;
- v = d;
- for(;;)
- {
- if(! unhex(d, *++it))
- break;
- auto const v0 = v;
- v = 16 * v + d;
- if(v < v0)
- return false;
- }
- return true;
- }
-
- static
- bool
- parse_crlf(char const*& it)
- {
- if( it[0] != '\r' || it[1] != '\n')
- return false;
- it += 2;
- return true;
- }
-
- static
- void
- parse_method(
- char const*& it, char const* last,
- string_view& result, error_code& ec)
- {
- // parse token SP
- auto const first = it;
- for(;; ++it)
- {
- if(it + 1 > last)
- {
- ec = error::need_more;
- return;
- }
- if(! detail::is_token_char(*it))
- break;
- }
- if(it + 1 > last)
- {
- ec = error::need_more;
- return;
- }
- if(*it != ' ')
- {
- ec = error::bad_method;
- return;
- }
- if(it == first)
- {
- // cannot be empty
- ec = error::bad_method;
- return;
- }
- result = make_string(first, it++);
- }
-
- static
- void
- parse_target(
- char const*& it, char const* last,
- string_view& result, error_code& ec)
- {
- // parse target SP
- auto const first = it;
- for(;; ++it)
- {
- if(it + 1 > last)
- {
- ec = error::need_more;
- return;
- }
- if(! is_pathchar(*it))
- break;
- }
- if(it + 1 > last)
- {
- ec = error::need_more;
- return;
- }
- if(*it != ' ')
- {
- ec = error::bad_target;
- return;
- }
- if(it == first)
- {
- // cannot be empty
- ec = error::bad_target;
- return;
- }
- result = make_string(first, it++);
- }
-
- static
- void
- parse_version(
- char const*& it, char const* last,
- int& result, error_code& ec)
- {
- if(it + 8 > last)
- {
- ec = error::need_more;
- return;
- }
- if(*it++ != 'H')
- {
- ec = error::bad_version;
- return;
- }
- if(*it++ != 'T')
- {
- ec = error::bad_version;
- return;
- }
- if(*it++ != 'T')
- {
- ec = error::bad_version;
- return;
- }
- if(*it++ != 'P')
- {
- ec = error::bad_version;
- return;
- }
- if(*it++ != '/')
- {
- ec = error::bad_version;
- return;
- }
- if(! is_digit(*it))
- {
- ec = error::bad_version;
- return;
- }
- result = 10 * (*it++ - '0');
- if(*it++ != '.')
- {
- ec = error::bad_version;
- return;
- }
- if(! is_digit(*it))
- {
- ec = error::bad_version;
- return;
- }
- result += *it++ - '0';
- }
-
- static
- void
- parse_status(
- char const*& it, char const* last,
- unsigned short& result, error_code& ec)
- {
- // parse 3(digit) SP
- if(it + 4 > last)
- {
- ec = error::need_more;
- return;
- }
- if(! is_digit(*it))
- {
- ec = error::bad_status;
- return;
- }
- result = 100 * (*it++ - '0');
- if(! is_digit(*it))
- {
- ec = error::bad_status;
- return;
- }
- result += 10 * (*it++ - '0');
- if(! is_digit(*it))
- {
- ec = error::bad_status;
- return;
- }
- result += *it++ - '0';
- if(*it++ != ' ')
- {
- ec = error::bad_status;
- return;
- }
- }
-
- void
- parse_reason(
- char const*& it, char const* last,
- string_view& result, error_code& ec)
- {
- auto const first = it;
- char const* token_last = nullptr;
- auto p = parse_token_to_eol(
- it, last, token_last, ec);
- if(ec)
- return;
- if(! p)
- {
- ec = error::bad_reason;
- return;
- }
- result = make_string(first, token_last);
- it = p;
- }
-
- template<std::size_t N>
- void
- parse_field(
- char const*& p,
- char const* last,
- string_view& name,
- string_view& value,
- static_string<N>& buf,
- error_code& ec)
- {
- /* header-field = field-name ":" OWS field-value OWS
-
- field-name = token
- field-value = *( field-content / obs-fold )
- field-content = field-vchar [ 1*( SP / HTAB ) field-vchar ]
- field-vchar = VCHAR / obs-text
-
- obs-fold = CRLF 1*( SP / HTAB )
- ; obsolete line folding
- ; see Section 3.2.4
-
- token = 1*<any CHAR except CTLs or separators>
- CHAR = <any US-ASCII character (octets 0 - 127)>
- sep = "(" | ")" | "<" | ">" | "@"
- | "," | ";" | ":" | "\" | <">
- | "/" | "[" | "]" | "?" | "="
- | "{" | "}" | SP | HT
- */
- static char const* is_token =
- "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0"
- "\0\1\0\1\1\1\1\1\0\0\1\1\0\1\1\0\1\1\1\1\1\1\1\1\1\1\0\0\0\0\0\0"
- "\0\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\0\0\0\1\1"
- "\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\1\0\1\0\1\0"
- "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0"
- "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0"
- "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0"
- "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0";
-
- // name
- BOOST_ALIGNMENT(16) static const char ranges1[] =
- "\x00 " /* control chars and up to SP */
- "\"\"" /* 0x22 */
- "()" /* 0x28,0x29 */
- ",," /* 0x2c */
- "//" /* 0x2f */
- ":@" /* 0x3a-0x40 */
- "[]" /* 0x5b-0x5d */
- "{\377"; /* 0x7b-0xff */
- auto first = p;
- bool found;
- std::tie(p, found) = find_fast(
- p, last, ranges1, sizeof(ranges1)-1);
- if(! found && p >= last)
- {
- ec = error::need_more;
- return;
- }
- for(;;)
- {
- if(*p == ':')
- break;
- if(! is_token[static_cast<
- unsigned char>(*p)])
- {
- ec = error::bad_field;
- return;
- }
- ++p;
- if(p >= last)
- {
- ec = error::need_more;
- return;
- }
- }
- if(p == first)
- {
- // empty name
- ec = error::bad_field;
- return;
- }
- name = make_string(first, p);
- ++p; // eat ':'
- char const* token_last = nullptr;
- for(;;)
- {
- // eat leading ' ' and '\t'
- for(;;++p)
- {
- if(p + 1 > last)
- {
- ec = error::need_more;
- return;
- }
- if(! (*p == ' ' || *p == '\t'))
- break;
- }
- // parse to CRLF
- first = p;
- p = parse_token_to_eol(p, last, token_last, ec);
- if(ec)
- return;
- if(! p)
- {
- ec = error::bad_value;
- return;
- }
- // Look 1 char past the CRLF to handle obs-fold.
- if(p + 1 > last)
- {
- ec = error::need_more;
- return;
- }
- token_last =
- trim_back(token_last, first);
- if(*p != ' ' && *p != '\t')
- {
- value = make_string(first, token_last);
- return;
- }
- ++p;
- if(token_last != first)
- break;
- }
- buf.resize(0);
- buf.append(first, token_last);
- BOOST_ASSERT(! buf.empty());
- try
- {
- for(;;)
- {
- // eat leading ' ' and '\t'
- for(;;++p)
- {
- if(p + 1 > last)
- {
- ec = error::need_more;
- return;
- }
- if(! (*p == ' ' || *p == '\t'))
- break;
- }
- // parse to CRLF
- first = p;
- p = parse_token_to_eol(p, last, token_last, ec);
- if(ec)
- return;
- if(! p)
- {
- ec = error::bad_value;
- return;
- }
- // Look 1 char past the CRLF to handle obs-fold.
- if(p + 1 > last)
- {
- ec = error::need_more;
- return;
- }
- token_last = trim_back(token_last, first);
- if(first != token_last)
- {
- buf.push_back(' ');
- buf.append(first, token_last);
- }
- if(*p != ' ' && *p != '\t')
- {
- value = {buf.data(), buf.size()};
- return;
- }
- ++p;
- }
- }
- catch(std::length_error const&)
- {
- ec = error::header_limit;
- return;
- }
- }
-
- void
- parse_chunk_extensions(
- char const*& it,
- char const* last,
- error_code& ec)
- {
- /*
- chunk-ext = *( BWS ";" BWS chunk-ext-name [ BWS "=" BWS chunk-ext-val ] )
- BWS = *( SP / HTAB ) ; "Bad White Space"
- chunk-ext-name = token
- chunk-ext-val = token / quoted-string
- token = 1*tchar
- quoted-string = DQUOTE *( qdtext / quoted-pair ) DQUOTE
- qdtext = HTAB / SP / "!" / %x23-5B ; '#'-'[' / %x5D-7E ; ']'-'~' / obs-text
- quoted-pair = "\" ( HTAB / SP / VCHAR / obs-text )
- obs-text = %x80-FF
-
- https://www.rfc-editor.org/errata_search.php?rfc=7230&eid=4667
- */
- loop:
- if(it == last)
- {
- ec = error::need_more;
- return;
- }
- if(*it != ' ' && *it != '\t' && *it != ';')
- return;
- // BWS
- if(*it == ' ' || *it == '\t')
- {
- for(;;)
- {
- ++it;
- if(it == last)
- {
- ec = error::need_more;
- return;
- }
- if(*it != ' ' && *it != '\t')
- break;
- }
- }
- // ';'
- if(*it != ';')
- {
- ec = error::bad_chunk_extension;
- return;
- }
- semi:
- ++it; // skip ';'
- // BWS
- for(;;)
- {
- if(it == last)
- {
- ec = error::need_more;
- return;
- }
- if(*it != ' ' && *it != '\t')
- break;
- ++it;
- }
- // chunk-ext-name
- if(! detail::is_token_char(*it))
- {
- ec = error::bad_chunk_extension;
- return;
- }
- for(;;)
- {
- ++it;
- if(it == last)
- {
- ec = error::need_more;
- return;
- }
- if(! detail::is_token_char(*it))
- break;
- }
- // BWS [ ";" / "=" ]
- {
- bool bws;
- if(*it == ' ' || *it == '\t')
- {
- for(;;)
- {
- ++it;
- if(it == last)
- {
- ec = error::need_more;
- return;
- }
- if(*it != ' ' && *it != '\t')
- break;
- }
- bws = true;
- }
- else
- {
- bws = false;
- }
- if(*it == ';')
- goto semi;
- if(*it != '=')
- {
- if(bws)
- ec = error::bad_chunk_extension;
- return;
- }
- ++it; // skip '='
- }
- // BWS
- for(;;)
- {
- if(it == last)
- {
- ec = error::need_more;
- return;
- }
- if(*it != ' ' && *it != '\t')
- break;
- ++it;
- }
- // chunk-ext-val
- if(*it != '"')
- {
- // token
- if(! detail::is_token_char(*it))
- {
- ec = error::bad_chunk_extension;
- return;
- }
- for(;;)
- {
- ++it;
- if(it == last)
- {
- ec = error::need_more;
- return;
- }
- if(! detail::is_token_char(*it))
- break;
- }
- }
- else
- {
- // quoted-string
- for(;;)
- {
- ++it;
- if(it == last)
- {
- ec = error::need_more;
- return;
- }
- if(*it == '"')
- break;
- if(*it == '\\')
- {
- ++it;
- if(it == last)
- {
- ec = error::need_more;
- return;
- }
- }
- }
- ++it;
- }
- goto loop;
- }
-};
-
-} // detail
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/detail/chunk_encode.hpp b/contrib/restricted/boost/boost/beast/http/detail/chunk_encode.hpp
deleted file mode 100644
index cad48418d9..0000000000
--- a/contrib/restricted/boost/boost/beast/http/detail/chunk_encode.hpp
+++ /dev/null
@@ -1,247 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_DETAIL_CHUNK_ENCODE_HPP
-#define BOOST_BEAST_HTTP_DETAIL_CHUNK_ENCODE_HPP
-
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/http/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <algorithm>
-#include <array>
-#include <cstddef>
-#include <memory>
-
-namespace boost {
-namespace beast {
-namespace http {
-namespace detail {
-
-struct chunk_extensions
-{
- virtual ~chunk_extensions() = default;
- virtual boost::asio::const_buffer str() = 0;
-};
-
-template<class ChunkExtensions>
-struct chunk_extensions_impl : chunk_extensions
-{
- ChunkExtensions ext_;
-
- chunk_extensions_impl(ChunkExtensions&& ext)
- : ext_(std::move(ext))
- {
- }
-
- chunk_extensions_impl(ChunkExtensions const& ext)
- : ext_(ext)
- {
- }
-
- boost::asio::const_buffer
- str() override
- {
- auto const s = ext_.str();
- return {s.data(), s.size()};
- }
-};
-
-template<class T, class = void>
-struct is_chunk_extensions : std::false_type {};
-
-template<class T>
-struct is_chunk_extensions<T, beast::detail::void_t<decltype(
- std::declval<string_view&>() = std::declval<T&>().str(),
- (void)0)>> : std::true_type
-{
-};
-
-//------------------------------------------------------------------------------
-
-/** A buffer sequence containing a chunk-encoding header
-*/
-class chunk_size
-{
- template<class OutIter>
- static
- OutIter
- to_hex(OutIter last, std::size_t n)
- {
- if(n == 0)
- {
- *--last = '0';
- return last;
- }
- while(n)
- {
- *--last = "0123456789abcdef"[n&0xf];
- n>>=4;
- }
- return last;
- }
-
- struct sequence
- {
- boost::asio::const_buffer b;
- char data[1 + 2 * sizeof(std::size_t)];
-
- explicit
- sequence(std::size_t n)
- {
- char* it0 = data + sizeof(data);
- auto it = to_hex(it0, n);
- b = {it,
- static_cast<std::size_t>(it0 - it)};
- }
- };
-
- std::shared_ptr<sequence> sp_;
-
-public:
- using value_type = boost::asio::const_buffer;
-
- using const_iterator = value_type const*;
-
- chunk_size(chunk_size const& other) = default;
-
- /** Construct a chunk header
-
- @param n The number of octets in this chunk.
- */
- chunk_size(std::size_t n)
- : sp_(std::make_shared<sequence>(n))
- {
- }
-
- const_iterator
- begin() const
- {
- return &sp_->b;
- }
-
- const_iterator
- end() const
- {
- return begin() + 1;
- }
-};
-
-//------------------------------------------------------------------------------
-
-/// Returns a buffer sequence holding a CRLF for chunk encoding
-inline
-boost::asio::const_buffer
-chunk_crlf()
-{
- return {"\r\n", 2};
-}
-
-/// Returns a buffer sequence holding a final chunk header
-inline
-boost::asio::const_buffer
-chunk_last()
-{
- return {"0\r\n", 3};
-}
-
-//------------------------------------------------------------------------------
-
-template<class = void>
-struct chunk_crlf_iter_type
-{
- class value_type
- {
- char const s[2] = {'\r', '\n'};
-
- public:
- value_type() = default;
-
- operator
- boost::asio::const_buffer() const
- {
- return {s, sizeof(s)};
- }
- };
- static value_type value;
-};
-
-template<class T>
-typename chunk_crlf_iter_type<T>::value_type
-chunk_crlf_iter_type<T>::value;
-
-using chunk_crlf_iter = chunk_crlf_iter_type<void>;
-
-//------------------------------------------------------------------------------
-
-template<class = void>
-struct chunk_size0_iter_type
-{
- class value_type
- {
- char const s[3] = {'0', '\r', '\n'};
-
- public:
- value_type() = default;
-
- operator
- boost::asio::const_buffer() const
- {
- return {s, sizeof(s)};
- }
- };
- static value_type value;
-};
-
-template<class T>
-typename chunk_size0_iter_type<T>::value_type
-chunk_size0_iter_type<T>::value;
-
-using chunk_size0_iter = chunk_size0_iter_type<void>;
-
-struct chunk_size0
-{
- using value_type = chunk_size0_iter::value_type;
-
- using const_iterator = value_type const*;
-
- const_iterator
- begin() const
- {
- return &chunk_size0_iter::value;
- }
-
- const_iterator
- end() const
- {
- return begin() + 1;
- }
-};
-
-//------------------------------------------------------------------------------
-
-template<class T,
- bool = is_fields<T>::value>
-struct buffers_or_fields
-{
- using type = typename
- T::writer::const_buffers_type;
-};
-
-template<class T>
-struct buffers_or_fields<T, false>
-{
- using type = T;
-};
-
-} // detail
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/detail/rfc7230.hpp b/contrib/restricted/boost/boost/beast/http/detail/rfc7230.hpp
deleted file mode 100644
index fac6790579..0000000000
--- a/contrib/restricted/boost/boost/beast/http/detail/rfc7230.hpp
+++ /dev/null
@@ -1,473 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_DETAIL_RFC7230_HPP
-#define BOOST_BEAST_HTTP_DETAIL_RFC7230_HPP
-
-#include <boost/beast/core/string.hpp>
-#include <iterator>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-namespace detail {
-
-inline
-bool
-is_digit(char c)
-{
- return c >= '0' && c <= '9';
-}
-
-inline
-char
-is_alpha(char c)
-{
- static char constexpr tab[] = {
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 0
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 16
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 32
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 48
- 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 64
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, // 80
- 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 96
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, // 112
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 128
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 144
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 160
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 176
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 192
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 208
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 224
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 // 240
- };
- BOOST_STATIC_ASSERT(sizeof(tab) == 256);
- return tab[static_cast<unsigned char>(c)];
-}
-
-inline
-char
-is_text(char c)
-{
- // TEXT = <any OCTET except CTLs, but including LWS>
- static char constexpr tab[] = {
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, // 0
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 16
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 32
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 48
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 64
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 80
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 96
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, // 112
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 128
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 144
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 160
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 176
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 192
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 208
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 224
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 // 240
- };
- BOOST_STATIC_ASSERT(sizeof(tab) == 256);
- return tab[static_cast<unsigned char>(c)];
-}
-
-inline
-char
-is_token_char(char c)
-{
- /*
- tchar = "!" | "#" | "$" | "%" | "&" |
- "'" | "*" | "+" | "-" | "." |
- "^" | "_" | "`" | "|" | "~" |
- DIGIT | ALPHA
- */
- static char constexpr tab[] = {
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 0
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 16
- 0, 1, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, // 32
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, // 48
- 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 64
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, // 80
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 96
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 0, 1, 0, // 112
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 128
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 144
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 160
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 176
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 192
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 208
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 224
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 // 240
- };
- BOOST_STATIC_ASSERT(sizeof(tab) == 256);
- return tab[static_cast<unsigned char>(c)];
-}
-
-inline
-char
-is_qdchar(char c)
-{
- /*
- qdtext = HTAB / SP / "!" / %x23-5B ; '#'-'[' / %x5D-7E ; ']'-'~' / obs-text
- */
- static char constexpr tab[] = {
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, // 0
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 16
- 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 32
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 48
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 64
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, // 80
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 96
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, // 112
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 128
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 144
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 160
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 176
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 192
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 208
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 224
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 // 240
- };
- BOOST_STATIC_ASSERT(sizeof(tab) == 256);
- return tab[static_cast<unsigned char>(c)];
-}
-
-inline
-char
-is_qpchar(char c)
-{
- /*
- quoted-pair = "\" ( HTAB / SP / VCHAR / obs-text )
- obs-text = %x80-FF
- */
- static char constexpr tab[] = {
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, // 0
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 16
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 32
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 48
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 64
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 80
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 96
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, // 112
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 128
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 144
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 160
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 176
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 192
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 208
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, // 224
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 // 240
- };
- BOOST_STATIC_ASSERT(sizeof(tab) == 256);
- return tab[static_cast<unsigned char>(c)];
-}
-
-// converts to lower case,
-// returns 0 if not a valid text char
-//
-inline
-char
-to_value_char(char c)
-{
- // TEXT = <any OCTET except CTLs, but including LWS>
- static unsigned char constexpr tab[] = {
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 9, 0, 0, 0, 0, 0, 0, // 0
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, // 16
- 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, // 32
- 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, // 48
- 64, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, // 64
- 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, 122, 91, 92, 93, 94, 95, // 80
- 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, // 96
- 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, 124, 125, 126, 0, // 112
- 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, // 128
- 144, 145, 146, 147, 148, 149, 150, 151, 152, 153, 154, 155, 156, 157, 158, 159, // 144
- 160, 161, 162, 163, 164, 165, 166, 167, 168, 169, 170, 171, 172, 173, 174, 175, // 160
- 176, 177, 178, 179, 180, 181, 182, 183, 184, 185, 186, 187, 188, 189, 190, 191, // 176
- 192, 193, 194, 195, 196, 197, 198, 199, 200, 201, 202, 203, 204, 205, 206, 207, // 192
- 208, 209, 210, 211, 212, 213, 214, 215, 216, 217, 218, 219, 220, 221, 222, 223, // 208
- 224, 225, 226, 227, 228, 229, 230, 231, 232, 233, 234, 235, 236, 237, 238, 239, // 224
- 240, 241, 242, 243, 244, 245, 246, 247, 248, 249, 250, 251, 252, 253, 254, 255 // 240
- };
- BOOST_STATIC_ASSERT(sizeof(tab) == 256);
- return static_cast<char>(tab[static_cast<unsigned char>(c)]);
-}
-
-// VFALCO TODO Make this return unsigned?
-inline
-std::int8_t
-unhex(char c)
-{
- static signed char constexpr tab[] = {
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 0
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 16
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 32
- 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, -1, -1, -1, -1, -1, -1, // 48
- -1, 10, 11, 12, 13, 14, 15, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 64
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 80
- -1, 10, 11, 12, 13, 14, 15, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 96
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 112
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 128
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 144
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 160
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 176
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 192
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 208
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 224
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1 // 240
- };
- BOOST_STATIC_ASSERT(sizeof(tab) == 256);
- return tab[static_cast<unsigned char>(c)];
-}
-
-template<class FwdIt>
-inline
-void
-skip_ows(FwdIt& it, FwdIt const& end)
-{
- while(it != end)
- {
- if(*it != ' ' && *it != '\t')
- break;
- ++it;
- }
-}
-
-template<class RanIt>
-inline
-void
-skip_ows_rev(
- RanIt& it, RanIt const& first)
-{
- while(it != first)
- {
- auto const c = it[-1];
- if(c != ' ' && c != '\t')
- break;
- --it;
- }
-}
-
-// obs-fold = CRLF 1*( SP / HTAB )
-// return `false` on parse error
-//
-template<class FwdIt>
-inline
-bool
-skip_obs_fold(
- FwdIt& it, FwdIt const& last)
-{
- for(;;)
- {
- if(*it != '\r')
- return true;
- if(++it == last)
- return false;
- if(*it != '\n')
- return false;
- if(++it == last)
- return false;
- if(*it != ' ' && *it != '\t')
- return false;
- for(;;)
- {
- if(++it == last)
- return true;
- if(*it != ' ' && *it != '\t')
- return true;
- }
- }
-}
-
-template<class FwdIt>
-void
-skip_token(FwdIt& it, FwdIt const& last)
-{
- while(it != last && is_token_char(*it))
- ++it;
-}
-
-inline
-string_view
-trim(string_view s)
-{
- auto first = s.begin();
- auto last = s.end();
- skip_ows(first, last);
- while(first != last)
- {
- auto const c = *std::prev(last);
- if(c != ' ' && c != '\t')
- break;
- --last;
- }
- if(first == last)
- return {};
- return {&*first,
- static_cast<std::size_t>(last - first)};
-}
-
-struct param_iter
-{
- using iter_type = string_view::const_iterator;
-
- iter_type it;
- iter_type first;
- iter_type last;
- std::pair<string_view, string_view> v;
-
- bool
- empty() const
- {
- return first == it;
- }
-
- template<class = void>
- void
- increment();
-};
-
-template<class>
-void
-param_iter::
-increment()
-{
-/*
- param-list = *( OWS ";" OWS param )
- param = token OWS [ "=" OWS ( token / quoted-string ) ]
- quoted-string = DQUOTE *( qdtext / quoted-pair ) DQUOTE
- qdtext = HTAB / SP / "!" / %x23-5B ; '#'-'[' / %x5D-7E ; ']'-'~' / obs-text
- quoted-pair = "\" ( HTAB / SP / VCHAR / obs-text )
- obs-text = %x80-FF
-*/
- auto const err =
- [&]
- {
- it = first;
- };
- v.first = {};
- v.second = {};
- detail::skip_ows(it, last);
- first = it;
- if(it == last)
- return err();
- if(*it != ';')
- return err();
- ++it;
- detail::skip_ows(it, last);
- if(it == last)
- return err();
- // param
- if(! detail::is_token_char(*it))
- return err();
- auto const p0 = it;
- skip_token(++it, last);
- auto const p1 = it;
- v.first = { &*p0, static_cast<std::size_t>(p1 - p0) };
- detail::skip_ows(it, last);
- if(it == last)
- return;
- if(*it == ';')
- return;
- if(*it != '=')
- return err();
- ++it;
- detail::skip_ows(it, last);
- if(it == last)
- return;
- if(*it == '"')
- {
- // quoted-string
- auto const p2 = it;
- ++it;
- for(;;)
- {
- if(it == last)
- return err();
- auto c = *it++;
- if(c == '"')
- break;
- if(detail::is_qdchar(c))
- continue;
- if(c != '\\')
- return err();
- if(it == last)
- return err();
- c = *it++;
- if(! detail::is_qpchar(c))
- return err();
- }
- v.second = { &*p2, static_cast<std::size_t>(it - p2) };
- }
- else
- {
- // token
- if(! detail::is_token_char(*it))
- return err();
- auto const p2 = it;
- skip_token(++it, last);
- v.second = { &*p2, static_cast<std::size_t>(it - p2) };
- }
-}
-
-/*
- #token = [ ( "," / token ) *( OWS "," [ OWS token ] ) ]
-*/
-struct opt_token_list_policy
-{
- using value_type = string_view;
-
- bool
- operator()(value_type& v,
- char const*& it, string_view s) const
- {
- v = {};
- auto need_comma = it != s.begin();
- for(;;)
- {
- detail::skip_ows(it, s.end());
- if(it == s.end())
- {
- it = nullptr;
- return true;
- }
- auto const c = *it;
- if(detail::is_token_char(c))
- {
- if(need_comma)
- return false;
- auto const p0 = it;
- for(;;)
- {
- ++it;
- if(it == s.end())
- break;
- if(! detail::is_token_char(*it))
- break;
- }
- v = string_view{&*p0,
- static_cast<std::size_t>(it - p0)};
- return true;
- }
- if(c != ',')
- return false;
- need_comma = false;
- ++it;
- }
- }
-};
-
-} // detail
-} // http
-} // beast
-} // boost
-
-#endif
-
diff --git a/contrib/restricted/boost/boost/beast/http/detail/type_traits.hpp b/contrib/restricted/boost/boost/beast/http/detail/type_traits.hpp
deleted file mode 100644
index 1d0c991826..0000000000
--- a/contrib/restricted/boost/boost/beast/http/detail/type_traits.hpp
+++ /dev/null
@@ -1,218 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_DETAIL_TYPE_TRAITS_HPP
-#define BOOST_BEAST_HTTP_DETAIL_TYPE_TRAITS_HPP
-
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/optional.hpp>
-#include <cstdint>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-template<bool isRequest, class Fields>
-struct header;
-
-template<bool, class, class>
-struct message;
-
-template<bool isRequest,class Body, class Fields>
-class parser;
-
-namespace detail {
-
-template<class T>
-class is_header_impl
-{
- template<bool b, class F>
- static std::true_type check(
- header<b, F> const*);
- static std::false_type check(...);
-public:
- using type = decltype(check((T*)0));
-};
-
-template<class T>
-using is_header = typename is_header_impl<T>::type;
-
-template<class T>
-struct is_parser : std::false_type {};
-
-template<bool isRequest, class Body, class Fields>
-struct is_parser<parser<isRequest, Body, Fields>> : std::true_type {};
-
-struct fields_model
-{
- struct writer;
-
- string_view method() const;
- string_view reason() const;
- string_view target() const;
-
-protected:
- string_view get_method_impl() const;
- string_view get_target_impl() const;
- string_view get_reason_impl() const;
- bool get_chunked_impl() const;
- bool get_keep_alive_impl(unsigned) const;
- bool has_content_length_impl() const;
- void set_method_impl(string_view);
- void set_target_impl(string_view);
- void set_reason_impl(string_view);
- void set_chunked_impl(bool);
- void set_content_length_impl(boost::optional<std::uint64_t>);
- void set_keep_alive_impl(unsigned, bool);
-};
-
-template<class T, class = beast::detail::void_t<>>
-struct has_value_type : std::false_type {};
-
-template<class T>
-struct has_value_type<T, beast::detail::void_t<
- typename T::value_type
- > > : std::true_type {};
-
-/** Determine if a @b Body type has a size
-
- This metafunction is equivalent to `std::true_type` if
- Body contains a static member function called `size`.
-*/
-template<class T, class = void>
-struct is_body_sized : std::false_type {};
-
-template<class T>
-struct is_body_sized<T, beast::detail::void_t<
- typename T::value_type,
- decltype(
- std::declval<std::uint64_t&>() =
- T::size(std::declval<typename T::value_type const&>()),
- (void)0)>> : std::true_type {};
-
-template<class T>
-struct is_fields_helper : T
-{
- template<class U = is_fields_helper>
- static auto f1(int) -> decltype(
- std::declval<string_view&>() = std::declval<U const&>().get_method_impl(),
- std::true_type());
- static auto f1(...) -> std::false_type;
- using t1 = decltype(f1(0));
-
- template<class U = is_fields_helper>
- static auto f2(int) -> decltype(
- std::declval<string_view&>() = std::declval<U const&>().get_target_impl(),
- std::true_type());
- static auto f2(...) -> std::false_type;
- using t2 = decltype(f2(0));
-
- template<class U = is_fields_helper>
- static auto f3(int) -> decltype(
- std::declval<string_view&>() = std::declval<U const&>().get_reason_impl(),
- std::true_type());
- static auto f3(...) -> std::false_type;
- using t3 = decltype(f3(0));
-
- template<class U = is_fields_helper>
- static auto f4(int) -> decltype(
- std::declval<bool&>() = std::declval<U const&>().get_chunked_impl(),
- std::true_type());
- static auto f4(...) -> std::false_type;
- using t4 = decltype(f4(0));
-
- template<class U = is_fields_helper>
- static auto f5(int) -> decltype(
- std::declval<bool&>() = std::declval<U const&>().get_keep_alive_impl(
- std::declval<unsigned>()),
- std::true_type());
- static auto f5(...) -> std::false_type;
- using t5 = decltype(f5(0));
-
- template<class U = is_fields_helper>
- static auto f6(int) -> decltype(
- std::declval<bool&>() = std::declval<U const&>().has_content_length_impl(),
- std::true_type());
- static auto f6(...) -> std::false_type;
- using t6 = decltype(f6(0));
-
- template<class U = is_fields_helper>
- static auto f7(int) -> decltype(
- void(std::declval<U&>().set_method_impl(std::declval<string_view>())),
- std::true_type());
- static auto f7(...) -> std::false_type;
- using t7 = decltype(f7(0));
-
- template<class U = is_fields_helper>
- static auto f8(int) -> decltype(
- void(std::declval<U&>().set_target_impl(std::declval<string_view>())),
- std::true_type());
- static auto f8(...) -> std::false_type;
- using t8 = decltype(f8(0));
-
- template<class U = is_fields_helper>
- static auto f9(int) -> decltype(
- void(std::declval<U&>().set_reason_impl(std::declval<string_view>())),
- std::true_type());
- static auto f9(...) -> std::false_type;
- using t9 = decltype(f9(0));
-
- template<class U = is_fields_helper>
- static auto f10(int) -> decltype(
- void(std::declval<U&>().set_chunked_impl(std::declval<bool>())),
- std::true_type());
- static auto f10(...) -> std::false_type;
- using t10 = decltype(f10(0));
-
- template<class U = is_fields_helper>
- static auto f11(int) -> decltype(
- void(std::declval<U&>().set_content_length_impl(
- std::declval<boost::optional<std::uint64_t>>())),
- std::true_type());
- static auto f11(...) -> std::false_type;
- using t11 = decltype(f11(0));
-
- template<class U = is_fields_helper>
- static auto f12(int) -> decltype(
- void(std::declval<U&>().set_keep_alive_impl(
- std::declval<unsigned>(),
- std::declval<bool>())),
- std::true_type());
- static auto f12(...) -> std::false_type;
- using t12 = decltype(f12(0));
-
- using type = std::integral_constant<bool,
- t1::value && t2::value && t3::value &&
- t4::value && t5::value && t6::value &&
- t7::value && t8::value && t9::value &&
- t10::value && t11::value && t12::value>;
-};
-
-template<class T>
-using has_deprecated_body_writer =
- std::integral_constant<bool,
- std::is_constructible<typename T::writer,
- message<true, T, detail::fields_model>&>::value &&
- std::is_constructible<typename T::writer,
- message<false, T, detail::fields_model>&>::value>;
-
-template<class T>
-using has_deprecated_body_reader =
- std::integral_constant<bool,
- std::is_constructible<typename T::reader,
- message<true, T, detail::fields_model>&>::value &&
- std::is_constructible<typename T::reader,
- message<false, T, detail::fields_model>&>::value>;
-
-} // detail
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/dynamic_body.hpp b/contrib/restricted/boost/boost/beast/http/dynamic_body.hpp
deleted file mode 100644
index 9c3df8a1d2..0000000000
--- a/contrib/restricted/boost/boost/beast/http/dynamic_body.hpp
+++ /dev/null
@@ -1,30 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_DYNAMIC_BODY_HPP
-#define BOOST_BEAST_HTTP_DYNAMIC_BODY_HPP
-
-#include <boost/beast/core/multi_buffer.hpp>
-#include <boost/beast/http/basic_dynamic_body.hpp>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** A dynamic message body represented by a @ref multi_buffer
-
- Meets the requirements of @b Body.
-*/
-using dynamic_body = basic_dynamic_body<multi_buffer>;
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/empty_body.hpp b/contrib/restricted/boost/boost/beast/http/empty_body.hpp
deleted file mode 100644
index d56c14b4ef..0000000000
--- a/contrib/restricted/boost/boost/beast/http/empty_body.hpp
+++ /dev/null
@@ -1,131 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_EMPTY_BODY_HPP
-#define BOOST_BEAST_HTTP_EMPTY_BODY_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/http/error.hpp>
-#include <boost/beast/http/message.hpp>
-#include <boost/optional.hpp>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** An empty @b Body
-
- This body is used to represent messages which do not have a
- message body. If this body is used with a parser, and the
- parser encounters octets corresponding to a message body,
- the parser will fail with the error @ref http::unexpected_body.
-
- The Content-Length of this body is always 0.
-*/
-struct empty_body
-{
- /** The type of container used for the body
-
- This determines the type of @ref message::body
- when this body type is used with a message container.
- */
- struct value_type
- {
- };
-
- /** Returns the payload size of the body
-
- When this body is used with @ref message::prepare_payload,
- the Content-Length will be set to the payload size, and
- any chunked Transfer-Encoding will be removed.
- */
- static
- std::uint64_t
- size(value_type)
- {
- return 0;
- }
-
- /** The algorithm for parsing the body
-
- Meets the requirements of @b BodyReader.
- */
-#if BOOST_BEAST_DOXYGEN
- using reader = implementation_defined;
-#else
- struct reader
- {
- template<bool isRequest, class Fields>
- explicit
- reader(header<isRequest, Fields>&, value_type&)
- {
- }
-
- void
- init(boost::optional<std::uint64_t> const&, error_code& ec)
- {
- ec.assign(0, ec.category());
- }
-
- template<class ConstBufferSequence>
- std::size_t
- put(ConstBufferSequence const&,
- error_code& ec)
- {
- ec = error::unexpected_body;
- return 0;
- }
-
- void
- finish(error_code& ec)
- {
- ec.assign(0, ec.category());
- }
- };
-#endif
-
- /** The algorithm for serializing the body
-
- Meets the requirements of @b BodyWriter.
- */
-#if BOOST_BEAST_DOXYGEN
- using writer = implementation_defined;
-#else
- struct writer
- {
- using const_buffers_type =
- boost::asio::const_buffer;
-
- template<bool isRequest, class Fields>
- explicit
- writer(header<isRequest, Fields> const&, value_type const&)
- {
- }
-
- void
- init(error_code& ec)
- {
- ec.assign(0, ec.category());
- }
-
- boost::optional<std::pair<const_buffers_type, bool>>
- get(error_code& ec)
- {
- ec.assign(0, ec.category());
- return boost::none;
- }
- };
-#endif
-};
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/error.hpp b/contrib/restricted/boost/boost/beast/http/error.hpp
deleted file mode 100644
index b3d9fb1188..0000000000
--- a/contrib/restricted/boost/boost/beast/http/error.hpp
+++ /dev/null
@@ -1,156 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_ERROR_HPP
-#define BOOST_BEAST_HTTP_ERROR_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/error.hpp>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/// Error codes returned from HTTP algorithms and operations.
-enum class error
-{
- /** The end of the stream was reached.
-
- This error is returned when attempting to read HTTP data,
- and the stream returns the error `boost::asio::error::eof`
- before any octets corresponding to a new HTTP message have
- been received.
- */
- end_of_stream = 1,
-
- /** The incoming message is incomplete.
-
- This happens when the end of stream is reached during
- parsing and some octets have been received, but not the
- entire message.
- */
- partial_message,
-
- /** Additional buffers are required.
-
- This error is returned during parsing when additional
- octets are needed. The caller should append more data
- to the existing buffer and retry the parse operaetion.
- */
- need_more,
-
- /** An unexpected body was encountered during parsing.
-
- This error is returned when attempting to parse body
- octets into a message container which has the
- @ref empty_body body type.
-
- @see @ref empty_body
- */
- unexpected_body,
-
- /** Additional buffers are required.
-
- This error is returned under the following conditions:
-
- @li During serialization when using @ref buffer_body.
- The caller should update the body to point to a new
- buffer or indicate that there are no more octets in
- the body.
-
- @li During parsing when using @ref buffer_body.
- The caller should update the body to point to a new
- storage area to receive additional body octets.
- */
- need_buffer,
-
- /** The end of a chunk was reached
- */
- end_of_chunk,
-
- /** Buffer maximum exceeded.
-
- This error is returned when reading HTTP content
- into a dynamic buffer, and the operation would
- exceed the maximum size of the buffer.
- */
- buffer_overflow,
-
- /** Header limit exceeded.
-
- The parser detected an incoming message header which
- exceeded a configured limit.
- */
- header_limit,
-
- /** Body limit exceeded.
-
- The parser detected an incoming message body which
- exceeded a configured limit.
- */
- body_limit,
-
- /** A memory allocation failed.
-
- When basic_fields throws std::bad_alloc, it is
- converted into this error by @ref parser.
- */
- bad_alloc,
-
- //
- // (parser errors)
- //
-
- /// The line ending was malformed
- bad_line_ending,
-
- /// The method is invalid.
- bad_method,
-
- /// The request-target is invalid.
- bad_target,
-
- /// The HTTP-version is invalid.
- bad_version,
-
- /// The status-code is invalid.
- bad_status,
-
- /// The reason-phrase is invalid.
- bad_reason,
-
- /// The field name is invalid.
- bad_field,
-
- /// The field value is invalid.
- bad_value,
-
- /// The Content-Length is invalid.
- bad_content_length,
-
- /// The Transfer-Encoding is invalid.
- bad_transfer_encoding,
-
- /// The chunk syntax is invalid.
- bad_chunk,
-
- /// The chunk extension is invalid.
- bad_chunk_extension,
-
- /// An obs-fold exceeded an internal limit.
- bad_obs_fold
-};
-
-} // http
-} // beast
-} // boost
-
-#include <boost/beast/http/impl/error.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/field.hpp b/contrib/restricted/boost/boost/beast/http/field.hpp
deleted file mode 100644
index 09d9dfffdf..0000000000
--- a/contrib/restricted/boost/boost/beast/http/field.hpp
+++ /dev/null
@@ -1,410 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_FIELD_HPP
-#define BOOST_BEAST_HTTP_FIELD_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/string.hpp>
-#include <iosfwd>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-enum class field : unsigned short
-{
- unknown = 0,
-
- a_im,
- accept,
- accept_additions,
- accept_charset,
- accept_datetime,
- accept_encoding,
- accept_features,
- accept_language,
- accept_patch,
- accept_post,
- accept_ranges,
- access_control,
- access_control_allow_credentials,
- access_control_allow_headers,
- access_control_allow_methods,
- access_control_allow_origin,
- access_control_expose_headers,
- access_control_max_age,
- access_control_request_headers,
- access_control_request_method,
- age,
- allow,
- alpn,
- also_control,
- alt_svc,
- alt_used,
- alternate_recipient,
- alternates,
- apparently_to,
- apply_to_redirect_ref,
- approved,
- archive,
- archived_at,
- article_names,
- article_updates,
- authentication_control,
- authentication_info,
- authentication_results,
- authorization,
- auto_submitted,
- autoforwarded,
- autosubmitted,
- base,
- bcc,
- body,
- c_ext,
- c_man,
- c_opt,
- c_pep,
- c_pep_info,
- cache_control,
- caldav_timezones,
- cancel_key,
- cancel_lock,
- cc,
- close,
- comments,
- compliance,
- connection,
- content_alternative,
- content_base,
- content_description,
- content_disposition,
- content_duration,
- content_encoding,
- content_features,
- content_id,
- content_identifier,
- content_language,
- content_length,
- content_location,
- content_md5,
- content_range,
- content_return,
- content_script_type,
- content_style_type,
- content_transfer_encoding,
- content_type,
- content_version,
- control,
- conversion,
- conversion_with_loss,
- cookie,
- cookie2,
- cost,
- dasl,
- date,
- date_received,
- dav,
- default_style,
- deferred_delivery,
- delivery_date,
- delta_base,
- depth,
- derived_from,
- destination,
- differential_id,
- digest,
- discarded_x400_ipms_extensions,
- discarded_x400_mts_extensions,
- disclose_recipients,
- disposition_notification_options,
- disposition_notification_to,
- distribution,
- dkim_signature,
- dl_expansion_history,
- downgraded_bcc,
- downgraded_cc,
- downgraded_disposition_notification_to,
- downgraded_final_recipient,
- downgraded_from,
- downgraded_in_reply_to,
- downgraded_mail_from,
- downgraded_message_id,
- downgraded_original_recipient,
- downgraded_rcpt_to,
- downgraded_references,
- downgraded_reply_to,
- downgraded_resent_bcc,
- downgraded_resent_cc,
- downgraded_resent_from,
- downgraded_resent_reply_to,
- downgraded_resent_sender,
- downgraded_resent_to,
- downgraded_return_path,
- downgraded_sender,
- downgraded_to,
- ediint_features,
- eesst_version,
- encoding,
- encrypted,
- errors_to,
- etag,
- expect,
- expires,
- expiry_date,
- ext,
- followup_to,
- forwarded,
- from,
- generate_delivery_report,
- getprofile,
- hobareg,
- host,
- http2_settings,
- if_,
- if_match,
- if_modified_since,
- if_none_match,
- if_range,
- if_schedule_tag_match,
- if_unmodified_since,
- im,
- importance,
- in_reply_to,
- incomplete_copy,
- injection_date,
- injection_info,
- jabber_id,
- keep_alive,
- keywords,
- label,
- language,
- last_modified,
- latest_delivery_time,
- lines,
- link,
- list_archive,
- list_help,
- list_id,
- list_owner,
- list_post,
- list_subscribe,
- list_unsubscribe,
- list_unsubscribe_post,
- location,
- lock_token,
- man,
- max_forwards,
- memento_datetime,
- message_context,
- message_id,
- message_type,
- meter,
- method_check,
- method_check_expires,
- mime_version,
- mmhs_acp127_message_identifier,
- mmhs_authorizing_users,
- mmhs_codress_message_indicator,
- mmhs_copy_precedence,
- mmhs_exempted_address,
- mmhs_extended_authorisation_info,
- mmhs_handling_instructions,
- mmhs_message_instructions,
- mmhs_message_type,
- mmhs_originator_plad,
- mmhs_originator_reference,
- mmhs_other_recipients_indicator_cc,
- mmhs_other_recipients_indicator_to,
- mmhs_primary_precedence,
- mmhs_subject_indicator_codes,
- mt_priority,
- negotiate,
- newsgroups,
- nntp_posting_date,
- nntp_posting_host,
- non_compliance,
- obsoletes,
- opt,
- optional,
- optional_www_authenticate,
- ordering_type,
- organization,
- origin,
- original_encoded_information_types,
- original_from,
- original_message_id,
- original_recipient,
- original_sender,
- original_subject,
- originator_return_address,
- overwrite,
- p3p,
- path,
- pep,
- pep_info,
- pics_label,
- position,
- posting_version,
- pragma,
- prefer,
- preference_applied,
- prevent_nondelivery_report,
- priority,
- privicon,
- profileobject,
- protocol,
- protocol_info,
- protocol_query,
- protocol_request,
- proxy_authenticate,
- proxy_authentication_info,
- proxy_authorization,
- proxy_connection,
- proxy_features,
- proxy_instruction,
- public_,
- public_key_pins,
- public_key_pins_report_only,
- range,
- received,
- received_spf,
- redirect_ref,
- references,
- referer,
- referer_root,
- relay_version,
- reply_by,
- reply_to,
- require_recipient_valid_since,
- resent_bcc,
- resent_cc,
- resent_date,
- resent_from,
- resent_message_id,
- resent_reply_to,
- resent_sender,
- resent_to,
- resolution_hint,
- resolver_location,
- retry_after,
- return_path,
- safe,
- schedule_reply,
- schedule_tag,
- sec_websocket_accept,
- sec_websocket_extensions,
- sec_websocket_key,
- sec_websocket_protocol,
- sec_websocket_version,
- security_scheme,
- see_also,
- sender,
- sensitivity,
- server,
- set_cookie,
- set_cookie2,
- setprofile,
- sio_label,
- sio_label_history,
- slug,
- soapaction,
- solicitation,
- status_uri,
- strict_transport_security,
- subject,
- subok,
- subst,
- summary,
- supersedes,
- surrogate_capability,
- surrogate_control,
- tcn,
- te,
- timeout,
- title,
- to,
- topic,
- trailer,
- transfer_encoding,
- ttl,
- ua_color,
- ua_media,
- ua_pixels,
- ua_resolution,
- ua_windowpixels,
- upgrade,
- urgency,
- uri,
- user_agent,
- variant_vary,
- vary,
- vbr_info,
- version,
- via,
- want_digest,
- warning,
- www_authenticate,
- x_archived_at,
- x_device_accept,
- x_device_accept_charset,
- x_device_accept_encoding,
- x_device_accept_language,
- x_device_user_agent,
- x_frame_options,
- x_mittente,
- x_pgp_sig,
- x_ricevuta,
- x_riferimento_message_id,
- x_tiporicevuta,
- x_trasporto,
- x_verificasicurezza,
- x400_content_identifier,
- x400_content_return,
- x400_content_type,
- x400_mts_identifier,
- x400_originator,
- x400_received,
- x400_recipients,
- x400_trace,
- xref,
-};
-
-/** Convert a field enum to a string.
-
- @param f The field to convert
-*/
-string_view
-to_string(field f);
-
-/** Attempt to convert a string to a field enum.
-
- The string comparison is case-insensitive.
-
- @return The corresponding field, or @ref field::unknown
- if no known field matches.
-*/
-field
-string_to_field(string_view s);
-
-/// Write the text for a field name to an output stream.
-inline
-std::ostream&
-operator<<(std::ostream& os, field f)
-{
- return os << to_string(f);
-}
-
-} // http
-} // beast
-} // boost
-
-#include <boost/beast/http/impl/field.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/fields.hpp b/contrib/restricted/boost/boost/beast/http/fields.hpp
deleted file mode 100644
index e2f3847408..0000000000
--- a/contrib/restricted/boost/boost/beast/http/fields.hpp
+++ /dev/null
@@ -1,767 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_FIELDS_HPP
-#define BOOST_BEAST_HTTP_FIELDS_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/string_param.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/core/detail/allocator.hpp>
-#include <boost/beast/core/detail/empty_base_optimization.hpp>
-#include <boost/beast/http/field.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/intrusive/list.hpp>
-#include <boost/intrusive/set.hpp>
-#include <boost/optional.hpp>
-#include <algorithm>
-#include <cctype>
-#include <cstring>
-#include <memory>
-#include <string>
-#include <type_traits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** A container for storing HTTP header fields.
-
- This container is designed to store the field value pairs that make
- up the fields and trailers in an HTTP message. Objects of this type
- are iterable, with each element holding the field name and field
- value.
-
- Field names are stored as-is, but comparisons are case-insensitive.
- The container behaves as a `std::multiset`; there will be a separate
- value for each occurrence of the same field name. When the container
- is iterated the fields are presented in the order of insertion, with
- fields having the same name following each other consecutively.
-
- Meets the requirements of @b Fields
-
- @tparam Allocator The allocator to use. This must meet the
- requirements of @b Allocator.
-*/
-template<class Allocator>
-class basic_fields
-#ifndef BOOST_BEAST_DOXYGEN
- : private beast::detail::empty_base_optimization<Allocator>
-#endif
-{
- // Fancy pointers are not supported
- static_assert(std::is_pointer<typename
- std::allocator_traits<Allocator>::pointer>::value,
- "Allocator must use regular pointers");
-
- friend class fields_test; // for `header`
-
- static std::size_t constexpr max_static_buffer = 4096;
-
- using off_t = std::uint16_t;
-
-public:
- /// The type of allocator used.
- using allocator_type = Allocator;
-
- /// The type of element used to represent a field
- class value_type
- {
- friend class basic_fields;
-
- boost::asio::const_buffer
- buffer() const;
-
- value_type(field name,
- string_view sname, string_view value);
-
- boost::intrusive::list_member_hook<
- boost::intrusive::link_mode<
- boost::intrusive::normal_link>>
- list_hook_;
- boost::intrusive::set_member_hook<
- boost::intrusive::link_mode<
- boost::intrusive::normal_link>>
- set_hook_;
- off_t off_;
- off_t len_;
- field f_;
-
- public:
- /// Constructor (deleted)
- value_type(value_type const&) = delete;
-
- /// Assignment (deleted)
- value_type& operator=(value_type const&) = delete;
-
- /// Returns the field enum, which can be @ref field::unknown
- field
- name() const;
-
- /// Returns the field name as a string
- string_view
- name_string() const;
-
- /// Returns the value of the field
- string_view
- value() const;
- };
-
- /** A strictly less predicate for comparing keys, using a case-insensitive comparison.
-
- The case-comparison operation is defined only for low-ASCII characters.
- */
- struct key_compare : beast::iless
- {
- /// Returns `true` if lhs is less than rhs using a strict ordering
- template<class String>
- bool
- operator()(
- String const& lhs,
- value_type const& rhs) const noexcept
- {
- if(lhs.size() < rhs.name_string().size())
- return true;
- if(lhs.size() > rhs.name_string().size())
- return false;
- return iless::operator()(lhs, rhs.name_string());
- }
-
- /// Returns `true` if lhs is less than rhs using a strict ordering
- template<class String>
- bool
- operator()(
- value_type const& lhs,
- String const& rhs) const noexcept
- {
- if(lhs.name_string().size() < rhs.size())
- return true;
- if(lhs.name_string().size() > rhs.size())
- return false;
- return iless::operator()(lhs.name_string(), rhs);
- }
-
- /// Returns `true` if lhs is less than rhs using a strict ordering
- bool
- operator()(
- value_type const& lhs,
- value_type const& rhs) const noexcept
- {
- if(lhs.name_string().size() < rhs.name_string().size())
- return true;
- if(lhs.name_string().size() > rhs.name_string().size())
- return false;
- return iless::operator()(lhs.name_string(), rhs.name_string());
- }
- };
-
- /// The algorithm used to serialize the header
-#if BOOST_BEAST_DOXYGEN
- using writer = implementation_defined;
-#else
- class writer;
-#endif
-
-private:
- using list_t = typename boost::intrusive::make_list<
- value_type, boost::intrusive::member_hook<
- value_type, boost::intrusive::list_member_hook<
- boost::intrusive::link_mode<
- boost::intrusive::normal_link>>,
- &value_type::list_hook_>,
- boost::intrusive::constant_time_size<
- false>>::type;
-
- using set_t = typename boost::intrusive::make_multiset<
- value_type, boost::intrusive::member_hook<value_type,
- boost::intrusive::set_member_hook<
- boost::intrusive::link_mode<
- boost::intrusive::normal_link>>,
- &value_type::set_hook_>,
- boost::intrusive::constant_time_size<true>,
- boost::intrusive::compare<key_compare>>::type;
-
- using align_type = typename
- boost::type_with_alignment<alignof(value_type)>::type;
-
- using rebind_type = typename
- beast::detail::allocator_traits<Allocator>::
- template rebind_alloc<align_type>;
-
- using alloc_traits =
- beast::detail::allocator_traits<rebind_type>;
-
- using size_type = typename
- beast::detail::allocator_traits<Allocator>::size_type;
-
-
-public:
- /// Destructor
- ~basic_fields();
-
- /// Constructor.
- basic_fields() = default;
-
- /** Constructor.
-
- @param alloc The allocator to use.
- */
- explicit
- basic_fields(Allocator const& alloc) noexcept;
-
- /** Move constructor.
-
- The state of the moved-from object is
- as if constructed using the same allocator.
- */
- basic_fields(basic_fields&&) noexcept;
-
- /** Move constructor.
-
- The state of the moved-from object is
- as if constructed using the same allocator.
-
- @param alloc The allocator to use.
- */
- basic_fields(basic_fields&&, Allocator const& alloc);
-
- /// Copy constructor.
- basic_fields(basic_fields const&);
-
- /** Copy constructor.
-
- @param alloc The allocator to use.
- */
- basic_fields(basic_fields const&, Allocator const& alloc);
-
- /// Copy constructor.
- template<class OtherAlloc>
- basic_fields(basic_fields<OtherAlloc> const&);
-
- /** Copy constructor.
-
- @param alloc The allocator to use.
- */
- template<class OtherAlloc>
- basic_fields(basic_fields<OtherAlloc> const&,
- Allocator const& alloc);
-
- /** Move assignment.
-
- The state of the moved-from object is
- as if constructed using the same allocator.
- */
- basic_fields& operator=(basic_fields&&) noexcept(
- alloc_traits::propagate_on_container_move_assignment::value);
-
- /// Copy assignment.
- basic_fields& operator=(basic_fields const&);
-
- /// Copy assignment.
- template<class OtherAlloc>
- basic_fields& operator=(basic_fields<OtherAlloc> const&);
-
-public:
- /// A constant iterator to the field sequence.
-#if BOOST_BEAST_DOXYGEN
- using const_iterator = implementation_defined;
-#else
- using const_iterator = typename list_t::const_iterator;
-#endif
-
- /// A constant iterator to the field sequence.
- using iterator = const_iterator;
-
- /// Return a copy of the allocator associated with the container.
- allocator_type
- get_allocator() const
- {
- return this->member();
- }
-
- //--------------------------------------------------------------------------
- //
- // Element access
- //
- //--------------------------------------------------------------------------
-
- /** Returns the value for a field, or throws an exception.
-
- If more than one field with the specified name exists, the
- first field defined by insertion order is returned.
-
- @param name The name of the field.
-
- @return The field value.
-
- @throws std::out_of_range if the field is not found.
- */
- string_view const
- at(field name) const;
-
- /** Returns the value for a field, or throws an exception.
-
- If more than one field with the specified name exists, the
- first field defined by insertion order is returned.
-
- @param name The name of the field.
-
- @return The field value.
-
- @throws std::out_of_range if the field is not found.
- */
- string_view const
- at(string_view name) const;
-
- /** Returns the value for a field, or `""` if it does not exist.
-
- If more than one field with the specified name exists, the
- first field defined by insertion order is returned.
-
- @param name The name of the field.
- */
- string_view const
- operator[](field name) const;
-
- /** Returns the value for a case-insensitive matching header, or `""` if it does not exist.
-
- If more than one field with the specified name exists, the
- first field defined by insertion order is returned.
-
- @param name The name of the field.
- */
- string_view const
- operator[](string_view name) const;
-
- //--------------------------------------------------------------------------
- //
- // Iterators
- //
- //--------------------------------------------------------------------------
-
- /// Return a const iterator to the beginning of the field sequence.
- const_iterator
- begin() const
- {
- return list_.cbegin();
- }
-
- /// Return a const iterator to the end of the field sequence.
- const_iterator
- end() const
- {
- return list_.cend();
- }
-
- /// Return a const iterator to the beginning of the field sequence.
- const_iterator
- cbegin() const
- {
- return list_.cbegin();
- }
-
- /// Return a const iterator to the end of the field sequence.
- const_iterator
- cend() const
- {
- return list_.cend();
- }
-
- //--------------------------------------------------------------------------
- //
- // Capacity
- //
- //--------------------------------------------------------------------------
-
-private:
- // VFALCO Since the header and message derive from Fields,
- // what does the expression m.empty() mean? Its confusing.
- bool
- empty() const
- {
- return list_.empty();
- }
-public:
-
- //--------------------------------------------------------------------------
- //
- // Modifiers
- //
- //--------------------------------------------------------------------------
-
- /** Remove all fields from the container
-
- All references, pointers, or iterators referring to contained
- elements are invalidated. All past-the-end iterators are also
- invalidated.
-
- @par Postconditions:
- @code
- std::distance(this->begin(), this->end()) == 0
- @endcode
- */
- void
- clear();
-
- /** Insert a field.
-
- If one or more fields with the same name already exist,
- the new field will be inserted after the last field with
- the matching name, in serialization order.
-
- @param name The field name.
-
- @param value The value of the field, as a @ref string_param
- */
- void
- insert(field name, string_param const& value);
-
- /** Insert a field.
-
- If one or more fields with the same name already exist,
- the new field will be inserted after the last field with
- the matching name, in serialization order.
-
- @param name The field name.
-
- @param value The value of the field, as a @ref string_param
- */
- void
- insert(string_view name, string_param const& value);
-
- /** Insert a field.
-
- If one or more fields with the same name already exist,
- the new field will be inserted after the last field with
- the matching name, in serialization order.
-
- @param name The field name.
-
- @param name_string The literal text corresponding to the
- field name. If `name != field::unknown`, then this value
- must be equal to `to_string(name)` using a case-insensitive
- comparison, otherwise the behavior is undefined.
-
- @param value The value of the field, as a @ref string_param
- */
- void
- insert(field name, string_view name_string,
- string_param const& value);
-
- /** Set a field value, removing any other instances of that field.
-
- First removes any values with matching field names, then
- inserts the new field value.
-
- @param name The field name.
-
- @param value The value of the field, as a @ref string_param
-
- @return The field value.
- */
- void
- set(field name, string_param const& value);
-
- /** Set a field value, removing any other instances of that field.
-
- First removes any values with matching field names, then
- inserts the new field value.
-
- @param name The field name.
-
- @param value The value of the field, as a @ref string_param
- */
- void
- set(string_view name, string_param const& value);
-
- /** Remove a field.
-
- References and iterators to the erased elements are
- invalidated. Other references and iterators are not
- affected.
-
- @param pos An iterator to the element to remove.
-
- @return An iterator following the last removed element.
- If the iterator refers to the last element, the end()
- iterator is returned.
- */
- const_iterator
- erase(const_iterator pos);
-
- /** Remove all fields with the specified name.
-
- All fields with the same field name are erased from the
- container.
- References and iterators to the erased elements are
- invalidated. Other references and iterators are not
- affected.
-
- @param name The field name.
-
- @return The number of fields removed.
- */
- std::size_t
- erase(field name);
-
- /** Remove all fields with the specified name.
-
- All fields with the same field name are erased from the
- container.
- References and iterators to the erased elements are
- invalidated. Other references and iterators are not
- affected.
-
- @param name The field name.
-
- @return The number of fields removed.
- */
- std::size_t
- erase(string_view name);
-
- /** Return a buffer sequence representing the trailers.
-
- This function returns a buffer sequence holding the
- serialized representation of the trailer fields promised
- in the Accept field. Before calling this function the
- Accept field must contain the exact trailer fields
- desired. Each field must also exist.
- */
-
-
- /// Swap this container with another
- void
- swap(basic_fields& other);
-
- /// Swap two field containers
- template<class Alloc>
- friend
- void
- swap(basic_fields<Alloc>& lhs, basic_fields<Alloc>& rhs);
-
- //--------------------------------------------------------------------------
- //
- // Lookup
- //
- //--------------------------------------------------------------------------
-
- /** Return the number of fields with the specified name.
-
- @param name The field name.
- */
- std::size_t
- count(field name) const;
-
- /** Return the number of fields with the specified name.
-
- @param name The field name.
- */
- std::size_t
- count(string_view name) const;
-
- /** Returns an iterator to the case-insensitive matching field.
-
- If more than one field with the specified name exists, the
- first field defined by insertion order is returned.
-
- @param name The field name.
-
- @return An iterator to the matching field, or `end()` if
- no match was found.
- */
- const_iterator
- find(field name) const;
-
- /** Returns an iterator to the case-insensitive matching field name.
-
- If more than one field with the specified name exists, the
- first field defined by insertion order is returned.
-
- @param name The field name.
-
- @return An iterator to the matching field, or `end()` if
- no match was found.
- */
- const_iterator
- find(string_view name) const;
-
- /** Returns a range of iterators to the fields with the specified name.
-
- @param name The field name.
-
- @return A range of iterators to fields with the same name,
- otherwise an empty range.
- */
- std::pair<const_iterator, const_iterator>
- equal_range(field name) const;
-
- /** Returns a range of iterators to the fields with the specified name.
-
- @param name The field name.
-
- @return A range of iterators to fields with the same name,
- otherwise an empty range.
- */
- std::pair<const_iterator, const_iterator>
- equal_range(string_view name) const;
-
- //--------------------------------------------------------------------------
- //
- // Observers
- //
- //--------------------------------------------------------------------------
-
- /// Returns a copy of the key comparison function
- key_compare
- key_comp() const
- {
- return key_compare{};
- }
-
-protected:
- /** Returns the request-method string.
-
- @note Only called for requests.
- */
- string_view
- get_method_impl() const;
-
- /** Returns the request-target string.
-
- @note Only called for requests.
- */
- string_view
- get_target_impl() const;
-
- /** Returns the response reason-phrase string.
-
- @note Only called for responses.
- */
- string_view
- get_reason_impl() const;
-
- /** Returns the chunked Transfer-Encoding setting
- */
- bool
- get_chunked_impl() const;
-
- /** Returns the keep-alive setting
- */
- bool
- get_keep_alive_impl(unsigned version) const;
-
- /** Returns `true` if the Content-Length field is present.
- */
- bool
- has_content_length_impl() const;
-
- /** Set or clear the method string.
-
- @note Only called for requests.
- */
- void
- set_method_impl(string_view s);
-
- /** Set or clear the target string.
-
- @note Only called for requests.
- */
- void
- set_target_impl(string_view s);
-
- /** Set or clear the reason string.
-
- @note Only called for responses.
- */
- void
- set_reason_impl(string_view s);
-
- /** Adjusts the chunked Transfer-Encoding value
- */
- void
- set_chunked_impl(bool value);
-
- /** Sets or clears the Content-Length field
- */
- void
- set_content_length_impl(
- boost::optional<std::uint64_t> const& value);
-
- /** Adjusts the Connection field
- */
- void
- set_keep_alive_impl(
- unsigned version, bool keep_alive);
-
-private:
- template<class OtherAlloc>
- friend class basic_fields;
-
- value_type&
- new_element(field name,
- string_view sname, string_view value);
-
- void
- delete_element(value_type& e);
-
- void
- set_element(value_type& e);
-
- void
- realloc_string(string_view& dest, string_view s);
-
- void
- realloc_target(
- string_view& dest, string_view s);
-
- template<class OtherAlloc>
- void
- copy_all(basic_fields<OtherAlloc> const&);
-
- void
- clear_all();
-
- void
- delete_list();
-
- void
- move_assign(basic_fields&, std::true_type);
-
- void
- move_assign(basic_fields&, std::false_type);
-
- void
- copy_assign(basic_fields const&, std::true_type);
-
- void
- copy_assign(basic_fields const&, std::false_type);
-
- void
- swap(basic_fields& other, std::true_type);
-
- void
- swap(basic_fields& other, std::false_type);
-
- set_t set_;
- list_t list_;
- string_view method_;
- string_view target_or_reason_;
-};
-
-/// A typical HTTP header fields container
-using fields = basic_fields<std::allocator<char>>;
-
-} // http
-} // beast
-} // boost
-
-#include <boost/beast/http/impl/fields.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/file_body.hpp b/contrib/restricted/boost/boost/beast/http/file_body.hpp
deleted file mode 100644
index 42e7a15330..0000000000
--- a/contrib/restricted/boost/boost/beast/http/file_body.hpp
+++ /dev/null
@@ -1,35 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_FILE_BODY_HPP
-#define BOOST_BEAST_HTTP_FILE_BODY_HPP
-
-#include <boost/beast/core/file.hpp>
-#include <boost/beast/http/basic_file_body.hpp>
-#include <boost/assert.hpp>
-#include <boost/optional.hpp>
-#include <algorithm>
-#include <cstdio>
-#include <cstdint>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/// A message body represented by a file on the filesystem.
-using file_body = basic_file_body<file>;
-
-} // http
-} // beast
-} // boost
-
-#include <boost/beast/http/impl/file_body_win32.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/impl/basic_parser.ipp b/contrib/restricted/boost/boost/beast/http/impl/basic_parser.ipp
deleted file mode 100644
index 39ad3cc68e..0000000000
--- a/contrib/restricted/boost/boost/beast/http/impl/basic_parser.ipp
+++ /dev/null
@@ -1,928 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_IMPL_BASIC_PARSER_IPP
-#define BOOST_BEAST_HTTP_IMPL_BASIC_PARSER_IPP
-
-#include <boost/beast/core/static_string.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/core/detail/clamp.hpp>
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/http/error.hpp>
-#include <boost/beast/http/rfc7230.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/make_unique.hpp>
-#include <algorithm>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-template<bool isRequest, class Derived>
-template<class OtherDerived>
-basic_parser<isRequest, Derived>::
-basic_parser(basic_parser<
- isRequest, OtherDerived>&& other)
- : body_limit_(other.body_limit_)
- , len_(other.len_)
- , buf_(std::move(other.buf_))
- , buf_len_(other.buf_len_)
- , skip_(other.skip_)
- , header_limit_(other.header_limit_)
- , status_(other.status_)
- , state_(other.state_)
- , f_(other.f_)
-{
-}
-
-template<bool isRequest, class Derived>
-bool
-basic_parser<isRequest, Derived>::
-keep_alive() const
-{
- BOOST_ASSERT(is_header_done());
- if(f_ & flagHTTP11)
- {
- if(f_ & flagConnectionClose)
- return false;
- }
- else
- {
- if(! (f_ & flagConnectionKeepAlive))
- return false;
- }
- return (f_ & flagNeedEOF) == 0;
-}
-
-template<bool isRequest, class Derived>
-boost::optional<std::uint64_t>
-basic_parser<isRequest, Derived>::
-content_length() const
-{
- BOOST_ASSERT(is_header_done());
- if(! (f_ & flagContentLength))
- return boost::none;
- return len_;
-}
-
-template<bool isRequest, class Derived>
-void
-basic_parser<isRequest, Derived>::
-skip(bool v)
-{
- BOOST_ASSERT(! got_some());
- if(v)
- f_ |= flagSkipBody;
- else
- f_ &= ~flagSkipBody;
-}
-
-template<bool isRequest, class Derived>
-template<class ConstBufferSequence>
-std::size_t
-basic_parser<isRequest, Derived>::
-put(ConstBufferSequence const& buffers,
- error_code& ec)
-{
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- using boost::asio::buffer_copy;
- using boost::asio::buffer_size;
- auto const p = boost::asio::buffer_sequence_begin(buffers);
- auto const last = boost::asio::buffer_sequence_end(buffers);
- if(p == last)
- {
- ec.assign(0, ec.category());
- return 0;
- }
- if(std::next(p) == last)
- {
- // single buffer
- return put(boost::asio::const_buffer(*p), ec);
- }
- auto const size = buffer_size(buffers);
- if(size <= max_stack_buffer)
- return put_from_stack(size, buffers, ec);
- if(size > buf_len_)
- {
- // reallocate
- buf_ = boost::make_unique_noinit<char[]>(size);
- buf_len_ = size;
- }
- // flatten
- buffer_copy(boost::asio::buffer(
- buf_.get(), buf_len_), buffers);
- return put(boost::asio::const_buffer{
- buf_.get(), buf_len_}, ec);
-}
-
-template<bool isRequest, class Derived>
-std::size_t
-basic_parser<isRequest, Derived>::
-put(boost::asio::const_buffer const& buffer,
- error_code& ec)
-{
- BOOST_ASSERT(state_ != state::complete);
- using boost::asio::buffer_size;
- auto p = reinterpret_cast<
- char const*>(buffer.data());
- auto n = buffer.size();
- auto const p0 = p;
- auto const p1 = p0 + n;
- ec.assign(0, ec.category());
-loop:
- switch(state_)
- {
- case state::nothing_yet:
- if(n == 0)
- {
- ec = error::need_more;
- return 0;
- }
- state_ = state::start_line;
- BOOST_FALLTHROUGH;
-
- case state::start_line:
- {
- maybe_need_more(p, n, ec);
- if(ec)
- goto done;
- parse_start_line(p, p + (std::min<std::size_t>)(
- header_limit_, n), ec, is_request{});
- if(ec)
- {
- if(ec == error::need_more)
- {
- if(n >= header_limit_)
- {
- ec = error::header_limit;
- goto done;
- }
- if(p + 3 <= p1)
- skip_ = static_cast<
- std::size_t>(p1 - p - 3);
- }
- goto done;
- }
- BOOST_ASSERT(! is_done());
- n = static_cast<std::size_t>(p1 - p);
- if(p >= p1)
- {
- ec = error::need_more;
- goto done;
- }
- BOOST_FALLTHROUGH;
- }
-
- case state::fields:
- maybe_need_more(p, n, ec);
- if(ec)
- goto done;
- parse_fields(p, p + (std::min<std::size_t>)(
- header_limit_, n), ec);
- if(ec)
- {
- if(ec == error::need_more)
- {
- if(n >= header_limit_)
- {
- ec = error::header_limit;
- goto done;
- }
- if(p + 3 <= p1)
- skip_ = static_cast<
- std::size_t>(p1 - p - 3);
- }
- goto done;
- }
- finish_header(ec, is_request{});
- break;
-
- case state::body0:
- BOOST_ASSERT(! skip_);
- impl().on_body_init_impl(content_length(), ec);
- if(ec)
- goto done;
- state_ = state::body;
- BOOST_FALLTHROUGH;
-
- case state::body:
- BOOST_ASSERT(! skip_);
- parse_body(p, n, ec);
- if(ec)
- goto done;
- break;
-
- case state::body_to_eof0:
- BOOST_ASSERT(! skip_);
- impl().on_body_init_impl(content_length(), ec);
- if(ec)
- goto done;
- state_ = state::body_to_eof;
- BOOST_FALLTHROUGH;
-
- case state::body_to_eof:
- BOOST_ASSERT(! skip_);
- parse_body_to_eof(p, n, ec);
- if(ec)
- goto done;
- break;
-
- case state::chunk_header0:
- impl().on_body_init_impl(content_length(), ec);
- if(ec)
- goto done;
- state_ = state::chunk_header;
- BOOST_FALLTHROUGH;
-
- case state::chunk_header:
- parse_chunk_header(p, n, ec);
- if(ec)
- goto done;
- break;
-
- case state::chunk_body:
- parse_chunk_body(p, n, ec);
- if(ec)
- goto done;
- break;
-
- case state::complete:
- ec.assign(0, ec.category());
- goto done;
- }
- if(p < p1 && ! is_done() && eager())
- {
- n = static_cast<std::size_t>(p1 - p);
- goto loop;
- }
-done:
- return static_cast<std::size_t>(p - p0);
-}
-
-template<bool isRequest, class Derived>
-void
-basic_parser<isRequest, Derived>::
-put_eof(error_code& ec)
-{
- BOOST_ASSERT(got_some());
- if( state_ == state::start_line ||
- state_ == state::fields)
- {
- ec = error::partial_message;
- return;
- }
- if(f_ & (flagContentLength | flagChunked))
- {
- if(state_ != state::complete)
- {
- ec = error::partial_message;
- return;
- }
- ec.assign(0, ec.category());
- return;
- }
- impl().on_finish_impl(ec);
- if(ec)
- return;
- state_ = state::complete;
-}
-
-template<bool isRequest, class Derived>
-template<class ConstBufferSequence>
-std::size_t
-basic_parser<isRequest, Derived>::
-put_from_stack(std::size_t size,
- ConstBufferSequence const& buffers,
- error_code& ec)
-{
- char buf[max_stack_buffer];
- using boost::asio::buffer;
- using boost::asio::buffer_copy;
- buffer_copy(buffer(buf, sizeof(buf)), buffers);
- return put(boost::asio::const_buffer{
- buf, size}, ec);
-}
-
-template<bool isRequest, class Derived>
-inline
-void
-basic_parser<isRequest, Derived>::
-maybe_need_more(
- char const* p, std::size_t n,
- error_code& ec)
-{
- if(skip_ == 0)
- return;
- if( n > header_limit_)
- n = header_limit_;
- if(n < skip_ + 4)
- {
- ec = error::need_more;
- return;
- }
- auto const term =
- find_eom(p + skip_, p + n);
- if(! term)
- {
- skip_ = n - 3;
- if(skip_ + 4 > header_limit_)
- {
- ec = error::header_limit;
- return;
- }
- ec = error::need_more;
- return;
- }
- skip_ = 0;
-}
-
-template<bool isRequest, class Derived>
-inline
-void
-basic_parser<isRequest, Derived>::
-parse_start_line(
- char const*& in, char const* last,
- error_code& ec, std::true_type)
-{
-/*
- request-line = method SP request-target SP HTTP-version CRLF
- method = token
-*/
- auto p = in;
-
- string_view method;
- parse_method(p, last, method, ec);
- if(ec)
- return;
-
- string_view target;
- parse_target(p, last, target, ec);
- if(ec)
- return;
-
- int version = 0;
- parse_version(p, last, version, ec);
- if(ec)
- return;
- if(version < 10 || version > 11)
- {
- ec = error::bad_version;
- return;
- }
-
- if(p + 2 > last)
- {
- ec = error::need_more;
- return;
- }
- if(p[0] != '\r' || p[1] != '\n')
- {
- ec = error::bad_version;
- return;
- }
- p += 2;
-
- if(version >= 11)
- f_ |= flagHTTP11;
-
- impl().on_request_impl(string_to_verb(method),
- method, target, version, ec);
- if(ec)
- return;
-
- in = p;
- state_ = state::fields;
-}
-
-template<bool isRequest, class Derived>
-inline
-void
-basic_parser<isRequest, Derived>::
-parse_start_line(
- char const*& in, char const* last,
- error_code& ec, std::false_type)
-{
-/*
- status-line = HTTP-version SP status-code SP reason-phrase CRLF
- status-code = 3*DIGIT
- reason-phrase = *( HTAB / SP / VCHAR / obs-text )
-*/
- auto p = in;
-
- int version = 0;
- parse_version(p, last, version, ec);
- if(ec)
- return;
- if(version < 10 || version > 11)
- {
- ec = error::bad_version;
- return;
- }
-
- // SP
- if(p + 1 > last)
- {
- ec = error::need_more;
- return;
- }
- if(*p++ != ' ')
- {
- ec = error::bad_version;
- return;
- }
-
- parse_status(p, last, status_, ec);
- if(ec)
- return;
-
- // parse reason CRLF
- string_view reason;
- parse_reason(p, last, reason, ec);
- if(ec)
- return;
-
- if(version >= 11)
- f_ |= flagHTTP11;
-
- impl().on_response_impl(
- status_, reason, version, ec);
- if(ec)
- return;
-
- in = p;
- state_ = state::fields;
-}
-
-template<bool isRequest, class Derived>
-void
-basic_parser<isRequest, Derived>::
-parse_fields(char const*& in,
- char const* last, error_code& ec)
-{
- string_view name;
- string_view value;
- // https://stackoverflow.com/questions/686217/maximum-on-http-header-values
- static_string<max_obs_fold> buf;
- auto p = in;
- for(;;)
- {
- if(p + 2 > last)
- {
- ec = error::need_more;
- return;
- }
- if(p[0] == '\r')
- {
- if(p[1] != '\n')
- ec = error::bad_line_ending;
- in = p + 2;
- return;
- }
- parse_field(p, last, name, value, buf, ec);
- if(ec)
- return;
- auto const f = string_to_field(name);
- do_field(f, value, ec);
- if(ec)
- return;
- impl().on_field_impl(f, name, value, ec);
- if(ec)
- return;
- in = p;
- }
-}
-
-template<bool isRequest, class Derived>
-inline
-void
-basic_parser<isRequest, Derived>::
-finish_header(error_code& ec, std::true_type)
-{
- // RFC 7230 section 3.3
- // https://tools.ietf.org/html/rfc7230#section-3.3
-
- if(f_ & flagSkipBody)
- {
- state_ = state::complete;
- }
- else if(f_ & flagContentLength)
- {
- if(len_ > body_limit_)
- {
- ec = error::body_limit;
- return;
- }
- if(len_ > 0)
- {
- f_ |= flagHasBody;
- state_ = state::body0;
- }
- else
- {
- state_ = state::complete;
- }
- }
- else if(f_ & flagChunked)
- {
- f_ |= flagHasBody;
- state_ = state::chunk_header0;
- }
- else
- {
- len_ = 0;
- state_ = state::complete;
- }
-
- impl().on_header_impl(ec);
- if(ec)
- return;
- if(state_ == state::complete)
- {
- impl().on_finish_impl(ec);
- if(ec)
- return;
- }
-}
-
-template<bool isRequest, class Derived>
-inline
-void
-basic_parser<isRequest, Derived>::
-finish_header(error_code& ec, std::false_type)
-{
- // RFC 7230 section 3.3
- // https://tools.ietf.org/html/rfc7230#section-3.3
-
- if( (f_ & flagSkipBody) || // e.g. response to a HEAD request
- status_ / 100 == 1 || // 1xx e.g. Continue
- status_ == 204 || // No Content
- status_ == 304) // Not Modified
- {
- // VFALCO Content-Length may be present, but we
- // treat the message as not having a body.
- // https://github.com/boostorg/beast/issues/692
- state_ = state::complete;
- }
- else if(f_ & flagContentLength)
- {
- if(len_ > body_limit_)
- {
- ec = error::body_limit;
- return;
- }
- if(len_ > 0)
- {
- f_ |= flagHasBody;
- state_ = state::body0;
- }
- else
- {
- state_ = state::complete;
- }
- }
- else if(f_ & flagChunked)
- {
- f_ |= flagHasBody;
- state_ = state::chunk_header0;
- }
- else
- {
- f_ |= flagHasBody;
- f_ |= flagNeedEOF;
- state_ = state::body_to_eof0;
- }
-
- impl().on_header_impl(ec);
- if(ec)
- return;
- if(state_ == state::complete)
- {
- impl().on_finish_impl(ec);
- if(ec)
- return;
- }
-}
-
-template<bool isRequest, class Derived>
-inline
-void
-basic_parser<isRequest, Derived>::
-parse_body(char const*& p,
- std::size_t n, error_code& ec)
-{
- n = impl().on_body_impl(string_view{p,
- beast::detail::clamp(len_, n)}, ec);
- p += n;
- len_ -= n;
- if(ec)
- return;
- if(len_ > 0)
- return;
- impl().on_finish_impl(ec);
- if(ec)
- return;
- state_ = state::complete;
-}
-
-template<bool isRequest, class Derived>
-inline
-void
-basic_parser<isRequest, Derived>::
-parse_body_to_eof(char const*& p,
- std::size_t n, error_code& ec)
-{
- if(n > body_limit_)
- {
- ec = error::body_limit;
- return;
- }
- body_limit_ = body_limit_ - n;
- n = impl().on_body_impl(string_view{p, n}, ec);
- p += n;
- if(ec)
- return;
-}
-
-template<bool isRequest, class Derived>
-void
-basic_parser<isRequest, Derived>::
-parse_chunk_header(char const*& p0,
- std::size_t n, error_code& ec)
-{
-/*
- chunked-body = *chunk last-chunk trailer-part CRLF
-
- chunk = chunk-size [ chunk-ext ] CRLF chunk-data CRLF
- last-chunk = 1*("0") [ chunk-ext ] CRLF
- trailer-part = *( header-field CRLF )
-
- chunk-size = 1*HEXDIG
- chunk-data = 1*OCTET ; a sequence of chunk-size octets
- chunk-ext = *( ";" chunk-ext-name [ "=" chunk-ext-val ] )
- chunk-ext-name = token
- chunk-ext-val = token / quoted-string
-*/
-
- auto p = p0;
- auto const pend = p + n;
- char const* eol;
-
- if(! (f_ & flagFinalChunk))
- {
- if(n < skip_ + 2)
- {
- ec = error::need_more;
- return;
- }
- if(f_ & flagExpectCRLF)
- {
- // Treat the last CRLF in a chunk as
- // part of the next chunk, so p can
- // be parsed in one call instead of two.
- if(! parse_crlf(p))
- {
- ec = error::bad_chunk;
- return;
- }
- }
- eol = find_eol(p0 + skip_, pend, ec);
- if(ec)
- return;
- if(! eol)
- {
- ec = error::need_more;
- skip_ = n - 1;
- return;
- }
- skip_ = static_cast<
- std::size_t>(eol - 2 - p0);
-
- std::uint64_t size;
- if(! parse_hex(p, size))
- {
- ec = error::bad_chunk;
- return;
- }
- if(size != 0)
- {
- if(size > body_limit_)
- {
- ec = error::body_limit;
- return;
- }
- body_limit_ -= size;
- auto const start = p;
- parse_chunk_extensions(p, pend, ec);
- if(ec)
- return;
- if(p != eol -2 )
- {
- ec = error::bad_chunk_extension;
- return;
- }
- auto const ext = make_string(start, p);
- impl().on_chunk_header_impl(size, ext, ec);
- if(ec)
- return;
- len_ = size;
- skip_ = 2;
- p0 = eol;
- f_ |= flagExpectCRLF;
- state_ = state::chunk_body;
- return;
- }
-
- f_ |= flagFinalChunk;
- }
- else
- {
- BOOST_ASSERT(n >= 5);
- if(f_ & flagExpectCRLF)
- BOOST_VERIFY(parse_crlf(p));
- std::uint64_t size;
- BOOST_VERIFY(parse_hex(p, size));
- eol = find_eol(p, pend, ec);
- BOOST_ASSERT(! ec);
- }
-
- auto eom = find_eom(p0 + skip_, pend);
- if(! eom)
- {
- BOOST_ASSERT(n >= 3);
- skip_ = n - 3;
- ec = error::need_more;
- return;
- }
-
- auto const start = p;
- parse_chunk_extensions(p, pend, ec);
- if(ec)
- return;
- if(p != eol - 2)
- {
- ec = error::bad_chunk_extension;
- return;
- }
- auto const ext = make_string(start, p);
- impl().on_chunk_header_impl(0, ext, ec);
- if(ec)
- return;
- p = eol;
- parse_fields(p, eom, ec);
- if(ec)
- return;
- BOOST_ASSERT(p == eom);
- p0 = eom;
-
- impl().on_finish_impl(ec);
- if(ec)
- return;
- state_ = state::complete;
-}
-
-template<bool isRequest, class Derived>
-inline
-void
-basic_parser<isRequest, Derived>::
-parse_chunk_body(char const*& p,
- std::size_t n, error_code& ec)
-{
- n = impl().on_chunk_body_impl(
- len_, string_view{p,
- beast::detail::clamp(len_, n)}, ec);
- p += n;
- len_ -= n;
- if(len_ == 0)
- state_ = state::chunk_header;
-}
-
-template<bool isRequest, class Derived>
-void
-basic_parser<isRequest, Derived>::
-do_field(field f,
- string_view value, error_code& ec)
-{
- // Connection
- if(f == field::connection ||
- f == field::proxy_connection)
- {
- auto const list = opt_token_list{value};
- if(! validate_list(list))
- {
- // VFALCO Should this be a field specific error?
- ec = error::bad_value;
- return;
- }
- for(auto const& s : list)
- {
- if(iequals({"close", 5}, s))
- {
- f_ |= flagConnectionClose;
- continue;
- }
-
- if(iequals({"keep-alive", 10}, s))
- {
- f_ |= flagConnectionKeepAlive;
- continue;
- }
-
- if(iequals({"upgrade", 7}, s))
- {
- f_ |= flagConnectionUpgrade;
- continue;
- }
- }
- ec.assign(0, ec.category());
- return;
- }
-
- // Content-Length
- if(f == field::content_length)
- {
- if(f_ & flagContentLength)
- {
- // duplicate
- ec = error::bad_content_length;
- return;
- }
-
- if(f_ & flagChunked)
- {
- // conflicting field
- ec = error::bad_content_length;
- return;
- }
-
- std::uint64_t v;
- if(! parse_dec(
- value.begin(), value.end(), v))
- {
- ec = error::bad_content_length;
- return;
- }
-
- ec.assign(0, ec.category());
- len_ = v;
- f_ |= flagContentLength;
- return;
- }
-
- // Transfer-Encoding
- if(f == field::transfer_encoding)
- {
- if(f_ & flagChunked)
- {
- // duplicate
- ec = error::bad_transfer_encoding;
- return;
- }
-
- if(f_ & flagContentLength)
- {
- // conflicting field
- ec = error::bad_transfer_encoding;
- return;
- }
-
- ec.assign(0, ec.category());
- auto const v = token_list{value};
- auto const p = std::find_if(v.begin(), v.end(),
- [&](typename token_list::value_type const& s)
- {
- return iequals({"chunked", 7}, s);
- });
- if(p == v.end())
- return;
- if(std::next(p) != v.end())
- return;
- len_ = 0;
- f_ |= flagChunked;
- return;
- }
-
- // Upgrade
- if(f == field::upgrade)
- {
- ec.assign(0, ec.category());
- f_ |= flagUpgrade;
- return;
- }
-
- ec.assign(0, ec.category());
-}
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/impl/chunk_encode.ipp b/contrib/restricted/boost/boost/beast/http/impl/chunk_encode.ipp
deleted file mode 100644
index 51296041f7..0000000000
--- a/contrib/restricted/boost/boost/beast/http/impl/chunk_encode.ipp
+++ /dev/null
@@ -1,707 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_IMPL_CHUNK_ENCODE_IPP
-#define BOOST_BEAST_HTTP_IMPL_CHUNK_ENCODE_IPP
-
-#include <boost/beast/core/detail/varint.hpp>
-#include <boost/beast/http/error.hpp>
-#include <boost/beast/http/detail/rfc7230.hpp>
-#include <algorithm>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-inline
-chunk_header::
-chunk_header(std::size_t size)
- : view_(
- size,
- boost::asio::const_buffer{nullptr, 0},
- chunk_crlf{})
-{
- BOOST_ASSERT(size > 0);
-}
-
-inline
-chunk_header::
-chunk_header(
- std::size_t size,
- string_view extensions)
- : view_(
- size,
- boost::asio::const_buffer{
- extensions.data(), extensions.size()},
- chunk_crlf{})
-{
- BOOST_ASSERT(size > 0);
-}
-
-template<class ChunkExtensions, class>
-chunk_header::
-chunk_header(
- std::size_t size,
- ChunkExtensions&& extensions)
- : exts_(std::make_shared<detail::chunk_extensions_impl<
- typename std::decay<ChunkExtensions>::type>>(
- std::forward<ChunkExtensions>(extensions)))
- , view_(
- size,
- exts_->str(),
- chunk_crlf{})
-{
- static_assert(
- detail::is_chunk_extensions<ChunkExtensions>::value,
- "ChunkExtensions requirements not met");
- BOOST_ASSERT(size > 0);
-}
-
-template<class ChunkExtensions, class Allocator, class>
-chunk_header::
-chunk_header(
- std::size_t size,
- ChunkExtensions&& extensions,
- Allocator const& allocator)
- : exts_(std::allocate_shared<detail::chunk_extensions_impl<
- typename std::decay<ChunkExtensions>::type>>(allocator,
- std::forward<ChunkExtensions>(extensions)))
- , view_(
- size,
- exts_->str(),
- chunk_crlf{})
-{
- static_assert(
- detail::is_chunk_extensions<ChunkExtensions>::value,
- "ChunkExtensions requirements not met");
- BOOST_ASSERT(size > 0);
-}
-
-//------------------------------------------------------------------------------
-
-template<class ConstBufferSequence>
-chunk_body<ConstBufferSequence>::
-chunk_body(ConstBufferSequence const& buffers)
- : view_(
- boost::asio::buffer_size(buffers),
- boost::asio::const_buffer{nullptr, 0},
- chunk_crlf{},
- buffers,
- chunk_crlf{})
-{
-}
-
-template<class ConstBufferSequence>
-chunk_body<ConstBufferSequence>::
-chunk_body(
- ConstBufferSequence const& buffers,
- string_view extensions)
- : view_(
- boost::asio::buffer_size(buffers),
- boost::asio::const_buffer{
- extensions.data(), extensions.size()},
- chunk_crlf{},
- buffers,
- chunk_crlf{})
-{
-}
-
-template<class ConstBufferSequence>
-template<class ChunkExtensions, class>
-chunk_body<ConstBufferSequence>::
-chunk_body(
- ConstBufferSequence const& buffers,
- ChunkExtensions&& extensions)
- : exts_(std::make_shared<detail::chunk_extensions_impl<
- typename std::decay<ChunkExtensions>::type>>(
- std::forward<ChunkExtensions>(extensions)))
- , view_(
- boost::asio::buffer_size(buffers),
- exts_->str(),
- chunk_crlf{},
- buffers,
- chunk_crlf{})
-{
-}
-
-template<class ConstBufferSequence>
-template<class ChunkExtensions, class Allocator, class>
-chunk_body<ConstBufferSequence>::
-chunk_body(
- ConstBufferSequence const& buffers,
- ChunkExtensions&& extensions,
- Allocator const& allocator)
- : exts_(std::allocate_shared<detail::chunk_extensions_impl<
- typename std::decay<ChunkExtensions>::type>>(allocator,
- std::forward<ChunkExtensions>(extensions)))
- , view_(
- boost::asio::buffer_size(buffers),
- exts_->str(),
- chunk_crlf{},
- buffers,
- chunk_crlf{})
-{
-}
-
-//------------------------------------------------------------------------------
-
-template<class Trailer>
-template<class Allocator>
-auto
-chunk_last<Trailer>::
-prepare(Trailer const& trailer, Allocator const& allocator) ->
- buffers_type
-{
- auto sp = std::allocate_shared<typename
- Trailer::writer>(allocator, trailer);
- sp_ = sp;
- return sp->get();
-}
-
-template<class Trailer>
-auto
-chunk_last<Trailer>::
-prepare(Trailer const& trailer, std::true_type) ->
- buffers_type
-{
- auto sp = std::make_shared<
- typename Trailer::writer>(trailer);
- sp_ = sp;
- return sp->get();
-}
-
-template<class Trailer>
-auto
-chunk_last<Trailer>::
-prepare(Trailer const& trailer, std::false_type) ->
- buffers_type
-{
- return trailer;
-}
-
-template<class Trailer>
-chunk_last<Trailer>::
-chunk_last()
- : view_(
- detail::chunk_size0{},
- Trailer{})
-{
-}
-
-template<class Trailer>
-chunk_last<Trailer>::
-chunk_last(Trailer const& trailer)
- : view_(
- detail::chunk_size0{},
- prepare(trailer, is_fields<Trailer>{}))
-{
-}
-
-template<class Trailer>
-template<class DeducedTrailer, class Allocator, class>
-chunk_last<Trailer>::
-chunk_last(
- DeducedTrailer const& trailer, Allocator const& allocator)
- : view_(
- detail::chunk_size0{},
- prepare(trailer, allocator))
-{
-}
-
-//------------------------------------------------------------------------------
-
-template<class Allocator>
-class basic_chunk_extensions<Allocator>::const_iterator
-{
- friend class basic_chunk_extensions;
-
- using iter_type = char const*;
-
- iter_type it_;
- typename basic_chunk_extensions::value_type value_;
-
- explicit
- const_iterator(iter_type it)
- : it_(it)
- {
- }
-
- void
- increment();
-
-public:
- using value_type = typename
- basic_chunk_extensions::value_type;
- using pointer = value_type const*;
- using reference = value_type const&;
- using difference_type = std::ptrdiff_t;
- using iterator_category =
- std::forward_iterator_tag;
-
- const_iterator() = default;
- const_iterator(const_iterator&& other) = default;
- const_iterator(const_iterator const& other) = default;
- const_iterator& operator=(const_iterator&& other) = default;
- const_iterator& operator=(const_iterator const& other) = default;
-
- bool
- operator==(const_iterator const& other) const
- {
- return it_ == other.it_;
- }
-
- bool
- operator!=(const_iterator const& other) const
- {
- return !(*this == other);
- }
-
- reference
- operator*();
-
- pointer
- operator->()
- {
- return &(**this);
- }
-
- const_iterator&
- operator++()
- {
- increment();
- return *this;
- }
-
- const_iterator
- operator++(int)
- {
- auto temp = *this;
- increment();
- return temp;
- }
-};
-
-template<class Allocator>
-void
-basic_chunk_extensions<Allocator>::
-const_iterator::
-increment()
-{
- using beast::detail::varint_read;
- auto n = varint_read(it_);
- it_ += n;
- n = varint_read(it_);
- it_ += n;
-}
-
-template<class Allocator>
-auto
-basic_chunk_extensions<Allocator>::
-const_iterator::
-operator*() ->
- reference
-{
- using beast::detail::varint_read;
- auto it = it_;
- auto n = varint_read(it);
- value_.first = string_view{it, n};
- it += n;
- n = varint_read(it);
- value_.second = string_view{it, n};
- return value_;
-}
-
-//------------------------------------------------------------------------------
-
-template<class Allocator>
-template<class FwdIt>
-FwdIt
-basic_chunk_extensions<Allocator>::
-do_parse(FwdIt it, FwdIt last, error_code& ec)
-{
-/*
- chunk-ext = *( BWS ";" BWS chunk-ext-name [ BWS "=" BWS chunk-ext-val ] )
- BWS = *( SP / HTAB ) ; "Bad White Space"
- chunk-ext-name = token
- chunk-ext-val = token / quoted-string
- token = 1*tchar
- quoted-string = DQUOTE *( qdtext / quoted-pair ) DQUOTE
- qdtext = HTAB / SP / "!" / %x23-5B ; '#'-'[' / %x5D-7E ; ']'-'~' / obs-text
- quoted-pair = "\" ( HTAB / SP / VCHAR / obs-text )
- obs-text = %x80-FF
-
- https://www.rfc-editor.org/errata_search.php?rfc=7230&eid=4667
-*/
- using beast::detail::varint_size;
- using beast::detail::varint_write;
- using CharT = char;
- using Traits = std::char_traits<CharT>;
- range_.reserve(static_cast<std::size_t>(
- std::distance(it, last) * 1.2));
- range_.resize(0);
- auto const emit_string =
- [this](FwdIt from, FwdIt to)
- {
- auto const len =
- std::distance(from, to);
- auto const offset = range_.size();
- range_.resize(
- offset +
- varint_size(len) +
- len);
- auto dest = &range_[offset];
- varint_write(dest, len);
- Traits::copy(dest, from, len);
- };
- auto const emit_string_plus_empty =
- [this](FwdIt from, FwdIt to)
- {
- auto const len =
- std::distance(from, to);
- auto const offset = range_.size();
- range_.resize(
- offset +
- varint_size(len) +
- len +
- varint_size(0));
- auto dest = &range_[offset];
- varint_write(dest, len);
- Traits::copy(dest, from, len);
- dest += len;
- varint_write(dest, 0);
- };
- auto const emit_empty_string =
- [this]
- {
- auto const offset = range_.size();
- range_.resize(offset + varint_size(0));
- auto dest = &range_[offset];
- varint_write(dest, 0);
- };
-loop:
- if(it == last)
- {
- ec.assign(0, ec.category());
- return it;
- }
- // BWS
- if(*it == ' ' || *it == '\t')
- {
- for(;;)
- {
- ++it;
- if(it == last)
- {
- ec = error::bad_chunk_extension;
- return it;
- }
- if(*it != ' ' && *it != '\t')
- break;
- }
- }
- // ';'
- if(*it != ';')
- {
- ec = error::bad_chunk_extension;
- return it;
- }
-semi:
- ++it; // skip ';'
- // BWS
- for(;;)
- {
- if(it == last)
- {
- ec = error::bad_chunk_extension;
- return it;
- }
- if(*it != ' ' && *it != '\t')
- break;
- ++it;
- }
- // chunk-ext-name
- {
- if(! detail::is_token_char(*it))
- {
- ec = error::bad_chunk_extension;
- return it;
- }
- auto const first = it;
- for(;;)
- {
- ++it;
- if(it == last)
- {
- emit_string_plus_empty(first, it);
- return it;
- }
- if(! detail::is_token_char(*it))
- break;
- }
- emit_string(first, it);
- }
- // BWS [ ";" / "=" ]
- for(;;)
- {
- if(*it != ' ' && *it != '\t')
- break;
- ++it;
- if(it == last)
- {
- ec = error::bad_chunk_extension;
- return it;
- }
- }
- if(*it == ';')
- {
- emit_empty_string();
- goto semi;
- }
- if(*it != '=')
- {
- ec = error::bad_chunk_extension;
- return it;
- }
- ++it; // skip '='
- // BWS
- for(;;)
- {
- if(it == last)
- {
- ec = error::bad_chunk_extension;
- return it;
- }
- if(*it != ' ' && *it != '\t')
- break;
- ++it;
- }
- // chunk-ext-val
- if(*it != '"')
- {
- // token
- if(! detail::is_token_char(*it))
- {
- ec = error::bad_chunk_extension;
- return it;
- }
- auto const first = it;
- for(;;)
- {
- ++it;
- if(it == last)
- break;
- if(! detail::is_token_char(*it))
- break;
- }
- emit_string(first, it);
- if(it == last)
- return it;
- }
- else
- {
- // quoted-string
- auto const first = ++it; // skip DQUOTE
- // first pass, count chars
- std::size_t len = 0;
- for(;;)
- {
- if(it == last)
- {
- ec = error::bad_chunk_extension;
- return it;
- }
- if(*it == '"')
- break;
- if(*it == '\\')
- {
- ++it;
- if(it == last)
- {
- ec = error::bad_chunk_extension;
- return it;
- }
- }
- ++len;
- ++it;
- }
- // now build the string
- auto const offset = range_.size();
- range_.resize(
- offset +
- varint_size(len) +
- len);
- auto dest = &range_[offset];
- varint_write(dest, len);
- it = first;
- for(;;)
- {
- BOOST_ASSERT(it != last);
- if(*it == '"')
- break;
- if(*it == '\\')
- {
- ++it;
- BOOST_ASSERT(it != last);
- }
- Traits::assign(*dest++, *it++);
- }
- ++it; // skip DQUOTE
- }
- goto loop;
-}
-
-template<class Allocator>
-void
-basic_chunk_extensions<Allocator>::
-do_insert(string_view name, string_view value)
-{
-/*
- chunk-ext = *( ";" chunk-ext-name [ "=" chunk-ext-val ] )
- chunk-ext-name = token
- chunk-ext-val = token / quoted-string
- token = 1*tchar
- quoted-string = DQUOTE *( qdtext / quoted-pair ) DQUOTE
- qdtext = HTAB / SP / "!" / %x23-5B ; '#'-'[' / %x5D-7E ; ']'-'~' / obs-text
- quoted-pair = "\" ( HTAB / SP / VCHAR / obs-text )
- obs-text = %x80-FF
-*/
- if(value.empty())
- {
- s_.reserve(1 + name.size());
- s_.push_back(';');
- s_.append(name.data(), name.size());
- return;
- }
-
- bool is_token = true;
- for(auto const c : value)
- {
- if(! detail::is_token_char(c))
- {
- is_token = false;
- break;
- }
- }
- if(is_token)
- {
- // token
- s_.reserve(1 + name.size() + 1 + value.size());
- s_.push_back(';');
- s_.append(name.data(), name.size());
- s_.push_back('=');
- s_.append(value.data(), value.size());
- }
- else
- {
- // quoted-string
- s_.reserve(
- 1 + name.size() + 1 +
- 1 + value.size() + 20 + 1);
- s_.push_back(';');
- s_.append(name.data(), name.size());
- s_.append("=\"", 2);
- for(auto const c : value)
- {
- if(c == '\\')
- s_.append(R"(\\)", 2);
- else if(c == '\"')
- s_.append(R"(\")", 2);
- else
- s_.push_back(c);
- }
- s_.push_back('"');
- }
-}
-
-template<class Allocator>
-void
-basic_chunk_extensions<Allocator>::
-parse(string_view s, error_code& ec)
-{
- do_parse(s.data(), s.data() + s.size(), ec);
- if(! ec)
- {
- s_.clear();
- for(auto const& v : *this)
- do_insert(v.first, v.second);
- }
-}
-
-template<class Allocator>
-void
-basic_chunk_extensions<Allocator>::
-insert(string_view name)
-{
- do_insert(name, {});
-
- using beast::detail::varint_size;
- using beast::detail::varint_write;
- auto const offset = range_.size();
- range_.resize(
- offset +
- varint_size(name.size()) +
- name.size() +
- varint_size(0));
- auto dest = &range_[offset];
- varint_write(dest, name.size());
- std::memcpy(dest, name.data(), name.size());
- dest += name.size();
- varint_write(dest, 0);
-}
-
-template<class Allocator>
-void
-basic_chunk_extensions<Allocator>::
-insert(string_view name, string_view value)
-{
- do_insert(name, value);
-
- using beast::detail::varint_size;
- using beast::detail::varint_write;
- auto const offset = range_.size();
- range_.resize(
- offset +
- varint_size(name.size()) +
- name.size() +
- varint_size(value.size()) +
- value.size());
- auto dest = &range_[offset];
- varint_write(dest, name.size());
- std::memcpy(dest, name.data(), name.size());
- dest += name.size();
- varint_write(dest, value.size());
- std::memcpy(dest, value.data(), value.size());
-}
-
-template<class Allocator>
-inline
-auto
-basic_chunk_extensions<Allocator>::
-begin() const ->
- const_iterator
-{
- return const_iterator{range_.data()};
-}
-
-template<class Allocator>
-inline
-auto
-basic_chunk_extensions<Allocator>::
-end() const ->
- const_iterator
-{
- return const_iterator{
- range_.data() + range_.size()};
-}
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/impl/error.ipp b/contrib/restricted/boost/boost/beast/http/impl/error.ipp
deleted file mode 100644
index 45075f5c18..0000000000
--- a/contrib/restricted/boost/boost/beast/http/impl/error.ipp
+++ /dev/null
@@ -1,120 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_IMPL_ERROR_IPP
-#define BOOST_BEAST_HTTP_IMPL_ERROR_IPP
-
-#include <type_traits>
-
-namespace boost {
-
-namespace system {
-template<>
-struct is_error_code_enum<beast::http::error>
-{
- static bool const value = true;
-};
-} // system
-
-namespace beast {
-namespace http {
-namespace detail {
-
-class http_error_category : public error_category
-{
-public:
- const char*
- name() const noexcept override
- {
- return "beast.http";
- }
-
- std::string
- message(int ev) const override
- {
- switch(static_cast<error>(ev))
- {
- case error::end_of_stream: return "end of stream";
- case error::partial_message: return "partial message";
- case error::need_more: return "need more";
- case error::unexpected_body: return "unexpected body";
- case error::need_buffer: return "need buffer";
- case error::end_of_chunk: return "end of chunk";
- case error::buffer_overflow: return "buffer overflow";
- case error::header_limit: return "header limit exceeded";
- case error::body_limit: return "body limit exceeded";
- case error::bad_alloc: return "bad alloc";
- case error::bad_line_ending: return "bad line ending";
- case error::bad_method: return "bad method";
- case error::bad_target: return "bad target";
- case error::bad_version: return "bad version";
- case error::bad_status: return "bad status";
- case error::bad_reason: return "bad reason";
- case error::bad_field: return "bad field";
- case error::bad_value: return "bad value";
- case error::bad_content_length: return "bad Content-Length";
- case error::bad_transfer_encoding: return "bad Transfer-Encoding";
- case error::bad_chunk: return "bad chunk";
- case error::bad_chunk_extension: return "bad chunk extension";
- case error::bad_obs_fold: return "bad obs-fold";
-
- default:
- return "beast.http error";
- }
- }
-
- error_condition
- default_error_condition(
- int ev) const noexcept override
- {
- return error_condition{ev, *this};
- }
-
- bool
- equivalent(int ev,
- error_condition const& condition
- ) const noexcept override
- {
- return condition.value() == ev &&
- &condition.category() == this;
- }
-
- bool
- equivalent(error_code const& error,
- int ev) const noexcept override
- {
- return error.value() == ev &&
- &error.category() == this;
- }
-};
-
-inline
-error_category const&
-get_http_error_category()
-{
- static http_error_category const cat{};
- return cat;
-}
-
-} // detail
-
-inline
-error_code
-make_error_code(error ev)
-{
- return error_code{
- static_cast<std::underlying_type<error>::type>(ev),
- detail::get_http_error_category()};
-}
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/impl/field.ipp b/contrib/restricted/boost/boost/beast/http/impl/field.ipp
deleted file mode 100644
index 467a40aeee..0000000000
--- a/contrib/restricted/boost/boost/beast/http/impl/field.ipp
+++ /dev/null
@@ -1,562 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_IMPL_FIELD_IPP
-#define BOOST_BEAST_HTTP_IMPL_FIELD_IPP
-
-#include <boost/beast/core/string.hpp>
-#include <algorithm>
-#include <array>
-#include <unordered_map>
-#include <vector>
-#include <boost/assert.hpp>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-namespace detail {
-
-struct field_table
-{
- using array_type =
- std::array<string_view, 353>;
-
- struct hash
- {
- std::size_t
- operator()(string_view s) const
- {
- auto const n = s.size();
- return
- beast::detail::ascii_tolower(s[0]) *
- beast::detail::ascii_tolower(s[n/2]) ^
- beast::detail::ascii_tolower(s[n-1]); // hist[] = 331, 10, max_load_factor = 0.15f
- }
- };
-
- struct iequal
- {
- // assumes inputs have equal length
- bool
- operator()(
- string_view lhs,
- string_view rhs) const
- {
- auto p1 = lhs.data();
- auto p2 = rhs.data();
- auto pend = lhs.end();
- char a, b;
- while(p1 < pend)
- {
- a = *p1++;
- b = *p2++;
- if(a != b)
- goto slow;
- }
- return true;
-
- while(p1 < pend)
- {
- slow:
- if( beast::detail::ascii_tolower(a) !=
- beast::detail::ascii_tolower(b))
- return false;
- a = *p1++;
- b = *p2++;
- }
- return true;
- }
- };
-
- using map_type = std::unordered_map<
- string_view, field, hash, iequal>;
-
- array_type by_name_;
- std::vector<map_type> by_size_;
-/*
- From:
-
- https://www.iana.org/assignments/message-headers/message-headers.xhtml
-*/
- field_table()
- : by_name_({{
- "<unknown-field>",
- "A-IM",
- "Accept",
- "Accept-Additions",
- "Accept-Charset",
- "Accept-Datetime",
- "Accept-Encoding",
- "Accept-Features",
- "Accept-Language",
- "Accept-Patch",
- "Accept-Post",
- "Accept-Ranges",
- "Access-Control",
- "Access-Control-Allow-Credentials",
- "Access-Control-Allow-Headers",
- "Access-Control-Allow-Methods",
- "Access-Control-Allow-Origin",
- "Access-Control-Expose-Headers",
- "Access-Control-Max-Age",
- "Access-Control-Request-Headers",
- "Access-Control-Request-Method",
- "Age",
- "Allow",
- "ALPN",
- "Also-Control",
- "Alt-Svc",
- "Alt-Used",
- "Alternate-Recipient",
- "Alternates",
- "Apparently-To",
- "Apply-To-Redirect-Ref",
- "Approved",
- "Archive",
- "Archived-At",
- "Article-Names",
- "Article-Updates",
- "Authentication-Control",
- "Authentication-Info",
- "Authentication-Results",
- "Authorization",
- "Auto-Submitted",
- "Autoforwarded",
- "Autosubmitted",
- "Base",
- "Bcc",
- "Body",
- "C-Ext",
- "C-Man",
- "C-Opt",
- "C-PEP",
- "C-PEP-Info",
- "Cache-Control",
- "CalDAV-Timezones",
- "Cancel-Key",
- "Cancel-Lock",
- "Cc",
- "Close",
- "Comments",
- "Compliance",
- "Connection",
- "Content-Alternative",
- "Content-Base",
- "Content-Description",
- "Content-Disposition",
- "Content-Duration",
- "Content-Encoding",
- "Content-features",
- "Content-ID",
- "Content-Identifier",
- "Content-Language",
- "Content-Length",
- "Content-Location",
- "Content-MD5",
- "Content-Range",
- "Content-Return",
- "Content-Script-Type",
- "Content-Style-Type",
- "Content-Transfer-Encoding",
- "Content-Type",
- "Content-Version",
- "Control",
- "Conversion",
- "Conversion-With-Loss",
- "Cookie",
- "Cookie2",
- "Cost",
- "DASL",
- "Date",
- "Date-Received",
- "DAV",
- "Default-Style",
- "Deferred-Delivery",
- "Delivery-Date",
- "Delta-Base",
- "Depth",
- "Derived-From",
- "Destination",
- "Differential-ID",
- "Digest",
- "Discarded-X400-IPMS-Extensions",
- "Discarded-X400-MTS-Extensions",
- "Disclose-Recipients",
- "Disposition-Notification-Options",
- "Disposition-Notification-To",
- "Distribution",
- "DKIM-Signature",
- "DL-Expansion-History",
- "Downgraded-Bcc",
- "Downgraded-Cc",
- "Downgraded-Disposition-Notification-To",
- "Downgraded-Final-Recipient",
- "Downgraded-From",
- "Downgraded-In-Reply-To",
- "Downgraded-Mail-From",
- "Downgraded-Message-Id",
- "Downgraded-Original-Recipient",
- "Downgraded-Rcpt-To",
- "Downgraded-References",
- "Downgraded-Reply-To",
- "Downgraded-Resent-Bcc",
- "Downgraded-Resent-Cc",
- "Downgraded-Resent-From",
- "Downgraded-Resent-Reply-To",
- "Downgraded-Resent-Sender",
- "Downgraded-Resent-To",
- "Downgraded-Return-Path",
- "Downgraded-Sender",
- "Downgraded-To",
- "EDIINT-Features",
- "Eesst-Version",
- "Encoding",
- "Encrypted",
- "Errors-To",
- "ETag",
- "Expect",
- "Expires",
- "Expiry-Date",
- "Ext",
- "Followup-To",
- "Forwarded",
- "From",
- "Generate-Delivery-Report",
- "GetProfile",
- "Hobareg",
- "Host",
- "HTTP2-Settings",
- "If",
- "If-Match",
- "If-Modified-Since",
- "If-None-Match",
- "If-Range",
- "If-Schedule-Tag-Match",
- "If-Unmodified-Since",
- "IM",
- "Importance",
- "In-Reply-To",
- "Incomplete-Copy",
- "Injection-Date",
- "Injection-Info",
- "Jabber-ID",
- "Keep-Alive",
- "Keywords",
- "Label",
- "Language",
- "Last-Modified",
- "Latest-Delivery-Time",
- "Lines",
- "Link",
- "List-Archive",
- "List-Help",
- "List-ID",
- "List-Owner",
- "List-Post",
- "List-Subscribe",
- "List-Unsubscribe",
- "List-Unsubscribe-Post",
- "Location",
- "Lock-Token",
- "Man",
- "Max-Forwards",
- "Memento-Datetime",
- "Message-Context",
- "Message-ID",
- "Message-Type",
- "Meter",
- "Method-Check",
- "Method-Check-Expires",
- "MIME-Version",
- "MMHS-Acp127-Message-Identifier",
- "MMHS-Authorizing-Users",
- "MMHS-Codress-Message-Indicator",
- "MMHS-Copy-Precedence",
- "MMHS-Exempted-Address",
- "MMHS-Extended-Authorisation-Info",
- "MMHS-Handling-Instructions",
- "MMHS-Message-Instructions",
- "MMHS-Message-Type",
- "MMHS-Originator-PLAD",
- "MMHS-Originator-Reference",
- "MMHS-Other-Recipients-Indicator-CC",
- "MMHS-Other-Recipients-Indicator-To",
- "MMHS-Primary-Precedence",
- "MMHS-Subject-Indicator-Codes",
- "MT-Priority",
- "Negotiate",
- "Newsgroups",
- "NNTP-Posting-Date",
- "NNTP-Posting-Host",
- "Non-Compliance",
- "Obsoletes",
- "Opt",
- "Optional",
- "Optional-WWW-Authenticate",
- "Ordering-Type",
- "Organization",
- "Origin",
- "Original-Encoded-Information-Types",
- "Original-From",
- "Original-Message-ID",
- "Original-Recipient",
- "Original-Sender",
- "Original-Subject",
- "Originator-Return-Address",
- "Overwrite",
- "P3P",
- "Path",
- "PEP",
- "Pep-Info",
- "PICS-Label",
- "Position",
- "Posting-Version",
- "Pragma",
- "Prefer",
- "Preference-Applied",
- "Prevent-NonDelivery-Report",
- "Priority",
- "Privicon",
- "ProfileObject",
- "Protocol",
- "Protocol-Info",
- "Protocol-Query",
- "Protocol-Request",
- "Proxy-Authenticate",
- "Proxy-Authentication-Info",
- "Proxy-Authorization",
- "Proxy-Connection",
- "Proxy-Features",
- "Proxy-Instruction",
- "Public",
- "Public-Key-Pins",
- "Public-Key-Pins-Report-Only",
- "Range",
- "Received",
- "Received-SPF",
- "Redirect-Ref",
- "References",
- "Referer",
- "Referer-Root",
- "Relay-Version",
- "Reply-By",
- "Reply-To",
- "Require-Recipient-Valid-Since",
- "Resent-Bcc",
- "Resent-Cc",
- "Resent-Date",
- "Resent-From",
- "Resent-Message-ID",
- "Resent-Reply-To",
- "Resent-Sender",
- "Resent-To",
- "Resolution-Hint",
- "Resolver-Location",
- "Retry-After",
- "Return-Path",
- "Safe",
- "Schedule-Reply",
- "Schedule-Tag",
- "Sec-WebSocket-Accept",
- "Sec-WebSocket-Extensions",
- "Sec-WebSocket-Key",
- "Sec-WebSocket-Protocol",
- "Sec-WebSocket-Version",
- "Security-Scheme",
- "See-Also",
- "Sender",
- "Sensitivity",
- "Server",
- "Set-Cookie",
- "Set-Cookie2",
- "SetProfile",
- "SIO-Label",
- "SIO-Label-History",
- "SLUG",
- "SoapAction",
- "Solicitation",
- "Status-URI",
- "Strict-Transport-Security",
- "Subject",
- "SubOK",
- "Subst",
- "Summary",
- "Supersedes",
- "Surrogate-Capability",
- "Surrogate-Control",
- "TCN",
- "TE",
- "Timeout",
- "Title",
- "To",
- "Topic",
- "Trailer",
- "Transfer-Encoding",
- "TTL",
- "UA-Color",
- "UA-Media",
- "UA-Pixels",
- "UA-Resolution",
- "UA-Windowpixels",
- "Upgrade",
- "Urgency",
- "URI",
- "User-Agent",
- "Variant-Vary",
- "Vary",
- "VBR-Info",
- "Version",
- "Via",
- "Want-Digest",
- "Warning",
- "WWW-Authenticate",
- "X-Archived-At",
- "X-Device-Accept",
- "X-Device-Accept-Charset",
- "X-Device-Accept-Encoding",
- "X-Device-Accept-Language",
- "X-Device-User-Agent",
- "X-Frame-Options",
- "X-Mittente",
- "X-PGP-Sig",
- "X-Ricevuta",
- "X-Riferimento-Message-ID",
- "X-TipoRicevuta",
- "X-Trasporto",
- "X-VerificaSicurezza",
- "X400-Content-Identifier",
- "X400-Content-Return",
- "X400-Content-Type",
- "X400-MTS-Identifier",
- "X400-Originator",
- "X400-Received",
- "X400-Recipients",
- "X400-Trace",
- "Xref"
- }})
- {
- // find the longest field length
- std::size_t high = 0;
- for(auto const& s : by_name_)
- if(high < s.size())
- high = s.size();
- // build by_size map
- // skip field::unknown
- by_size_.resize(high + 1);
- for(auto& map : by_size_)
- map.max_load_factor(.15f);
- for(std::size_t i = 1;
- i < by_name_.size(); ++i)
- {
- auto const& s = by_name_[i];
- by_size_[s.size()].emplace(
- s, static_cast<field>(i));
- }
-
-#if 0
- // This snippet calculates the performance
- // of the hash function and map settings
- {
- std::vector<std::size_t> hist;
- for(auto const& map : by_size_)
- {
- for(std::size_t i = 0; i < map.bucket_count(); ++i)
- {
- auto const n = map.bucket_size(i);
- if(n > 0)
- {
- if(hist.size() < n)
- hist.resize(n);
- ++hist[n-1];
- }
- }
- }
- }
-#endif
- }
-
- field
- string_to_field(string_view s) const
- {
- if(s.size() >= by_size_.size())
- return field::unknown;
- auto const& map = by_size_[s.size()];
- if(map.empty())
- return field::unknown;
- auto it = map.find(s);
- if(it == map.end())
- return field::unknown;
- return it->second;
- }
-
- //
- // Deprecated
- //
-
- using const_iterator =
- array_type::const_iterator;
-
- std::size_t
- size() const
- {
- return by_name_.size();
- }
-
- const_iterator
- begin() const
- {
- return by_name_.begin();
- }
-
- const_iterator
- end() const
- {
- return by_name_.end();
- }
-};
-
-inline
-field_table const&
-get_field_table()
-{
- static field_table const tab;
- return tab;
-}
-
-template<class = void>
-string_view
-to_string(field f)
-{
- auto const& v = get_field_table();
- BOOST_ASSERT(static_cast<unsigned>(f) < v.size());
- return v.begin()[static_cast<unsigned>(f)];
-}
-
-} // detail
-
-inline
-string_view
-to_string(field f)
-{
- return detail::to_string(f);
-}
-
-inline
-field
-string_to_field(string_view s)
-{
- return detail::get_field_table().string_to_field(s);
-}
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/impl/fields.ipp b/contrib/restricted/boost/boost/beast/http/impl/fields.ipp
deleted file mode 100644
index 24e3012e3a..0000000000
--- a/contrib/restricted/boost/boost/beast/http/impl/fields.ipp
+++ /dev/null
@@ -1,1393 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_IMPL_FIELDS_IPP
-#define BOOST_BEAST_HTTP_IMPL_FIELDS_IPP
-
-#include <boost/beast/core/buffers_cat.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/core/static_string.hpp>
-#include <boost/beast/core/detail/buffers_ref.hpp>
-#include <boost/beast/http/verb.hpp>
-#include <boost/beast/http/rfc7230.hpp>
-#include <boost/beast/http/status.hpp>
-#include <boost/beast/http/chunk_encode.hpp>
-#include <boost/throw_exception.hpp>
-#include <stdexcept>
-#include <string>
-
-#if defined(BOOST_LIBSTDCXX_VERSION) && BOOST_LIBSTDCXX_VERSION < 60000
- // Workaround for https://gcc.gnu.org/bugzilla/show_bug.cgi?id=56437
-#ifndef BOOST_BEAST_HTTP_NO_FIELDS_BASIC_STRING_ALLOCATOR
-#define BOOST_BEAST_HTTP_NO_FIELDS_BASIC_STRING_ALLOCATOR
-#endif
-#endif
-
-namespace boost {
-namespace beast {
-namespace http {
-
-template<class Allocator>
-class basic_fields<Allocator>::writer
-{
-public:
- using iter_type = typename list_t::const_iterator;
-
- struct field_iterator
- {
- iter_type it_;
-
- using value_type = boost::asio::const_buffer;
- using pointer = value_type const*;
- using reference = value_type const;
- using difference_type = std::ptrdiff_t;
- using iterator_category =
- std::bidirectional_iterator_tag;
-
- field_iterator() = default;
- field_iterator(field_iterator&& other) = default;
- field_iterator(field_iterator const& other) = default;
- field_iterator& operator=(field_iterator&& other) = default;
- field_iterator& operator=(field_iterator const& other) = default;
-
- explicit
- field_iterator(iter_type it)
- : it_(it)
- {
- }
-
- bool
- operator==(field_iterator const& other) const
- {
- return it_ == other.it_;
- }
-
- bool
- operator!=(field_iterator const& other) const
- {
- return !(*this == other);
- }
-
- reference
- operator*() const
- {
- return it_->buffer();
- }
-
- field_iterator&
- operator++()
- {
- ++it_;
- return *this;
- }
-
- field_iterator
- operator++(int)
- {
- auto temp = *this;
- ++(*this);
- return temp;
- }
-
- field_iterator&
- operator--()
- {
- --it_;
- return *this;
- }
-
- field_iterator
- operator--(int)
- {
- auto temp = *this;
- --(*this);
- return temp;
- }
- };
-
- class field_range
- {
- field_iterator first_;
- field_iterator last_;
-
- public:
- using const_iterator =
- field_iterator;
-
- using value_type =
- typename const_iterator::value_type;
-
- field_range(iter_type first, iter_type last)
- : first_(first)
- , last_(last)
- {
- }
-
- const_iterator
- begin() const
- {
- return first_;
- }
-
- const_iterator
- end() const
- {
- return last_;
- }
- };
-
- using view_type = buffers_cat_view<
- boost::asio::const_buffer,
- boost::asio::const_buffer,
- boost::asio::const_buffer,
- field_range,
- chunk_crlf>;
-
- basic_fields const& f_;
- boost::optional<view_type> view_;
- char buf_[13];
-
-public:
- using const_buffers_type =
- beast::detail::buffers_ref<view_type>;
-
- writer(basic_fields const& f,
- unsigned version, verb v);
-
- writer(basic_fields const& f,
- unsigned version, unsigned code);
-
- writer(basic_fields const& f);
-
- const_buffers_type
- get() const
- {
- return const_buffers_type(*view_);
- }
-};
-
-template<class Allocator>
-basic_fields<Allocator>::writer::
-writer(basic_fields const& f)
- : f_(f)
-{
- view_.emplace(
- boost::asio::const_buffer{nullptr, 0},
- boost::asio::const_buffer{nullptr, 0},
- boost::asio::const_buffer{nullptr, 0},
- field_range(f_.list_.begin(), f_.list_.end()),
- chunk_crlf());
-}
-
-template<class Allocator>
-basic_fields<Allocator>::writer::
-writer(basic_fields const& f,
- unsigned version, verb v)
- : f_(f)
-{
-/*
- request
- "<method>"
- " <target>"
- " HTTP/X.Y\r\n" (11 chars)
-*/
- string_view sv;
- if(v == verb::unknown)
- sv = f_.get_method_impl();
- else
- sv = to_string(v);
-
- // target_or_reason_ has a leading SP
-
- buf_[0] = ' ';
- buf_[1] = 'H';
- buf_[2] = 'T';
- buf_[3] = 'T';
- buf_[4] = 'P';
- buf_[5] = '/';
- buf_[6] = '0' + static_cast<char>(version / 10);
- buf_[7] = '.';
- buf_[8] = '0' + static_cast<char>(version % 10);
- buf_[9] = '\r';
- buf_[10]= '\n';
-
- view_.emplace(
- boost::asio::const_buffer{sv.data(), sv.size()},
- boost::asio::const_buffer{
- f_.target_or_reason_.data(),
- f_.target_or_reason_.size()},
- boost::asio::const_buffer{buf_, 11},
- field_range(f_.list_.begin(), f_.list_.end()),
- chunk_crlf());
-}
-
-template<class Allocator>
-basic_fields<Allocator>::writer::
-writer(basic_fields const& f,
- unsigned version, unsigned code)
- : f_(f)
-{
-/*
- response
- "HTTP/X.Y ### " (13 chars)
- "<reason>"
- "\r\n"
-*/
- buf_[0] = 'H';
- buf_[1] = 'T';
- buf_[2] = 'T';
- buf_[3] = 'P';
- buf_[4] = '/';
- buf_[5] = '0' + static_cast<char>(version / 10);
- buf_[6] = '.';
- buf_[7] = '0' + static_cast<char>(version % 10);
- buf_[8] = ' ';
- buf_[9] = '0' + static_cast<char>(code / 100);
- buf_[10]= '0' + static_cast<char>((code / 10) % 10);
- buf_[11]= '0' + static_cast<char>(code % 10);
- buf_[12]= ' ';
-
- string_view sv;
- if(! f_.target_or_reason_.empty())
- sv = f_.target_or_reason_;
- else
- sv = obsolete_reason(static_cast<status>(code));
-
- view_.emplace(
- boost::asio::const_buffer{buf_, 13},
- boost::asio::const_buffer{sv.data(), sv.size()},
- boost::asio::const_buffer{"\r\n", 2},
- field_range(f_.list_.begin(), f_.list_.end()),
- chunk_crlf{});
-}
-
-//------------------------------------------------------------------------------
-
-template<class Allocator>
-basic_fields<Allocator>::
-value_type::
-value_type(
- field name,
- string_view sname,
- string_view value)
- : off_(static_cast<off_t>(sname.size() + 2))
- , len_(static_cast<off_t>(value.size()))
- , f_(name)
-{
- //BOOST_ASSERT(name == field::unknown ||
- // iequals(sname, to_string(name)));
- char* p = reinterpret_cast<char*>(this + 1);
- p[off_-2] = ':';
- p[off_-1] = ' ';
- p[off_ + len_] = '\r';
- p[off_ + len_ + 1] = '\n';
- sname.copy(p, sname.size());
- value.copy(p + off_, value.size());
-}
-
-template<class Allocator>
-inline
-field
-basic_fields<Allocator>::
-value_type::
-name() const
-{
- return f_;
-}
-
-template<class Allocator>
-inline
-string_view
-basic_fields<Allocator>::
-value_type::
-name_string() const
-{
- return {reinterpret_cast<
- char const*>(this + 1),
- static_cast<std::size_t>(off_ - 2)};
-}
-
-template<class Allocator>
-inline
-string_view
-basic_fields<Allocator>::
-value_type::
-value() const
-{
- return {reinterpret_cast<
- char const*>(this + 1) + off_,
- static_cast<std::size_t>(len_)};
-}
-
-template<class Allocator>
-inline
-boost::asio::const_buffer
-basic_fields<Allocator>::
-value_type::
-buffer() const
-{
- return boost::asio::const_buffer{
- reinterpret_cast<char const*>(this + 1),
- static_cast<std::size_t>(off_) + len_ + 2};
-}
-
-//------------------------------------------------------------------------------
-
-template<class Allocator>
-basic_fields<Allocator>::
-~basic_fields()
-{
- delete_list();
- realloc_string(method_, {});
- realloc_string(
- target_or_reason_, {});
-}
-
-template<class Allocator>
-basic_fields<Allocator>::
-basic_fields(Allocator const& alloc) noexcept
- : beast::detail::empty_base_optimization<Allocator>(alloc)
-{
-}
-
-template<class Allocator>
-basic_fields<Allocator>::
-basic_fields(basic_fields&& other) noexcept
- : beast::detail::empty_base_optimization<Allocator>(
- std::move(other.member()))
- , set_(std::move(other.set_))
- , list_(std::move(other.list_))
- , method_(other.method_)
- , target_or_reason_(other.target_or_reason_)
-{
- other.method_ = {};
- other.target_or_reason_ = {};
-}
-
-template<class Allocator>
-basic_fields<Allocator>::
-basic_fields(basic_fields&& other, Allocator const& alloc)
- : beast::detail::empty_base_optimization<Allocator>(alloc)
-{
- if(this->member() != other.member())
- {
- copy_all(other);
- other.clear_all();
- }
- else
- {
- set_ = std::move(other.set_);
- list_ = std::move(other.list_);
- method_ = other.method_;
- target_or_reason_ = other.target_or_reason_;
- }
-}
-
-template<class Allocator>
-basic_fields<Allocator>::
-basic_fields(basic_fields const& other)
- : beast::detail::empty_base_optimization<Allocator>(alloc_traits::
- select_on_container_copy_construction(other.member()))
-{
- copy_all(other);
-}
-
-template<class Allocator>
-basic_fields<Allocator>::
-basic_fields(basic_fields const& other,
- Allocator const& alloc)
- : beast::detail::empty_base_optimization<Allocator>(alloc)
-{
- copy_all(other);
-}
-
-template<class Allocator>
-template<class OtherAlloc>
-basic_fields<Allocator>::
-basic_fields(basic_fields<OtherAlloc> const& other)
-{
- copy_all(other);
-}
-
-template<class Allocator>
-template<class OtherAlloc>
-basic_fields<Allocator>::
-basic_fields(basic_fields<OtherAlloc> const& other,
- Allocator const& alloc)
- : beast::detail::empty_base_optimization<Allocator>(alloc)
-{
- copy_all(other);
-}
-
-template<class Allocator>
-auto
-basic_fields<Allocator>::
-operator=(basic_fields&& other) noexcept(
- alloc_traits::propagate_on_container_move_assignment::value)
- -> basic_fields&
-{
- static_assert(is_nothrow_move_assignable<Allocator>::value,
- "Allocator must be noexcept assignable.");
- if(this == &other)
- return *this;
- move_assign(other, std::integral_constant<bool,
- alloc_traits:: propagate_on_container_move_assignment::value>{});
- return *this;
-}
-
-template<class Allocator>
-auto
-basic_fields<Allocator>::
-operator=(basic_fields const& other) ->
- basic_fields&
-{
- copy_assign(other, std::integral_constant<bool,
- alloc_traits::propagate_on_container_copy_assignment::value>{});
- return *this;
-}
-
-template<class Allocator>
-template<class OtherAlloc>
-auto
-basic_fields<Allocator>::
-operator=(basic_fields<OtherAlloc> const& other) ->
- basic_fields&
-{
- clear_all();
- copy_all(other);
- return *this;
-}
-
-//------------------------------------------------------------------------------
-//
-// Element access
-//
-//------------------------------------------------------------------------------
-
-template<class Allocator>
-string_view const
-basic_fields<Allocator>::
-at(field name) const
-{
- BOOST_ASSERT(name != field::unknown);
- auto const it = find(name);
- if(it == end())
- BOOST_THROW_EXCEPTION(std::out_of_range{
- "field not found"});
- return it->value();
-}
-
-template<class Allocator>
-string_view const
-basic_fields<Allocator>::
-at(string_view name) const
-{
- auto const it = find(name);
- if(it == end())
- BOOST_THROW_EXCEPTION(std::out_of_range{
- "field not found"});
- return it->value();
-}
-
-template<class Allocator>
-string_view const
-basic_fields<Allocator>::
-operator[](field name) const
-{
- BOOST_ASSERT(name != field::unknown);
- auto const it = find(name);
- if(it == end())
- return {};
- return it->value();
-}
-
-template<class Allocator>
-string_view const
-basic_fields<Allocator>::
-operator[](string_view name) const
-{
- auto const it = find(name);
- if(it == end())
- return {};
- return it->value();
-}
-
-//------------------------------------------------------------------------------
-//
-// Modifiers
-//
-//------------------------------------------------------------------------------
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-clear()
-{
- delete_list();
- set_.clear();
- list_.clear();
-}
-
-template<class Allocator>
-inline
-void
-basic_fields<Allocator>::
-insert(field name, string_param const& value)
-{
- BOOST_ASSERT(name != field::unknown);
- insert(name, to_string(name), value);
-}
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-insert(string_view sname, string_param const& value)
-{
- auto const name =
- string_to_field(sname);
- insert(name, sname, value);
-}
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-insert(field name,
- string_view sname, string_param const& value)
-{
- auto& e = new_element(name, sname,
- static_cast<string_view>(value));
- auto const before =
- set_.upper_bound(sname, key_compare{});
- if(before == set_.begin())
- {
- BOOST_ASSERT(count(sname) == 0);
- set_.insert_before(before, e);
- list_.push_back(e);
- return;
- }
- auto const last = std::prev(before);
- // VFALCO is it worth comparing `field name` first?
- if(! iequals(sname, last->name_string()))
- {
- BOOST_ASSERT(count(sname) == 0);
- set_.insert_before(before, e);
- list_.push_back(e);
- return;
- }
- // keep duplicate fields together in the list
- set_.insert_before(before, e);
- list_.insert(++list_.iterator_to(*last), e);
-}
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-set(field name, string_param const& value)
-{
- BOOST_ASSERT(name != field::unknown);
- set_element(new_element(name, to_string(name),
- static_cast<string_view>(value)));
-}
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-set(string_view sname, string_param const& value)
-{
- set_element(new_element(
- string_to_field(sname), sname,
- static_cast<string_view>(value)));
-}
-
-template<class Allocator>
-auto
-basic_fields<Allocator>::
-erase(const_iterator pos) ->
- const_iterator
-{
- auto next = pos;
- auto& e = *next++;
- set_.erase(e);
- list_.erase(pos);
- delete_element(const_cast<value_type&>(e));
- return next;
-}
-
-template<class Allocator>
-std::size_t
-basic_fields<Allocator>::
-erase(field name)
-{
- BOOST_ASSERT(name != field::unknown);
- return erase(to_string(name));
-}
-
-template<class Allocator>
-std::size_t
-basic_fields<Allocator>::
-erase(string_view name)
-{
- std::size_t n =0;
- set_.erase_and_dispose(name, key_compare{},
- [&](value_type* e)
- {
- ++n;
- list_.erase(list_.iterator_to(*e));
- delete_element(*e);
- });
- return n;
-}
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-swap(basic_fields<Allocator>& other)
-{
- swap(other, std::integral_constant<bool,
- alloc_traits::propagate_on_container_swap::value>{});
-}
-
-template<class Allocator>
-void
-swap(
- basic_fields<Allocator>& lhs,
- basic_fields<Allocator>& rhs)
-{
- lhs.swap(rhs);
-}
-
-//------------------------------------------------------------------------------
-//
-// Lookup
-//
-//------------------------------------------------------------------------------
-
-template<class Allocator>
-inline
-std::size_t
-basic_fields<Allocator>::
-count(field name) const
-{
- BOOST_ASSERT(name != field::unknown);
- return count(to_string(name));
-}
-
-template<class Allocator>
-std::size_t
-basic_fields<Allocator>::
-count(string_view name) const
-{
- return set_.count(name, key_compare{});
-}
-
-template<class Allocator>
-inline
-auto
-basic_fields<Allocator>::
-find(field name) const ->
- const_iterator
-{
- BOOST_ASSERT(name != field::unknown);
- return find(to_string(name));
-}
-
-template<class Allocator>
-auto
-basic_fields<Allocator>::
-find(string_view name) const ->
- const_iterator
-{
- auto const it = set_.find(
- name, key_compare{});
- if(it == set_.end())
- return list_.end();
- return list_.iterator_to(*it);
-}
-
-template<class Allocator>
-inline
-auto
-basic_fields<Allocator>::
-equal_range(field name) const ->
- std::pair<const_iterator, const_iterator>
-{
- BOOST_ASSERT(name != field::unknown);
- return equal_range(to_string(name));
-}
-
-template<class Allocator>
-auto
-basic_fields<Allocator>::
-equal_range(string_view name) const ->
- std::pair<const_iterator, const_iterator>
-{
- auto result =
- set_.equal_range(name, key_compare{});
- if(result.first == result.second)
- return {list_.end(), list_.end()};
- return {
- list_.iterator_to(*result.first),
- ++list_.iterator_to(*(--result.second))};
-}
-
-//------------------------------------------------------------------------------
-
-namespace detail {
-
-// Filter a token list
-//
-template<class String, class Pred>
-void
-filter_token_list(
- String& s,
- string_view value,
- Pred&& pred)
-{
- token_list te{value};
- auto it = te.begin();
- auto last = te.end();
- if(it == last)
- return;
- while(pred(*it))
- if(++it == last)
- return;
- s.append(it->data(), it->size());
- while(++it != last)
- {
- if(! pred(*it))
- {
- s.append(", ");
- s.append(it->data(), it->size());
- }
- }
-}
-
-// Filter the last item in a token list
-template<class String, class Pred>
-void
-filter_token_list_last(
- String& s,
- string_view value,
- Pred&& pred)
-{
- token_list te{value};
- if(te.begin() != te.end())
- {
- auto it = te.begin();
- auto next = std::next(it);
- if(next == te.end())
- {
- if(! pred(*it))
- s.append(it->data(), it->size());
- return;
- }
- s.append(it->data(), it->size());
- for(;;)
- {
- it = next;
- next = std::next(it);
- if(next == te.end())
- {
- if(! pred(*it))
- {
- s.append(", ");
- s.append(it->data(), it->size());
- }
- return;
- }
- s.append(", ");
- s.append(it->data(), it->size());
- }
- }
-}
-
-template<class String>
-void
-keep_alive_impl(
- String& s, string_view value,
- unsigned version, bool keep_alive)
-{
- if(version < 11)
- {
- if(keep_alive)
- {
- // remove close
- filter_token_list(s, value,
- [](string_view s)
- {
- return iequals(s, "close");
- });
- // add keep-alive
- if(s.empty())
- s.append("keep-alive");
- else if(! token_list{value}.exists("keep-alive"))
- s.append(", keep-alive");
- }
- else
- {
- // remove close and keep-alive
- filter_token_list(s, value,
- [](string_view s)
- {
- return
- iequals(s, "close") ||
- iequals(s, "keep-alive");
- });
- }
- }
- else
- {
- if(keep_alive)
- {
- // remove close and keep-alive
- filter_token_list(s, value,
- [](string_view s)
- {
- return
- iequals(s, "close") ||
- iequals(s, "keep-alive");
- });
- }
- else
- {
- // remove keep-alive
- filter_token_list(s, value,
- [](string_view s)
- {
- return iequals(s, "keep-alive");
- });
- // add close
- if(s.empty())
- s.append("close");
- else if(! token_list{value}.exists("close"))
- s.append(", close");
- }
- }
-}
-
-} // detail
-
-//------------------------------------------------------------------------------
-
-// Fields
-
-template<class Allocator>
-inline
-string_view
-basic_fields<Allocator>::
-get_method_impl() const
-{
- return method_;
-}
-
-template<class Allocator>
-inline
-string_view
-basic_fields<Allocator>::
-get_target_impl() const
-{
- if(target_or_reason_.empty())
- return target_or_reason_;
- return {
- target_or_reason_.data() + 1,
- target_or_reason_.size() - 1};
-}
-
-template<class Allocator>
-inline
-string_view
-basic_fields<Allocator>::
-get_reason_impl() const
-{
- return target_or_reason_;
-}
-
-template<class Allocator>
-bool
-basic_fields<Allocator>::
-get_chunked_impl() const
-{
- auto const te = token_list{
- (*this)[field::transfer_encoding]};
- for(auto it = te.begin(); it != te.end();)
- {
- auto const next = std::next(it);
- if(next == te.end())
- return iequals(*it, "chunked");
- it = next;
- }
- return false;
-}
-
-template<class Allocator>
-bool
-basic_fields<Allocator>::
-get_keep_alive_impl(unsigned version) const
-{
- auto const it = find(field::connection);
- if(version < 11)
- {
- if(it == end())
- return false;
- return token_list{
- it->value()}.exists("keep-alive");
- }
- if(it == end())
- return true;
- return ! token_list{
- it->value()}.exists("close");
-}
-
-template<class Allocator>
-bool
-basic_fields<Allocator>::
-has_content_length_impl() const
-{
- return count(field::content_length) > 0;
-}
-
-template<class Allocator>
-inline
-void
-basic_fields<Allocator>::
-set_method_impl(string_view s)
-{
- realloc_string(method_, s);
-}
-
-template<class Allocator>
-inline
-void
-basic_fields<Allocator>::
-set_target_impl(string_view s)
-{
- realloc_target(
- target_or_reason_, s);
-}
-
-template<class Allocator>
-inline
-void
-basic_fields<Allocator>::
-set_reason_impl(string_view s)
-{
- realloc_string(
- target_or_reason_, s);
-}
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-set_chunked_impl(bool value)
-{
- auto it = find(field::transfer_encoding);
- if(value)
- {
- // append "chunked"
- if(it == end())
- {
- set(field::transfer_encoding, "chunked");
- return;
- }
- auto const te = token_list{it->value()};
- for(auto itt = te.begin();;)
- {
- auto const next = std::next(itt);
- if(next == te.end())
- {
- if(iequals(*itt, "chunked"))
- return; // already set
- break;
- }
- itt = next;
- }
- static_string<max_static_buffer> buf;
- if(it->value().size() <= buf.size() + 9)
- {
- buf.append(it->value().data(), it->value().size());
- buf.append(", chunked", 9);
- set(field::transfer_encoding, buf);
- }
- else
- {
- #ifdef BOOST_BEAST_HTTP_NO_FIELDS_BASIC_STRING_ALLOCATOR
- // Workaround for https://gcc.gnu.org/bugzilla/show_bug.cgi?id=56437
- std::string s;
- #else
- using A =
- typename beast::detail::allocator_traits<
- Allocator>::template rebind_alloc<char>;
- std::basic_string<
- char,
- std::char_traits<char>,
- A> s{A{this->member()}};
- #endif
- s.reserve(it->value().size() + 9);
- s.append(it->value().data(), it->value().size());
- s.append(", chunked", 9);
- set(field::transfer_encoding, s);
- }
- return;
- }
- // filter "chunked"
- if(it == end())
- return;
- try
- {
- static_string<max_static_buffer> buf;
- detail::filter_token_list_last(buf, it->value(),
- [](string_view s)
- {
- return iequals(s, "chunked");
- });
- if(! buf.empty())
- set(field::transfer_encoding, buf);
- else
- erase(field::transfer_encoding);
- }
- catch(std::length_error const&)
- {
- #ifdef BOOST_BEAST_HTTP_NO_FIELDS_BASIC_STRING_ALLOCATOR
- // Workaround for https://gcc.gnu.org/bugzilla/show_bug.cgi?id=56437
- std::string s;
- #else
- using A =
- typename beast::detail::allocator_traits<
- Allocator>::template rebind_alloc<char>;
- std::basic_string<
- char,
- std::char_traits<char>,
- A> s{A{this->member()}};
- #endif
- s.reserve(it->value().size());
- detail::filter_token_list_last(s, it->value(),
- [](string_view s)
- {
- return iequals(s, "chunked");
- });
- if(! s.empty())
- set(field::transfer_encoding, s);
- else
- erase(field::transfer_encoding);
- }
-}
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-set_content_length_impl(
- boost::optional<std::uint64_t> const& value)
-{
- if(! value)
- erase(field::content_length);
- else
- set(field::content_length, *value);
-}
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-set_keep_alive_impl(
- unsigned version, bool keep_alive)
-{
- // VFALCO What about Proxy-Connection ?
- auto const value = (*this)[field::connection];
- try
- {
- static_string<max_static_buffer> buf;
- detail::keep_alive_impl(
- buf, value, version, keep_alive);
- if(buf.empty())
- erase(field::connection);
- else
- set(field::connection, buf);
- }
- catch(std::length_error const&)
- {
- #ifdef BOOST_BEAST_HTTP_NO_FIELDS_BASIC_STRING_ALLOCATOR
- // Workaround for https://gcc.gnu.org/bugzilla/show_bug.cgi?id=56437
- std::string s;
- #else
- using A =
- typename beast::detail::allocator_traits<
- Allocator>::template rebind_alloc<char>;
- std::basic_string<
- char,
- std::char_traits<char>,
- A> s{A{this->member()}};
- #endif
- s.reserve(value.size());
- detail::keep_alive_impl(
- s, value, version, keep_alive);
- if(s.empty())
- erase(field::connection);
- else
- set(field::connection, s);
- }
-}
-
-//------------------------------------------------------------------------------
-
-template<class Allocator>
-auto
-basic_fields<Allocator>::
-new_element(field name,
- string_view sname, string_view value) ->
- value_type&
-{
- if(sname.size() + 2 >
- (std::numeric_limits<off_t>::max)())
- BOOST_THROW_EXCEPTION(std::length_error{
- "field name too large"});
- if(value.size() + 2 >
- (std::numeric_limits<off_t>::max)())
- BOOST_THROW_EXCEPTION(std::length_error{
- "field value too large"});
- value = detail::trim(value);
- std::uint16_t const off =
- static_cast<off_t>(sname.size() + 2);
- std::uint16_t const len =
- static_cast<off_t>(value.size());
- auto a = rebind_type{this->member()};
- auto const p = alloc_traits::allocate(a,
- (sizeof(value_type) + off + len + 2 + sizeof(align_type) - 1) /
- sizeof(align_type));
- // VFALCO allocator can't call the constructor because its private
- //alloc_traits::construct(a, p, name, sname, value);
- new(p) value_type{name, sname, value};
- return *reinterpret_cast<value_type*>(p);
-}
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-delete_element(value_type& e)
-{
- auto a = rebind_type{this->member()};
- auto const n =
- (sizeof(value_type) + e.off_ + e.len_ + 2 + sizeof(align_type) - 1) /
- sizeof(align_type);
- //alloc_traits::destroy(a, &e);
- e.~value_type();
- alloc_traits::deallocate(a,
- reinterpret_cast<align_type*>(&e), n);
-}
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-set_element(value_type& e)
-{
- auto it = set_.lower_bound(
- e.name_string(), key_compare{});
- if(it == set_.end() || ! iequals(
- e.name_string(), it->name_string()))
- {
- set_.insert_before(it, e);
- list_.push_back(e);
- return;
- }
- for(;;)
- {
- auto next = it;
- ++next;
- set_.erase(it);
- list_.erase(list_.iterator_to(*it));
- delete_element(*it);
- it = next;
- if(it == set_.end() ||
- ! iequals(e.name_string(), it->name_string()))
- break;
- }
- set_.insert_before(it, e);
- list_.push_back(e);
-}
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-realloc_string(string_view& dest, string_view s)
-{
- if(dest.empty() && s.empty())
- return;
- auto a = typename beast::detail::allocator_traits<
- Allocator>::template rebind_alloc<
- char>(this->member());
- char* p = nullptr;
- if(! s.empty())
- {
- p = a.allocate(s.size());
- s.copy(p, s.size());
- }
- if(! dest.empty())
- a.deallocate(const_cast<char*>(
- dest.data()), dest.size());
- if(p)
- dest = {p, s.size()};
- else
- dest = {};
-}
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-realloc_target(
- string_view& dest, string_view s)
-{
- // The target string are stored with an
- // extra space at the beginning to help
- // the writer class.
- if(dest.empty() && s.empty())
- return;
- auto a = typename beast::detail::allocator_traits<
- Allocator>::template rebind_alloc<
- char>(this->member());
- char* p = nullptr;
- if(! s.empty())
- {
- p = a.allocate(1 + s.size());
- p[0] = ' ';
- s.copy(p + 1, s.size());
- }
- if(! dest.empty())
- a.deallocate(const_cast<char*>(
- dest.data()), dest.size());
- if(p)
- dest = {p, 1 + s.size()};
- else
- dest = {};
-}
-
-template<class Allocator>
-template<class OtherAlloc>
-void
-basic_fields<Allocator>::
-copy_all(basic_fields<OtherAlloc> const& other)
-{
- for(auto const& e : other.list_)
- insert(e.name(), e.name_string(), e.value());
- realloc_string(method_, other.method_);
- realloc_string(target_or_reason_,
- other.target_or_reason_);
-}
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-clear_all()
-{
- clear();
- realloc_string(method_, {});
- realloc_string(target_or_reason_, {});
-}
-
-template<class Allocator>
-void
-basic_fields<Allocator>::
-delete_list()
-{
- for(auto it = list_.begin(); it != list_.end();)
- delete_element(*it++);
-}
-
-//------------------------------------------------------------------------------
-
-template<class Allocator>
-inline
-void
-basic_fields<Allocator>::
-move_assign(basic_fields& other, std::true_type)
-{
- clear_all();
- set_ = std::move(other.set_);
- list_ = std::move(other.list_);
- method_ = other.method_;
- target_or_reason_ = other.target_or_reason_;
- other.method_ = {};
- other.target_or_reason_ = {};
- this->member() = other.member();
-}
-
-template<class Allocator>
-inline
-void
-basic_fields<Allocator>::
-move_assign(basic_fields& other, std::false_type)
-{
- clear_all();
- if(this->member() != other.member())
- {
- copy_all(other);
- other.clear_all();
- }
- else
- {
- set_ = std::move(other.set_);
- list_ = std::move(other.list_);
- method_ = other.method_;
- target_or_reason_ = other.target_or_reason_;
- other.method_ = {};
- other.target_or_reason_ = {};
- }
-}
-
-template<class Allocator>
-inline
-void
-basic_fields<Allocator>::
-copy_assign(basic_fields const& other, std::true_type)
-{
- clear_all();
- this->member() = other.member();
- copy_all(other);
-}
-
-template<class Allocator>
-inline
-void
-basic_fields<Allocator>::
-copy_assign(basic_fields const& other, std::false_type)
-{
- clear_all();
- copy_all(other);
-}
-
-template<class Allocator>
-inline
-void
-basic_fields<Allocator>::
-swap(basic_fields& other, std::true_type)
-{
- using std::swap;
- swap(this->member(), other.member());
- swap(set_, other.set_);
- swap(list_, other.list_);
- swap(method_, other.method_);
- swap(target_or_reason_, other.target_or_reason_);
-}
-
-template<class Allocator>
-inline
-void
-basic_fields<Allocator>::
-swap(basic_fields& other, std::false_type)
-{
- BOOST_ASSERT(this->member() == other.member());
- using std::swap;
- swap(set_, other.set_);
- swap(list_, other.list_);
- swap(method_, other.method_);
- swap(target_or_reason_, other.target_or_reason_);
-}
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/impl/file_body_win32.ipp b/contrib/restricted/boost/boost/beast/http/impl/file_body_win32.ipp
deleted file mode 100644
index 627401f531..0000000000
--- a/contrib/restricted/boost/boost/beast/http/impl/file_body_win32.ipp
+++ /dev/null
@@ -1,595 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_IMPL_FILE_BODY_WIN32_IPP
-#define BOOST_BEAST_HTTP_IMPL_FILE_BODY_WIN32_IPP
-
-#if BOOST_BEAST_USE_WIN32_FILE
-
-#include <boost/beast/core/bind_handler.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/core/detail/clamp.hpp>
-#include <boost/beast/http/serializer.hpp>
-#include <boost/asio/associated_allocator.hpp>
-#include <boost/asio/associated_executor.hpp>
-#include <boost/asio/async_result.hpp>
-#include <boost/asio/basic_stream_socket.hpp>
-#include <boost/asio/handler_continuation_hook.hpp>
-#include <boost/asio/handler_invoke_hook.hpp>
-#include <boost/asio/windows/overlapped_ptr.hpp>
-#include <boost/make_unique.hpp>
-#include <boost/smart_ptr/make_shared_array.hpp>
-#include <boost/winapi/basic_types.hpp>
-#include <boost/winapi/get_last_error.hpp>
-#include <algorithm>
-#include <cstring>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-namespace detail {
-template<class, class, bool, class>
-class write_some_win32_op;
-} // detail
-
-template<>
-struct basic_file_body<file_win32>
-{
- using file_type = file_win32;
-
- class writer;
- class reader;
-
- //--------------------------------------------------------------------------
-
- class value_type
- {
- friend class writer;
- friend class reader;
- friend struct basic_file_body<file_win32>;
-
- template<class, class, bool, class>
- friend class detail::write_some_win32_op;
- template<
- class Protocol, bool isRequest, class Fields>
- friend
- std::size_t
- write_some(
- boost::asio::basic_stream_socket<Protocol>& sock,
- serializer<isRequest,
- basic_file_body<file_win32>, Fields>& sr,
- error_code& ec);
-
- file_win32 file_;
- std::uint64_t size_ = 0; // cached file size
- std::uint64_t first_; // starting offset of the range
- std::uint64_t last_; // ending offset of the range
-
- public:
- ~value_type() = default;
- value_type() = default;
- value_type(value_type&& other) = default;
- value_type& operator=(value_type&& other) = default;
-
- bool
- is_open() const
- {
- return file_.is_open();
- }
-
- std::uint64_t
- size() const
- {
- return size_;
- }
-
- void
- close();
-
- void
- open(char const* path, file_mode mode, error_code& ec);
-
- void
- reset(file_win32&& file, error_code& ec);
- };
-
- //--------------------------------------------------------------------------
-
- class writer
- {
- template<class, class, bool, class>
- friend class detail::write_some_win32_op;
- template<
- class Protocol, bool isRequest, class Fields>
- friend
- std::size_t
- write_some(
- boost::asio::basic_stream_socket<Protocol>& sock,
- serializer<isRequest,
- basic_file_body<file_win32>, Fields>& sr,
- error_code& ec);
-
- value_type& body_; // The body we are reading from
- std::uint64_t pos_; // The current position in the file
- char buf_[4096]; // Small buffer for reading
-
- public:
- using const_buffers_type =
- boost::asio::const_buffer;
-
- template<bool isRequest, class Fields>
- writer(header<isRequest, Fields>&, value_type& b)
- : body_(b)
- {
- }
-
- void
- init(error_code&)
- {
- BOOST_ASSERT(body_.file_.is_open());
- pos_ = body_.first_;
- }
-
- boost::optional<std::pair<const_buffers_type, bool>>
- get(error_code& ec)
- {
- std::size_t const n = (std::min)(sizeof(buf_),
- beast::detail::clamp(body_.last_ - pos_));
- if(n == 0)
- {
- ec.assign(0, ec.category());
- return boost::none;
- }
- auto const nread = body_.file_.read(buf_, n, ec);
- if(ec)
- return boost::none;
- BOOST_ASSERT(nread != 0);
- pos_ += nread;
- ec.assign(0, ec.category());
- return {{
- {buf_, nread}, // buffer to return.
- pos_ < body_.last_}}; // `true` if there are more buffers.
- }
- };
-
- //--------------------------------------------------------------------------
-
- class reader
- {
- value_type& body_;
-
- public:
- template<bool isRequest, class Fields>
- explicit
- reader(header<isRequest, Fields>&, value_type& b)
- : body_(b)
- {
- }
-
- void
- init(boost::optional<
- std::uint64_t> const& content_length,
- error_code& ec)
- {
- // VFALCO We could reserve space in the file
- boost::ignore_unused(content_length);
- BOOST_ASSERT(body_.file_.is_open());
- ec.assign(0, ec.category());
- }
-
- template<class ConstBufferSequence>
- std::size_t
- put(ConstBufferSequence const& buffers,
- error_code& ec)
- {
- std::size_t nwritten = 0;
- for(auto buffer : beast::detail::buffers_range(buffers))
- {
- nwritten += body_.file_.write(
- buffer.data(), buffer.size(), ec);
- if(ec)
- return nwritten;
- }
- ec.assign(0, ec.category());
- return nwritten;
- }
-
- void
- finish(error_code& ec)
- {
- ec.assign(0, ec.category());
- }
- };
-
- //--------------------------------------------------------------------------
-
- static
- std::uint64_t
- size(value_type const& body)
- {
- return body.size();
- }
-};
-
-//------------------------------------------------------------------------------
-
-inline
-void
-basic_file_body<file_win32>::
-value_type::
-close()
-{
- error_code ignored;
- file_.close(ignored);
-}
-
-inline
-void
-basic_file_body<file_win32>::
-value_type::
-open(char const* path, file_mode mode, error_code& ec)
-{
- file_.open(path, mode, ec);
- if(ec)
- return;
- size_ = file_.size(ec);
- if(ec)
- {
- close();
- return;
- }
- first_ = 0;
- last_ = size_;
-}
-
-inline
-void
-basic_file_body<file_win32>::
-value_type::
-reset(file_win32&& file, error_code& ec)
-{
- if(file_.is_open())
- {
- error_code ignored;
- file_.close(ignored);
- }
- file_ = std::move(file);
- if(file_.is_open())
- {
- size_ = file_.size(ec);
- if(ec)
- {
- close();
- return;
- }
- first_ = 0;
- last_ = size_;
- }
-}
-
-//------------------------------------------------------------------------------
-
-namespace detail {
-
-template<class Unsigned>
-inline
-boost::winapi::DWORD_
-lowPart(Unsigned n)
-{
- return static_cast<
- boost::winapi::DWORD_>(
- n & 0xffffffff);
-}
-
-template<class Unsigned>
-inline
-boost::winapi::DWORD_
-highPart(Unsigned n, std::true_type)
-{
- return static_cast<
- boost::winapi::DWORD_>(
- (n>>32)&0xffffffff);
-}
-
-template<class Unsigned>
-inline
-boost::winapi::DWORD_
-highPart(Unsigned, std::false_type)
-{
- return 0;
-}
-
-template<class Unsigned>
-inline
-boost::winapi::DWORD_
-highPart(Unsigned n)
-{
- return highPart(n, std::integral_constant<
- bool, (sizeof(Unsigned)>4)>{});
-}
-
-class null_lambda
-{
-public:
- template<class ConstBufferSequence>
- void
- operator()(error_code&,
- ConstBufferSequence const&) const
- {
- BOOST_ASSERT(false);
- }
-};
-
-//------------------------------------------------------------------------------
-
-#if BOOST_ASIO_HAS_WINDOWS_OVERLAPPED_PTR
-
-template<
- class Protocol, class Handler,
- bool isRequest, class Fields>
-class write_some_win32_op
-{
- boost::asio::basic_stream_socket<Protocol>& sock_;
- serializer<isRequest,
- basic_file_body<file_win32>, Fields>& sr_;
- std::size_t bytes_transferred_ = 0;
- Handler h_;
- bool header_ = false;
-
-public:
- write_some_win32_op(write_some_win32_op&&) = default;
- write_some_win32_op(write_some_win32_op const&) = delete;
-
- template<class DeducedHandler>
- write_some_win32_op(
- DeducedHandler&& h,
- boost::asio::basic_stream_socket<Protocol>& s,
- serializer<isRequest,
- basic_file_body<file_win32>,Fields>& sr)
- : sock_(s)
- , sr_(sr)
- , h_(std::forward<DeducedHandler>(h))
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(h_);
- }
-
- using executor_type =
- boost::asio::associated_executor_t<Handler, decltype(std::declval<
- boost::asio::basic_stream_socket<Protocol>&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- h_, sock_.get_executor());
- }
-
- void
- operator()();
-
- void
- operator()(
- error_code ec,
- std::size_t bytes_transferred = 0);
-
- friend
- bool asio_handler_is_continuation(write_some_win32_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return asio_handler_is_continuation(
- std::addressof(op->h_));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, write_some_win32_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f, std::addressof(op->h_));
- }
-};
-
-template<
- class Protocol, class Handler,
- bool isRequest, class Fields>
-void
-write_some_win32_op<
- Protocol, Handler, isRequest, Fields>::
-operator()()
-{
- if(! sr_.is_header_done())
- {
- header_ = true;
- sr_.split(true);
- return detail::async_write_some_impl(
- sock_, sr_, std::move(*this));
- }
- if(sr_.get().chunked())
- {
- return detail::async_write_some_impl(
- sock_, sr_, std::move(*this));
- }
- auto& w = sr_.writer_impl();
- boost::winapi::DWORD_ const nNumberOfBytesToWrite =
- static_cast<boost::winapi::DWORD_>(
- (std::min<std::uint64_t>)(
- (std::min<std::uint64_t>)(w.body_.last_ - w.pos_, sr_.limit()),
- (std::numeric_limits<boost::winapi::DWORD_>::max)()));
- boost::asio::windows::overlapped_ptr overlapped{
- sock_.get_executor().context(), std::move(*this)};
- // Note that we have moved *this, so we cannot access
- // the handler since it is now moved-from. We can still
- // access simple things like references and built-in types.
- auto& ov = *overlapped.get();
- ov.Offset = lowPart(w.pos_);
- ov.OffsetHigh = highPart(w.pos_);
- auto const bSuccess = ::TransmitFile(
- sock_.native_handle(),
- sr_.get().body().file_.native_handle(),
- nNumberOfBytesToWrite,
- 0,
- overlapped.get(),
- nullptr,
- 0);
- auto const dwError = boost::winapi::GetLastError();
- if(! bSuccess && dwError !=
- boost::winapi::ERROR_IO_PENDING_)
- {
- // VFALCO This needs review, is 0 the right number?
- // completed immediately (with error?)
- overlapped.complete(error_code{static_cast<int>(dwError),
- system_category()}, 0);
- return;
- }
- overlapped.release();
-}
-
-template<
- class Protocol, class Handler,
- bool isRequest, class Fields>
-void
-write_some_win32_op<
- Protocol, Handler, isRequest, Fields>::
-operator()(
- error_code ec, std::size_t bytes_transferred)
-{
- bytes_transferred_ += bytes_transferred;
- if(! ec)
- {
- if(header_)
- {
- header_ = false;
- return (*this)();
- }
- auto& w = sr_.writer_impl();
- w.pos_ += bytes_transferred;
- BOOST_ASSERT(w.pos_ <= w.body_.last_);
- if(w.pos_ >= w.body_.last_)
- {
- sr_.next(ec, null_lambda{});
- BOOST_ASSERT(! ec);
- BOOST_ASSERT(sr_.is_done());
- }
- }
- h_(ec, bytes_transferred_);
-}
-
-#endif
-
-} // detail
-
-//------------------------------------------------------------------------------
-
-template<class Protocol, bool isRequest, class Fields>
-std::size_t
-write_some(
- boost::asio::basic_stream_socket<Protocol>& sock,
- serializer<isRequest,
- basic_file_body<file_win32>, Fields>& sr,
- error_code& ec)
-{
- if(! sr.is_header_done())
- {
- sr.split(true);
- auto const bytes_transferred =
- detail::write_some_impl(sock, sr, ec);
- if(ec)
- return bytes_transferred;
- return bytes_transferred;
- }
- if(sr.get().chunked())
- {
- auto const bytes_transferred =
- detail::write_some_impl(sock, sr, ec);
- if(ec)
- return bytes_transferred;
- return bytes_transferred;
- }
- auto& w = sr.writer_impl();
- w.body_.file_.seek(w.pos_, ec);
- if(ec)
- return 0;
- boost::winapi::DWORD_ const nNumberOfBytesToWrite =
- static_cast<boost::winapi::DWORD_>(
- (std::min<std::uint64_t>)(
- (std::min<std::uint64_t>)(w.body_.last_ - w.pos_, sr.limit()),
- (std::numeric_limits<boost::winapi::DWORD_>::max)()));
- auto const bSuccess = ::TransmitFile(
- sock.native_handle(),
- w.body_.file_.native_handle(),
- nNumberOfBytesToWrite,
- 0,
- nullptr,
- nullptr,
- 0);
- if(! bSuccess)
- {
- ec.assign(static_cast<int>(
- boost::winapi::GetLastError()),
- system_category());
- return 0;
- }
- w.pos_ += nNumberOfBytesToWrite;
- BOOST_ASSERT(w.pos_ <= w.body_.last_);
- if(w.pos_ < w.body_.last_)
- {
- ec.assign(0, ec.category());
- }
- else
- {
- sr.next(ec, detail::null_lambda{});
- BOOST_ASSERT(! ec);
- BOOST_ASSERT(sr.is_done());
- }
- return nNumberOfBytesToWrite;
-}
-
-#if BOOST_ASIO_HAS_WINDOWS_OVERLAPPED_PTR
-
-template<
- class Protocol,
- bool isRequest, class Fields,
- class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
-async_write_some(
- boost::asio::basic_stream_socket<Protocol>& sock,
- serializer<isRequest,
- basic_file_body<file_win32>, Fields>& sr,
- WriteHandler&& handler)
-{
- BOOST_BEAST_HANDLER_INIT(
- WriteHandler, void(error_code, std::size_t));
- detail::write_some_win32_op<
- Protocol,
- BOOST_ASIO_HANDLER_TYPE(WriteHandler,
- void(error_code, std::size_t)),
- isRequest, Fields>{
- std::move(init.completion_handler), sock, sr}();
- return init.result.get();
-}
-
-#endif
-
-} // http
-} // beast
-} // boost
-
-#endif
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/impl/message.ipp b/contrib/restricted/boost/boost/beast/http/impl/message.ipp
deleted file mode 100644
index 64d96eb6f1..0000000000
--- a/contrib/restricted/boost/boost/beast/http/impl/message.ipp
+++ /dev/null
@@ -1,437 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_IMPL_MESSAGE_IPP
-#define BOOST_BEAST_HTTP_IMPL_MESSAGE_IPP
-
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/assert.hpp>
-#include <boost/throw_exception.hpp>
-#include <stdexcept>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-template<class Fields>
-template<class Arg1, class... ArgN, class>
-header<true, Fields>::
-header(Arg1&& arg1, ArgN&&... argn)
- : Fields(std::forward<Arg1>(arg1),
- std::forward<ArgN>(argn)...)
-{
-}
-
-template<class Fields>
-inline
-verb
-header<true, Fields>::
-method() const
-{
- return method_;
-}
-
-template<class Fields>
-void
-header<true, Fields>::
-method(verb v)
-{
- if(v == verb::unknown)
- BOOST_THROW_EXCEPTION(
- std::invalid_argument{"unknown method"});
- method_ = v;
- this->set_method_impl({});
-}
-
-template<class Fields>
-string_view
-header<true, Fields>::
-method_string() const
-{
- if(method_ != verb::unknown)
- return to_string(method_);
- return this->get_method_impl();
-}
-
-template<class Fields>
-void
-header<true, Fields>::
-method_string(string_view s)
-{
- method_ = string_to_verb(s);
- if(method_ != verb::unknown)
- this->set_method_impl({});
- else
- this->set_method_impl(s);
-}
-
-template<class Fields>
-inline
-string_view
-header<true, Fields>::
-target() const
-{
- return this->get_target_impl();
-}
-
-template<class Fields>
-inline
-void
-header<true, Fields>::
-target(string_view s)
-{
- this->set_target_impl(s);
-}
-
-template<class Fields>
-void
-swap(
- header<true, Fields>& h1,
- header<true, Fields>& h2)
-{
- using std::swap;
- swap(
- static_cast<Fields&>(h1),
- static_cast<Fields&>(h2));
- swap(h1.version_, h2.version_);
- swap(h1.method_, h2.method_);
-}
-
-//------------------------------------------------------------------------------
-
-template<class Fields>
-template<class Arg1, class... ArgN, class>
-header<false, Fields>::
-header(Arg1&& arg1, ArgN&&... argn)
- : Fields(std::forward<Arg1>(arg1),
- std::forward<ArgN>(argn)...)
-{
-}
-
-template<class Fields>
-inline
-status
-header<false, Fields>::
-result() const
-{
- return int_to_status(
- static_cast<int>(result_));
-}
-
-template<class Fields>
-inline
-void
-header<false, Fields>::
-result(status v)
-{
- result_ = v;
-}
-
-template<class Fields>
-inline
-void
-header<false, Fields>::
-result(unsigned v)
-{
- if(v > 999)
- BOOST_THROW_EXCEPTION(
- std::invalid_argument{
- "invalid status-code"});
- result_ = static_cast<status>(v);
-}
-
-template<class Fields>
-inline
-unsigned
-header<false, Fields>::
-result_int() const
-{
- return static_cast<unsigned>(result_);
-}
-
-template<class Fields>
-string_view
-header<false, Fields>::
-reason() const
-{
- auto const s = this->get_reason_impl();
- if(! s.empty())
- return s;
- return obsolete_reason(result_);
-}
-
-template<class Fields>
-inline
-void
-header<false, Fields>::
-reason(string_view s)
-{
- this->set_reason_impl(s);
-}
-
-template<class Fields>
-void
-swap(
- header<false, Fields>& h1,
- header<false, Fields>& h2)
-{
- using std::swap;
- swap(
- static_cast<Fields&>(h1),
- static_cast<Fields&>(h2));
- swap(h1.version_, h2.version_);
- swap(h1.result_, h2.result_);
-}
-
-//------------------------------------------------------------------------------
-
-template<bool isRequest, class Body, class Fields>
-template<class... BodyArgs>
-message<isRequest, Body, Fields>::
-message(header_type&& h, BodyArgs&&... body_args)
- : header_type(std::move(h))
- , beast::detail::empty_base_optimization<
- typename Body::value_type>(
- std::forward<BodyArgs>(body_args)...)
-{
-}
-
-template<bool isRequest, class Body, class Fields>
-template<class... BodyArgs>
-message<isRequest, Body, Fields>::
-message(header_type const& h, BodyArgs&&... body_args)
- : header_type(h)
- , beast::detail::empty_base_optimization<
- typename Body::value_type>(
- std::forward<BodyArgs>(body_args)...)
-{
-}
-
-template<bool isRequest, class Body, class Fields>
-template<class Version, class>
-message<isRequest, Body, Fields>::
-message(verb method, string_view target, Version version)
- : header_type(method, target, version)
-{
-}
-
-template<bool isRequest, class Body, class Fields>
-template<class Version, class BodyArg, class>
-message<isRequest, Body, Fields>::
-message(verb method, string_view target,
- Version version, BodyArg&& body_arg)
- : header_type(method, target, version)
- , beast::detail::empty_base_optimization<
- typename Body::value_type>(
- std::forward<BodyArg>(body_arg))
-{
-}
-
-template<bool isRequest, class Body, class Fields>
-template<class Version, class BodyArg, class FieldsArg, class>
-message<isRequest, Body, Fields>::
-message(
- verb method, string_view target, Version version,
- BodyArg&& body_arg,
- FieldsArg&& fields_arg)
- : header_type(method, target, version,
- std::forward<FieldsArg>(fields_arg))
- , beast::detail::empty_base_optimization<
- typename Body::value_type>(
- std::forward<BodyArg>(body_arg))
-{
-}
-
-template<bool isRequest, class Body, class Fields>
-template<class Version, class>
-message<isRequest, Body, Fields>::
-message(status result, Version version)
- : header_type(result, version)
-{
-}
-
-template<bool isRequest, class Body, class Fields>
-template<class Version, class BodyArg, class>
-message<isRequest, Body, Fields>::
-message(status result, Version version,
- BodyArg&& body_arg)
- : header_type(result, version)
- , beast::detail::empty_base_optimization<
- typename Body::value_type>(
- std::forward<BodyArg>(body_arg))
-{
-}
-
-template<bool isRequest, class Body, class Fields>
-template<class Version, class BodyArg, class FieldsArg, class>
-message<isRequest, Body, Fields>::
-message(status result, Version version,
- BodyArg&& body_arg, FieldsArg&& fields_arg)
- : header_type(result, version,
- std::forward<FieldsArg>(fields_arg))
- , beast::detail::empty_base_optimization<
- typename Body::value_type>(
- std::forward<BodyArg>(body_arg))
-{
-}
-
-template<bool isRequest, class Body, class Fields>
-message<isRequest, Body, Fields>::
-message(std::piecewise_construct_t)
-{
-}
-
-template<bool isRequest, class Body, class Fields>
-template<class... BodyArgs>
-message<isRequest, Body, Fields>::
-message(std::piecewise_construct_t,
- std::tuple<BodyArgs...> body_args)
- : message(std::piecewise_construct,
- body_args,
- beast::detail::make_index_sequence<
- sizeof...(BodyArgs)>{})
-{
-}
-
-template<bool isRequest, class Body, class Fields>
-template<class... BodyArgs, class... FieldsArgs>
-message<isRequest, Body, Fields>::
-message(std::piecewise_construct_t,
- std::tuple<BodyArgs...> body_args,
- std::tuple<FieldsArgs...> fields_args)
- : message(std::piecewise_construct,
- body_args,
- fields_args,
- beast::detail::make_index_sequence<
- sizeof...(BodyArgs)>{},
- beast::detail::make_index_sequence<
- sizeof...(FieldsArgs)>{})
-{
-}
-
-template<bool isRequest, class Body, class Fields>
-void
-message<isRequest, Body, Fields>::
-chunked(bool value)
-{
- this->set_chunked_impl(value);
- this->set_content_length_impl(boost::none);
-}
-
-template<bool isRequest, class Body, class Fields>
-void
-message<isRequest, Body, Fields>::
-content_length(
- boost::optional<std::uint64_t> const& value)
-{
- this->set_content_length_impl(value);
- this->set_chunked_impl(false);
-}
-
-template<bool isRequest, class Body, class Fields>
-boost::optional<std::uint64_t>
-message<isRequest, Body, Fields>::
-payload_size() const
-{
- return payload_size(detail::is_body_sized<Body>{});
-}
-
-template<bool isRequest, class Body, class Fields>
-bool
-message<isRequest, Body, Fields>::
-need_eof(std::false_type) const
-{
- // VFALCO Do we need a way to let the caller say "the body is intentionally skipped"?
- if( this->result() == status::no_content ||
- this->result() == status::not_modified ||
- to_status_class(this->result()) ==
- status_class::informational ||
- has_content_length() ||
- chunked())
- return ! keep_alive();
- return true;
-}
-
-template<bool isRequest, class Body, class Fields>
-void
-message<isRequest, Body, Fields>::
-prepare_payload(std::true_type)
-{
- auto const n = payload_size();
- if(this->method() == verb::trace && (! n || *n > 0))
- BOOST_THROW_EXCEPTION(std::invalid_argument{
- "invalid request body"});
- if(n)
- {
- if(*n > 0 ||
- this->method() == verb::options ||
- this->method() == verb::put ||
- this->method() == verb::post)
- {
- this->content_length(n);
- }
- else
- {
- this->chunked(false);
- }
- }
- else if(this->version() == 11)
- {
- this->chunked(true);
- }
- else
- {
- this->chunked(false);
- }
-}
-
-template<bool isRequest, class Body, class Fields>
-void
-message<isRequest, Body, Fields>::
-prepare_payload(std::false_type)
-{
- auto const n = payload_size();
- if( (! n || *n > 0) && (
- (status_class(this->result()) == status_class::informational ||
- this->result() == status::no_content ||
- this->result() == status::not_modified)))
- {
- // The response body MUST be empty for this case
- BOOST_THROW_EXCEPTION(std::invalid_argument{
- "invalid response body"});
- }
- if(n)
- this->content_length(n);
- else if(this->version() == 11)
- this->chunked(true);
- else
- this->chunked(false);
-}
-
-//------------------------------------------------------------------------------
-
-template<bool isRequest, class Body, class Fields>
-void
-swap(
- message<isRequest, Body, Fields>& m1,
- message<isRequest, Body, Fields>& m2)
-{
- using std::swap;
- swap(
- static_cast<header<isRequest, Fields>&>(m1),
- static_cast<header<isRequest, Fields>&>(m2));
- swap(m1.body(), m2.body());
-}
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/impl/parser.ipp b/contrib/restricted/boost/boost/beast/http/impl/parser.ipp
deleted file mode 100644
index 8a6cab30af..0000000000
--- a/contrib/restricted/boost/boost/beast/http/impl/parser.ipp
+++ /dev/null
@@ -1,136 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_IMPL_PARSER_IPP
-#define BOOST_BEAST_HTTP_IMPL_PARSER_IPP
-
-#include <boost/throw_exception.hpp>
-#include <stdexcept>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-template<bool isRequest, class Body, class Allocator>
-parser<isRequest, Body, Allocator>::
-parser()
- : parser{detail::has_deprecated_body_reader<Body>{}}
-{
-}
-
-template<bool isRequest, class Body, class Allocator>
-parser<isRequest, Body, Allocator>::
-parser(std::true_type)
- : rd_(m_)
-{
-#ifndef BOOST_BEAST_ALLOW_DEPRECATED
- // Deprecated BodyReader Concept (v1.66)
- static_assert(sizeof(Body) == 0,
- BOOST_BEAST_DEPRECATION_STRING);
-#endif
-}
-
-template<bool isRequest, class Body, class Allocator>
-parser<isRequest, Body, Allocator>::
-parser(std::false_type)
- : rd_(m_.base(), m_.body())
-{
-}
-
-template<bool isRequest, class Body, class Allocator>
-template<class Arg1, class... ArgN, class>
-parser<isRequest, Body, Allocator>::
-parser(Arg1&& arg1, ArgN&&... argn)
- : parser(std::forward<Arg1>(arg1),
- detail::has_deprecated_body_reader<Body>{},
- std::forward<ArgN>(argn)...)
-{
-}
-
-// VFALCO arg1 comes before `true_type` to make
-// the signature unambiguous.
-template<bool isRequest, class Body, class Allocator>
-template<class Arg1, class... ArgN, class>
-parser<isRequest, Body, Allocator>::
-parser(Arg1&& arg1, std::true_type, ArgN&&... argn)
- : m_(std::forward<Arg1>(arg1),
- std::forward<ArgN>(argn)...)
- , rd_(m_)
-{
- m_.clear();
-#ifndef BOOST_BEAST_ALLOW_DEPRECATED
- /* Deprecated BodyWriter Concept (v1.66) */
- static_assert(sizeof(Body) == 0,
- BOOST_BEAST_DEPRECATION_STRING);
-#endif // BOOST_BEAST_ALLOW_DEPRECATED
-}
-
-// VFALCO arg1 comes before `false_type` to make
-// the signature unambiguous.
-template<bool isRequest, class Body, class Allocator>
-template<class Arg1, class... ArgN, class>
-parser<isRequest, Body, Allocator>::
-parser(Arg1&& arg1, std::false_type, ArgN&&... argn)
- : m_(std::forward<Arg1>(arg1),
- std::forward<ArgN>(argn)...)
- , rd_(m_.base(), m_.body())
-{
- m_.clear();
-}
-
-template<bool isRequest, class Body, class Allocator>
-template<class OtherBody, class... Args, class>
-parser<isRequest, Body, Allocator>::
-parser(
- parser<isRequest, OtherBody, Allocator>&& other,
- Args&&... args)
- : parser(detail::has_deprecated_body_reader<Body>{},
- std::move(other), std::forward<Args>(args)...)
-{
-}
-
-template<bool isRequest, class Body, class Allocator>
-template<class OtherBody, class... Args, class>
-parser<isRequest, Body, Allocator>::
-parser(std::true_type,
- parser<isRequest, OtherBody, Allocator>&& other,
- Args&&... args)
- : base_type(std::move(other))
- , m_(other.release(), std::forward<Args>(args)...)
- , rd_(m_)
-{
- if(other.rd_inited_)
- BOOST_THROW_EXCEPTION(std::invalid_argument{
- "moved-from parser has a body"});
-#ifndef BOOST_BEAST_ALLOW_DEPRECATED
- // Deprecated BodyReader Concept (v1.66)
- static_assert(sizeof(Body) == 0,
- BOOST_BEAST_DEPRECATION_STRING);
-#endif
-}
-
-template<bool isRequest, class Body, class Allocator>
-template<class OtherBody, class... Args, class>
-parser<isRequest, Body, Allocator>::
-parser(std::false_type, parser<isRequest, OtherBody, Allocator>&& other,
- Args&&... args)
- : base_type(std::move(other))
- , m_(other.release(), std::forward<Args>(args)...)
- , rd_(m_.base(), m_.body())
-{
- if(other.rd_inited_)
- BOOST_THROW_EXCEPTION(std::invalid_argument{
- "moved-from parser has a body"});
-}
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/impl/read.ipp b/contrib/restricted/boost/boost/beast/http/impl/read.ipp
deleted file mode 100644
index 28ff0a3c44..0000000000
--- a/contrib/restricted/boost/boost/beast/http/impl/read.ipp
+++ /dev/null
@@ -1,838 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_IMPL_READ_IPP_HPP
-#define BOOST_BEAST_HTTP_IMPL_READ_IPP_HPP
-
-#include <boost/beast/http/type_traits.hpp>
-#include <boost/beast/http/error.hpp>
-#include <boost/beast/http/parser.hpp>
-#include <boost/beast/http/read.hpp>
-#include <boost/beast/core/bind_handler.hpp>
-#include <boost/beast/core/handler_ptr.hpp>
-#include <boost/beast/core/read_size.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/asio/associated_allocator.hpp>
-#include <boost/asio/associated_executor.hpp>
-#include <boost/asio/coroutine.hpp>
-#include <boost/asio/handler_continuation_hook.hpp>
-#include <boost/asio/handler_invoke_hook.hpp>
-#include <boost/asio/post.hpp>
-#include <boost/assert.hpp>
-#include <boost/config.hpp>
-#include <boost/optional.hpp>
-#include <boost/throw_exception.hpp>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-namespace detail {
-
-//------------------------------------------------------------------------------
-
-template<class Stream, class DynamicBuffer,
- bool isRequest, class Derived, class Handler>
-class read_some_op
- : public boost::asio::coroutine
-{
- Stream& s_;
- DynamicBuffer& b_;
- basic_parser<isRequest, Derived>& p_;
- std::size_t bytes_transferred_ = 0;
- Handler h_;
- bool cont_ = false;
-
-public:
- read_some_op(read_some_op&&) = default;
- read_some_op(read_some_op const&) = delete;
-
- template<class DeducedHandler>
- read_some_op(DeducedHandler&& h, Stream& s,
- DynamicBuffer& b, basic_parser<isRequest, Derived>& p)
- : s_(s)
- , b_(b)
- , p_(p)
- , h_(std::forward<DeducedHandler>(h))
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(h_);
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<Stream&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- h_, s_.get_executor());
- }
-
- void
- operator()(
- error_code ec,
- std::size_t bytes_transferred = 0,
- bool cont = true);
-
- friend
- bool asio_handler_is_continuation(read_some_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return op->cont_ ? true :
- asio_handler_is_continuation(
- std::addressof(op->h_));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, read_some_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f, std::addressof(op->h_));
- }
-};
-
-template<class Stream, class DynamicBuffer,
- bool isRequest, class Derived, class Handler>
-void
-read_some_op<Stream, DynamicBuffer,
- isRequest, Derived, Handler>::
-operator()(
- error_code ec,
- std::size_t bytes_transferred,
- bool cont)
-{
- cont_ = cont;
- boost::optional<typename
- DynamicBuffer::mutable_buffers_type> mb;
- BOOST_ASIO_CORO_REENTER(*this)
- {
- if(b_.size() == 0)
- goto do_read;
- for(;;)
- {
- // parse
- {
- auto const used = p_.put(b_.data(), ec);
- bytes_transferred_ += used;
- b_.consume(used);
- }
- if(ec != http::error::need_more)
- break;
-
- do_read:
- try
- {
- mb.emplace(b_.prepare(
- read_size_or_throw(b_, 65536)));
- }
- catch(std::length_error const&)
- {
- ec = error::buffer_overflow;
- break;
- }
- BOOST_ASIO_CORO_YIELD
- s_.async_read_some(*mb, std::move(*this));
- if(ec == boost::asio::error::eof)
- {
- BOOST_ASSERT(bytes_transferred == 0);
- if(p_.got_some())
- {
- // caller sees EOF on next read
- ec.assign(0, ec.category());
- p_.put_eof(ec);
- if(ec)
- goto upcall;
- BOOST_ASSERT(p_.is_done());
- goto upcall;
- }
- ec = error::end_of_stream;
- break;
- }
- if(ec)
- break;
- b_.commit(bytes_transferred);
- }
-
- upcall:
- if(! cont_)
- return boost::asio::post(
- s_.get_executor(),
- bind_handler(std::move(h_),
- ec, bytes_transferred_));
- h_(ec, bytes_transferred_);
- }
-}
-
-//------------------------------------------------------------------------------
-
-struct parser_is_done
-{
- template<bool isRequest, class Derived>
- bool
- operator()(basic_parser<
- isRequest, Derived> const& p) const
- {
- return p.is_done();
- }
-};
-
-struct parser_is_header_done
-{
- template<bool isRequest, class Derived>
- bool
- operator()(basic_parser<
- isRequest, Derived> const& p) const
- {
- return p.is_header_done();
- }
-};
-
-template<class Stream, class DynamicBuffer,
- bool isRequest, class Derived, class Condition,
- class Handler>
-class read_op
- : public boost::asio::coroutine
-{
- Stream& s_;
- DynamicBuffer& b_;
- basic_parser<isRequest, Derived>& p_;
- std::size_t bytes_transferred_ = 0;
- Handler h_;
- bool cont_ = false;
-
-public:
- read_op(read_op&&) = default;
- read_op(read_op const&) = delete;
-
- template<class DeducedHandler>
- read_op(DeducedHandler&& h, Stream& s,
- DynamicBuffer& b, basic_parser<isRequest,
- Derived>& p)
- : s_(s)
- , b_(b)
- , p_(p)
- , h_(std::forward<DeducedHandler>(h))
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(h_);
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<Stream&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- h_, s_.get_executor());
- }
-
- void
- operator()(
- error_code ec,
- std::size_t bytes_transferred = 0,
- bool cont = true);
-
- friend
- bool asio_handler_is_continuation(read_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return op->cont_ ? true :
- asio_handler_is_continuation(
- std::addressof(op->h_));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, read_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f, std::addressof(op->h_));
- }
-};
-
-template<class Stream, class DynamicBuffer,
- bool isRequest, class Derived, class Condition,
- class Handler>
-void
-read_op<Stream, DynamicBuffer,
- isRequest, Derived, Condition, Handler>::
-operator()(
- error_code ec,
- std::size_t bytes_transferred,
- bool cont)
-{
- cont_ = cont;
- BOOST_ASIO_CORO_REENTER(*this)
- {
- if(Condition{}(p_))
- {
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(s_.get_executor(),
- bind_handler(std::move(*this), ec));
- goto upcall;
- }
- for(;;)
- {
- BOOST_ASIO_CORO_YIELD
- async_read_some(
- s_, b_, p_, std::move(*this));
- if(ec)
- goto upcall;
- bytes_transferred_ += bytes_transferred;
- if(Condition{}(p_))
- goto upcall;
- }
- upcall:
- h_(ec, bytes_transferred_);
- }
-}
-
-//------------------------------------------------------------------------------
-
-template<class Stream, class DynamicBuffer,
- bool isRequest, class Body, class Allocator,
- class Handler>
-class read_msg_op
- : public boost::asio::coroutine
-{
- using parser_type =
- parser<isRequest, Body, Allocator>;
-
- using message_type =
- typename parser_type::value_type;
-
- struct data
- {
- Stream& s;
- DynamicBuffer& b;
- message_type& m;
- parser_type p;
- std::size_t bytes_transferred = 0;
- bool cont = false;
-
- data(Handler const&, Stream& s_,
- DynamicBuffer& b_, message_type& m_)
- : s(s_)
- , b(b_)
- , m(m_)
- , p(std::move(m))
- {
- p.eager(true);
- }
- };
-
- handler_ptr<data, Handler> d_;
-
-public:
- read_msg_op(read_msg_op&&) = default;
- read_msg_op(read_msg_op const&) = delete;
-
- template<class DeducedHandler, class... Args>
- read_msg_op(DeducedHandler&& h, Stream& s, Args&&... args)
- : d_(std::forward<DeducedHandler>(h),
- s, std::forward<Args>(args)...)
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(d_.handler());
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<Stream&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- d_.handler(), d_->s.get_executor());
- }
-
- void
- operator()(
- error_code ec,
- std::size_t bytes_transferred = 0,
- bool cont = true);
-
- friend
- bool asio_handler_is_continuation(read_msg_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return op->d_->cont ? true :
- asio_handler_is_continuation(
- std::addressof(op->d_.handler()));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, read_msg_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f, std::addressof(op->d_.handler()));
- }
-};
-
-template<class Stream, class DynamicBuffer,
- bool isRequest, class Body, class Allocator,
- class Handler>
-void
-read_msg_op<Stream, DynamicBuffer,
- isRequest, Body, Allocator, Handler>::
-operator()(
- error_code ec,
- std::size_t bytes_transferred,
- bool cont)
-{
- auto& d = *d_;
- d.cont = cont;
- BOOST_ASIO_CORO_REENTER(*this)
- {
- for(;;)
- {
- BOOST_ASIO_CORO_YIELD
- async_read_some(
- d.s, d.b, d.p, std::move(*this));
- if(ec)
- goto upcall;
- d.bytes_transferred +=
- bytes_transferred;
- if(d.p.is_done())
- {
- d.m = d.p.release();
- goto upcall;
- }
- }
- upcall:
- bytes_transferred = d.bytes_transferred;
- d_.invoke(ec, bytes_transferred);
- }
-}
-
-} // detail
-
-//------------------------------------------------------------------------------
-
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived>
-std::size_t
-read_some(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser)
-{
- static_assert(is_sync_read_stream<SyncReadStream>::value,
- "SyncReadStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- BOOST_ASSERT(! parser.is_done());
- error_code ec;
- auto const bytes_transferred =
- read_some(stream, buffer, parser, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
- return bytes_transferred;
-}
-
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived>
-std::size_t
-read_some(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser,
- error_code& ec)
-{
- static_assert(is_sync_read_stream<SyncReadStream>::value,
- "SyncReadStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- BOOST_ASSERT(! parser.is_done());
- std::size_t bytes_transferred = 0;
- if(buffer.size() == 0)
- goto do_read;
- for(;;)
- {
- // invoke parser
- {
- auto const n = parser.put(buffer.data(), ec);
- bytes_transferred += n;
- buffer.consume(n);
- if(! ec)
- break;
- if(ec != http::error::need_more)
- break;
- }
- do_read:
- boost::optional<typename
- DynamicBuffer::mutable_buffers_type> b;
- try
- {
- b.emplace(buffer.prepare(
- read_size_or_throw(buffer, 65536)));
- }
- catch(std::length_error const&)
- {
- ec = error::buffer_overflow;
- return bytes_transferred;
- }
- auto const n = stream.read_some(*b, ec);
- if(ec == boost::asio::error::eof)
- {
- BOOST_ASSERT(n == 0);
- if(parser.got_some())
- {
- // caller sees EOF on next read
- parser.put_eof(ec);
- if(ec)
- break;
- BOOST_ASSERT(parser.is_done());
- break;
- }
- ec = error::end_of_stream;
- break;
- }
- if(ec)
- break;
- buffer.commit(n);
- }
- return bytes_transferred;
-}
-
-template<
- class AsyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived,
- class ReadHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
-async_read_some(
- AsyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser,
- ReadHandler&& handler)
-{
- static_assert(is_async_read_stream<AsyncReadStream>::value,
- "AsyncReadStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- BOOST_ASSERT(! parser.is_done());
- BOOST_BEAST_HANDLER_INIT(
- ReadHandler, void(error_code, std::size_t));
- detail::read_some_op<AsyncReadStream,
- DynamicBuffer, isRequest, Derived, BOOST_ASIO_HANDLER_TYPE(
- ReadHandler, void(error_code, std::size_t))>{
- std::move(init.completion_handler), stream, buffer, parser}(
- {}, 0, false);
- return init.result.get();
-}
-
-//------------------------------------------------------------------------------
-
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived>
-std::size_t
-read_header(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser)
-{
- static_assert(is_sync_read_stream<SyncReadStream>::value,
- "SyncReadStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- error_code ec;
- auto const bytes_transferred =
- read_header(stream, buffer, parser, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
- return bytes_transferred;
-}
-
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived>
-std::size_t
-read_header(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser,
- error_code& ec)
-{
- static_assert(is_sync_read_stream<SyncReadStream>::value,
- "SyncReadStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- parser.eager(false);
- if(parser.is_header_done())
- {
- ec.assign(0, ec.category());
- return 0;
- }
- std::size_t bytes_transferred = 0;
- do
- {
- bytes_transferred += read_some(
- stream, buffer, parser, ec);
- if(ec)
- return bytes_transferred;
- }
- while(! parser.is_header_done());
- return bytes_transferred;
-}
-
-template<
- class AsyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived,
- class ReadHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
-async_read_header(
- AsyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser,
- ReadHandler&& handler)
-{
- static_assert(is_async_read_stream<AsyncReadStream>::value,
- "AsyncReadStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- parser.eager(false);
- BOOST_BEAST_HANDLER_INIT(
- ReadHandler, void(error_code, std::size_t));
- detail::read_op<AsyncReadStream, DynamicBuffer,
- isRequest, Derived, detail::parser_is_header_done,
- BOOST_ASIO_HANDLER_TYPE(ReadHandler, void(error_code, std::size_t))>{
- std::move(init.completion_handler), stream,
- buffer, parser}({}, 0, false);
- return init.result.get();
-}
-
-//------------------------------------------------------------------------------
-
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived>
-std::size_t
-read(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser)
-{
- static_assert(is_sync_read_stream<SyncReadStream>::value,
- "SyncReadStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- error_code ec;
- auto const bytes_transferred =
- read(stream, buffer, parser, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
- return bytes_transferred;
-}
-
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived>
-std::size_t
-read(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser,
- error_code& ec)
-{
- static_assert(is_sync_read_stream<SyncReadStream>::value,
- "SyncReadStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- parser.eager(true);
- if(parser.is_done())
- {
- ec.assign(0, ec.category());
- return 0;
- }
- std::size_t bytes_transferred = 0;
- do
- {
- bytes_transferred += read_some(
- stream, buffer, parser, ec);
- if(ec)
- return bytes_transferred;
- }
- while(! parser.is_done());
- return bytes_transferred;
-}
-
-template<
- class AsyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived,
- class ReadHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
-async_read(
- AsyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser,
- ReadHandler&& handler)
-{
- static_assert(is_async_read_stream<AsyncReadStream>::value,
- "AsyncReadStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- parser.eager(true);
- BOOST_BEAST_HANDLER_INIT(
- ReadHandler, void(error_code, std::size_t));
- detail::read_op<AsyncReadStream, DynamicBuffer,
- isRequest, Derived, detail::parser_is_done,
- BOOST_ASIO_HANDLER_TYPE(ReadHandler, void(error_code, std::size_t))>{
- std::move(init.completion_handler), stream, buffer, parser}(
- {}, 0, false);
- return init.result.get();
-}
-
-//------------------------------------------------------------------------------
-
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Body, class Allocator>
-std::size_t
-read(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- message<isRequest, Body, basic_fields<Allocator>>& msg)
-{
- static_assert(is_sync_read_stream<SyncReadStream>::value,
- "SyncReadStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- static_assert(is_body_reader<Body>::value,
- "BodyReader requirements not met");
- error_code ec;
- auto const bytes_transferred =
- read(stream, buffer, msg, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
- return bytes_transferred;
-}
-
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Body, class Allocator>
-std::size_t
-read(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- message<isRequest, Body, basic_fields<Allocator>>& msg,
- error_code& ec)
-{
- static_assert(is_sync_read_stream<SyncReadStream>::value,
- "SyncReadStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- static_assert(is_body_reader<Body>::value,
- "BodyReader requirements not met");
- parser<isRequest, Body, Allocator> p{std::move(msg)};
- p.eager(true);
- auto const bytes_transferred =
- read(stream, buffer, p.base(), ec);
- if(ec)
- return bytes_transferred;
- msg = p.release();
- return bytes_transferred;
-}
-
-template<
- class AsyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Body, class Allocator,
- class ReadHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
-async_read(
- AsyncReadStream& stream,
- DynamicBuffer& buffer,
- message<isRequest, Body, basic_fields<Allocator>>& msg,
- ReadHandler&& handler)
-{
- static_assert(is_async_read_stream<AsyncReadStream>::value,
- "AsyncReadStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- static_assert(is_body_reader<Body>::value,
- "BodyReader requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- ReadHandler, void(error_code, std::size_t));
- detail::read_msg_op<
- AsyncReadStream,
- DynamicBuffer,
- isRequest, Body, Allocator,
- BOOST_ASIO_HANDLER_TYPE(
- ReadHandler, void(error_code, std::size_t))>{
- std::move(init.completion_handler), stream, buffer, msg}(
- {}, 0, false);
- return init.result.get();
-}
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/impl/rfc7230.ipp b/contrib/restricted/boost/boost/beast/http/impl/rfc7230.ipp
deleted file mode 100644
index 96ec902ceb..0000000000
--- a/contrib/restricted/boost/boost/beast/http/impl/rfc7230.ipp
+++ /dev/null
@@ -1,572 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_IMPL_RFC7230_IPP
-#define BOOST_BEAST_HTTP_IMPL_RFC7230_IPP
-
-#include <boost/beast/http/detail/rfc7230.hpp>
-#include <iterator>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-class param_list::const_iterator
-{
- using iter_type = string_view::const_iterator;
-
- std::string s_;
- detail::param_iter pi_;
-
-public:
- using value_type = param_list::value_type;
- using pointer = value_type const*;
- using reference = value_type const&;
- using difference_type = std::ptrdiff_t;
- using iterator_category = std::input_iterator_tag;
-
- const_iterator() = default;
-
- bool
- operator==(const_iterator const& other) const
- {
- return
- other.pi_.it == pi_.it &&
- other.pi_.last == pi_.last &&
- other.pi_.first == pi_.first;
- }
-
- bool
- operator!=(const_iterator const& other) const
- {
- return !(*this == other);
- }
-
- reference
- operator*() const
- {
- return pi_.v;
- }
-
- pointer
- operator->() const
- {
- return &*(*this);
- }
-
- const_iterator&
- operator++()
- {
- increment();
- return *this;
- }
-
- const_iterator
- operator++(int)
- {
- auto temp = *this;
- ++(*this);
- return temp;
- }
-
-private:
- friend class param_list;
-
- const_iterator(iter_type first, iter_type last)
- {
- pi_.it = first;
- pi_.first = first;
- pi_.last = last;
- increment();
- }
-
- template<class = void>
- static
- std::string
- unquote(string_view sr);
-
- template<class = void>
- void
- increment();
-};
-
-inline
-auto
-param_list::
-begin() const ->
- const_iterator
-{
- return const_iterator{s_.begin(), s_.end()};
-}
-
-inline
-auto
-param_list::
-end() const ->
- const_iterator
-{
- return const_iterator{s_.end(), s_.end()};
-}
-
-inline
-auto
-param_list::
-cbegin() const ->
- const_iterator
-{
- return const_iterator{s_.begin(), s_.end()};
-}
-
-inline
-auto
-param_list::
-cend() const ->
- const_iterator
-{
- return const_iterator{s_.end(), s_.end()};
-}
-
-template<class>
-std::string
-param_list::const_iterator::
-unquote(string_view sr)
-{
- std::string s;
- s.reserve(sr.size());
- auto it = sr.begin() + 1;
- auto end = sr.end() - 1;
- while(it != end)
- {
- if(*it == '\\')
- ++it;
- s.push_back(*it);
- ++it;
- }
- return s;
-}
-
-template<class>
-void
-param_list::const_iterator::
-increment()
-{
- s_.clear();
- pi_.increment();
- if(pi_.empty())
- {
- pi_.it = pi_.last;
- pi_.first = pi_.last;
- }
- else if(! pi_.v.second.empty() &&
- pi_.v.second.front() == '"')
- {
- s_ = unquote(pi_.v.second);
- pi_.v.second = string_view{
- s_.data(), s_.size()};
- }
-}
-
-//------------------------------------------------------------------------------
-
-class ext_list::const_iterator
-{
- ext_list::value_type v_;
- iter_type it_;
- iter_type first_;
- iter_type last_;
-
-public:
- using value_type = ext_list::value_type;
- using pointer = value_type const*;
- using reference = value_type const&;
- using difference_type = std::ptrdiff_t;
- using iterator_category = std::forward_iterator_tag;
-
- const_iterator() = default;
-
- bool
- operator==(const_iterator const& other) const
- {
- return
- other.it_ == it_ &&
- other.first_ == first_ &&
- other.last_ == last_;
- }
-
- bool
- operator!=(const_iterator const& other) const
- {
- return !(*this == other);
- }
-
- reference
- operator*() const
- {
- return v_;
- }
-
- pointer
- operator->() const
- {
- return &*(*this);
- }
-
- const_iterator&
- operator++()
- {
- increment();
- return *this;
- }
-
- const_iterator
- operator++(int)
- {
- auto temp = *this;
- ++(*this);
- return temp;
- }
-
-private:
- friend class ext_list;
-
- const_iterator(iter_type begin, iter_type end)
- {
- it_ = begin;
- first_ = begin;
- last_ = end;
- increment();
- }
-
- template<class = void>
- void
- increment();
-};
-
-inline
-auto
-ext_list::
-begin() const ->
- const_iterator
-{
- return const_iterator{s_.begin(), s_.end()};
-}
-
-inline
-auto
-ext_list::
-end() const ->
- const_iterator
-{
- return const_iterator{s_.end(), s_.end()};
-}
-
-inline
-auto
-ext_list::
-cbegin() const ->
- const_iterator
-{
- return const_iterator{s_.begin(), s_.end()};
-}
-
-inline
-auto
-ext_list::
-cend() const ->
- const_iterator
-{
- return const_iterator{s_.end(), s_.end()};
-}
-
-template<class T>
-auto
-ext_list::
-find(T const& s) ->
- const_iterator
-{
- return std::find_if(begin(), end(),
- [&s](value_type const& v)
- {
- return iequals(s, v.first);
- });
-}
-
-template<class T>
-bool
-ext_list::
-exists(T const& s)
-{
- return find(s) != end();
-}
-
-template<class>
-void
-ext_list::const_iterator::
-increment()
-{
- /*
- ext-list = *( "," OWS ) ext *( OWS "," [ OWS ext ] )
- ext = token param-list
- param-list = *( OWS ";" OWS param )
- param = token OWS "=" OWS ( token / quoted-string )
-
- chunked;a=b;i=j,gzip;windowBits=12
- x,y
- ,,,,,chameleon
- */
- auto const err =
- [&]
- {
- it_ = last_;
- first_ = last_;
- };
- auto need_comma = it_ != first_;
- v_.first = {};
- first_ = it_;
- for(;;)
- {
- detail::skip_ows(it_, last_);
- if(it_ == last_)
- return err();
- auto const c = *it_;
- if(detail::is_token_char(c))
- {
- if(need_comma)
- return err();
- auto const p0 = it_;
- for(;;)
- {
- ++it_;
- if(it_ == last_)
- break;
- if(! detail::is_token_char(*it_))
- break;
- }
- v_.first = string_view{&*p0,
- static_cast<std::size_t>(it_ - p0)};
- detail::param_iter pi;
- pi.it = it_;
- pi.first = it_;
- pi.last = last_;
- for(;;)
- {
- pi.increment();
- if(pi.empty())
- break;
- }
- v_.second = param_list{string_view{&*it_,
- static_cast<std::size_t>(pi.it - it_)}};
- it_ = pi.it;
- return;
- }
- if(c != ',')
- return err();
- need_comma = false;
- ++it_;
- }
-}
-
-//------------------------------------------------------------------------------
-
-class token_list::const_iterator
-{
- token_list::value_type v_;
- iter_type it_;
- iter_type first_;
- iter_type last_;
-
-public:
- using value_type = token_list::value_type;
- using pointer = value_type const*;
- using reference = value_type const&;
- using difference_type = std::ptrdiff_t;
- using iterator_category = std::forward_iterator_tag;
-
- const_iterator() = default;
-
- bool
- operator==(const_iterator const& other) const
- {
- return
- other.it_ == it_ &&
- other.first_ == first_ &&
- other.last_ == last_;
- }
-
- bool
- operator!=(const_iterator const& other) const
- {
- return !(*this == other);
- }
-
- reference
- operator*() const
- {
- return v_;
- }
-
- pointer
- operator->() const
- {
- return &*(*this);
- }
-
- const_iterator&
- operator++()
- {
- increment();
- return *this;
- }
-
- const_iterator
- operator++(int)
- {
- auto temp = *this;
- ++(*this);
- return temp;
- }
-
-private:
- friend class token_list;
-
- const_iterator(iter_type begin, iter_type end)
- {
- it_ = begin;
- first_ = begin;
- last_ = end;
- increment();
- }
-
- template<class = void>
- void
- increment();
-};
-
-inline
-auto
-token_list::
-begin() const ->
- const_iterator
-{
- return const_iterator{s_.begin(), s_.end()};
-}
-
-inline
-auto
-token_list::
-end() const ->
- const_iterator
-{
- return const_iterator{s_.end(), s_.end()};
-}
-
-inline
-auto
-token_list::
-cbegin() const ->
- const_iterator
-{
- return const_iterator{s_.begin(), s_.end()};
-}
-
-inline
-auto
-token_list::
-cend() const ->
- const_iterator
-{
- return const_iterator{s_.end(), s_.end()};
-}
-
-template<class>
-void
-token_list::const_iterator::
-increment()
-{
- /*
- token-list = *( "," OWS ) token *( OWS "," [ OWS ext ] )
- */
- auto const err =
- [&]
- {
- it_ = last_;
- first_ = last_;
- };
- auto need_comma = it_ != first_;
- v_ = {};
- first_ = it_;
- for(;;)
- {
- detail::skip_ows(it_, last_);
- if(it_ == last_)
- return err();
- auto const c = *it_;
- if(detail::is_token_char(c))
- {
- if(need_comma)
- return err();
- auto const p0 = it_;
- for(;;)
- {
- ++it_;
- if(it_ == last_)
- break;
- if(! detail::is_token_char(*it_))
- break;
- }
- v_ = string_view{&*p0,
- static_cast<std::size_t>(it_ - p0)};
- return;
- }
- if(c != ',')
- return err();
- need_comma = false;
- ++it_;
- }
-}
-
-template<class T>
-bool
-token_list::
-exists(T const& s)
-{
- return std::find_if(begin(), end(),
- [&s](value_type const& v)
- {
- return iequals(s, v);
- }
- ) != end();
-}
-
-template<class Policy>
-bool
-validate_list(detail::basic_parsed_list<
- Policy> const& list)
-{
- auto const last = list.end();
- auto it = list.begin();
- if(it.error())
- return false;
- while(it != last)
- {
- ++it;
- if(it.error())
- return false;
- if(it == last)
- break;
- }
- return true;
-}
-
-} // http
-} // beast
-} // boost
-
-#endif
-
diff --git a/contrib/restricted/boost/boost/beast/http/impl/serializer.ipp b/contrib/restricted/boost/boost/beast/http/impl/serializer.ipp
deleted file mode 100644
index b37856567f..0000000000
--- a/contrib/restricted/boost/boost/beast/http/impl/serializer.ipp
+++ /dev/null
@@ -1,454 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_IMPL_SERIALIZER_IPP
-#define BOOST_BEAST_HTTP_IMPL_SERIALIZER_IPP
-
-#include <boost/beast/core/detail/buffers_ref.hpp>
-#include <boost/beast/http/error.hpp>
-#include <boost/beast/http/status.hpp>
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/assert.hpp>
-#include <ostream>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-template<
- bool isRequest, class Body, class Fields>
-void
-serializer<isRequest, Body, Fields>::
-fwrinit(std::true_type)
-{
- fwr_.emplace(m_, m_.version(), m_.method());
-}
-
-template<
- bool isRequest, class Body, class Fields>
-void
-serializer<isRequest, Body, Fields>::
-fwrinit(std::false_type)
-{
- fwr_.emplace(m_, m_.version(), m_.result_int());
-}
-
-template<
- bool isRequest, class Body, class Fields>
-template<std::size_t I, class Visit>
-inline
-void
-serializer<isRequest, Body, Fields>::
-do_visit(error_code& ec, Visit& visit)
-{
- pv_.template emplace<I>(limit_, v_.template get<I>());
- visit(ec, beast::detail::make_buffers_ref(
- pv_.template get<I>()));
-}
-
-//------------------------------------------------------------------------------
-
-template<
- bool isRequest, class Body, class Fields>
-serializer<isRequest, Body, Fields>::
-serializer(value_type& m, std::true_type)
- : m_(m)
- , wr_(m_)
-{
-#ifndef BOOST_BEAST_ALLOW_DEPRECATED
- // Deprecated BodyWriter Concept (v1.66)
- static_assert(sizeof(Body) == 0,
- BOOST_BEAST_DEPRECATION_STRING);
-#endif
-}
-
-template<
- bool isRequest, class Body, class Fields>
-serializer<isRequest, Body, Fields>::
-serializer(value_type& m, std::false_type)
- : m_(m)
- , wr_(m_.base(), m_.body())
-{
-}
-
-template<
- bool isRequest, class Body, class Fields>
-serializer<isRequest, Body, Fields>::
-serializer(value_type& m)
- : serializer(m, detail::has_deprecated_body_writer<Body>{})
-{
-}
-
-template<
- bool isRequest, class Body, class Fields>
-template<class Visit>
-void
-serializer<isRequest, Body, Fields>::
-next(error_code& ec, Visit&& visit)
-{
- using boost::asio::buffer_size;
- switch(s_)
- {
- case do_construct:
- {
- fwrinit(std::integral_constant<bool,
- isRequest>{});
- if(m_.chunked())
- goto go_init_c;
- s_ = do_init;
- BOOST_FALLTHROUGH;
- }
-
- case do_init:
- {
- wr_.init(ec);
- if(ec)
- return;
- if(split_)
- goto go_header_only;
- auto result = wr_.get(ec);
- if(ec == error::need_more)
- goto go_header_only;
- if(ec)
- return;
- if(! result)
- goto go_header_only;
- more_ = result->second;
- v_.template emplace<2>(
- boost::in_place_init,
- fwr_->get(),
- result->first);
- s_ = do_header;
- BOOST_FALLTHROUGH;
- }
-
- case do_header:
- do_visit<2>(ec, visit);
- break;
-
- go_header_only:
- v_.template emplace<1>(fwr_->get());
- s_ = do_header_only;
- BOOST_FALLTHROUGH;
- case do_header_only:
- do_visit<1>(ec, visit);
- break;
-
- case do_body:
- s_ = do_body + 1;
- BOOST_FALLTHROUGH;
-
- case do_body + 1:
- {
- auto result = wr_.get(ec);
- if(ec)
- return;
- if(! result)
- goto go_complete;
- more_ = result->second;
- v_.template emplace<3>(result->first);
- s_ = do_body + 2;
- BOOST_FALLTHROUGH;
- }
-
- case do_body + 2:
- do_visit<3>(ec, visit);
- break;
-
- //----------------------------------------------------------------------
-
- go_init_c:
- s_ = do_init_c;
- BOOST_FALLTHROUGH;
- case do_init_c:
- {
- wr_.init(ec);
- if(ec)
- return;
- if(split_)
- goto go_header_only_c;
- auto result = wr_.get(ec);
- if(ec == error::need_more)
- goto go_header_only_c;
- if(ec)
- return;
- if(! result)
- goto go_header_only_c;
- more_ = result->second;
- if(! more_)
- {
- // do it all in one buffer
- v_.template emplace<7>(
- boost::in_place_init,
- fwr_->get(),
- buffer_size(result->first),
- boost::asio::const_buffer{nullptr, 0},
- chunk_crlf{},
- result->first,
- chunk_crlf{},
- detail::chunk_last(),
- boost::asio::const_buffer{nullptr, 0},
- chunk_crlf{});
- goto go_all_c;
- }
- v_.template emplace<4>(
- boost::in_place_init,
- fwr_->get(),
- buffer_size(result->first),
- boost::asio::const_buffer{nullptr, 0},
- chunk_crlf{},
- result->first,
- chunk_crlf{});
- s_ = do_header_c;
- BOOST_FALLTHROUGH;
- }
-
- case do_header_c:
- do_visit<4>(ec, visit);
- break;
-
- go_header_only_c:
- v_.template emplace<1>(fwr_->get());
- s_ = do_header_only_c;
- BOOST_FALLTHROUGH;
-
- case do_header_only_c:
- do_visit<1>(ec, visit);
- break;
-
- case do_body_c:
- s_ = do_body_c + 1;
- BOOST_FALLTHROUGH;
-
- case do_body_c + 1:
- {
- auto result = wr_.get(ec);
- if(ec)
- return;
- if(! result)
- goto go_final_c;
- more_ = result->second;
- if(! more_)
- {
- // do it all in one buffer
- v_.template emplace<6>(
- boost::in_place_init,
- buffer_size(result->first),
- boost::asio::const_buffer{nullptr, 0},
- chunk_crlf{},
- result->first,
- chunk_crlf{},
- detail::chunk_last(),
- boost::asio::const_buffer{nullptr, 0},
- chunk_crlf{});
- goto go_body_final_c;
- }
- v_.template emplace<5>(
- boost::in_place_init,
- buffer_size(result->first),
- boost::asio::const_buffer{nullptr, 0},
- chunk_crlf{},
- result->first,
- chunk_crlf{});
- s_ = do_body_c + 2;
- BOOST_FALLTHROUGH;
- }
-
- case do_body_c + 2:
- do_visit<5>(ec, visit);
- break;
-
- go_body_final_c:
- s_ = do_body_final_c;
- BOOST_FALLTHROUGH;
- case do_body_final_c:
- do_visit<6>(ec, visit);
- break;
-
- go_all_c:
- s_ = do_all_c;
- BOOST_FALLTHROUGH;
- case do_all_c:
- do_visit<7>(ec, visit);
- break;
-
- go_final_c:
- case do_final_c:
- v_.template emplace<8>(
- boost::in_place_init,
- detail::chunk_last(),
- boost::asio::const_buffer{nullptr, 0},
- chunk_crlf{});
- s_ = do_final_c + 1;
- BOOST_FALLTHROUGH;
-
- case do_final_c + 1:
- do_visit<8>(ec, visit);
- break;
-
- //----------------------------------------------------------------------
-
- default:
- case do_complete:
- BOOST_ASSERT(false);
- break;
-
- go_complete:
- s_ = do_complete;
- break;
- }
-}
-
-template<
- bool isRequest, class Body, class Fields>
-void
-serializer<isRequest, Body, Fields>::
-consume(std::size_t n)
-{
- using boost::asio::buffer_size;
- switch(s_)
- {
- case do_header:
- BOOST_ASSERT(
- n <= buffer_size(v_.template get<2>()));
- v_.template get<2>().consume(n);
- if(buffer_size(v_.template get<2>()) > 0)
- break;
- header_done_ = true;
- v_.reset();
- if(! more_)
- goto go_complete;
- s_ = do_body + 1;
- break;
-
- case do_header_only:
- BOOST_ASSERT(
- n <= buffer_size(v_.template get<1>()));
- v_.template get<1>().consume(n);
- if(buffer_size(v_.template get<1>()) > 0)
- break;
- fwr_ = boost::none;
- header_done_ = true;
- if(! split_)
- goto go_complete;
- s_ = do_body;
- break;
-
- case do_body + 2:
- {
- BOOST_ASSERT(
- n <= buffer_size(v_.template get<3>()));
- v_.template get<3>().consume(n);
- if(buffer_size(v_.template get<3>()) > 0)
- break;
- v_.reset();
- if(! more_)
- goto go_complete;
- s_ = do_body + 1;
- break;
- }
-
- //----------------------------------------------------------------------
-
- case do_header_c:
- BOOST_ASSERT(
- n <= buffer_size(v_.template get<4>()));
- v_.template get<4>().consume(n);
- if(buffer_size(v_.template get<4>()) > 0)
- break;
- header_done_ = true;
- v_.reset();
- if(more_)
- s_ = do_body_c + 1;
- else
- s_ = do_final_c;
- break;
-
- case do_header_only_c:
- {
- BOOST_ASSERT(
- n <= buffer_size(v_.template get<1>()));
- v_.template get<1>().consume(n);
- if(buffer_size(v_.template get<1>()) > 0)
- break;
- fwr_ = boost::none;
- header_done_ = true;
- if(! split_)
- {
- s_ = do_final_c;
- break;
- }
- s_ = do_body_c;
- break;
- }
-
- case do_body_c + 2:
- BOOST_ASSERT(
- n <= buffer_size(v_.template get<5>()));
- v_.template get<5>().consume(n);
- if(buffer_size(v_.template get<5>()) > 0)
- break;
- v_.reset();
- if(more_)
- s_ = do_body_c + 1;
- else
- s_ = do_final_c;
- break;
-
- case do_body_final_c:
- {
- BOOST_ASSERT(
- n <= buffer_size(v_.template get<6>()));
- v_.template get<6>().consume(n);
- if(buffer_size(v_.template get<6>()) > 0)
- break;
- v_.reset();
- s_ = do_complete;
- break;
- }
-
- case do_all_c:
- {
- BOOST_ASSERT(
- n <= buffer_size(v_.template get<7>()));
- v_.template get<7>().consume(n);
- if(buffer_size(v_.template get<7>()) > 0)
- break;
- header_done_ = true;
- v_.reset();
- s_ = do_complete;
- break;
- }
-
- case do_final_c + 1:
- BOOST_ASSERT(buffer_size(v_.template get<8>()));
- v_.template get<8>().consume(n);
- if(buffer_size(v_.template get<8>()) > 0)
- break;
- v_.reset();
- goto go_complete;
-
- //----------------------------------------------------------------------
-
- default:
- BOOST_ASSERT(false);
- case do_complete:
- break;
-
- go_complete:
- s_ = do_complete;
- break;
- }
-}
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/impl/status.ipp b/contrib/restricted/boost/boost/beast/http/impl/status.ipp
deleted file mode 100644
index 7d37919423..0000000000
--- a/contrib/restricted/boost/boost/beast/http/impl/status.ipp
+++ /dev/null
@@ -1,252 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_IMPL_STATUS_IPP
-#define BOOST_BEAST_HTTP_IMPL_STATUS_IPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/throw_exception.hpp>
-
-namespace boost {
-namespace beast {
-namespace http {
-namespace detail {
-
-template<class = void>
-status
-int_to_status(unsigned v)
-{
- switch(static_cast<status>(v))
- {
- // 1xx
- case status::continue_:
- case status::switching_protocols:
- case status::processing:
- BOOST_FALLTHROUGH;
-
- // 2xx
- case status::ok:
- case status::created:
- case status::accepted:
- case status::non_authoritative_information:
- case status::no_content:
- case status::reset_content:
- case status::partial_content:
- case status::multi_status:
- case status::already_reported:
- case status::im_used:
- BOOST_FALLTHROUGH;
-
- // 3xx
- case status::multiple_choices:
- case status::moved_permanently:
- case status::found:
- case status::see_other:
- case status::not_modified:
- case status::use_proxy:
- case status::temporary_redirect:
- case status::permanent_redirect:
- BOOST_FALLTHROUGH;
-
- // 4xx
- case status::bad_request:
- case status::unauthorized:
- case status::payment_required:
- case status::forbidden:
- case status::not_found:
- case status::method_not_allowed:
- case status::not_acceptable:
- case status::proxy_authentication_required:
- case status::request_timeout:
- case status::conflict:
- case status::gone:
- case status::length_required:
- case status::precondition_failed:
- case status::payload_too_large:
- case status::uri_too_long:
- case status::unsupported_media_type:
- case status::range_not_satisfiable:
- case status::expectation_failed:
- case status::misdirected_request:
- case status::unprocessable_entity:
- case status::locked:
- case status::failed_dependency:
- case status::upgrade_required:
- case status::precondition_required:
- case status::too_many_requests:
- case status::request_header_fields_too_large:
- case status::connection_closed_without_response:
- case status::unavailable_for_legal_reasons:
- case status::client_closed_request:
- BOOST_FALLTHROUGH;
-
- // 5xx
- case status::internal_server_error:
- case status::not_implemented:
- case status::bad_gateway:
- case status::service_unavailable:
- case status::gateway_timeout:
- case status::http_version_not_supported:
- case status::variant_also_negotiates:
- case status::insufficient_storage:
- case status::loop_detected:
- case status::not_extended:
- case status::network_authentication_required:
- case status::network_connect_timeout_error:
- return static_cast<status>(v);
-
- default:
- break;
- }
- return status::unknown;
-}
-
-template<class = void>
-string_view
-status_to_string(unsigned v)
-{
- switch(static_cast<status>(v))
- {
- // 1xx
- case status::continue_: return "Continue";
- case status::switching_protocols: return "Switching Protocols";
- case status::processing: return "Processing";
-
- // 2xx
- case status::ok: return "OK";
- case status::created: return "Created";
- case status::accepted: return "Accepted";
- case status::non_authoritative_information: return "Non-Authoritative Information";
- case status::no_content: return "No Content";
- case status::reset_content: return "Reset Content";
- case status::partial_content: return "Partial Content";
- case status::multi_status: return "Multi-Status";
- case status::already_reported: return "Already Reported";
- case status::im_used: return "IM Used";
-
- // 3xx
- case status::multiple_choices: return "Multiple Choices";
- case status::moved_permanently: return "Moved Permanently";
- case status::found: return "Found";
- case status::see_other: return "See Other";
- case status::not_modified: return "Not Modified";
- case status::use_proxy: return "Use Proxy";
- case status::temporary_redirect: return "Temporary Redirect";
- case status::permanent_redirect: return "Permanent Redirect";
-
- // 4xx
- case status::bad_request: return "Bad Request";
- case status::unauthorized: return "Unauthorized";
- case status::payment_required: return "Payment Required";
- case status::forbidden: return "Forbidden";
- case status::not_found: return "Not Found";
- case status::method_not_allowed: return "Method Not Allowed";
- case status::not_acceptable: return "Not Acceptable";
- case status::proxy_authentication_required: return "Proxy Authentication Required";
- case status::request_timeout: return "Request Timeout";
- case status::conflict: return "Conflict";
- case status::gone: return "Gone";
- case status::length_required: return "Length Required";
- case status::precondition_failed: return "Precondition Failed";
- case status::payload_too_large: return "Payload Too Large";
- case status::uri_too_long: return "URI Too Long";
- case status::unsupported_media_type: return "Unsupported Media Type";
- case status::range_not_satisfiable: return "Range Not Satisfiable";
- case status::expectation_failed: return "Expectation Failed";
- case status::misdirected_request: return "Misdirected Request";
- case status::unprocessable_entity: return "Unprocessable Entity";
- case status::locked: return "Locked";
- case status::failed_dependency: return "Failed Dependency";
- case status::upgrade_required: return "Upgrade Required";
- case status::precondition_required: return "Precondition Required";
- case status::too_many_requests: return "Too Many Requests";
- case status::request_header_fields_too_large: return "Request Header Fields Too Large";
- case status::connection_closed_without_response: return "Connection Closed Without Response";
- case status::unavailable_for_legal_reasons: return "Unavailable For Legal Reasons";
- case status::client_closed_request: return "Client Closed Request";
- // 5xx
- case status::internal_server_error: return "Internal Server Error";
- case status::not_implemented: return "Not Implemented";
- case status::bad_gateway: return "Bad Gateway";
- case status::service_unavailable: return "Service Unavailable";
- case status::gateway_timeout: return "Gateway Timeout";
- case status::http_version_not_supported: return "HTTP Version Not Supported";
- case status::variant_also_negotiates: return "Variant Also Negotiates";
- case status::insufficient_storage: return "Insufficient Storage";
- case status::loop_detected: return "Loop Detected";
- case status::not_extended: return "Not Extended";
- case status::network_authentication_required: return "Network Authentication Required";
- case status::network_connect_timeout_error: return "Network Connect Timeout Error";
-
- default:
- break;
- }
- return "<unknown-status>";
-}
-
-template<class = void>
-status_class
-to_status_class(unsigned v)
-{
- switch(v / 100)
- {
- case 1: return status_class::informational;
- case 2: return status_class::successful;
- case 3: return status_class::redirection;
- case 4: return status_class::client_error;
- case 5: return status_class::server_error;
- default:
- break;
- }
- return status_class::unknown;
-}
-
-} // detail
-
-inline
-status
-int_to_status(unsigned v)
-{
- return detail::int_to_status(v);
-}
-
-inline
-status_class
-to_status_class(unsigned v)
-{
- return detail::to_status_class(v);
-}
-
-inline
-status_class
-to_status_class(status v)
-{
- return to_status_class(static_cast<int>(v));
-}
-
-inline
-string_view
-obsolete_reason(status v)
-{
- return detail::status_to_string(
- static_cast<unsigned>(v));
-}
-
-inline
-std::ostream&
-operator<<(std::ostream& os, status v)
-{
- return os << obsolete_reason(v);
-}
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/impl/verb.ipp b/contrib/restricted/boost/boost/beast/http/impl/verb.ipp
deleted file mode 100644
index 8f8b2e33bf..0000000000
--- a/contrib/restricted/boost/boost/beast/http/impl/verb.ipp
+++ /dev/null
@@ -1,341 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_IMPL_VERB_IPP
-#define BOOST_BEAST_HTTP_IMPL_VERB_IPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/throw_exception.hpp>
-#include <stdexcept>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-namespace detail {
-
-template<class = void>
-inline
-string_view
-verb_to_string(verb v)
-{
- switch(v)
- {
- case verb::delete_: return "DELETE";
- case verb::get: return "GET";
- case verb::head: return "HEAD";
- case verb::post: return "POST";
- case verb::put: return "PUT";
- case verb::connect: return "CONNECT";
- case verb::options: return "OPTIONS";
- case verb::trace: return "TRACE";
-
- case verb::copy: return "COPY";
- case verb::lock: return "LOCK";
- case verb::mkcol: return "MKCOL";
- case verb::move: return "MOVE";
- case verb::propfind: return "PROPFIND";
- case verb::proppatch: return "PROPPATCH";
- case verb::search: return "SEARCH";
- case verb::unlock: return "UNLOCK";
- case verb::bind: return "BIND";
- case verb::rebind: return "REBIND";
- case verb::unbind: return "UNBIND";
- case verb::acl: return "ACL";
-
- case verb::report: return "REPORT";
- case verb::mkactivity: return "MKACTIVITY";
- case verb::checkout: return "CHECKOUT";
- case verb::merge: return "MERGE";
-
- case verb::msearch: return "M-SEARCH";
- case verb::notify: return "NOTIFY";
- case verb::subscribe: return "SUBSCRIBE";
- case verb::unsubscribe: return "UNSUBSCRIBE";
-
- case verb::patch: return "PATCH";
- case verb::purge: return "PURGE";
-
- case verb::mkcalendar: return "MKCALENDAR";
-
- case verb::link: return "LINK";
- case verb::unlink: return "UNLINK";
-
- case verb::unknown:
- return "<unknown>";
- }
-
- BOOST_THROW_EXCEPTION(std::invalid_argument{"unknown verb"});
-
- // Help some compilers which don't know the next line is
- // unreachable, otherwise spurious warnings are generated.
- return "<unknown>";
-}
-
-template<class = void>
-verb
-string_to_verb(string_view v)
-{
-/*
- ACL
- BIND
- CHECKOUT
- CONNECT
- COPY
- DELETE
- GET
- HEAD
- LINK
- LOCK
- M-SEARCH
- MERGE
- MKACTIVITY
- MKCALENDAR
- MKCOL
- MOVE
- NOTIFY
- OPTIONS
- PATCH
- POST
- PROPFIND
- PROPPATCH
- PURGE
- PUT
- REBIND
- REPORT
- SEARCH
- SUBSCRIBE
- TRACE
- UNBIND
- UNLINK
- UNLOCK
- UNSUBSCRIBE
-*/
- if(v.size() < 3)
- return verb::unknown;
- // s must be null terminated
- auto const eq =
- [](string_view sv, char const* s)
- {
- auto p = sv.data();
- for(;;)
- {
- if(*s != *p)
- return false;
- ++s;
- ++p;
- if(! *s)
- return p == sv.end();
- }
- };
- auto c = v[0];
- v.remove_prefix(1);
- switch(c)
- {
- case 'A':
- if(v == "CL")
- return verb::acl;
- break;
-
- case 'B':
- if(v == "IND")
- return verb::bind;
- break;
-
- case 'C':
- c = v[0];
- v.remove_prefix(1);
- switch(c)
- {
- case 'H':
- if(eq(v, "ECKOUT"))
- return verb::checkout;
- break;
-
- case 'O':
- if(eq(v, "NNECT"))
- return verb::connect;
- if(eq(v, "PY"))
- return verb::copy;
- BOOST_FALLTHROUGH;
-
- default:
- break;
- }
- break;
-
- case 'D':
- if(eq(v, "ELETE"))
- return verb::delete_;
- break;
-
- case 'G':
- if(eq(v, "ET"))
- return verb::get;
- break;
-
- case 'H':
- if(eq(v, "EAD"))
- return verb::head;
- break;
-
- case 'L':
- if(eq(v, "INK"))
- return verb::link;
- if(eq(v, "OCK"))
- return verb::lock;
- break;
-
- case 'M':
- c = v[0];
- v.remove_prefix(1);
- switch(c)
- {
- case '-':
- if(eq(v, "SEARCH"))
- return verb::msearch;
- break;
-
- case 'E':
- if(eq(v, "RGE"))
- return verb::merge;
- break;
-
- case 'K':
- if(eq(v, "ACTIVITY"))
- return verb::mkactivity;
- if(v[0] == 'C')
- {
- v.remove_prefix(1);
- if(eq(v, "ALENDAR"))
- return verb::mkcalendar;
- if(eq(v, "OL"))
- return verb::mkcol;
- break;
- }
- break;
-
- case 'O':
- if(eq(v, "VE"))
- return verb::move;
- BOOST_FALLTHROUGH;
-
- default:
- break;
- }
- break;
-
- case 'N':
- if(eq(v, "OTIFY"))
- return verb::notify;
- break;
-
- case 'O':
- if(eq(v, "PTIONS"))
- return verb::options;
- break;
-
- case 'P':
- c = v[0];
- v.remove_prefix(1);
- switch(c)
- {
- case 'A':
- if(eq(v, "TCH"))
- return verb::patch;
- break;
-
- case 'O':
- if(eq(v, "ST"))
- return verb::post;
- break;
-
- case 'R':
- if(eq(v, "OPFIND"))
- return verb::propfind;
- if(eq(v, "OPPATCH"))
- return verb::proppatch;
- break;
-
- case 'U':
- if(eq(v, "RGE"))
- return verb::purge;
- if(eq(v, "T"))
- return verb::put;
- BOOST_FALLTHROUGH;
-
- default:
- break;
- }
- break;
-
- case 'R':
- if(v[0] != 'E')
- break;
- v.remove_prefix(1);
- if(eq(v, "BIND"))
- return verb::rebind;
- if(eq(v, "PORT"))
- return verb::report;
- break;
-
- case 'S':
- if(eq(v, "EARCH"))
- return verb::search;
- if(eq(v, "UBSCRIBE"))
- return verb::subscribe;
- break;
-
- case 'T':
- if(eq(v, "RACE"))
- return verb::trace;
- break;
-
- case 'U':
- if(v[0] != 'N')
- break;
- v.remove_prefix(1);
- if(eq(v, "BIND"))
- return verb::unbind;
- if(eq(v, "LINK"))
- return verb::unlink;
- if(eq(v, "LOCK"))
- return verb::unlock;
- if(eq(v, "SUBSCRIBE"))
- return verb::unsubscribe;
- break;
-
- default:
- break;
- }
-
- return verb::unknown;
-}
-
-} // detail
-
-inline
-string_view
-to_string(verb v)
-{
- return detail::verb_to_string(v);
-}
-
-inline
-verb
-string_to_verb(string_view s)
-{
- return detail::string_to_verb(s);
-}
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/impl/write.ipp b/contrib/restricted/boost/boost/beast/http/impl/write.ipp
deleted file mode 100644
index af31cd9be9..0000000000
--- a/contrib/restricted/boost/boost/beast/http/impl/write.ipp
+++ /dev/null
@@ -1,908 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_IMPL_WRITE_IPP
-#define BOOST_BEAST_HTTP_IMPL_WRITE_IPP
-
-#include <boost/beast/http/type_traits.hpp>
-#include <boost/beast/core/bind_handler.hpp>
-#include <boost/beast/core/ostream.hpp>
-#include <boost/beast/core/handler_ptr.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/asio/associated_allocator.hpp>
-#include <boost/asio/associated_executor.hpp>
-#include <boost/asio/handler_continuation_hook.hpp>
-#include <boost/asio/handler_invoke_hook.hpp>
-#include <boost/asio/post.hpp>
-#include <boost/asio/write.hpp>
-#include <boost/optional.hpp>
-#include <boost/throw_exception.hpp>
-#include <ostream>
-#include <sstream>
-
-namespace boost {
-namespace beast {
-namespace http {
-namespace detail {
-
-template<
- class Stream, class Handler,
- bool isRequest, class Body, class Fields>
-class write_some_op
-{
- Stream& s_;
- serializer<isRequest,Body, Fields>& sr_;
- Handler h_;
-
- class lambda
- {
- write_some_op& op_;
-
- public:
- bool invoked = false;
-
- explicit
- lambda(write_some_op& op)
- : op_(op)
- {
- }
-
- template<class ConstBufferSequence>
- void
- operator()(error_code& ec,
- ConstBufferSequence const& buffers)
- {
- invoked = true;
- ec.assign(0, ec.category());
- return op_.s_.async_write_some(
- buffers, std::move(op_));
- }
- };
-
-public:
- write_some_op(write_some_op&&) = default;
- write_some_op(write_some_op const&) = delete;
-
- template<class DeducedHandler>
- write_some_op(DeducedHandler&& h, Stream& s,
- serializer<isRequest, Body, Fields>& sr)
- : s_(s)
- , sr_(sr)
- , h_(std::forward<DeducedHandler>(h))
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(h_);
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<Stream&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- h_, s_.get_executor());
- }
-
- void
- operator()();
-
- void
- operator()(
- error_code ec,
- std::size_t bytes_transferred);
-
- friend
- bool asio_handler_is_continuation(write_some_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return asio_handler_is_continuation(
- std::addressof(op->h_));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, write_some_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f, std::addressof(op->h_));
- }
-};
-
-template<
- class Stream, class Handler,
- bool isRequest, class Body, class Fields>
-void
-write_some_op<
- Stream, Handler, isRequest, Body, Fields>::
-operator()()
-{
- error_code ec;
- if(! sr_.is_done())
- {
- lambda f{*this};
- sr_.next(ec, f);
- if(ec)
- {
- BOOST_ASSERT(! f.invoked);
- return boost::asio::post(
- s_.get_executor(),
- bind_handler(std::move(*this), ec, 0));
- }
- if(f.invoked)
- {
- // *this has been moved from,
- // cannot access members here.
- return;
- }
- // What else could it be?
- BOOST_ASSERT(sr_.is_done());
- }
- return boost::asio::post(
- s_.get_executor(),
- bind_handler(std::move(*this), ec, 0));
-}
-
-template<
- class Stream, class Handler,
- bool isRequest, class Body, class Fields>
-void
-write_some_op<
- Stream, Handler, isRequest, Body, Fields>::
-operator()(
- error_code ec, std::size_t bytes_transferred)
-{
- if(! ec)
- sr_.consume(bytes_transferred);
- h_(ec, bytes_transferred);
-}
-
-//------------------------------------------------------------------------------
-
-struct serializer_is_header_done
-{
- template<
- bool isRequest, class Body, class Fields>
- bool
- operator()(
- serializer<isRequest, Body, Fields>& sr) const
- {
- return sr.is_header_done();
- }
-};
-
-struct serializer_is_done
-{
- template<
- bool isRequest, class Body, class Fields>
- bool
- operator()(
- serializer<isRequest, Body, Fields>& sr) const
- {
- return sr.is_done();
- }
-};
-
-//------------------------------------------------------------------------------
-
-template<
- class Stream, class Handler, class Predicate,
- bool isRequest, class Body, class Fields>
-class write_op
-{
- int state_ = 0;
- Stream& s_;
- serializer<isRequest, Body, Fields>& sr_;
- std::size_t bytes_transferred_ = 0;
- Handler h_;
-
-public:
- write_op(write_op&&) = default;
- write_op(write_op const&) = delete;
-
- template<class DeducedHandler>
- write_op(DeducedHandler&& h, Stream& s,
- serializer<isRequest, Body, Fields>& sr)
- : s_(s)
- , sr_(sr)
- , h_(std::forward<DeducedHandler>(h))
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(h_);
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<Stream&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- h_, s_.get_executor());
- }
-
- void
- operator()(
- error_code ec = {},
- std::size_t bytes_transferred = 0);
-
- friend
- bool asio_handler_is_continuation(write_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return op->state_ >= 3 ||
- asio_handler_is_continuation(
- std::addressof(op->h_));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, write_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f, std::addressof(op->h_));
- }
-};
-
-template<
- class Stream, class Handler, class Predicate,
- bool isRequest, class Body, class Fields>
-void
-write_op<Stream, Handler, Predicate,
- isRequest, Body, Fields>::
-operator()(
- error_code ec, std::size_t bytes_transferred)
-{
- if(ec)
- goto upcall;
- switch(state_)
- {
- case 0:
- {
- if(Predicate{}(sr_))
- {
- state_ = 1;
- return boost::asio::post(
- s_.get_executor(),
- bind_handler(std::move(*this), ec, 0));
- }
- state_ = 2;
- return beast::http::async_write_some(
- s_, sr_, std::move(*this));
- }
-
- case 1:
- goto upcall;
-
- case 2:
- state_ = 3;
- BOOST_FALLTHROUGH;
-
- case 3:
- {
- bytes_transferred_ += bytes_transferred;
- if(Predicate{}(sr_))
- goto upcall;
- return beast::http::async_write_some(
- s_, sr_, std::move(*this));
- }
- }
-upcall:
- h_(ec, bytes_transferred_);
-}
-
-//------------------------------------------------------------------------------
-
-template<class Stream, class Handler,
- bool isRequest, class Body, class Fields>
-class write_msg_op
-{
- struct data
- {
- Stream& s;
- serializer<isRequest, Body, Fields> sr;
-
- data(Handler const&, Stream& s_, message<
- isRequest, Body, Fields>& m_)
- : s(s_)
- , sr(m_)
- {
- }
- };
-
- handler_ptr<data, Handler> d_;
-
-public:
- write_msg_op(write_msg_op&&) = default;
- write_msg_op(write_msg_op const&) = delete;
-
- template<class DeducedHandler, class... Args>
- write_msg_op(DeducedHandler&& h, Stream& s, Args&&... args)
- : d_(std::forward<DeducedHandler>(h),
- s, std::forward<Args>(args)...)
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(d_.handler());
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<Stream&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- d_.handler(), d_->s.get_executor());
- }
-
- void
- operator()();
-
- void
- operator()(
- error_code ec, std::size_t bytes_transferred);
-
- friend
- bool asio_handler_is_continuation(write_msg_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return asio_handler_is_continuation(
- std::addressof(op->d_.handler()));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, write_msg_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f, std::addressof(op->d_.handler()));
- }
-};
-
-template<class Stream, class Handler,
- bool isRequest, class Body, class Fields>
-void
-write_msg_op<
- Stream, Handler, isRequest, Body, Fields>::
-operator()()
-{
- auto& d = *d_;
- return async_write(d.s, d.sr, std::move(*this));
-}
-
-template<class Stream, class Handler,
- bool isRequest, class Body, class Fields>
-void
-write_msg_op<
- Stream, Handler, isRequest, Body, Fields>::
-operator()(error_code ec, std::size_t bytes_transferred)
-{
- d_.invoke(ec, bytes_transferred);
-}
-
-//------------------------------------------------------------------------------
-
-template<class Stream>
-class write_some_lambda
-{
- Stream& stream_;
-
-public:
- bool invoked = false;
- std::size_t bytes_transferred = 0;
-
- explicit
- write_some_lambda(Stream& stream)
- : stream_(stream)
- {
- }
-
- template<class ConstBufferSequence>
- void
- operator()(error_code& ec,
- ConstBufferSequence const& buffers)
- {
- invoked = true;
- bytes_transferred =
- stream_.write_some(buffers, ec);
- }
-};
-
-template<class Stream>
-class write_lambda
-{
- Stream& stream_;
-
-public:
- bool invoked = false;
- std::size_t bytes_transferred = 0;
-
- explicit
- write_lambda(Stream& stream)
- : stream_(stream)
- {
- }
-
- template<class ConstBufferSequence>
- void
- operator()(error_code& ec,
- ConstBufferSequence const& buffers)
- {
- invoked = true;
- bytes_transferred = boost::asio::write(
- stream_, buffers, ec);
- }
-};
-
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write_some_impl(
- SyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr,
- error_code& ec)
-{
- if(! sr.is_done())
- {
- write_some_lambda<SyncWriteStream> f{stream};
- sr.next(ec, f);
- if(ec)
- return f.bytes_transferred;
- if(f.invoked)
- sr.consume(f.bytes_transferred);
- return f.bytes_transferred;
- }
- ec.assign(0, ec.category());
- return 0;
-}
-
-template<
- class AsyncWriteStream,
- bool isRequest, class Body, class Fields,
- class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
-async_write_some_impl(
- AsyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr,
- WriteHandler&& handler)
-{
- BOOST_BEAST_HANDLER_INIT(
- WriteHandler, void(error_code, std::size_t));
- detail::write_some_op<
- AsyncWriteStream,
- BOOST_ASIO_HANDLER_TYPE(WriteHandler,
- void(error_code, std::size_t)),
- isRequest, Body, Fields>{
- std::move(init.completion_handler), stream, sr}();
- return init.result.get();
-}
-
-} // detail
-
-//------------------------------------------------------------------------------
-
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write_some(
- SyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr)
-{
- static_assert(is_sync_write_stream<SyncWriteStream>::value,
- "SyncWriteStream requirements not met");
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- static_assert(is_body_writer<Body>::value,
- "BodyWriter requirements not met");
- error_code ec;
- auto const bytes_transferred =
- write_some(stream, sr, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
- return bytes_transferred;
-}
-
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write_some(
- SyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr,
- error_code& ec)
-{
- static_assert(is_sync_write_stream<SyncWriteStream>::value,
- "SyncWriteStream requirements not met");
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- static_assert(is_body_writer<Body>::value,
- "BodyWriter requirements not met");
- return detail::write_some_impl(stream, sr, ec);
-}
-
-template<
- class AsyncWriteStream,
- bool isRequest, class Body, class Fields,
- class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
-async_write_some(
- AsyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr,
- WriteHandler&& handler)
-{
- static_assert(is_async_write_stream<
- AsyncWriteStream>::value,
- "AsyncWriteStream requirements not met");
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- static_assert(is_body_writer<Body>::value,
- "BodyWriter requirements not met");
- return detail::async_write_some_impl(stream, sr,
- std::forward<WriteHandler>(handler));
-}
-
-//------------------------------------------------------------------------------
-
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write_header(SyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr)
-{
- static_assert(is_sync_write_stream<SyncWriteStream>::value,
- "SyncWriteStream requirements not met");
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- static_assert(is_body_writer<Body>::value,
- "BodyWriter requirements not met");
- error_code ec;
- auto const bytes_transferred =
- write_header(stream, sr, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
- return bytes_transferred;
-}
-
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write_header(
- SyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr,
- error_code& ec)
-{
- static_assert(is_sync_write_stream<SyncWriteStream>::value,
- "SyncWriteStream requirements not met");
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- static_assert(is_body_writer<Body>::value,
- "BodyWriter requirements not met");
- sr.split(true);
- std::size_t bytes_transferred = 0;
- if(! sr.is_header_done())
- {
- detail::write_lambda<SyncWriteStream> f{stream};
- do
- {
- sr.next(ec, f);
- bytes_transferred += f.bytes_transferred;
- if(ec)
- return bytes_transferred;
- BOOST_ASSERT(f.invoked);
- sr.consume(f.bytes_transferred);
- }
- while(! sr.is_header_done());
- }
- else
- {
- ec.assign(0, ec.category());
- }
- return bytes_transferred;
-}
-
-template<
- class AsyncWriteStream,
- bool isRequest, class Body, class Fields,
- class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
-async_write_header(
- AsyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr,
- WriteHandler&& handler)
-{
- static_assert(is_async_write_stream<
- AsyncWriteStream>::value,
- "AsyncWriteStream requirements not met");
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- static_assert(is_body_writer<Body>::value,
- "BodyWriter requirements not met");
- sr.split(true);
- BOOST_BEAST_HANDLER_INIT(
- WriteHandler, void(error_code, std::size_t));
- detail::write_op<
- AsyncWriteStream,
- BOOST_ASIO_HANDLER_TYPE(WriteHandler,
- void(error_code, std::size_t)),
- detail::serializer_is_header_done,
- isRequest, Body, Fields>{
- std::move(init.completion_handler), stream, sr}();
- return init.result.get();
-}
-
-//------------------------------------------------------------------------------
-
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write(
- SyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr)
-{
- static_assert(is_sync_write_stream<SyncWriteStream>::value,
- "SyncWriteStream requirements not met");
- error_code ec;
- auto const bytes_transferred =
- write(stream, sr, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
- return bytes_transferred;
-}
-
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write(
- SyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr,
- error_code& ec)
-{
- static_assert(is_sync_write_stream<SyncWriteStream>::value,
- "SyncWriteStream requirements not met");
- std::size_t bytes_transferred = 0;
- sr.split(false);
- for(;;)
- {
- bytes_transferred +=
- write_some(stream, sr, ec);
- if(ec)
- return bytes_transferred;
- if(sr.is_done())
- break;
- }
- return bytes_transferred;
-}
-
-template<
- class AsyncWriteStream,
- bool isRequest, class Body, class Fields,
- class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
-async_write(
- AsyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr,
- WriteHandler&& handler)
-{
- static_assert(is_async_write_stream<
- AsyncWriteStream>::value,
- "AsyncWriteStream requirements not met");
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- static_assert(is_body_writer<Body>::value,
- "BodyWriter requirements not met");
- sr.split(false);
- BOOST_BEAST_HANDLER_INIT(
- WriteHandler, void(error_code, std::size_t));
- detail::write_op<
- AsyncWriteStream,
- BOOST_ASIO_HANDLER_TYPE(WriteHandler,
- void(error_code, std::size_t)),
- detail::serializer_is_done,
- isRequest, Body, Fields>{
- std::move(init.completion_handler), stream, sr}();
- return init.result.get();
-}
-
-//------------------------------------------------------------------------------
-
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write(
- SyncWriteStream& stream,
- message<isRequest, Body, Fields> const& msg)
-{
- static_assert(is_sync_write_stream<SyncWriteStream>::value,
- "SyncWriteStream requirements not met");
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- static_assert(is_body_writer<Body>::value,
- "BodyWriter requirements not met");
- error_code ec;
- auto const bytes_transferred =
- write(stream, msg, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
- return bytes_transferred;
-}
-
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write(
- SyncWriteStream& stream,
- message<isRequest, Body, Fields> const& msg,
- error_code& ec)
-{
- static_assert(is_sync_write_stream<SyncWriteStream>::value,
- "SyncWriteStream requirements not met");
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- static_assert(is_body_writer<Body>::value,
- "BodyWriter requirements not met");
- serializer<isRequest, Body, Fields> sr{msg};
- return write(stream, sr, ec);
-}
-
-template<
- class AsyncWriteStream,
- bool isRequest, class Body, class Fields,
- class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
-async_write(
- AsyncWriteStream& stream,
- message<isRequest, Body, Fields>& msg,
- WriteHandler&& handler)
-{
- static_assert(
- is_async_write_stream<AsyncWriteStream>::value,
- "AsyncWriteStream requirements not met");
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- static_assert(is_body_writer<Body>::value,
- "BodyWriter requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- WriteHandler, void(error_code, std::size_t));
- detail::write_msg_op<
- AsyncWriteStream,
- BOOST_ASIO_HANDLER_TYPE(WriteHandler,
- void(error_code, std::size_t)),
- isRequest, Body, Fields>{
- std::move(init.completion_handler), stream, msg}();
- return init.result.get();
-}
-
-//------------------------------------------------------------------------------
-
-namespace detail {
-
-template<class Serializer>
-class write_ostream_lambda
-{
- std::ostream& os_;
- Serializer& sr_;
-
-public:
- write_ostream_lambda(std::ostream& os,
- Serializer& sr)
- : os_(os)
- , sr_(sr)
- {
- }
-
- template<class ConstBufferSequence>
- void
- operator()(error_code& ec,
- ConstBufferSequence const& buffers) const
- {
- ec.assign(0, ec.category());
- if(os_.fail())
- return;
- std::size_t bytes_transferred = 0;
- for(auto b : buffers_range(buffers))
- {
- os_.write(reinterpret_cast<char const*>(
- b.data()), b.size());
- if(os_.fail())
- return;
- bytes_transferred += b.size();
- }
- sr_.consume(bytes_transferred);
- }
-};
-
-} // detail
-
-template<class Fields>
-std::ostream&
-operator<<(std::ostream& os,
- header<true, Fields> const& h)
-{
- typename Fields::writer fr{
- h, h.version(), h.method()};
- return os << buffers(fr.get());
-}
-
-template<class Fields>
-std::ostream&
-operator<<(std::ostream& os,
- header<false, Fields> const& h)
-{
- typename Fields::writer fr{
- h, h.version(), h.result_int()};
- return os << buffers(fr.get());
-}
-
-template<bool isRequest, class Body, class Fields>
-std::ostream&
-operator<<(std::ostream& os,
- message<isRequest, Body, Fields> const& msg)
-{
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- static_assert(is_body_writer<Body>::value,
- "BodyWriter requirements not met");
- serializer<isRequest, Body, Fields> sr{msg};
- error_code ec;
- detail::write_ostream_lambda<decltype(sr)> f{os, sr};
- do
- {
- sr.next(ec, f);
- if(os.fail())
- break;
- if(ec)
- {
- os.setstate(std::ios::failbit);
- break;
- }
- }
- while(! sr.is_done());
- return os;
-}
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/message.hpp b/contrib/restricted/boost/boost/beast/http/message.hpp
deleted file mode 100644
index 0455042786..0000000000
--- a/contrib/restricted/boost/boost/beast/http/message.hpp
+++ /dev/null
@@ -1,1003 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_MESSAGE_HPP
-#define BOOST_BEAST_HTTP_MESSAGE_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/http/fields.hpp>
-#include <boost/beast/http/verb.hpp>
-#include <boost/beast/http/status.hpp>
-#include <boost/beast/http/type_traits.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/core/detail/empty_base_optimization.hpp>
-#include <boost/beast/core/detail/integer_sequence.hpp>
-#include <boost/assert.hpp>
-#include <boost/optional.hpp>
-#include <boost/throw_exception.hpp>
-#include <memory>
-#include <stdexcept>
-#include <string>
-#include <tuple>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** A container for an HTTP request or response header.
-
- This container is derived from the `Fields` template type.
- To understand all of the members of this class it is necessary
- to view the declaration for the `Fields` type. When using
- the default fields container, those declarations are in
- @ref fields.
-
- Newly constructed header objects have version set to
- HTTP/1.1. Newly constructed response objects also have
- result code set to @ref status::ok.
-
- A `header` includes the start-line and header-fields.
-*/
-#if BOOST_BEAST_DOXYGEN
-template<bool isRequest, class Fields = fields>
-struct header : Fields
-
-#else
-template<bool isRequest, class Fields = fields>
-struct header;
-
-template<class Fields>
-struct header<true, Fields> : Fields
-#endif
-{
- static_assert(is_fields<Fields>::value,
- "Fields requirements not met");
-
- /// Indicates if the header is a request or response.
-#if BOOST_BEAST_DOXYGEN
- using is_request = std::integral_constant<bool, isRequest>;
-#else
- using is_request = std::true_type;
-#endif
-
- /// The type representing the fields.
- using fields_type = Fields;
-
- /// Constructor
- header() = default;
-
- /// Constructor
- header(header&&) = default;
-
- /// Constructor
- header(header const&) = default;
-
- /// Assignment
- header& operator=(header&&) = default;
-
- /// Assignment
- header& operator=(header const&) = default;
-
- /** Return the HTTP-version.
-
- This holds both the major and minor version numbers,
- using these formulas:
- @code
- unsigned major = version / 10;
- unsigned minor = version % 10;
- @endcode
-
- Newly constructed headers will use HTTP/1.1 by default.
- */
- unsigned version() const noexcept
- {
- return version_;
- }
-
- /** Set the HTTP-version.
-
- This holds both the major and minor version numbers,
- using these formulas:
- @code
- unsigned major = version / 10;
- unsigned minor = version % 10;
- @endcode
-
- Newly constructed headers will use HTTP/1.1 by default.
-
- @param value The version number to use
- */
- void version(unsigned value) noexcept
- {
- BOOST_ASSERT(value > 0 && value < 100);
- version_ = value;
- }
-
- /** Return the request-method verb.
-
- If the request-method is not one of the recognized verbs,
- @ref verb::unknown is returned. Callers may use @ref method_string
- to retrieve the exact text.
-
- @note This function is only available when `isRequest == true`.
-
- @see @ref method_string
- */
- verb
- method() const;
-
- /** Set the request-method.
-
- This function will set the method for requests to a known verb.
-
- @param v The request method verb to set.
- This may not be @ref verb::unknown.
-
- @throws std::invalid_argument when `v == verb::unknown`.
-
- @note This function is only available when `isRequest == true`.
- */
- void
- method(verb v);
-
- /** Return the request-method as a string.
-
- @note This function is only available when `isRequest == true`.
-
- @see @ref method
- */
- string_view
- method_string() const;
-
- /** Set the request-method.
-
- This function will set the request-method a known verb
- if the string matches, otherwise it will store a copy of
- the passed string.
-
- @param s A string representing the request-method.
-
- @note This function is only available when `isRequest == true`.
- */
- void
- method_string(string_view s);
-
- /** Returns the request-target string.
-
- The request target string returned is the same string which
- was received from the network or stored. In particular, it will
- contain url-encoded characters and should follow the syntax
- rules for URIs used with HTTP.
-
- @note This function is only available when `isRequest == true`.
- */
- string_view
- target() const;
-
- /** Set the request-target string.
-
- It is the caller's responsibility to ensure that the request
- target string follows the syntax rules for URIs used with
- HTTP. In particular, reserved or special characters must be
- url-encoded. The implementation does not perform syntax checking
- on the passed string.
-
- @param s A string representing the request-target.
-
- @note This function is only available when `isRequest == true`.
- */
- void
- target(string_view s);
-
- // VFALCO Don't rearrange these declarations or
- // ifdefs, or else the documentation will break.
-
- /** Constructor
-
- @param args Arguments forwarded to the `Fields`
- base class constructor.
-
- @note This constructor participates in overload
- resolution if and only if the first parameter is
- not convertible to @ref header, @ref verb, or
- @ref status.
- */
-#if BOOST_BEAST_DOXYGEN
- template<class... Args>
- explicit
- header(Args&&... args);
-
-#else
- template<class Arg1, class... ArgN,
- class = typename std::enable_if<
- ! std::is_convertible<typename
- std::decay<Arg1>::type, header>::value &&
- ! std::is_convertible<typename
- std::decay<Arg1>::type, verb>::value &&
- ! std::is_convertible<typename
- std::decay<Arg1>::type, header>::value
- >::type>
- explicit
- header(Arg1&& arg1, ArgN&&... argn);
-
-private:
- template<bool, class, class>
- friend struct message;
-
- template<class T>
- friend
- void
- swap(header<true, T>& m1, header<true, T>& m2);
-
- template<class... FieldsArgs>
- header(
- verb method,
- string_view target_,
- unsigned version_value,
- FieldsArgs&&... fields_args)
- : Fields(std::forward<FieldsArgs>(fields_args)...)
- , method_(method)
- {
- version(version_value);
- target(target_);
- }
-
- unsigned version_ = 11;
- verb method_ = verb::unknown;
-};
-
-/** A container for an HTTP request or response header.
-
- A `header` includes the start-line and header-fields.
-*/
-template<class Fields>
-struct header<false, Fields> : Fields
-{
- static_assert(is_fields<Fields>::value,
- "Fields requirements not met");
-
- /// Indicates if the header is a request or response.
- using is_request = std::false_type;
-
- /// The type representing the fields.
- using fields_type = Fields;
-
- /// Constructor.
- header() = default;
-
- /// Constructor
- header(header&&) = default;
-
- /// Constructor
- header(header const&) = default;
-
- /// Assignment
- header& operator=(header&&) = default;
-
- /// Assignment
- header& operator=(header const&) = default;
-
- /** Constructor
-
- @param args Arguments forwarded to the `Fields`
- base class constructor.
-
- @note This constructor participates in overload
- resolution if and only if the first parameter is
- not convertible to @ref header, @ref verb, or
- @ref status.
- */
- template<class Arg1, class... ArgN,
- class = typename std::enable_if<
- ! std::is_convertible<typename
- std::decay<Arg1>::type, status>::value &&
- ! std::is_convertible<typename
- std::decay<Arg1>::type, header>::value
- >::type>
- explicit
- header(Arg1&& arg1, ArgN&&... argn);
-
- /** Return the HTTP-version.
-
- This holds both the major and minor version numbers,
- using these formulas:
- @code
- unsigned major = version / 10;
- unsigned minor = version % 10;
- @endcode
-
- Newly constructed headers will use HTTP/1.1 by default.
- */
- unsigned version() const noexcept
- {
- return version_;
- }
-
- /** Set the HTTP-version.
-
- This holds both the major and minor version numbers,
- using these formulas:
- @code
- unsigned major = version / 10;
- unsigned minor = version % 10;
- @endcode
-
- Newly constructed headers will use HTTP/1.1 by default.
-
- @param value The version number to use
- */
- void version(unsigned value) noexcept
- {
- BOOST_ASSERT(value > 0 && value < 100);
- version_ = value;
- }
-#endif
-
- /** The response status-code result.
-
- If the actual status code is not a known code, this
- function returns @ref status::unknown. Use @ref result_int
- to return the raw status code as a number.
-
- @note This member is only available when `isRequest == false`.
- */
- status
- result() const;
-
- /** Set the response status-code.
-
- @param v The code to set.
-
- @note This member is only available when `isRequest == false`.
- */
- void
- result(status v);
-
- /** Set the response status-code as an integer.
-
- This sets the status code to the exact number passed in.
- If the number does not correspond to one of the known
- status codes, the function @ref result will return
- @ref status::unknown. Use @ref result_int to obtain the
- original raw status-code.
-
- @param v The status-code integer to set.
-
- @throws std::invalid_argument if `v > 999`.
- */
- void
- result(unsigned v);
-
- /** The response status-code expressed as an integer.
-
- This returns the raw status code as an integer, even
- when that code is not in the list of known status codes.
-
- @note This member is only available when `isRequest == false`.
- */
- unsigned
- result_int() const;
-
- /** Return the response reason-phrase.
-
- The reason-phrase is obsolete as of rfc7230.
-
- @note This function is only available when `isRequest == false`.
- */
- string_view
- reason() const;
-
- /** Set the response reason-phrase (deprecated)
-
- This function sets a custom reason-phrase to a copy of
- the string passed in. Normally it is not necessary to set
- the reason phrase on an outgoing response object; the
- implementation will automatically use the standard reason
- text for the corresponding status code.
-
- To clear a previously set custom phrase, pass an empty
- string. This will restore the default standard reason text
- based on the status code used when serializing.
-
- The reason-phrase is obsolete as of rfc7230.
-
- @param s The string to use for the reason-phrase.
-
- @note This function is only available when `isRequest == false`.
- */
- void
- reason(string_view s);
-
-private:
-#if ! BOOST_BEAST_DOXYGEN
- template<bool, class, class>
- friend struct message;
-
- template<class T>
- friend
- void
- swap(header<false, T>& m1, header<false, T>& m2);
-
- template<class... FieldsArgs>
- header(
- status result,
- unsigned version_value,
- FieldsArgs&&... fields_args)
- : Fields(std::forward<FieldsArgs>(fields_args)...)
- , result_(result)
- {
- version(version_value);
- }
-
- unsigned version_ = 11;
- status result_ = status::ok;
-#endif
-};
-
-/// A typical HTTP request header
-template<class Fields = fields>
-using request_header = header<true, Fields>;
-
-/// A typical HTTP response header
-template<class Fields = fields>
-using response_header = header<false, Fields>;
-
-#if defined(BOOST_MSVC)
-// Workaround for MSVC bug with private base classes
-namespace detail {
-template<class T>
-using value_type_t = typename T::value_type;
-} // detail
-#endif
-
-/** A container for a complete HTTP message.
-
- This container is derived from the `Fields` template type.
- To understand all of the members of this class it is necessary
- to view the declaration for the `Fields` type. When using
- the default fields container, those declarations are in
- @ref fields.
-
- A message can be a request or response, depending on the
- `isRequest` template argument value. Requests and responses
- have different types; functions may be overloaded based on
- the type if desired.
-
- The `Body` template argument type determines the model used
- to read or write the content body of the message.
-
- Newly constructed messages objects have version set to
- HTTP/1.1. Newly constructed response objects also have
- result code set to @ref status::ok.
-
- @tparam isRequest `true` if this represents a request,
- or `false` if this represents a response. Some class data
- members are conditionally present depending on this value.
-
- @tparam Body A type meeting the requirements of Body.
-
- @tparam Fields The type of container used to hold the
- field value pairs.
-*/
-template<bool isRequest, class Body, class Fields = fields>
-struct message
- : header<isRequest, Fields>
-#if ! BOOST_BEAST_DOXYGEN
- , beast::detail::empty_base_optimization<
- typename Body::value_type>
-#endif
-{
- /// The base class used to hold the header portion of the message.
- using header_type = header<isRequest, Fields>;
-
- /** The type providing the body traits.
-
- The @ref message::body member will be of type `body_type::value_type`.
- */
- using body_type = Body;
-
- /// Constructor
- message() = default;
-
- /// Constructor
- message(message&&) = default;
-
- /// Constructor
- message(message const&) = default;
-
- /// Assignment
- message& operator=(message&&) = default;
-
- /// Assignment
- message& operator=(message const&) = default;
-
- /** Constructor
-
- @param h The header to move construct from.
-
- @param body_args Optional arguments forwarded
- to the `body` constructor.
- */
- template<class... BodyArgs>
- explicit
- message(header_type&& h, BodyArgs&&... body_args);
-
- /** Constructor.
-
- @param h The header to copy construct from.
-
- @param body_args Optional arguments forwarded
- to the `body` constructor.
- */
- template<class... BodyArgs>
- explicit
- message(header_type const& h, BodyArgs&&... body_args);
-
- /** Constructor
-
- @param method The request-method to use
-
- @param target The request-target.
-
- @param version The HTTP-version
-
- @note This function is only available when `isRequest == true`.
- */
-#if BOOST_BEAST_DOXYGEN
- message(verb method, string_view target, unsigned version);
-#else
- template<class Version,
- class = typename std::enable_if<isRequest &&
- std::is_convertible<Version, unsigned>::value>::type>
- message(verb method, string_view target, Version version);
-#endif
-
- /** Constructor
-
- @param method The request-method to use
-
- @param target The request-target.
-
- @param version The HTTP-version
-
- @param body_arg An argument forwarded to the `body` constructor.
-
- @note This function is only available when `isRequest == true`.
- */
-#if BOOST_BEAST_DOXYGEN
- template<class BodyArg>
- message(verb method, string_view target,
- unsigned version, BodyArg&& body_arg);
-#else
- template<class Version, class BodyArg,
- class = typename std::enable_if<isRequest &&
- std::is_convertible<Version, unsigned>::value>::type>
- message(verb method, string_view target,
- Version version, BodyArg&& body_arg);
-#endif
-
- /** Constructor
-
- @param method The request-method to use
-
- @param target The request-target.
-
- @param version The HTTP-version
-
- @param body_arg An argument forwarded to the `body` constructor.
-
- @param fields_arg An argument forwarded to the `Fields` constructor.
-
- @note This function is only available when `isRequest == true`.
- */
-#if BOOST_BEAST_DOXYGEN
- template<class BodyArg, class FieldsArg>
- message(verb method, string_view target, unsigned version,
- BodyArg&& body_arg, FieldsArg&& fields_arg);
-#else
- template<class Version, class BodyArg, class FieldsArg,
- class = typename std::enable_if<isRequest &&
- std::is_convertible<Version, unsigned>::value>::type>
- message(verb method, string_view target, Version version,
- BodyArg&& body_arg, FieldsArg&& fields_arg);
-#endif
-
- /** Constructor
-
- @param result The status-code for the response
-
- @param version The HTTP-version
-
- @note This member is only available when `isRequest == false`.
- */
-#if BOOST_BEAST_DOXYGEN
- message(status result, unsigned version);
-#else
- template<class Version,
- class = typename std::enable_if<! isRequest &&
- std::is_convertible<Version, unsigned>::value>::type>
- message(status result, Version version);
-#endif
-
- /** Constructor
-
- @param result The status-code for the response
-
- @param version The HTTP-version
-
- @param body_arg An argument forwarded to the `body` constructor.
-
- @note This member is only available when `isRequest == false`.
- */
-#if BOOST_BEAST_DOXYGEN
- template<class BodyArg>
- message(status result, unsigned version, BodyArg&& body_arg);
-#else
- template<class Version, class BodyArg,
- class = typename std::enable_if<! isRequest &&
- std::is_convertible<Version, unsigned>::value>::type>
- message(status result, Version version, BodyArg&& body_arg);
-#endif
-
- /** Constructor
-
- @param result The status-code for the response
-
- @param version The HTTP-version
-
- @param body_arg An argument forwarded to the `body` constructor.
-
- @param fields_arg An argument forwarded to the `Fields` base class constructor.
-
- @note This member is only available when `isRequest == false`.
- */
-#if BOOST_BEAST_DOXYGEN
- template<class BodyArg, class FieldsArg>
- message(status result, unsigned version,
- BodyArg&& body_arg, FieldsArg&& fields_arg);
-#else
- template<class Version, class BodyArg, class FieldsArg,
- class = typename std::enable_if<! isRequest &&
- std::is_convertible<Version, unsigned>::value>::type>
- message(status result, Version version,
- BodyArg&& body_arg, FieldsArg&& fields_arg);
-#endif
-
- /** Constructor
-
- The header and body are default-constructed.
- */
- explicit
- message(std::piecewise_construct_t);
-
- /** Construct a message.
-
- @param body_args A tuple forwarded as a parameter
- pack to the body constructor.
- */
- template<class... BodyArgs>
- message(std::piecewise_construct_t,
- std::tuple<BodyArgs...> body_args);
-
- /** Construct a message.
-
- @param body_args A tuple forwarded as a parameter
- pack to the body constructor.
-
- @param fields_args A tuple forwarded as a parameter
- pack to the `Fields` constructor.
- */
- template<class... BodyArgs, class... FieldsArgs>
- message(std::piecewise_construct_t,
- std::tuple<BodyArgs...> body_args,
- std::tuple<FieldsArgs...> fields_args);
-
- /// Returns the header portion of the message
- header_type const&
- base() const
- {
- return *this;
- }
-
- /// Returns the header portion of the message
- header_type&
- base()
- {
- return *this;
- }
-
- /// Returns `true` if the chunked Transfer-Encoding is specified
- bool
- chunked() const
- {
- return this->get_chunked_impl();
- }
-
- /** Set or clear the chunked Transfer-Encoding
-
- This function will set or removed the "chunked" transfer
- encoding as the last item in the list of encodings in the
- field.
-
- If the result of removing the chunked token results in an
- empty string, the field is erased.
-
- The Content-Length field is erased unconditionally.
- */
- void
- chunked(bool value);
-
- /** Returns `true` if the Content-Length field is present.
-
- This function inspects the fields and returns `true` if
- the Content-Length field is present. The properties of the
- body are not checked, this only looks for the field.
- */
- bool
- has_content_length() const
- {
- return this->has_content_length_impl();
- }
-
- /** Set or clear the Content-Length field
-
- This function adjusts the Content-Length field as follows:
-
- @li If `value` specifies a value, the Content-Length field
- is set to the value. Otherwise
-
- @li The Content-Length field is erased.
-
- If "chunked" token appears as the last item in the
- Transfer-Encoding field it is unconditionally removed.
-
- @param value The value to set for Content-Length.
- */
- void
- content_length(boost::optional<std::uint64_t> const& value);
-
- /** Returns `true` if the message semantics indicate keep-alive
-
- The value depends on the version in the message, which must
- be set to the final value before this function is called or
- else the return value is unreliable.
- */
- bool
- keep_alive() const
- {
- return this->get_keep_alive_impl(this->version());
- }
-
- /** Set the keep-alive message semantic option
-
- This function adjusts the Connection field to indicate
- whether or not the connection should be kept open after
- the corresponding response. The result depends on the
- version set on the message, which must be set to the
- final value before making this call.
-
- @param value `true` if the connection should persist.
- */
- void
- keep_alive(bool value)
- {
- this->set_keep_alive_impl(this->version(), value);
- }
-
- /** Returns `true` if the message semantics require an end of file.
-
- For HTTP requests, this function returns the logical
- NOT of a call to @ref keep_alive.
-
- For HTTP responses, this function returns the logical NOT
- of a call to @ref keep_alive if any of the following are true:
-
- @li @ref has_content_length would return `true`
-
- @li @ref chunked would return `true`
-
- @li @ref result returns @ref status::no_content
-
- @li @ref result returns @ref status::not_modified
-
- @li @ref result returns any informational status class (100 to 199)
-
- Otherwise, the function returns `true`.
-
- @see https://tools.ietf.org/html/rfc7230#section-3.3
- */
- bool
- need_eof() const
- {
- return need_eof(typename header_type::is_request{});
- }
-
- /** Returns the payload size of the body in octets if possible.
-
- This function invokes the @b Body algorithm to measure
- the number of octets in the serialized body container. If
- there is no body, this will return zero. Otherwise, if the
- body exists but is not known ahead of time, `boost::none`
- is returned (usually indicating that a chunked Transfer-Encoding
- will be used).
-
- @note The value of the Content-Length field in the message
- is not inspected.
- */
- boost::optional<std::uint64_t>
- payload_size() const;
-
- /** Prepare the message payload fields for the body.
-
- This function will adjust the Content-Length and
- Transfer-Encoding field values based on the properties
- of the body.
-
- @par Example
- @code
- request<string_body> req{verb::post, "/"};
- req.set(field::user_agent, "Beast");
- req.body() = "Hello, world!";
- req.prepare_payload();
- @endcode
- */
- void
- prepare_payload()
- {
- prepare_payload(typename header_type::is_request{});
- }
-
- /// Returns the body
-#if BOOST_BEAST_DOXYGEN || ! defined(BOOST_MSVC)
- typename body_type::value_type&
-#else
- detail::value_type_t<Body>&
-#endif
- body()& noexcept
- {
- return this->beast::detail::empty_base_optimization<
- typename Body::value_type>::member();
- }
-
- /// Returns the body
-#if BOOST_BEAST_DOXYGEN || ! defined(BOOST_MSVC)
- typename body_type::value_type&&
-#else
- detail::value_type_t<Body>&&
-#endif
- body()&& noexcept
- {
- return std::move(
- this->beast::detail::empty_base_optimization<
- typename Body::value_type>::member());
- }
-
- /// Returns the body
-#if BOOST_BEAST_DOXYGEN || ! defined(BOOST_MSVC)
- typename body_type::value_type const&
-#else
- detail::value_type_t<Body> const&
-#endif
- body() const& noexcept
- {
- return this->beast::detail::empty_base_optimization<
- typename Body::value_type>::member();
- }
-
-private:
- static_assert(is_body<Body>::value,
- "Body requirements not met");
-
- template<
- class... BodyArgs,
- std::size_t... IBodyArgs>
- message(
- std::piecewise_construct_t,
- std::tuple<BodyArgs...>& body_args,
- beast::detail::index_sequence<IBodyArgs...>)
- : beast::detail::empty_base_optimization<
- typename Body::value_type>(
- std::forward<BodyArgs>(
- std::get<IBodyArgs>(body_args))...)
- {
- boost::ignore_unused(body_args);
- }
-
- template<
- class... BodyArgs,
- class... FieldsArgs,
- std::size_t... IBodyArgs,
- std::size_t... IFieldsArgs>
- message(
- std::piecewise_construct_t,
- std::tuple<BodyArgs...>& body_args,
- std::tuple<FieldsArgs...>& fields_args,
- beast::detail::index_sequence<IBodyArgs...>,
- beast::detail::index_sequence<IFieldsArgs...>)
- : header_type(std::forward<FieldsArgs>(
- std::get<IFieldsArgs>(fields_args))...)
- , beast::detail::empty_base_optimization<
- typename Body::value_type>(
- std::forward<BodyArgs>(
- std::get<IBodyArgs>(body_args))...)
- {
- boost::ignore_unused(body_args);
- boost::ignore_unused(fields_args);
- }
-
- bool
- need_eof(std::true_type) const
- {
- return ! keep_alive();
- }
-
- bool
- need_eof(std::false_type) const;
-
- boost::optional<std::uint64_t>
- payload_size(std::true_type) const
- {
- return Body::size(this->body());
- }
-
- boost::optional<std::uint64_t>
- payload_size(std::false_type) const
- {
- return boost::none;
- }
-
- void
- prepare_payload(std::true_type);
-
- void
- prepare_payload(std::false_type);
-};
-
-/// A typical HTTP request
-template<class Body, class Fields = fields>
-using request = message<true, Body, Fields>;
-
-/// A typical HTTP response
-template<class Body, class Fields = fields>
-using response = message<false, Body, Fields>;
-
-//------------------------------------------------------------------------------
-
-#if BOOST_BEAST_DOXYGEN
-/** Swap two header objects.
-
- @par Requirements
- `Fields` is @b Swappable.
-*/
-template<bool isRequest, class Fields>
-void
-swap(
- header<isRequest, Fields>& m1,
- header<isRequest, Fields>& m2);
-#endif
-
-/** Swap two message objects.
-
- @par Requirements:
- `Body::value_type` and `Fields` are @b Swappable.
-*/
-template<bool isRequest, class Body, class Fields>
-void
-swap(
- message<isRequest, Body, Fields>& m1,
- message<isRequest, Body, Fields>& m2);
-
-} // http
-} // beast
-} // boost
-
-#include <boost/beast/http/impl/message.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/parser.hpp b/contrib/restricted/boost/boost/beast/http/parser.hpp
deleted file mode 100644
index 69d93cf03c..0000000000
--- a/contrib/restricted/boost/boost/beast/http/parser.hpp
+++ /dev/null
@@ -1,465 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_PARSER_HPP
-#define BOOST_BEAST_HTTP_PARSER_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/http/basic_parser.hpp>
-#include <boost/beast/http/message.hpp>
-#include <boost/beast/http/type_traits.hpp>
-#include <boost/optional.hpp>
-#include <boost/throw_exception.hpp>
-#include <functional>
-#include <memory>
-#include <type_traits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** An HTTP/1 parser for producing a message.
-
- This class uses the basic HTTP/1 wire format parser to convert
- a series of octets into a @ref message using the @ref basic_fields
- container to represent the fields.
-
- @tparam isRequest Indicates whether a request or response
- will be parsed.
-
- @tparam Body The type used to represent the body. This must
- meet the requirements of @b Body.
-
- @tparam Allocator The type of allocator used with the
- @ref basic_fields container.
-
- @note A new instance of the parser is required for each message.
-*/
-template<
- bool isRequest,
- class Body,
- class Allocator = std::allocator<char>>
-class parser
- : public basic_parser<isRequest,
- parser<isRequest, Body, Allocator>>
-{
- static_assert(is_body<Body>::value,
- "Body requirements not met");
-
- static_assert(is_body_reader<Body>::value,
- "BodyReader requirements not met");
-
- template<bool, class, class>
- friend class parser;
-
- using base_type = basic_parser<isRequest,
- parser<isRequest, Body, Allocator>>;
-
- message<isRequest, Body, basic_fields<Allocator>> m_;
- typename Body::reader rd_;
- bool rd_inited_ = false;
-
- std::function<void(
- std::uint64_t,
- string_view,
- error_code&)> cb_h_;
-
- std::function<std::size_t(
- std::uint64_t,
- string_view,
- error_code&)> cb_b_;
-
-public:
- /// The type of message returned by the parser
- using value_type =
- message<isRequest, Body, basic_fields<Allocator>>;
-
- /// Destructor
- ~parser() = default;
-
- /// Constructor (disallowed)
- parser(parser const&) = delete;
-
- /// Assignment (disallowed)
- parser& operator=(parser const&) = delete;
-
- /// Constructor (disallowed)
- parser(parser&& other) = delete;
-
- /// Constructor
- parser();
-
- /** Constructor
-
- @param args Optional arguments forwarded to the
- @ref http::header constructor.
-
- @note This function participates in overload
- resolution only if the first argument is not a
- @ref parser.
- */
-#if BOOST_BEAST_DOXYGEN
- template<class... Args>
- explicit
- parser(Args&&... args);
-#else
- template<class Arg1, class... ArgN,
- class = typename std::enable_if<
- ! detail::is_parser<typename
- std::decay<Arg1>::type>::value>::type>
- explicit
- parser(Arg1&& arg1, ArgN&&... argn);
-#endif
-
- /** Construct a parser from another parser, changing the Body type.
-
- This constructs a new parser by move constructing the
- header from another parser with a different body type. The
- constructed-from parser must not have any parsed body octets or
- initialized @b BodyReader, otherwise an exception is generated.
-
- @par Example
- @code
- // Deferred body type commitment
- request_parser<empty_body> req0;
- ...
- request_parser<string_body> req{std::move(req0)};
- @endcode
-
- If an exception is thrown, the state of the constructed-from
- parser is undefined.
-
- @param parser The other parser to construct from. After
- this call returns, the constructed-from parser may only
- be destroyed.
-
- @param args Optional arguments forwarded to the message
- constructor.
-
- @throws std::invalid_argument Thrown when the constructed-from
- parser has already initialized a body reader.
-
- @note This function participates in overload resolution only
- if the other parser uses a different body type.
- */
-#if BOOST_BEAST_DOXYGEN
- template<class OtherBody, class... Args>
-#else
- template<class OtherBody, class... Args,
- class = typename std::enable_if<
- ! std::is_same<Body, OtherBody>::value>::type>
-#endif
- explicit
- parser(parser<isRequest, OtherBody,
- Allocator>&& parser, Args&&... args);
-
- /** Returns the parsed message.
-
- Depending on the parser's progress,
- parts of this object may be incomplete.
- */
- value_type const&
- get() const
- {
- return m_;
- }
-
- /** Returns the parsed message.
-
- Depending on the parser's progress,
- parts of this object may be incomplete.
- */
- value_type&
- get()
- {
- return m_;
- }
-
- /** Returns ownership of the parsed message.
-
- Ownership is transferred to the caller.
- Depending on the parser's progress,
- parts of this object may be incomplete.
-
- @par Requires
-
- @ref value_type is @b MoveConstructible
- */
- value_type
- release()
- {
- static_assert(std::is_move_constructible<decltype(m_)>::value,
- "MoveConstructible requirements not met");
- return std::move(m_);
- }
-
- /** Set a callback to be invoked on each chunk header.
-
- The callback will be invoked once for every chunk in the message
- payload, as well as once for the last chunk. The invocation
- happens after the chunk header is available but before any body
- octets have been parsed.
-
- The extensions are provided in raw, validated form, use
- @ref chunk_extensions::parse to parse the extensions into a
- structured container for easier access.
- The implementation type-erases the callback without requiring
- a dynamic allocation. For this reason, the callback object is
- passed by a non-constant reference.
-
- @par Example
- @code
- auto callback =
- [](std::uint64_t size, string_view extensions, error_code& ec)
- {
- //...
- };
- parser.on_chunk_header(callback);
- @endcode
-
- @param cb The function to set, which must be invocable with
- this equivalent signature:
- @code
- void
- on_chunk_header(
- std::uint64_t size, // Size of the chunk, zero for the last chunk
- string_view extensions, // The chunk-extensions in raw form
- error_code& ec); // May be set by the callback to indicate an error
- @endcode
- */
- template<class Callback>
- void
- on_chunk_header(Callback& cb)
- {
- // Callback may not be constant, caller is responsible for
- // managing the lifetime of the callback. Copies are not made.
- BOOST_STATIC_ASSERT(! std::is_const<Callback>::value);
-
- // Can't set the callback after receiving any chunk data!
- BOOST_ASSERT(! rd_inited_);
-
- cb_h_ = std::ref(cb);
- }
-
- /** Set a callback to be invoked on chunk body data
-
- The provided function object will be invoked one or more times
- to provide buffers corresponding to the chunk body for the current
- chunk. The callback receives the number of octets remaining in this
- chunk body including the octets in the buffer provided.
-
- The callback must return the number of octets actually consumed.
- Any octets not consumed will be presented again in a subsequent
- invocation of the callback.
- The implementation type-erases the callback without requiring
- a dynamic allocation. For this reason, the callback object is
- passed by a non-constant reference.
-
- @par Example
- @code
- auto callback =
- [](std::uint64_t remain, string_view body, error_code& ec)
- {
- //...
- };
- parser.on_chunk_body(callback);
- @endcode
-
- @param cb The function to set, which must be invocable with
- this equivalent signature:
- @code
- std::size_t
- on_chunk_header(
- std::uint64_t remain, // Octets remaining in this chunk, includes `body`
- string_view body, // A buffer holding some or all of the remainder of the chunk body
- error_code& ec); // May be set by the callback to indicate an error
- @endcode
- */
- template<class Callback>
- void
- on_chunk_body(Callback& cb)
- {
- // Callback may not be constant, caller is responsible for
- // managing the lifetime of the callback. Copies are not made.
- BOOST_STATIC_ASSERT(! std::is_const<Callback>::value);
-
- // Can't set the callback after receiving any chunk data!
- BOOST_ASSERT(! rd_inited_);
-
- cb_b_ = std::ref(cb);
- }
-
-private:
- friend class basic_parser<isRequest, parser>;
-
- parser(std::true_type);
- parser(std::false_type);
-
- template<class OtherBody, class... Args,
- class = typename std::enable_if<
- ! std::is_same<Body, OtherBody>::value>::type>
- parser(
- std::true_type,
- parser<isRequest, OtherBody, Allocator>&& parser,
- Args&&... args);
-
- template<class OtherBody, class... Args,
- class = typename std::enable_if<
- ! std::is_same<Body, OtherBody>::value>::type>
- parser(
- std::false_type,
- parser<isRequest, OtherBody, Allocator>&& parser,
- Args&&... args);
-
- template<class Arg1, class... ArgN,
- class = typename std::enable_if<
- ! detail::is_parser<typename
- std::decay<Arg1>::type>::value>::type>
- explicit
- parser(Arg1&& arg1, std::true_type, ArgN&&... argn);
-
- template<class Arg1, class... ArgN,
- class = typename std::enable_if<
- ! detail::is_parser<typename
- std::decay<Arg1>::type>::value>::type>
- explicit
- parser(Arg1&& arg1, std::false_type, ArgN&&... argn);
-
- void
- on_request_impl(
- verb method,
- string_view method_str,
- string_view target,
- int version,
- error_code& ec)
- {
- try
- {
- m_.target(target);
- if(method != verb::unknown)
- m_.method(method);
- else
- m_.method_string(method_str);
- ec.assign(0, ec.category());
- }
- catch(std::bad_alloc const&)
- {
- ec = error::bad_alloc;
- }
- m_.version(version);
- }
-
- void
- on_response_impl(
- int code,
- string_view reason,
- int version,
- error_code& ec)
- {
- m_.result(code);
- m_.version(version);
- try
- {
- m_.reason(reason);
- ec.assign(0, ec.category());
- }
- catch(std::bad_alloc const&)
- {
- ec = error::bad_alloc;
- }
- }
-
- void
- on_field_impl(
- field name,
- string_view name_string,
- string_view value,
- error_code& ec)
- {
- try
- {
- m_.insert(name, name_string, value);
- ec.assign(0, ec.category());
- }
- catch(std::bad_alloc const&)
- {
- ec = error::bad_alloc;
- }
- }
-
- void
- on_header_impl(error_code& ec)
- {
- ec.assign(0, ec.category());
- }
-
- void
- on_body_init_impl(
- boost::optional<std::uint64_t> const& content_length,
- error_code& ec)
- {
- rd_.init(content_length, ec);
- rd_inited_ = true;
- }
-
- std::size_t
- on_body_impl(
- string_view body,
- error_code& ec)
- {
- return rd_.put(boost::asio::buffer(
- body.data(), body.size()), ec);
- }
-
- void
- on_chunk_header_impl(
- std::uint64_t size,
- string_view extensions,
- error_code& ec)
- {
- if(cb_h_)
- return cb_h_(size, extensions, ec);
- ec.assign(0, ec.category());
- }
-
- std::size_t
- on_chunk_body_impl(
- std::uint64_t remain,
- string_view body,
- error_code& ec)
- {
- if(cb_b_)
- return cb_b_(remain, body, ec);
- return rd_.put(boost::asio::buffer(
- body.data(), body.size()), ec);
- }
-
- void
- on_finish_impl(error_code& ec)
- {
- rd_.finish(ec);
- }
-};
-
-/// An HTTP/1 parser for producing a request message.
-template<class Body, class Allocator = std::allocator<char>>
-using request_parser = parser<true, Body, Allocator>;
-
-/// An HTTP/1 parser for producing a response message.
-template<class Body, class Allocator = std::allocator<char>>
-using response_parser = parser<false, Body, Allocator>;
-
-} // http
-} // beast
-} // boost
-
-#include <boost/beast/http/impl/parser.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/read.hpp b/contrib/restricted/boost/boost/beast/http/read.hpp
deleted file mode 100644
index a4f0efe400..0000000000
--- a/contrib/restricted/boost/boost/beast/http/read.hpp
+++ /dev/null
@@ -1,765 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_READ_HPP
-#define BOOST_BEAST_HTTP_READ_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/http/basic_parser.hpp>
-#include <boost/beast/http/message.hpp>
-#include <boost/asio/async_result.hpp>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** Read part of a message from a stream using a parser.
-
- This function is used to read part of a message from a stream into a
- subclass of @ref basic_parser.
- The call will block until one of the following conditions is true:
-
- @li A call to @ref basic_parser::put with a non-empty buffer sequence
- is successful.
-
- @li An error occurs.
-
- This operation is implemented in terms of one or
- more calls to the stream's `read_some` function.
- The implementation may read additional octets that lie past the
- end of the message being read. This additional data is stored
- in the dynamic buffer, which must be retained for subsequent reads.
-
- If the stream returns the error `boost::asio::error::eof` indicating the
- end of file during a read, the error returned from this function will be:
-
- @li @ref error::end_of_stream if no octets were parsed, or
-
- @li @ref error::partial_message if any octets were parsed but the
- message was incomplete, otherwise:
-
- @li A successful result. A subsequent attempt to read will
- return @ref error::end_of_stream
-
- @param stream The stream from which the data is to be read.
- The type must support the @b SyncReadStream concept.
-
- @param buffer A @b DynamicBuffer holding additional bytes
- read by the implementation from the stream. This is both
- an input and an output parameter; on entry, any data in the
- dynamic buffer's input sequence will be given to the parser
- first.
-
- @param parser The parser to use.
-
- @return The number of bytes transferred to the parser.
-
- @throws system_error Thrown on failure.
-*/
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived>
-std::size_t
-read_some(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser);
-
-/** Read part of a message from a stream using a parser.
-
- This function is used to read part of a message from a stream into a
- subclass of @ref basic_parser.
- The call will block until one of the following conditions is true:
-
- @li A call to @ref basic_parser::put with a non-empty buffer sequence
- is successful.
-
- @li An error occurs.
-
- This operation is implemented in terms of one or
- more calls to the stream's `read_some` function.
- The implementation may read additional octets that lie past the
- end of the message being read. This additional data is stored
- in the dynamic buffer, which must be retained for subsequent reads.
-
- If the stream returns the error `boost::asio::error::eof` indicating the
- end of file during a read, the error returned from this function will be:
-
- @li @ref error::end_of_stream if no octets were parsed, or
-
- @li @ref error::partial_message if any octets were parsed but the
- message was incomplete, otherwise:
-
- @li A successful result. A subsequent attempt to read will
- return @ref error::end_of_stream
-
- The function returns the number of bytes processed from the dynamic
- buffer. The caller should remove these bytes by calling `consume` on
- the dynamic buffer, regardless of any error.
-
- @param stream The stream from which the data is to be read.
- The type must support the @b SyncReadStream concept.
-
- @param buffer A @b DynamicBuffer holding additional bytes
- read by the implementation from the stream. This is both
- an input and an output parameter; on entry, any data in the
- dynamic buffer's input sequence will be given to the parser
- first.
-
- @param parser The parser to use.
-
- @param ec Set to the error, if any occurred.
-
- @return The number of bytes transferred to the parser.
-*/
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived>
-std::size_t
-read_some(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser,
- error_code& ec);
-
-/** Read part of a message asynchronously from a stream using a parser.
-
- This function is used to asynchronously read part of a message from
- a stream into a subclass of @ref basic_parser.
- The function call always returns immediately. The asynchronous operation
- will continue until one of the following conditions is true:
-
- @li A call to @ref basic_parser::put with a non-empty buffer sequence
- is successful.
-
- @li An error occurs.
-
- This operation is implemented in terms of zero or more calls to
- the next layer's `async_read_some` function, and is known as a
- <em>composed operation</em>. The program must ensure that the
- stream performs no other reads until this operation completes.
- The implementation may read additional octets that lie past the
- end of the object being parsed. This additional data is stored
- in the stream buffer, which may be used in subsequent calls.
-
- If the stream returns the error `boost::asio::error::eof` indicating the
- end of file during a read, the error returned from this function will be:
-
- @li @ref error::end_of_stream if no octets were parsed, or
-
- @li @ref error::partial_message if any octets were parsed but the
- message was incomplete, otherwise:
-
- @li A successful result. A subsequent attempt to read will
- return @ref error::end_of_stream
-
- @param stream The stream from which the data is to be read.
- The type must support the @b AsyncReadStream concept.
-
- @param buffer A @b DynamicBuffer holding additional bytes
- read by the implementation from the stream. This is both
- an input and an output parameter; on entry, any data in the
- dynamic buffer's input sequence will be given to the parser
- first.
-
- @param parser The parser to use.
- The object must remain valid at least until the
- handler is called; ownership is not transferred.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& error, // result of operation
- std::size_t bytes_transferred // the number of bytes transferred to the parser
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
-
- The completion handler will receive as a parameter the number
- of octets processed from the dynamic buffer. The octets should
- be removed by calling `consume` on the dynamic buffer after
- the read completes, regardless of any error.
-*/
-template<
- class AsyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived,
- class ReadHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
-async_read_some(
- AsyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser,
- ReadHandler&& handler);
-
-//------------------------------------------------------------------------------
-
-/** Read a header from a stream using a parser.
-
- This function is used to read a header from a stream into a subclass
- of @ref basic_parser.
- The call will block until one of the following conditions is true:
-
- @li @ref basic_parser::is_header_done returns `true`
-
- @li An error occurs.
-
- This operation is implemented in terms of one or
- more calls to the stream's `read_some` function.
- The implementation may read additional octets that lie past the
- end of the message being read. This additional data is stored
- in the dynamic buffer, which must be retained for subsequent reads.
-
- If the stream returns the error `boost::asio::error::eof` indicating the
- end of file during a read, the error returned from this function will be:
-
- @li @ref error::end_of_stream if no octets were parsed, or
-
- @li @ref error::partial_message if any octets were parsed but the
- message was incomplete, otherwise:
-
- @li A successful result. A subsequent attempt to read will
- return @ref error::end_of_stream
-
- @param stream The stream from which the data is to be read.
- The type must support the @b SyncReadStream concept.
-
- @param buffer A @b DynamicBuffer holding additional bytes
- read by the implementation from the stream. This is both
- an input and an output parameter; on entry, any data in the
- dynamic buffer's input sequence will be given to the parser
- first.
-
- @param parser The parser to use.
-
- @return The number of bytes transferred to the parser.
-
- @throws system_error Thrown on failure.
-
- @note The implementation will call @ref basic_parser::eager
- with the value `false` on the parser passed in.
-*/
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived>
-std::size_t
-read_header(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser);
-
-/** Read a header from a stream using a parser.
-
- This function is used to read a header from a stream into a subclass
- of @ref basic_parser.
- The call will block until one of the following conditions is true:
-
- @li @ref basic_parser::is_header_done returns `true`
-
- @li An error occurs.
-
- This operation is implemented in terms of one or
- more calls to the stream's `read_some` function.
- The implementation may read additional octets that lie past the
- end of the message being read. This additional data is stored
- in the dynamic buffer, which must be retained for subsequent reads.
-
- If the stream returns the error `boost::asio::error::eof` indicating the
- end of file during a read, the error returned from this function will be:
-
- @li @ref error::end_of_stream if no octets were parsed, or
-
- @li @ref error::partial_message if any octets were parsed but the
- message was incomplete, otherwise:
-
- @li A successful result. A subsequent attempt to read will
- return @ref error::end_of_stream
-
- @param stream The stream from which the data is to be read.
- The type must support the @b SyncReadStream concept.
-
- @param buffer A @b DynamicBuffer holding additional bytes
- read by the implementation from the stream. This is both
- an input and an output parameter; on entry, any data in the
- dynamic buffer's input sequence will be given to the parser
- first.
-
- @param parser The parser to use.
-
- @param ec Set to the error, if any occurred.
-
- @return The number of bytes transferred to the parser.
-
- @note The implementation will call @ref basic_parser::eager
- with the value `false` on the parser passed in.
-*/
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived>
-std::size_t
-read_header(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser,
- error_code& ec);
-
-/** Read a header from a stream asynchronously using a parser.
-
- This function is used to asynchronously read a header from a stream
- into a subclass of @ref basic_parser.
- The function call always returns immediately. The asynchronous operation
- will continue until one of the following conditions is true:
-
- @li @ref basic_parser::is_header_done returns `true`
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls to
- the stream's `async_read_some` function, and is known as a
- <em>composed operation</em>. The program must ensure that the
- stream performs no other reads until this operation completes.
- The implementation may read additional octets that lie past the
- end of the message being read. This additional data is stored
- in the dynamic buffer, which must be retained for subsequent reads.
-
- If the stream returns the error `boost::asio::error::eof` indicating the
- end of file during a read, the error returned from this function will be:
-
- @li @ref error::end_of_stream if no octets were parsed, or
-
- @li @ref error::partial_message if any octets were parsed but the
- message was incomplete, otherwise:
-
- @li A successful result. A subsequent attempt to read will
- return @ref error::end_of_stream
-
- @param stream The stream from which the data is to be read.
- The type must support the @b AsyncReadStream concept.
-
- @param buffer A @b DynamicBuffer holding additional bytes
- read by the implementation from the stream. This is both
- an input and an output parameter; on entry, any data in the
- dynamic buffer's input sequence will be given to the parser
- first.
-
- @param parser The parser to use.
- The object must remain valid at least until the
- handler is called; ownership is not transferred.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& error, // result of operation,
- std::size_t bytes_transferred // the number of bytes transferred to the parser
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
-
- @note The implementation will call @ref basic_parser::eager
- with the value `false` on the parser passed in.
-*/
-template<
- class AsyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived,
- class ReadHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
-async_read_header(
- AsyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser,
- ReadHandler&& handler);
-
-//------------------------------------------------------------------------------
-
-/** Read a complete message from a stream using a parser.
-
- This function is used to read a complete message from a stream into a
- subclass of @ref basic_parser.
- The call will block until one of the following conditions is true:
-
- @li @ref basic_parser::is_done returns `true`
-
- @li An error occurs.
-
- This operation is implemented in terms of one or
- more calls to the stream's `read_some` function.
- The implementation may read additional octets that lie past the
- end of the message being read. This additional data is stored
- in the dynamic buffer, which must be retained for subsequent reads.
-
- If the stream returns the error `boost::asio::error::eof` indicating the
- end of file during a read, the error returned from this function will be:
-
- @li @ref error::end_of_stream if no octets were parsed, or
-
- @li @ref error::partial_message if any octets were parsed but the
- message was incomplete, otherwise:
-
- @li A successful result. A subsequent attempt to read will
- return @ref error::end_of_stream
-
- @param stream The stream from which the data is to be read.
- The type must support the @b SyncReadStream concept.
-
- @param buffer A @b DynamicBuffer holding additional bytes
- read by the implementation from the stream. This is both
- an input and an output parameter; on entry, any data in the
- dynamic buffer's input sequence will be given to the parser
- first.
-
- @param parser The parser to use.
-
- @return The number of bytes transferred to the parser.
-
- @throws system_error Thrown on failure.
-
- @note The implementation will call @ref basic_parser::eager
- with the value `true` on the parser passed in.
-*/
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived>
-std::size_t
-read(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser);
-
-/** Read a complete message from a stream using a parser.
-
- This function is used to read a complete message from a stream into a
- subclass of @ref basic_parser.
- The call will block until one of the following conditions is true:
-
- @li @ref basic_parser::is_done returns `true`
-
- @li An error occurs.
-
- This operation is implemented in terms of one or
- more calls to the stream's `read_some` function.
- The implementation may read additional octets that lie past the
- end of the message being read. This additional data is stored
- in the dynamic buffer, which must be retained for subsequent reads.
-
- If the stream returns the error `boost::asio::error::eof` indicating the
- end of file during a read, the error returned from this function will be:
-
- @li @ref error::end_of_stream if no octets were parsed, or
-
- @li @ref error::partial_message if any octets were parsed but the
- message was incomplete, otherwise:
-
- @li A successful result. A subsequent attempt to read will
- return @ref error::end_of_stream
-
- @param stream The stream from which the data is to be read.
- The type must support the @b SyncReadStream concept.
-
- @param buffer A @b DynamicBuffer holding additional bytes
- read by the implementation from the stream. This is both
- an input and an output parameter; on entry, any data in the
- dynamic buffer's input sequence will be given to the parser
- first.
-
- @param parser The parser to use.
-
- @param ec Set to the error, if any occurred.
-
- @return The number of bytes transferred to the parser.
-
- @note The implementation will call @ref basic_parser::eager
- with the value `true` on the parser passed in.
-*/
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived>
-std::size_t
-read(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser,
- error_code& ec);
-
-/** Read a complete message from a stream asynchronously using a parser.
-
- This function is used to asynchronously read a complete message from a
- stream into a subclass of @ref basic_parser.
- The function call always returns immediately. The asynchronous operation
- will continue until one of the following conditions is true:
-
- @li @ref basic_parser::is_done returns `true`
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls to
- the stream's `async_read_some` function, and is known as a
- <em>composed operation</em>. The program must ensure that the
- stream performs no other reads until this operation completes.
- The implementation may read additional octets that lie past the
- end of the message being read. This additional data is stored
- in the dynamic buffer, which must be retained for subsequent reads.
-
- If the stream returns the error `boost::asio::error::eof` indicating the
- end of file during a read, the error returned from this function will be:
-
- @li @ref error::end_of_stream if no octets were parsed, or
-
- @li @ref error::partial_message if any octets were parsed but the
- message was incomplete, otherwise:
-
- @li A successful result. A subsequent attempt to read will
- return @ref error::end_of_stream
-
- @param stream The stream from which the data is to be read.
- The type must support the @b AsyncReadStream concept.
-
- @param buffer A @b DynamicBuffer holding additional bytes
- read by the implementation from the stream. This is both
- an input and an output parameter; on entry, any data in the
- dynamic buffer's input sequence will be given to the parser
- first.
-
- @param parser The parser to use.
- The object must remain valid at least until the
- handler is called; ownership is not transferred.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& error, // result of operation,
- std::size_t bytes_transferred // the number of bytes transferred to the parser
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
-
- @note The implementation will call @ref basic_parser::eager
- with the value `true` on the parser passed in.
-*/
-template<
- class AsyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Derived,
- class ReadHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
-async_read(
- AsyncReadStream& stream,
- DynamicBuffer& buffer,
- basic_parser<isRequest, Derived>& parser,
- ReadHandler&& handler);
-
-//------------------------------------------------------------------------------
-
-/** Read a complete message from a stream.
-
- This function is used to read a complete message from a stream using HTTP/1.
- The call will block until one of the following conditions is true:
-
- @li The entire message is read.
-
- @li An error occurs.
-
- This operation is implemented in terms of one or
- more calls to the stream's `read_some` function.
- The implementation may read additional octets that lie past the
- end of the message being read. This additional data is stored
- in the dynamic buffer, which must be retained for subsequent reads.
-
- If the stream returns the error `boost::asio::error::eof` indicating the
- end of file during a read, the error returned from this function will be:
-
- @li @ref error::end_of_stream if no octets were parsed, or
-
- @li @ref error::partial_message if any octets were parsed but the
- message was incomplete, otherwise:
-
- @li A successful result. A subsequent attempt to read will
- return @ref error::end_of_stream
-
- @param stream The stream from which the data is to be read.
- The type must support the @b SyncReadStream concept.
-
- @param buffer A @b DynamicBuffer holding additional bytes
- read by the implementation from the stream. This is both
- an input and an output parameter; on entry, any data in the
- dynamic buffer's input sequence will be given to the parser
- first.
-
- @param msg An object in which to store the message contents.
- This object should not have previous contents, otherwise
- the behavior is undefined.
- The type must be @b MoveAssignable and @b MoveConstructible.
-
- @return The number of bytes transferred to the parser.
-
- @throws system_error Thrown on failure.
-*/
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Body, class Allocator>
-std::size_t
-read(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- message<isRequest, Body, basic_fields<Allocator>>& msg);
-
-/** Read a complete message from a stream.
-
- This function is used to read a complete message from a stream using HTTP/1.
- The call will block until one of the following conditions is true:
-
- @li The entire message is read.
-
- @li An error occurs.
-
- This operation is implemented in terms of one or
- more calls to the stream's `read_some` function.
- The implementation may read additional octets that lie past the
- end of the message being read. This additional data is stored
- in the dynamic buffer, which must be retained for subsequent reads.
-
- If the stream returns the error `boost::asio::error::eof` indicating the
- end of file during a read, the error returned from this function will be:
-
- @li @ref error::end_of_stream if no octets were parsed, or
-
- @li @ref error::partial_message if any octets were parsed but the
- message was incomplete, otherwise:
-
- @li A successful result. A subsequent attempt to read will
- return @ref error::end_of_stream
-
- @param stream The stream from which the data is to be read.
- The type must support the @b SyncReadStream concept.
-
- @param buffer A @b DynamicBuffer holding additional bytes
- read by the implementation from the stream. This is both
- an input and an output parameter; on entry, any data in the
- dynamic buffer's input sequence will be given to the parser
- first.
-
- @param msg An object in which to store the message contents.
- This object should not have previous contents, otherwise
- the behavior is undefined.
- The type must be @b MoveAssignable and @b MoveConstructible.
-
- @param ec Set to the error, if any occurred.
-
- @return The number of bytes transferred to the parser.
-*/
-template<
- class SyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Body, class Allocator>
-std::size_t
-read(
- SyncReadStream& stream,
- DynamicBuffer& buffer,
- message<isRequest, Body, basic_fields<Allocator>>& msg,
- error_code& ec);
-
-/** Read a complete message from a stream asynchronously.
-
- This function is used to asynchronously read a complete message from a
- stream using HTTP/1.
- The function call always returns immediately. The asynchronous operation
- will continue until one of the following conditions is true:
-
- @li The entire message is read.
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls to
- the stream's `async_read_some` function, and is known as a
- <em>composed operation</em>. The program must ensure that the
- stream performs no other reads until this operation completes.
- The implementation may read additional octets that lie past the
- end of the message being read. This additional data is stored
- in the dynamic buffer, which must be retained for subsequent reads.
-
- If the stream returns the error `boost::asio::error::eof` indicating the
- end of file during a read, the error returned from this function will be:
-
- @li @ref error::end_of_stream if no octets were parsed, or
-
- @li @ref error::partial_message if any octets were parsed but the
- message was incomplete, otherwise:
-
- @li A successful result. A subsequent attempt to read will
- return @ref error::end_of_stream
-
- @param stream The stream from which the data is to be read.
- The type must support the @b AsyncReadStream concept.
-
- @param buffer A @b DynamicBuffer holding additional bytes
- read by the implementation from the stream. This is both
- an input and an output parameter; on entry, any data in the
- dynamic buffer's input sequence will be given to the parser
- first.
-
- @param msg An object in which to store the message contents.
- This object should not have previous contents, otherwise
- the behavior is undefined.
- The type must be @b MoveAssignable and @b MoveConstructible.
-
- The object must remain valid at least until the
- handler is called; ownership is not transferred.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& error, // result of operation,
- std::size_t bytes_transferred // the number of bytes transferred to the parser
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
-*/
-template<
- class AsyncReadStream,
- class DynamicBuffer,
- bool isRequest, class Body, class Allocator,
- class ReadHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
-async_read(
- AsyncReadStream& stream,
- DynamicBuffer& buffer,
- message<isRequest, Body, basic_fields<Allocator>>& msg,
- ReadHandler&& handler);
-
-} // http
-} // beast
-} // boost
-
-#include <boost/beast/http/impl/read.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/rfc7230.hpp b/contrib/restricted/boost/boost/beast/http/rfc7230.hpp
deleted file mode 100644
index 952cb929d6..0000000000
--- a/contrib/restricted/boost/boost/beast/http/rfc7230.hpp
+++ /dev/null
@@ -1,329 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_RFC7230_HPP
-#define BOOST_BEAST_HTTP_RFC7230_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/http/detail/rfc7230.hpp>
-#include <boost/beast/http/detail/basic_parsed_list.hpp>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** A list of parameters in an HTTP extension field value.
-
- This container allows iteration of the parameter list in an HTTP
- extension. The parameter list is a series of name/value pairs
- with each pair starting with a semicolon. The value is optional.
-
- If a parsing error is encountered while iterating the string,
- the behavior of the container will be as if a string containing
- only characters up to but excluding the first invalid character
- was used to construct the list.
-
- @par BNF
- @code
- param-list = *( OWS ";" OWS param )
- param = token OWS [ "=" OWS ( token / quoted-string ) ]
- @endcode
-
- To use this class, construct with the string to be parsed and
- then use @ref begin and @ref end, or range-for to iterate each
- item:
-
- @par Example
- @code
- for(auto const& param : param_list{";level=9;no_context_takeover;bits=15"})
- {
- std::cout << ";" << param.first;
- if(! param.second.empty())
- std::cout << "=" << param.second;
- std::cout << "\n";
- }
- @endcode
-*/
-class param_list
-{
- string_view s_;
-
-public:
- /** The type of each element in the list.
-
- The first string in the pair is the name of the parameter,
- and the second string in the pair is its value (which may
- be empty).
- */
- using value_type =
- std::pair<string_view, string_view>;
-
- /// A constant iterator to the list
-#if BOOST_BEAST_DOXYGEN
- using const_iterator = implementation_defined;
-#else
- class const_iterator;
-#endif
-
- /// Default constructor.
- param_list() = default;
-
- /** Construct a list.
-
- @param s A string containing the list contents. The string
- must remain valid for the lifetime of the container.
- */
- explicit
- param_list(string_view s)
- : s_(s)
- {
- }
-
- /// Return a const iterator to the beginning of the list
- const_iterator begin() const;
-
- /// Return a const iterator to the end of the list
- const_iterator end() const;
-
- /// Return a const iterator to the beginning of the list
- const_iterator cbegin() const;
-
- /// Return a const iterator to the end of the list
- const_iterator cend() const;
-};
-
-//------------------------------------------------------------------------------
-
-/** A list of extensions in a comma separated HTTP field value.
-
- This container allows iteration of the extensions in an HTTP
- field value. The extension list is a comma separated list of
- token parameter list pairs.
-
- If a parsing error is encountered while iterating the string,
- the behavior of the container will be as if a string containing
- only characters up to but excluding the first invalid character
- was used to construct the list.
-
- @par BNF
- @code
- ext-list = *( "," OWS ) ext *( OWS "," [ OWS ext ] )
- ext = token param-list
- param-list = *( OWS ";" OWS param )
- param = token OWS [ "=" OWS ( token / quoted-string ) ]
- @endcode
-
- To use this class, construct with the string to be parsed and
- then use @ref begin and @ref end, or range-for to iterate each
- item:
-
- @par Example
- @code
- for(auto const& ext : ext_list{"none, 7z;level=9, zip;no_context_takeover;bits=15"})
- {
- std::cout << ext.first << "\n";
- for(auto const& param : ext.second)
- {
- std::cout << ";" << param.first;
- if(! param.second.empty())
- std::cout << "=" << param.second;
- std::cout << "\n";
- }
- }
- @endcode
-*/
-class ext_list
-{
- using iter_type = string_view::const_iterator;
-
- string_view s_;
-
-public:
- /** The type of each element in the list.
-
- The first element of the pair is the extension token, and the
- second element of the pair is an iterable container holding the
- extension's name/value parameters.
- */
- using value_type = std::pair<string_view, param_list>;
-
- /// A constant iterator to the list
-#if BOOST_BEAST_DOXYGEN
- using const_iterator = implementation_defined;
-#else
- class const_iterator;
-#endif
-
- /** Construct a list.
-
- @param s A string containing the list contents. The string
- must remain valid for the lifetime of the container.
- */
- explicit
- ext_list(string_view s)
- : s_(s)
- {
- }
-
- /// Return a const iterator to the beginning of the list
- const_iterator begin() const;
-
- /// Return a const iterator to the end of the list
- const_iterator end() const;
-
- /// Return a const iterator to the beginning of the list
- const_iterator cbegin() const;
-
- /// Return a const iterator to the end of the list
- const_iterator cend() const;
-
- /** Find a token in the list.
-
- @param s The token to find. A case-insensitive comparison is used.
-
- @return An iterator to the matching token, or `end()` if no
- token exists.
- */
- template<class T>
- const_iterator
- find(T const& s);
-
- /** Return `true` if a token is present in the list.
-
- @param s The token to find. A case-insensitive comparison is used.
- */
- template<class T>
- bool
- exists(T const& s);
-};
-
-//------------------------------------------------------------------------------
-
-/** A list of tokens in a comma separated HTTP field value.
-
- This container allows iteration of a list of items in a
- header field value. The input is a comma separated list of
- tokens.
-
- If a parsing error is encountered while iterating the string,
- the behavior of the container will be as if a string containing
- only characters up to but excluding the first invalid character
- was used to construct the list.
-
- @par BNF
- @code
- token-list = *( "," OWS ) token *( OWS "," [ OWS token ] )
- @endcode
-
- To use this class, construct with the string to be parsed and
- then use @ref begin and @ref end, or range-for to iterate each
- item:
-
- @par Example
- @code
- for(auto const& token : token_list{"apple, pear, banana"})
- std::cout << token << "\n";
- @endcode
-*/
-class token_list
-{
- using iter_type = string_view::const_iterator;
-
- string_view s_;
-
-public:
- /// The type of each element in the token list.
- using value_type = string_view;
-
- /// A constant iterator to the list
-#if BOOST_BEAST_DOXYGEN
- using const_iterator = implementation_defined;
-#else
- class const_iterator;
-#endif
-
- /** Construct a list.
-
- @param s A string containing the list contents. The string
- must remain valid for the lifetime of the container.
- */
- explicit
- token_list(string_view s)
- : s_(s)
- {
- }
-
- /// Return a const iterator to the beginning of the list
- const_iterator begin() const;
-
- /// Return a const iterator to the end of the list
- const_iterator end() const;
-
- /// Return a const iterator to the beginning of the list
- const_iterator cbegin() const;
-
- /// Return a const iterator to the end of the list
- const_iterator cend() const;
-
- /** Return `true` if a token is present in the list.
-
- @param s The token to find. A case-insensitive comparison is used.
- */
- template<class T>
- bool
- exists(T const& s);
-};
-
-/** A list of tokens in a comma separated HTTP field value.
-
- This container allows iteration of a list of items in a
- header field value. The input is a comma separated list of
- tokens.
-
- If a parsing error is encountered while iterating the string,
- the behavior of the container will be as if a string containing
- only characters up to but excluding the first invalid character
- was used to construct the list.
-
- @par BNF
- @code
- token-list = *( "," OWS ) token *( OWS "," [ OWS token ] )
- @endcode
-
- To use this class, construct with the string to be parsed and
- then use `begin` and `end`, or range-for to iterate each item:
-
- @par Example
- @code
- for(auto const& token : token_list{"apple, pear, banana"})
- std::cout << token << "\n";
- @endcode
-*/
-using opt_token_list =
- detail::basic_parsed_list<
- detail::opt_token_list_policy>;
-
-/** Returns `true` if a parsed list is parsed without errors.
-
- This function iterates a single pass through a parsed list
- and returns `true` if there were no parsing errors, else
- returns `false`.
-*/
-template<class Policy>
-bool
-validate_list(detail::basic_parsed_list<
- Policy> const& list);
-
-} // http
-} // beast
-} // boost
-
-#include <boost/beast/http/impl/rfc7230.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/serializer.hpp b/contrib/restricted/boost/boost/beast/http/serializer.hpp
deleted file mode 100644
index bbb562a620..0000000000
--- a/contrib/restricted/boost/boost/beast/http/serializer.hpp
+++ /dev/null
@@ -1,398 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_SERIALIZER_HPP
-#define BOOST_BEAST_HTTP_SERIALIZER_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/buffers_cat.hpp>
-#include <boost/beast/core/buffers_prefix.hpp>
-#include <boost/beast/core/buffers_suffix.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/core/detail/variant.hpp>
-#include <boost/beast/http/message.hpp>
-#include <boost/beast/http/chunk_encode.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/optional.hpp>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** Provides buffer oriented HTTP message serialization functionality.
-
- An object of this type is used to serialize a complete
- HTTP message into a sequence of octets. To use this class,
- construct an instance with the message to be serialized.
- The implementation will automatically perform chunk encoding
- if the contents of the message indicate that chunk encoding
- is required.
-
- Chunked output produced by the serializer never contains chunk
- extensions or trailers, and the location of chunk boundaries
- is not specified. If callers require chunk extensions, trailers,
- or control over the exact contents of each chunk they should
- use the serializer to write just the message header, and then
- assume control over serializing the chunked payload by using
- the chunk buffer sequence types @ref chunk_body, @ref chunk_crlf,
- @ref chunk_header, and @ref chunk_last.
-
- @tparam isRequest `true` if the message is a request.
-
- @tparam Body The body type of the message.
-
- @tparam Fields The type of fields in the message.
-*/
-template<
- bool isRequest,
- class Body,
- class Fields = fields>
-class serializer
-{
-public:
- static_assert(is_body<Body>::value,
- "Body requirements not met");
-
- static_assert(is_body_writer<Body>::value,
- "BodyWriter requirements not met");
-
- /** The type of message this serializer uses
-
- This may be const or non-const depending on the
- implementation of the corresponding @b BodyWriter.
- */
-#if BOOST_BEAST_DOXYGEN
- using value_type = implementation_defined;
-#else
- using value_type = typename std::conditional<
- (std::is_constructible<typename Body::writer,
- header<isRequest, Fields>&,
- typename Body::value_type&>::value &&
- ! std::is_constructible<typename Body::writer,
- header<isRequest, Fields> const&,
- typename Body::value_type const&>::value) ||
- // Deprecated BodyWriter Concept (v1.66)
- (std::is_constructible<typename Body::writer,
- message<isRequest, Body, Fields>&>::value &&
- ! std::is_constructible<typename Body::writer,
- message<isRequest, Body, Fields> const&>::value),
- message<isRequest, Body, Fields>,
- message<isRequest, Body, Fields> const>::type;
-#endif
-
-private:
- enum
- {
- do_construct = 0,
-
- do_init = 10,
- do_header_only = 20,
- do_header = 30,
- do_body = 40,
-
- do_init_c = 50,
- do_header_only_c = 60,
- do_header_c = 70,
- do_body_c = 80,
- do_final_c = 90,
- #ifndef BOOST_BEAST_NO_BIG_VARIANTS
- do_body_final_c = 100,
- do_all_c = 110,
- #endif
-
- do_complete = 120
- };
-
- void fwrinit(std::true_type);
- void fwrinit(std::false_type);
-
- template<std::size_t, class Visit>
- void
- do_visit(error_code& ec, Visit& visit);
-
- using writer = typename Body::writer;
-
- using cb1_t = buffers_suffix<typename
- Fields::writer::const_buffers_type>; // header
- using pcb1_t = buffers_prefix_view<cb1_t const&>;
-
- using cb2_t = buffers_suffix<buffers_cat_view<
- typename Fields::writer::const_buffers_type,// header
- typename writer::const_buffers_type>>; // body
- using pcb2_t = buffers_prefix_view<cb2_t const&>;
-
- using cb3_t = buffers_suffix<
- typename writer::const_buffers_type>; // body
- using pcb3_t = buffers_prefix_view<cb3_t const&>;
-
- using cb4_t = buffers_suffix<buffers_cat_view<
- typename Fields::writer::const_buffers_type,// header
- detail::chunk_size, // chunk-size
- boost::asio::const_buffer, // chunk-ext
- chunk_crlf, // crlf
- typename writer::const_buffers_type, // body
- chunk_crlf>>; // crlf
- using pcb4_t = buffers_prefix_view<cb4_t const&>;
-
- using cb5_t = buffers_suffix<buffers_cat_view<
- detail::chunk_size, // chunk-header
- boost::asio::const_buffer, // chunk-ext
- chunk_crlf, // crlf
- typename writer::const_buffers_type, // body
- chunk_crlf>>; // crlf
- using pcb5_t = buffers_prefix_view<cb5_t const&>;
-
- using cb6_t = buffers_suffix<buffers_cat_view<
- detail::chunk_size, // chunk-header
- boost::asio::const_buffer, // chunk-size
- chunk_crlf, // crlf
- typename writer::const_buffers_type, // body
- chunk_crlf, // crlf
- boost::asio::const_buffer, // chunk-final
- boost::asio::const_buffer, // trailers
- chunk_crlf>>; // crlf
- using pcb6_t = buffers_prefix_view<cb6_t const&>;
-
- using cb7_t = buffers_suffix<buffers_cat_view<
- typename Fields::writer::const_buffers_type,// header
- detail::chunk_size, // chunk-size
- boost::asio::const_buffer, // chunk-ext
- chunk_crlf, // crlf
- typename writer::const_buffers_type, // body
- chunk_crlf, // crlf
- boost::asio::const_buffer, // chunk-final
- boost::asio::const_buffer, // trailers
- chunk_crlf>>; // crlf
- using pcb7_t = buffers_prefix_view<cb7_t const&>;
-
- using cb8_t = buffers_suffix<buffers_cat_view<
- boost::asio::const_buffer, // chunk-final
- boost::asio::const_buffer, // trailers
- chunk_crlf>>; // crlf
- using pcb8_t = buffers_prefix_view<cb8_t const&>;
-
- value_type& m_;
- writer wr_;
- boost::optional<typename Fields::writer> fwr_;
- beast::detail::variant<
- cb1_t, cb2_t, cb3_t, cb4_t,
- cb5_t ,cb6_t, cb7_t, cb8_t> v_;
- beast::detail::variant<
- pcb1_t, pcb2_t, pcb3_t, pcb4_t,
- pcb5_t ,pcb6_t, pcb7_t, pcb8_t> pv_;
- std::size_t limit_ =
- (std::numeric_limits<std::size_t>::max)();
- int s_ = do_construct;
- bool split_ = false;
- bool header_done_ = false;
- bool more_;
-
- serializer(value_type& msg, std::true_type);
- serializer(value_type& msg, std::false_type);
-public:
- /// Constructor
- serializer(serializer&&) = default;
-
- /// Constructor
- serializer(serializer const&) = default;
-
- /// Assignment
- serializer& operator=(serializer const&) = delete;
-
- /** Constructor
-
- The implementation guarantees that the message passed on
- construction will not be accessed until the first call to
- @ref next. This allows the message to be lazily created.
- For example, if the header is filled in before serialization.
-
- @param msg A reference to the message to serialize, which must
- remain valid for the lifetime of the serializer. Depending on
- the type of Body used, this may or may not be a `const` reference.
-
- @note This function participates in overload resolution only if
- Body::writer is constructible from a `const` message reference.
- */
- explicit
- serializer(value_type& msg);
-
- /// Returns the message being serialized
- value_type&
- get()
- {
- return m_;
- }
-
- /// Returns the serialized buffer size limit
- std::size_t
- limit()
- {
- return limit_;
- }
-
- /** Set the serialized buffer size limit
-
- This function adjusts the limit on the maximum size of the
- buffers passed to the visitor. The new size limit takes effect
- in the following call to @ref next.
-
- The default is no buffer size limit.
-
- @param limit The new buffer size limit. If this number
- is zero, the size limit is removed.
- */
- void
- limit(std::size_t limit)
- {
- limit_ = limit > 0 ? limit :
- (std::numeric_limits<std::size_t>::max)();
- }
-
- /** Returns `true` if we will pause after writing the complete header.
- */
- bool
- split()
- {
- return split_;
- }
-
- /** Set whether the header and body are written separately.
-
- When the split feature is enabled, the implementation will
- write only the octets corresponding to the serialized header
- first. If the header has already been written, this function
- will have no effect on output.
- */
- void
- split(bool v)
- {
- split_ = v;
- }
-
- /** Return `true` if serialization of the header is complete.
-
- This function indicates whether or not all buffers containing
- serialized header octets have been retrieved.
- */
- bool
- is_header_done()
- {
- return header_done_;
- }
-
- /** Return `true` if serialization is complete.
-
- The operation is complete when all octets corresponding
- to the serialized representation of the message have been
- successfully retrieved.
- */
- bool
- is_done()
- {
- return s_ == do_complete;
- }
-
- /** Returns the next set of buffers in the serialization.
-
- This function will attempt to call the `visit` function
- object with a @b ConstBufferSequence of unspecified type
- representing the next set of buffers in the serialization
- of the message represented by this object.
-
- If there are no more buffers in the serialization, the
- visit function will not be called. In this case, no error
- will be indicated, and the function @ref is_done will
- return `true`.
-
- @param ec Set to the error, if any occurred.
-
- @param visit The function to call. The equivalent function
- signature of this object must be:
- @code
- template<class ConstBufferSequence>
- void visit(error_code&, ConstBufferSequence const&);
- @endcode
- The function is not copied, if no error occurs it will be
- invoked before the call to @ref next returns.
-
- */
- template<class Visit>
- void
- next(error_code& ec, Visit&& visit);
-
- /** Consume buffer octets in the serialization.
-
- This function should be called after one or more octets
- contained in the buffers provided in the prior call
- to @ref next have been used.
-
- After a call to @ref consume, callers should check the
- return value of @ref is_done to determine if the entire
- message has been serialized.
-
- @param n The number of octets to consume. This number must
- be greater than zero and no greater than the number of
- octets in the buffers provided in the prior call to @ref next.
- */
- void
- consume(std::size_t n);
-
- /** Provides low-level access to the associated @b BodyWriter (DEPRECATED)
-
- This function provides access to the instance of the writer
- associated with the body and created by the serializer
- upon construction. The behavior of accessing this object
- is defined by the specification of the particular writer
- and its associated body.
-
- @return A reference to the writer.
- */
- writer&
- reader_impl()
- {
- #ifndef BOOST_BEAST_ALLOW_DEPRECATED
- BOOST_STATIC_ASSERT_MSG(sizeof(Body) == 0,
- BOOST_BEAST_DEPRECATION_STRING);
- #endif
- return wr_;
- }
-
- /** Provides low-level access to the associated @b BodyWriter
-
- This function provides access to the instance of the writer
- associated with the body and created by the serializer
- upon construction. The behavior of accessing this object
- is defined by the specification of the particular writer
- and its associated body.
-
- @return A reference to the writer.
- */
- writer&
- writer_impl()
- {
- return wr_;
- }
-};
-
-/// A serializer for HTTP/1 requests
-template<class Body, class Fields = fields>
-using request_serializer = serializer<true, Body, Fields>;
-
-/// A serializer for HTTP/1 responses
-template<class Body, class Fields = fields>
-using response_serializer = serializer<false, Body, Fields>;
-
-} // http
-} // beast
-} // boost
-
-#include <boost/beast/http/impl/serializer.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/span_body.hpp b/contrib/restricted/boost/boost/beast/http/span_body.hpp
deleted file mode 100644
index 4688dc8741..0000000000
--- a/contrib/restricted/boost/boost/beast/http/span_body.hpp
+++ /dev/null
@@ -1,169 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_SPAN_BODY_HPP
-#define BOOST_BEAST_HTTP_SPAN_BODY_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/span.hpp>
-#include <boost/beast/http/error.hpp>
-#include <boost/beast/http/message.hpp>
-#include <boost/optional.hpp>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** A @b Body using @ref span
-
- This body uses @ref span as a memory-based container for
- holding message payloads. The container represents a
- non-owning reference to a continguous area of memory.
- Messages using this body type may be serialized and
- parsed.
-
- Unlike @ref buffer_body, only one buffer may be provided
- during a parse or serialize operation.
-*/
-template<class T>
-struct span_body
-{
-private:
- static_assert(std::is_pod<T>::value,
- "POD requirements not met");
-
-public:
- /** The type of container used for the body
-
- This determines the type of @ref message::body
- when this body type is used with a message container.
- */
- using value_type = span<T>;
-
- /** Returns the payload size of the body
-
- When this body is used with @ref message::prepare_payload,
- the Content-Length will be set to the payload size, and
- any chunked Transfer-Encoding will be removed.
- */
- static
- std::uint64_t
- size(value_type const& body)
- {
- return body.size();
- }
-
- /** The algorithm for parsing the body
-
- Meets the requirements of @b BodyReader.
- */
-#if BOOST_BEAST_DOXYGEN
- using reader = implementation_defined;
-#else
- class reader
- {
- value_type& body_;
-
- public:
- template<bool isRequest, class Fields>
- explicit
- reader(header<isRequest, Fields>&, value_type& b)
- : body_(b)
- {
- }
-
- void
- init(boost::optional<
- std::uint64_t> const& length, error_code& ec)
- {
- if(length && *length > body_.size())
- {
- ec = error::buffer_overflow;
- return;
- }
- ec.assign(0, ec.category());
- }
-
- template<class ConstBufferSequence>
- std::size_t
- put(ConstBufferSequence const& buffers,
- error_code& ec)
- {
- using boost::asio::buffer_size;
- using boost::asio::buffer_copy;
- auto const n = buffer_size(buffers);
- auto const len = body_.size();
- if(n > len)
- {
- ec = error::buffer_overflow;
- return 0;
- }
- ec.assign(0, ec.category());
- buffer_copy(boost::asio::buffer(
- body_.data(), n), buffers);
- body_ = value_type{
- body_.data() + n, body_.size() - n};
- return n;
- }
-
- void
- finish(error_code& ec)
- {
- ec.assign(0, ec.category());
- }
- };
-#endif
-
- /** The algorithm for serializing the body
-
- Meets the requirements of @b BodyWriter.
- */
-#if BOOST_BEAST_DOXYGEN
- using writer = implementation_defined;
-#else
- class writer
- {
- value_type const& body_;
-
- public:
- using const_buffers_type =
- boost::asio::const_buffer;
-
- template<bool isRequest, class Fields>
- explicit
- writer(header<isRequest, Fields> const&, value_type const& b)
- : body_(b)
- {
- }
-
- void
- init(error_code& ec)
- {
- ec.assign(0, ec.category());
- }
-
- boost::optional<std::pair<const_buffers_type, bool>>
- get(error_code& ec)
- {
- ec.assign(0, ec.category());
- return {{
- { body_.data(),
- body_.size() * sizeof(typename
- value_type::value_type)},
- false}};
- }
- };
-#endif
-};
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/status.hpp b/contrib/restricted/boost/boost/beast/http/status.hpp
deleted file mode 100644
index 8d7938ca0c..0000000000
--- a/contrib/restricted/boost/boost/beast/http/status.hpp
+++ /dev/null
@@ -1,167 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_STATUS_HPP
-#define BOOST_BEAST_HTTP_STATUS_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/string.hpp>
-#include <iosfwd>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-enum class status : unsigned
-{
- /** An unknown status-code.
-
- This value indicates that the value for the status code
- is not in the list of commonly recognized status codes.
- Callers interested in the exactly value should use the
- interface which provides the raw integer.
- */
- unknown = 0,
-
- continue_ = 100,
- switching_protocols = 101,
- processing = 102,
-
- ok = 200,
- created = 201,
- accepted = 202,
- non_authoritative_information = 203,
- no_content = 204,
- reset_content = 205,
- partial_content = 206,
- multi_status = 207,
- already_reported = 208,
- im_used = 226,
-
- multiple_choices = 300,
- moved_permanently = 301,
- found = 302,
- see_other = 303,
- not_modified = 304,
- use_proxy = 305,
- temporary_redirect = 307,
- permanent_redirect = 308,
-
- bad_request = 400,
- unauthorized = 401,
- payment_required = 402,
- forbidden = 403,
- not_found = 404,
- method_not_allowed = 405,
- not_acceptable = 406,
- proxy_authentication_required = 407,
- request_timeout = 408,
- conflict = 409,
- gone = 410,
- length_required = 411,
- precondition_failed = 412,
- payload_too_large = 413,
- uri_too_long = 414,
- unsupported_media_type = 415,
- range_not_satisfiable = 416,
- expectation_failed = 417,
- misdirected_request = 421,
- unprocessable_entity = 422,
- locked = 423,
- failed_dependency = 424,
- upgrade_required = 426,
- precondition_required = 428,
- too_many_requests = 429,
- request_header_fields_too_large = 431,
- connection_closed_without_response = 444,
- unavailable_for_legal_reasons = 451,
- client_closed_request = 499,
-
- internal_server_error = 500,
- not_implemented = 501,
- bad_gateway = 502,
- service_unavailable = 503,
- gateway_timeout = 504,
- http_version_not_supported = 505,
- variant_also_negotiates = 506,
- insufficient_storage = 507,
- loop_detected = 508,
- not_extended = 510,
- network_authentication_required = 511,
- network_connect_timeout_error = 599
-};
-
-/** Represents the class of a status-code.
-*/
-enum class status_class : unsigned
-{
- /// Unknown status-class
- unknown = 0,
-
- /// The request was received, continuing processing.
- informational = 1,
-
- /// The request was successfully received, understood, and accepted.
- successful = 2,
-
- /// Further action needs to be taken in order to complete the request.
- redirection = 3,
-
- /// The request contains bad syntax or cannot be fulfilled.
- client_error = 4,
-
- /// The server failed to fulfill an apparently valid request.
- server_error = 5,
-};
-
-/** Converts the integer to a known status-code.
-
- If the integer does not match a known status code,
- @ref status::unknown is returned.
-*/
-status
-int_to_status(unsigned v);
-
-/** Convert an integer to a status_class.
-
- @param v The integer representing a status code.
-
- @return The status class. If the integer does not match
- a known status class, @ref status_class::unknown is returned.
-*/
-status_class
-to_status_class(unsigned v);
-
-/** Convert a status_code to a status_class.
-
- @param v The status code to convert.
-
- @return The status class.
-*/
-status_class
-to_status_class(status v);
-
-/** Returns the obsolete reason-phrase text for a status code.
-
- @param v The status code to use.
-*/
-string_view
-obsolete_reason(status v);
-
-/// Outputs the standard reason phrase of a status code to a stream.
-std::ostream&
-operator<<(std::ostream&, status);
-
-} // http
-} // beast
-} // boost
-
-#include <boost/beast/http/impl/status.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/string_body.hpp b/contrib/restricted/boost/boost/beast/http/string_body.hpp
deleted file mode 100644
index 89447e50ff..0000000000
--- a/contrib/restricted/boost/boost/beast/http/string_body.hpp
+++ /dev/null
@@ -1,197 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_STRING_BODY_HPP
-#define BOOST_BEAST_HTTP_STRING_BODY_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/http/error.hpp>
-#include <boost/beast/http/message.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/optional.hpp>
-#include <cstdint>
-#include <limits>
-#include <memory>
-#include <stdexcept>
-#include <string>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** A @b Body using `std::basic_string`
-
- This body uses `std::basic_string` as a memory-based container
- for holding message payloads. Messages using this body type
- may be serialized and parsed.
-*/
-template<
- class CharT,
- class Traits = std::char_traits<CharT>,
- class Allocator = std::allocator<CharT>>
-struct basic_string_body
-{
-private:
- static_assert(
- std::is_integral<CharT>::value &&
- sizeof(CharT) == 1,
- "CharT requirements not met");
-
-public:
- /** The type of container used for the body
-
- This determines the type of @ref message::body
- when this body type is used with a message container.
- */
- using value_type =
- std::basic_string<CharT, Traits, Allocator>;
-
- /** Returns the payload size of the body
-
- When this body is used with @ref message::prepare_payload,
- the Content-Length will be set to the payload size, and
- any chunked Transfer-Encoding will be removed.
- */
- static
- std::uint64_t
- size(value_type const& body)
- {
- return body.size();
- }
-
- /** The algorithm for parsing the body
-
- Meets the requirements of @b BodyReader.
- */
-#if BOOST_BEAST_DOXYGEN
- using reader = implementation_defined;
-#else
- class reader
- {
- value_type& body_;
-
- public:
- template<bool isRequest, class Fields>
- explicit
- reader(header<isRequest, Fields>&, value_type& b)
- : body_(b)
- {
- }
-
- void
- init(boost::optional<
- std::uint64_t> const& length, error_code& ec)
- {
- if(length)
- {
- if(static_cast<std::size_t>(*length) != *length)
- {
- ec = error::buffer_overflow;
- return;
- }
- try
- {
- body_.reserve(
- static_cast<std::size_t>(*length));
- }
- catch(std::exception const&)
- {
- ec = error::buffer_overflow;
- return;
- }
- }
- ec.assign(0, ec.category());
- }
-
- template<class ConstBufferSequence>
- std::size_t
- put(ConstBufferSequence const& buffers,
- error_code& ec)
- {
- using boost::asio::buffer_size;
- using boost::asio::buffer_copy;
- auto const extra = buffer_size(buffers);
- auto const size = body_.size();
- try
- {
- body_.resize(size + extra);
- }
- catch(std::exception const&)
- {
- ec = error::buffer_overflow;
- return 0;
- }
- ec.assign(0, ec.category());
- CharT* dest = &body_[size];
- for(auto b : beast::detail::buffers_range(buffers))
- {
- Traits::copy(dest, reinterpret_cast<
- CharT const*>(b.data()), b.size());
- dest += b.size();
- }
- return extra;
- }
-
- void
- finish(error_code& ec)
- {
- ec.assign(0, ec.category());
- }
- };
-#endif
-
- /** The algorithm for serializing the body
-
- Meets the requirements of @b BodyWriter.
- */
-#if BOOST_BEAST_DOXYGEN
- using writer = implementation_defined;
-#else
- class writer
- {
- value_type const& body_;
-
- public:
- using const_buffers_type =
- boost::asio::const_buffer;
-
- template<bool isRequest, class Fields>
- explicit
- writer(header<isRequest, Fields> const&, value_type const& b)
- : body_(b)
- {
- }
-
- void
- init(error_code& ec)
- {
- ec.assign(0, ec.category());
- }
-
- boost::optional<std::pair<const_buffers_type, bool>>
- get(error_code& ec)
- {
- ec.assign(0, ec.category());
- return {{const_buffers_type{
- body_.data(), body_.size()}, false}};
- }
- };
-#endif
-};
-
-/// A @b Body using `std::string`
-using string_body = basic_string_body<char>;
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/type_traits.hpp b/contrib/restricted/boost/boost/beast/http/type_traits.hpp
deleted file mode 100644
index 0c8210443e..0000000000
--- a/contrib/restricted/boost/boost/beast/http/type_traits.hpp
+++ /dev/null
@@ -1,200 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_TYPE_TRAITS_HPP
-#define BOOST_BEAST_HTTP_TYPE_TRAITS_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/http/detail/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/optional.hpp>
-#include <type_traits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-template<bool, class, class>
-struct message;
-
-/** Determine if `T` meets the requirements of @b Body.
-
- This metafunction is equivalent to `std::true_type`
- if `T` has a nested type named `value_type`.
-
- @tparam T The body type to test.
-
- @par Example
- @code
- template<bool isRequest, class Body, class Fields>
- void check_body(message<isRequest, Body, Fields> const&)
- {
- static_assert(is_body<Body>::value,
- "Body requirements not met");
- }
- @endcode
-*/
-template<class T>
-#if BOOST_BEAST_DOXYGEN
-struct is_body : std::integral_constant<bool, ...>{};
-#else
-using is_body = detail::has_value_type<T>;
-#endif
-
-/** Determine if a @b Body type has a reader.
-
- This metafunction is equivalent to `std::true_type` if:
-
- @li `T` has a nested type named `reader`
-
- @li The nested type meets the requirements of @b BodyWriter.
-
- @tparam T The body type to test.
-
- @par Example
- @code
- template<bool isRequest, class Body, class Fields>
- void check_can_serialize(message<isRequest, Body, Fields> const&)
- {
- static_assert(is_body_writer<Body>::value,
- "Cannot serialize Body, no reader");
- }
- @endcode
-*/
-#if BOOST_BEAST_DOXYGEN
-template<class T>
-struct is_body_writer : std::integral_constant<bool, ...> {};
-#else
-template<class T, class = void>
-struct is_body_writer : std::false_type {};
-
-template<class T>
-struct is_body_writer<T, beast::detail::void_t<
- typename T::writer,
- typename T::writer::const_buffers_type,
- decltype(
- std::declval<typename T::writer&>().init(std::declval<error_code&>()),
- std::declval<boost::optional<std::pair<
- typename T::writer::const_buffers_type, bool>>&>() =
- std::declval<typename T::writer>().get(std::declval<error_code&>()),
- (void)0)>> : std::integral_constant<bool,
- boost::asio::is_const_buffer_sequence<
- typename T::writer::const_buffers_type>::value && (
- (std::is_constructible<typename T::writer,
- header<true, detail::fields_model>&,
- typename T::value_type&>::value &&
- std::is_constructible<typename T::writer,
- header<false, detail::fields_model>&,
- typename T::value_type&>::value) ||
- // Deprecated BodyWriter Concept (v1.66)
- (std::is_constructible<typename T::writer,
- message<true, T, detail::fields_model>&>::value &&
- std::is_constructible<typename T::writer,
- message<false, T, detail::fields_model>&>::value)
- )
- > {};
-#endif
-
-/** Determine if a @b Body type has a reader.
-
- This metafunction is equivalent to `std::true_type` if:
-
- @li `T` has a nested type named `reader`
-
- @li The nested type meets the requirements of @b BodyReader.
-
- @tparam T The body type to test.
-
- @par Example
- @code
- template<bool isRequest, class Body, class Fields>
- void check_can_parse(message<isRequest, Body, Fields>&)
- {
- static_assert(is_body_reader<Body>::value,
- "Cannot parse Body, no reader");
- }
- @endcode
-*/
-#if BOOST_BEAST_DOXYGEN
-template<class T>
-struct is_body_reader : std::integral_constant<bool, ...> {};
-#else
-template<class T, class = void>
-struct is_body_reader : std::false_type {};
-
-template<class T>
-struct is_body_reader<T, beast::detail::void_t<decltype(
- std::declval<typename T::reader&>().init(
- boost::optional<std::uint64_t>(),
- std::declval<error_code&>()),
- std::declval<std::size_t&>() =
- std::declval<typename T::reader&>().put(
- std::declval<boost::asio::const_buffer>(),
- std::declval<error_code&>()),
- std::declval<typename T::reader&>().finish(
- std::declval<error_code&>()),
- (void)0)>> : std::integral_constant<bool,
- (std::is_constructible<typename T::reader,
- header<true, detail::fields_model>&,
- typename T::value_type&>::value &&
- std::is_constructible<typename T::reader,
- header<false,detail::fields_model>&,
- typename T::value_type&>::value) ||
- // Deprecated BodyReader Concept (v1.66)
- (std::is_constructible<typename T::reader,
- message<true, T, detail::fields_model>&>::value &&
- std::is_constructible<typename T::reader,
- message<false, T, detail::fields_model>&>::value)
- >
-{
-};
-#endif
-
-/** Determine if `T` meets the requirements of @b Fields
-
- @tparam T The body type to test.
-
- @par Example
-
- Use with `static_assert`:
-
- @code
- template<bool isRequest, class Body, class Fields>
- void f(message<isRequest, Body, Fields> const&)
- {
- static_assert(is_fields<Fields>::value,
- "Fields requirements not met");
- ...
- @endcode
-
- Use with `std::enable_if` (SFINAE):
-
- @code
- template<bool isRequest, class Body, class Fields>
- typename std::enable_if<is_fields<Fields>::value>::type
- f(message<isRequest, Body, Fields> const&);
- @endcode
-*/
-#if BOOST_BEAST_DOXYGEN
-template<class T>
-struct is_fields : std::integral_constant<bool, ...> {};
-#else
-template<class T>
-using is_fields = typename detail::is_fields_helper<T>::type;
-#endif
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/vector_body.hpp b/contrib/restricted/boost/boost/beast/http/vector_body.hpp
deleted file mode 100644
index 40c885e43e..0000000000
--- a/contrib/restricted/boost/boost/beast/http/vector_body.hpp
+++ /dev/null
@@ -1,183 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_VECTOR_BODY_HPP
-#define BOOST_BEAST_HTTP_VECTOR_BODY_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/http/error.hpp>
-#include <boost/beast/http/message.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/optional.hpp>
-#include <cstdint>
-#include <limits>
-#include <memory>
-#include <stdexcept>
-#include <string>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** A @b Body using `std::vector`
-
- This body uses `std::vector` as a memory-based container
- for holding message payloads. Messages using this body type
- may be serialized and parsed.
-*/
-template<class T, class Allocator = std::allocator<T>>
-struct vector_body
-{
-private:
- static_assert(sizeof(T) == 1 &&
- std::is_integral<T>::value,
- "T requirements not met");
-
-public:
- /** The type of container used for the body
-
- This determines the type of @ref message::body
- when this body type is used with a message container.
- */
- using value_type = std::vector<T, Allocator>;
-
- /** Returns the payload size of the body
-
- When this body is used with @ref message::prepare_payload,
- the Content-Length will be set to the payload size, and
- any chunked Transfer-Encoding will be removed.
- */
- static
- std::uint64_t
- size(value_type const& body)
- {
- return body.size();
- }
-
- /** The algorithm for parsing the body
-
- Meets the requirements of @b BodyReader.
- */
-#if BOOST_BEAST_DOXYGEN
- using reader = implementation_defined;
-#else
- class reader
- {
- value_type& body_;
-
- public:
- template<bool isRequest, class Fields>
- explicit
- reader(header<isRequest, Fields>&, value_type& b)
- : body_(b)
- {
- }
-
- void
- init(boost::optional<
- std::uint64_t> const& length, error_code& ec)
- {
- if(length)
- {
- if(static_cast<std::size_t>(*length) != *length)
- {
- ec = error::buffer_overflow;
- return;
- }
- try
- {
- body_.reserve(
- static_cast<std::size_t>(*length));
- }
- catch(std::exception const&)
- {
- ec = error::buffer_overflow;
- return;
- }
- }
- ec.assign(0, ec.category());
- }
-
- template<class ConstBufferSequence>
- std::size_t
- put(ConstBufferSequence const& buffers,
- error_code& ec)
- {
- using boost::asio::buffer_size;
- using boost::asio::buffer_copy;
- auto const n = buffer_size(buffers);
- auto const len = body_.size();
- try
- {
- body_.resize(len + n);
- }
- catch(std::exception const&)
- {
- ec = error::buffer_overflow;
- return 0;
- }
- ec.assign(0, ec.category());
- return buffer_copy(boost::asio::buffer(
- &body_[0] + len, n), buffers);
- }
-
- void
- finish(error_code& ec)
- {
- ec.assign(0, ec.category());
- }
- };
-#endif
-
- /** The algorithm for serializing the body
-
- Meets the requirements of @b BodyWriter.
- */
-#if BOOST_BEAST_DOXYGEN
- using writer = implementation_defined;
-#else
- class writer
- {
- value_type const& body_;
-
- public:
- using const_buffers_type =
- boost::asio::const_buffer;
-
- template<bool isRequest, class Fields>
- explicit
- writer(header<isRequest, Fields> const&, value_type const& b)
- : body_(b)
- {
- }
-
- void
- init(error_code& ec)
- {
- ec.assign(0, ec.category());
- }
-
- boost::optional<std::pair<const_buffers_type, bool>>
- get(error_code& ec)
- {
- ec.assign(0, ec.category());
- return {{const_buffers_type{
- body_.data(), body_.size()}, false}};
- }
- };
-#endif
-};
-
-} // http
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/verb.hpp b/contrib/restricted/boost/boost/beast/http/verb.hpp
deleted file mode 100644
index 1540a243e8..0000000000
--- a/contrib/restricted/boost/boost/beast/http/verb.hpp
+++ /dev/null
@@ -1,157 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_VERB_HPP
-#define BOOST_BEAST_HTTP_VERB_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/string.hpp>
-#include <iosfwd>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** HTTP request method verbs
-
- Each verb corresponds to a particular method string
- used in HTTP request messages.
-*/
-enum class verb
-{
- /** An unknown method.
-
- This value indicates that the request method string is not
- one of the recognized verbs. Callers interested in the method
- should use an interface which returns the original string.
- */
- unknown = 0,
-
- /// The DELETE method deletes the specified resource
- delete_,
-
- /** The GET method requests a representation of the specified resource.
-
- Requests using GET should only retrieve data and should have no other effect.
- */
- get,
-
- /** The HEAD method asks for a response identical to that of a GET request, but without the response body.
-
- This is useful for retrieving meta-information written in response
- headers, without having to transport the entire content.
- */
- head,
-
- /** The POST method requests that the server accept the entity enclosed in the request as a new subordinate of the web resource identified by the URI.
-
- The data POSTed might be, for example, an annotation for existing
- resources; a message for a bulletin board, newsgroup, mailing list,
- or comment thread; a block of data that is the result of submitting
- a web form to a data-handling process; or an item to add to a database
- */
- post,
-
- /** The PUT method requests that the enclosed entity be stored under the supplied URI.
-
- If the URI refers to an already existing resource, it is modified;
- if the URI does not point to an existing resource, then the server
- can create the resource with that URI.
- */
- put,
-
- /** The CONNECT method converts the request connection to a transparent TCP/IP tunnel.
-
- This is usually to facilitate SSL-encrypted communication (HTTPS)
- through an unencrypted HTTP proxy.
- */
- connect,
-
- /** The OPTIONS method returns the HTTP methods that the server supports for the specified URL.
-
- This can be used to check the functionality of a web server by requesting
- '*' instead of a specific resource.
- */
- options,
-
- /** The TRACE method echoes the received request so that a client can see what (if any) changes or additions have been made by intermediate servers.
- */
- trace,
-
- // WebDAV
-
- copy,
- lock,
- mkcol,
- move,
- propfind,
- proppatch,
- search,
- unlock,
- bind,
- rebind,
- unbind,
- acl,
-
- // subversion
-
- report,
- mkactivity,
- checkout,
- merge,
-
- // upnp
-
- msearch,
- notify,
- subscribe,
- unsubscribe,
-
- // RFC-5789
-
- patch,
- purge,
-
- // CalDAV
-
- mkcalendar,
-
- // RFC-2068, section 19.6.1.2
-
- link,
- unlink
-};
-
-/** Converts a string to the request method verb.
-
- If the string does not match a known request method,
- @ref verb::unknown is returned.
-*/
-verb
-string_to_verb(string_view s);
-
-/// Returns the text representation of a request method verb.
-string_view
-to_string(verb v);
-
-/// Write the text for a request method verb to an output stream.
-inline
-std::ostream&
-operator<<(std::ostream& os, verb v)
-{
- return os << to_string(v);
-}
-
-} // http
-} // beast
-} // boost
-
-#include <boost/beast/http/impl/verb.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/http/write.hpp b/contrib/restricted/boost/boost/beast/http/write.hpp
deleted file mode 100644
index 3b916b1d7b..0000000000
--- a/contrib/restricted/boost/boost/beast/http/write.hpp
+++ /dev/null
@@ -1,569 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_HTTP_WRITE_HPP
-#define BOOST_BEAST_HTTP_WRITE_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/buffers_cat.hpp>
-#include <boost/beast/core/buffers_suffix.hpp>
-#include <boost/beast/core/multi_buffer.hpp>
-#include <boost/beast/http/message.hpp>
-#include <boost/beast/http/serializer.hpp>
-#include <boost/beast/http/detail/chunk_encode.hpp>
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/asio/async_result.hpp>
-#include <iosfwd>
-#include <limits>
-#include <memory>
-#include <type_traits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace http {
-
-/** Write part of a message to a stream using a serializer.
-
- This function is used to write part of a message to a stream using
- a caller-provided HTTP/1 serializer. The call will block until one
- of the following conditions is true:
-
- @li One or more bytes have been transferred.
-
- @li The function @ref serializer::is_done returns `true`
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls
- to the stream's `write_some` function.
-
- The amount of data actually transferred is controlled by the behavior
- of the underlying stream, subject to the buffer size limit of the
- serializer obtained or set through a call to @ref serializer::limit.
- Setting a limit and performing bounded work helps applications set
- reasonable timeouts. It also allows application-level flow control
- to function correctly. For example when using a TCP/IP based
- stream.
-
- @param stream The stream to which the data is to be written.
- The type must support the @b SyncWriteStream concept.
-
- @param sr The serializer to use.
-
- @return The number of bytes written to the stream.
-
- @throws system_error Thrown on failure.
-
- @see serializer
-*/
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write_some(
- SyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr);
-
-/** Write part of a message to a stream using a serializer.
-
- This function is used to write part of a message to a stream using
- a caller-provided HTTP/1 serializer. The call will block until one
- of the following conditions is true:
-
- @li One or more bytes have been transferred.
-
- @li The function @ref serializer::is_done returns `true`
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls
- to the stream's `write_some` function.
-
- The amount of data actually transferred is controlled by the behavior
- of the underlying stream, subject to the buffer size limit of the
- serializer obtained or set through a call to @ref serializer::limit.
- Setting a limit and performing bounded work helps applications set
- reasonable timeouts. It also allows application-level flow control
- to function correctly. For example when using a TCP/IP based
- stream.
-
- @param stream The stream to which the data is to be written.
- The type must support the @b SyncWriteStream concept.
-
- @param sr The serializer to use.
-
- @param ec Set to indicate what error occurred, if any.
-
- @return The number of bytes written to the stream.
-
- @see @ref async_write_some, @ref serializer
-*/
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write_some(
- SyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr,
- error_code& ec);
-
-/** Write part of a message to a stream asynchronously using a serializer.
-
- This function is used to write part of a message to a stream
- asynchronously using a caller-provided HTTP/1 serializer. The function
- call always returns immediately. The asynchronous operation will continue
- until one of the following conditions is true:
-
- @li One or more bytes have been transferred.
-
- @li The function @ref serializer::is_done returns `true`
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of zero or more calls to the stream's
- `async_write_some` function, and is known as a <em>composed operation</em>.
- The program must ensure that the stream performs no other writes
- until this operation completes.
-
- The amount of data actually transferred is controlled by the behavior
- of the underlying stream, subject to the buffer size limit of the
- serializer obtained or set through a call to @ref serializer::limit.
- Setting a limit and performing bounded work helps applications set
- reasonable timeouts. It also allows application-level flow control
- to function correctly. For example when using a TCP/IP based
- stream.
-
- @param stream The stream to which the data is to be written.
- The type must support the @b AsyncWriteStream concept.
-
- @param sr The serializer to use.
- The object must remain valid at least until the
- handler is called; ownership is not transferred.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& error, // result of operation
- std::size_t bytes_transferred // the number of bytes written to the stream
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
-
- @see @ref serializer
-*/
-template<
- class AsyncWriteStream,
- bool isRequest, class Body, class Fields,
- class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
-async_write_some(
- AsyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr,
- WriteHandler&& handler);
-
-//------------------------------------------------------------------------------
-
-/** Write a header to a stream using a serializer.
-
- This function is used to write a header to a stream using a
- caller-provided HTTP/1 serializer. The call will block until one
- of the following conditions is true:
-
- @li The function @ref serializer::is_header_done returns `true`
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls
- to the stream's `write_some` function.
-
- @param stream The stream to which the data is to be written.
- The type must support the @b SyncWriteStream concept.
-
- @param sr The serializer to use.
-
- @return The number of bytes written to the stream.
-
- @throws system_error Thrown on failure.
-
- @note The implementation will call @ref serializer::split with
- the value `true` on the serializer passed in.
-
- @see @ref serializer
-*/
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write_header(
- SyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr);
-
-/** Write a header to a stream using a serializer.
-
- This function is used to write a header to a stream using a
- caller-provided HTTP/1 serializer. The call will block until one
- of the following conditions is true:
-
- @li The function @ref serializer::is_header_done returns `true`
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls
- to the stream's `write_some` function.
-
- @param stream The stream to which the data is to be written.
- The type must support the @b SyncWriteStream concept.
-
- @param sr The serializer to use.
-
- @param ec Set to indicate what error occurred, if any.
-
- @return The number of bytes written to the stream.
-
- @note The implementation will call @ref serializer::split with
- the value `true` on the serializer passed in.
-
- @see @ref serializer
-*/
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write_header(
- SyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr,
- error_code& ec);
-
-/** Write a header to a stream asynchronously using a serializer.
-
- This function is used to write a header to a stream asynchronously
- using a caller-provided HTTP/1 serializer. The function call always
- returns immediately. The asynchronous operation will continue until
- one of the following conditions is true:
-
- @li The function @ref serializer::is_header_done returns `true`
-
- @li An error occurs.
-
- This operation is implemented in terms of zero or more calls to the stream's
- `async_write_some` function, and is known as a <em>composed operation</em>.
- The program must ensure that the stream performs no other writes
- until this operation completes.
-
- @param stream The stream to which the data is to be written.
- The type must support the @b AsyncWriteStream concept.
-
- @param sr The serializer to use.
- The object must remain valid at least until the
- handler is called; ownership is not transferred.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& error, // result of operation
- std::size_t bytes_transferred // the number of bytes written to the stream
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
-
- @note The implementation will call @ref serializer::split with
- the value `true` on the serializer passed in.
-
- @see @ref serializer
-*/
-template<
- class AsyncWriteStream,
- bool isRequest, class Body, class Fields,
- class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
-async_write_header(
- AsyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr,
- WriteHandler&& handler);
-
-//------------------------------------------------------------------------------
-
-/** Write a complete message to a stream using a serializer.
-
- This function is used to write a complete message to a stream using
- a caller-provided HTTP/1 serializer. The call will block until one
- of the following conditions is true:
-
- @li The function @ref serializer::is_done returns `true`
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls
- to the stream's `write_some` function.
-
- @param stream The stream to which the data is to be written.
- The type must support the @b SyncWriteStream concept.
-
- @param sr The serializer to use.
-
- @return The number of bytes written to the stream.
-
- @throws system_error Thrown on failure.
-
- @see @ref serializer
-*/
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write(
- SyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr);
-
-/** Write a complete message to a stream using a serializer.
-
- This function is used to write a complete message to a stream using
- a caller-provided HTTP/1 serializer. The call will block until one
- of the following conditions is true:
-
- @li The function @ref serializer::is_done returns `true`
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls
- to the stream's `write_some` function.
-
- @param stream The stream to which the data is to be written.
- The type must support the @b SyncWriteStream concept.
-
- @param sr The serializer to use.
-
- @param ec Set to the error, if any occurred.
-
- @return The number of bytes written to the stream.
-
- @see @ref serializer
-*/
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write(
- SyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr,
- error_code& ec);
-
-/** Write a complete message to a stream asynchronously using a serializer.
-
- This function is used to write a complete message to a stream
- asynchronously using a caller-provided HTTP/1 serializer. The
- function call always returns immediately. The asynchronous
- operation will continue until one of the following conditions is true:
-
- @li The function @ref serializer::is_done returns `true`
-
- @li An error occurs.
-
- This operation is implemented in terms of zero or more calls to the stream's
- `async_write_some` function, and is known as a <em>composed operation</em>.
- The program must ensure that the stream performs no other writes
- until this operation completes.
-
- @param stream The stream to which the data is to be written.
- The type must support the @b AsyncWriteStream concept.
-
- @param sr The serializer to use.
- The object must remain valid at least until the
- handler is called; ownership is not transferred.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& error, // result of operation
- std::size_t bytes_transferred // the number of bytes written to the stream
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
-
- @see @ref serializer
-*/
-template<
- class AsyncWriteStream,
- bool isRequest, class Body, class Fields,
- class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
-async_write(
- AsyncWriteStream& stream,
- serializer<isRequest, Body, Fields>& sr,
- WriteHandler&& handler);
-
-//------------------------------------------------------------------------------
-
-/** Write a complete message to a stream.
-
- This function is used to write a complete message to a stream using
- HTTP/1. The call will block until one of the following conditions is true:
-
- @li The entire message is written.
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls to the stream's
- `write_some` function. The algorithm will use a temporary @ref serializer
- with an empty chunk decorator to produce buffers.
-
- @param stream The stream to which the data is to be written.
- The type must support the @b SyncWriteStream concept.
-
- @param msg The message to write.
-
- @return The number of bytes written to the stream.
-
- @throws system_error Thrown on failure.
-
- @see @ref message
-*/
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write(
- SyncWriteStream& stream,
- message<isRequest, Body, Fields> const& msg);
-
-/** Write a complete message to a stream.
-
- This function is used to write a complete message to a stream using
- HTTP/1. The call will block until one of the following conditions is true:
-
- @li The entire message is written.
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls to the stream's
- `write_some` function. The algorithm will use a temporary @ref serializer
- with an empty chunk decorator to produce buffers.
-
- @param stream The stream to which the data is to be written.
- The type must support the @b SyncWriteStream concept.
-
- @param msg The message to write.
-
- @param ec Set to the error, if any occurred.
-
- @return The number of bytes written to the stream.
-
- @see @ref message
-*/
-template<
- class SyncWriteStream,
- bool isRequest, class Body, class Fields>
-std::size_t
-write(
- SyncWriteStream& stream,
- message<isRequest, Body, Fields> const& msg,
- error_code& ec);
-
-/** Write a complete message to a stream asynchronously.
-
- This function is used to write a complete message to a stream asynchronously
- using HTTP/1. The function call always returns immediately. The asynchronous
- operation will continue until one of the following conditions is true:
-
- @li The entire message is written.
-
- @li An error occurs.
-
- This operation is implemented in terms of zero or more calls to the stream's
- `async_write_some` function, and is known as a <em>composed operation</em>.
- The program must ensure that the stream performs no other writes
- until this operation completes. The algorithm will use a temporary
- @ref serializer with an empty chunk decorator to produce buffers.
-
- @param stream The stream to which the data is to be written.
- The type must support the @b AsyncWriteStream concept.
-
- @param msg The message to write.
- The object must remain valid at least until the
- handler is called; ownership is not transferred.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& error, // result of operation
- std::size_t bytes_transferred // the number of bytes written to the stream
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
-
- @see @ref message
-*/
-template<
- class AsyncWriteStream,
- bool isRequest, class Body, class Fields,
- class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
-async_write(
- AsyncWriteStream& stream,
- message<isRequest, Body, Fields>& msg,
- WriteHandler&& handler);
-
-//------------------------------------------------------------------------------
-
-/** Serialize an HTTP/1 header to a `std::ostream`.
-
- The function converts the header to its HTTP/1 serialized
- representation and stores the result in the output stream.
-
- @param os The output stream to write to.
-
- @param msg The message fields to write.
-*/
-template<bool isRequest, class Fields>
-std::ostream&
-operator<<(std::ostream& os,
- header<isRequest, Fields> const& msg);
-
-/** Serialize an HTTP/1 message to a `std::ostream`.
-
- The function converts the message to its HTTP/1 serialized
- representation and stores the result in the output stream.
-
- The implementation will automatically perform chunk encoding if
- the contents of the message indicate that chunk encoding is required.
-
- @param os The output stream to write to.
-
- @param msg The message to write.
-*/
-template<bool isRequest, class Body, class Fields>
-std::ostream&
-operator<<(std::ostream& os,
- message<isRequest, Body, Fields> const& msg);
-
-} // http
-} // beast
-} // boost
-
-#include <boost/beast/http/impl/write.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/version.hpp b/contrib/restricted/boost/boost/beast/version.hpp
deleted file mode 100644
index c0c7b6fb06..0000000000
--- a/contrib/restricted/boost/boost/beast/version.hpp
+++ /dev/null
@@ -1,28 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_VERSION_HPP
-#define BOOST_BEAST_VERSION_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/config.hpp>
-
-/** @def BOOST_BEAST_API_VERSION
-
- Identifies the API version of Beast.
-
- This is a simple integer that is incremented by one every
- time a set of code changes is merged to the develop branch.
-*/
-#define BOOST_BEAST_VERSION 167
-
-#define BOOST_BEAST_VERSION_STRING "Boost.Beast/" BOOST_STRINGIZE(BOOST_BEAST_VERSION)
-
-#endif
-
diff --git a/contrib/restricted/boost/boost/beast/websocket.hpp b/contrib/restricted/boost/boost/beast/websocket.hpp
deleted file mode 100644
index 551eaff47b..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket.hpp
+++ /dev/null
@@ -1,22 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_HPP
-#define BOOST_BEAST_WEBSOCKET_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-
-#include <boost/beast/websocket/error.hpp>
-#include <boost/beast/websocket/option.hpp>
-#include <boost/beast/websocket/rfc6455.hpp>
-#include <boost/beast/websocket/stream.hpp>
-#include <boost/beast/websocket/stream_fwd.hpp>
-#include <boost/beast/websocket/teardown.hpp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/detail/error.hpp b/contrib/restricted/boost/boost/beast/websocket/detail/error.hpp
deleted file mode 100644
index 57b837bd4c..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/detail/error.hpp
+++ /dev/null
@@ -1,78 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_DETAIL_ERROR_IPP
-#define BOOST_BEAST_WEBSOCKET_DETAIL_ERROR_IPP
-
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/core/string.hpp>
-
-namespace boost {
-
-namespace beast {
-namespace websocket {
-enum class error;
-enum class condition;
-} // websocket
-} // beast
-
-namespace system {
-template<>
-struct is_error_code_enum<beast::websocket::error>
-{
- static bool const value = true;
-};
-template<>
-struct is_error_condition_enum<beast::websocket::condition>
-{
- static bool const value = true;
-};
-} // system
-
-namespace beast {
-namespace websocket {
-namespace detail {
-
-class error_codes : public error_category
-{
-public:
- const char*
- name() const noexcept override;
-
- std::string
- message(int ev) const override;
-
- error_condition
- default_error_condition(int ev) const noexcept override;
-};
-
-class error_conditions : public error_category
-{
-public:
- const char*
- name() const noexcept override;
-
- std::string
- message(int cv) const override;
-};
-
-} // detail
-
-error_code
-make_error_code(error e);
-
-error_condition
-make_error_condition(condition c);
-
-} // websocket
-} // beast
-
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/detail/frame.hpp b/contrib/restricted/boost/boost/beast/websocket/detail/frame.hpp
deleted file mode 100644
index c3bd1690a9..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/detail/frame.hpp
+++ /dev/null
@@ -1,309 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_DETAIL_FRAME_HPP
-#define BOOST_BEAST_WEBSOCKET_DETAIL_FRAME_HPP
-
-#include <boost/beast/websocket/error.hpp>
-#include <boost/beast/websocket/rfc6455.hpp>
-#include <boost/beast/websocket/detail/utf8_checker.hpp>
-#include <boost/beast/core/buffers_suffix.hpp>
-#include <boost/beast/core/flat_static_buffer.hpp>
-#include <boost/beast/core/static_string.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/assert.hpp>
-#include <boost/endian/buffers.hpp>
-#include <cstdint>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-namespace detail {
-
-inline
-std::uint16_t
-big_uint16_to_native(void const* buf)
-{
- auto const p = reinterpret_cast<
- std::uint8_t const*>(buf);
- return (p[0]<<8) + p[1];
-}
-
-inline
-std::uint64_t
-big_uint64_to_native(void const* buf)
-{
- auto const p = reinterpret_cast<
- std::uint8_t const*>(buf);
- return
- (static_cast<std::uint64_t>(p[0])<<56) +
- (static_cast<std::uint64_t>(p[1])<<48) +
- (static_cast<std::uint64_t>(p[2])<<40) +
- (static_cast<std::uint64_t>(p[3])<<32) +
- (static_cast<std::uint64_t>(p[4])<<24) +
- (static_cast<std::uint64_t>(p[5])<<16) +
- (static_cast<std::uint64_t>(p[6])<< 8) +
- p[7];
-}
-
-inline
-std::uint32_t
-little_uint32_to_native(void const* buf)
-{
- auto const p = reinterpret_cast<
- std::uint8_t const*>(buf);
- return
- p[0] +
- (static_cast<std::uint32_t>(p[1])<< 8) +
- (static_cast<std::uint32_t>(p[2])<<16) +
- (static_cast<std::uint32_t>(p[3])<<24);
-}
-
-inline
-void
-native_to_little_uint32(std::uint32_t v, void* buf)
-{
- auto p = reinterpret_cast<std::uint8_t*>(buf);
- p[0] = v & 0xff;
- p[1] = (v >> 8) & 0xff;
- p[2] = (v >> 16) & 0xff;
- p[3] = (v >> 24) & 0xff;
-}
-
-// frame header opcodes
-enum class opcode : std::uint8_t
-{
- cont = 0,
- text = 1,
- binary = 2,
- rsv3 = 3,
- rsv4 = 4,
- rsv5 = 5,
- rsv6 = 6,
- rsv7 = 7,
- close = 8,
- ping = 9,
- pong = 10,
- crsvb = 11,
- crsvc = 12,
- crsvd = 13,
- crsve = 14,
- crsvf = 15
-};
-
-// Contents of a WebSocket frame header
-struct frame_header
-{
- std::uint64_t len;
- std::uint32_t key;
- opcode op;
- bool fin : 1;
- bool mask : 1;
- bool rsv1 : 1;
- bool rsv2 : 1;
- bool rsv3 : 1;
-};
-
-// holds the largest possible frame header
-using fh_buffer = flat_static_buffer<14>;
-
-// holds the largest possible control frame
-using frame_buffer =
- flat_static_buffer< 2 + 8 + 4 + 125 >;
-
-inline
-bool constexpr
-is_reserved(opcode op)
-{
- return
- (op >= opcode::rsv3 && op <= opcode::rsv7) ||
- (op >= opcode::crsvb && op <= opcode::crsvf);
-}
-
-inline
-bool constexpr
-is_valid(opcode op)
-{
- return op <= opcode::crsvf;
-}
-
-inline
-bool constexpr
-is_control(opcode op)
-{
- return op >= opcode::close;
-}
-
-inline
-bool
-is_valid_close_code(std::uint16_t v)
-{
- switch(v)
- {
- case close_code::normal: // 1000
- case close_code::going_away: // 1001
- case close_code::protocol_error: // 1002
- case close_code::unknown_data: // 1003
- case close_code::bad_payload: // 1007
- case close_code::policy_error: // 1008
- case close_code::too_big: // 1009
- case close_code::needs_extension: // 1010
- case close_code::internal_error: // 1011
- case close_code::service_restart: // 1012
- case close_code::try_again_later: // 1013
- return true;
-
- // explicitly reserved
- case close_code::reserved1: // 1004
- case close_code::no_status: // 1005
- case close_code::abnormal: // 1006
- case close_code::reserved2: // 1014
- case close_code::reserved3: // 1015
- return false;
- }
- // reserved
- if(v >= 1016 && v <= 2999)
- return false;
- // not used
- if(v <= 999)
- return false;
- return true;
-}
-
-//------------------------------------------------------------------------------
-
-// Write frame header to dynamic buffer
-//
-template<class DynamicBuffer>
-void
-write(DynamicBuffer& db, frame_header const& fh)
-{
- using boost::asio::buffer;
- using boost::asio::buffer_copy;
- using namespace boost::endian;
- std::size_t n;
- std::uint8_t b[14];
- b[0] = (fh.fin ? 0x80 : 0x00) | static_cast<std::uint8_t>(fh.op);
- if(fh.rsv1)
- b[0] |= 0x40;
- if(fh.rsv2)
- b[0] |= 0x20;
- if(fh.rsv3)
- b[0] |= 0x10;
- b[1] = fh.mask ? 0x80 : 0x00;
- if(fh.len <= 125)
- {
- b[1] |= fh.len;
- n = 2;
- }
- else if(fh.len <= 65535)
- {
- b[1] |= 126;
- ::new(&b[2]) big_uint16_buf_t{
- (std::uint16_t)fh.len};
- n = 4;
- }
- else
- {
- b[1] |= 127;
- ::new(&b[2]) big_uint64_buf_t{fh.len};
- n = 10;
- }
- if(fh.mask)
- {
- native_to_little_uint32(fh.key, &b[n]);
- n += 4;
- }
- db.commit(buffer_copy(
- db.prepare(n), buffer(b)));
-}
-
-// Read data from buffers
-// This is for ping and pong payloads
-//
-template<class Buffers>
-void
-read_ping(ping_data& data, Buffers const& bs)
-{
- using boost::asio::buffer_copy;
- using boost::asio::buffer_size;
- using boost::asio::mutable_buffer;
- BOOST_ASSERT(buffer_size(bs) <= data.max_size());
- data.resize(buffer_size(bs));
- buffer_copy(mutable_buffer{
- data.data(), data.size()}, bs);
-}
-
-// Read close_reason, return true on success
-// This is for the close payload
-//
-template<class Buffers>
-void
-read_close(
- close_reason& cr,
- Buffers const& bs,
- error_code& ec)
-{
- using boost::asio::buffer;
- using boost::asio::buffer_copy;
- using boost::asio::buffer_size;
- using namespace boost::endian;
- auto n = buffer_size(bs);
- BOOST_ASSERT(n <= 125);
- if(n == 0)
- {
- cr = close_reason{};
- ec.assign(0, ec.category());
- return;
- }
- if(n == 1)
- {
- // invalid payload size == 1
- ec = error::bad_close_size;
- return;
- }
- buffers_suffix<Buffers> cb(bs);
- {
- std::uint8_t b[2];
- buffer_copy(buffer(b), cb);
- cr.code = big_uint16_to_native(&b[0]);
- cb.consume(2);
- n -= 2;
- if(! is_valid_close_code(cr.code))
- {
- // invalid close code
- ec = error::bad_close_code;
- return;
- }
- }
- if(n > 0)
- {
- cr.reason.resize(n);
- buffer_copy(buffer(&cr.reason[0], n), cb);
- if(! check_utf8(
- cr.reason.data(), cr.reason.size()))
- {
- // not valid utf-8
- ec = error::bad_close_payload;
- return;
- }
- }
- else
- {
- cr.reason = "";
- }
- ec.assign(0, ec.category());
-}
-
-} // detail
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/detail/hybi13.hpp b/contrib/restricted/boost/boost/beast/websocket/detail/hybi13.hpp
deleted file mode 100644
index b9c67b8200..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/detail/hybi13.hpp
+++ /dev/null
@@ -1,75 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_DETAIL_HYBI13_HPP
-#define BOOST_BEAST_WEBSOCKET_DETAIL_HYBI13_HPP
-
-#include <boost/beast/core/static_string.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/core/detail/base64.hpp>
-#include <boost/beast/core/detail/sha1.hpp>
-#include <boost/assert.hpp>
-#include <array>
-#include <cstdint>
-#include <string>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-namespace detail {
-
-using sec_ws_key_type = static_string<
- beast::detail::base64::encoded_size(16)>;
-
-using sec_ws_accept_type = static_string<
- beast::detail::base64::encoded_size(20)>;
-
-template<class Gen>
-void
-make_sec_ws_key(sec_ws_key_type& key, Gen& g)
-{
- char a[16];
- for(int i = 0; i < 16; i += 4)
- {
- auto const v = g();
- a[i ] = v & 0xff;
- a[i+1] = (v >> 8) & 0xff;
- a[i+2] = (v >> 16) & 0xff;
- a[i+3] = (v >> 24) & 0xff;
- }
- key.resize(key.max_size());
- key.resize(beast::detail::base64::encode(
- key.data(), &a[0], 16));
-}
-
-template<class = void>
-void
-make_sec_ws_accept(sec_ws_accept_type& accept,
- string_view key)
-{
- BOOST_ASSERT(key.size() <= sec_ws_key_type::max_size_n);
- static_string<sec_ws_key_type::max_size_n + 36> m(key);
- m.append("258EAFA5-E914-47DA-95CA-C5AB0DC85B11");
- beast::detail::sha1_context ctx;
- beast::detail::init(ctx);
- beast::detail::update(ctx, m.data(), m.size());
- char digest[beast::detail::sha1_context::digest_size];
- beast::detail::finish(ctx, &digest[0]);
- accept.resize(accept.max_size());
- accept.resize(beast::detail::base64::encode(
- accept.data(), &digest[0], sizeof(digest)));
-}
-
-} // detail
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/detail/mask.hpp b/contrib/restricted/boost/boost/beast/websocket/detail/mask.hpp
deleted file mode 100644
index 8958d793b8..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/detail/mask.hpp
+++ /dev/null
@@ -1,148 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_DETAIL_MASK_HPP
-#define BOOST_BEAST_WEBSOCKET_DETAIL_MASK_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <array>
-#include <climits>
-#include <cstdint>
-#include <random>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-namespace detail {
-
-// Pseudo-random source of mask keys
-//
-template<class Generator>
-class maskgen_t
-{
- Generator g_;
-
-public:
- using result_type =
- typename Generator::result_type;
-
- maskgen_t();
-
- result_type
- operator()() noexcept;
-
- void
- rekey();
-};
-
-template<class Generator>
-maskgen_t<Generator>::maskgen_t()
-{
- rekey();
-}
-
-template<class Generator>
-auto
-maskgen_t<Generator>::operator()() noexcept ->
- result_type
-{
- for(;;)
- if(auto key = g_())
- return key;
-}
-
-template<class _>
-void
-maskgen_t<_>::rekey()
-{
- std::random_device rng;
-#if 0
- std::array<std::uint32_t, 32> e;
- for(auto& i : e)
- i = rng();
- // VFALCO This constructor causes
- // address sanitizer to fail, no idea why.
- std::seed_seq ss(e.begin(), e.end());
- g_.seed(ss);
-#else
- g_.seed(rng());
-#endif
-}
-
-// VFALCO NOTE This generator has 5KB of state!
-//using maskgen = maskgen_t<std::mt19937>;
-using maskgen = maskgen_t<std::minstd_rand>;
-
-//------------------------------------------------------------------------------
-
-using prepared_key = std::array<unsigned char, 4>;
-
-inline
-void
-prepare_key(prepared_key& prepared, std::uint32_t key)
-{
- prepared[0] = (key >> 0) & 0xff;
- prepared[1] = (key >> 8) & 0xff;
- prepared[2] = (key >> 16) & 0xff;
- prepared[3] = (key >> 24) & 0xff;
-}
-
-template<std::size_t N>
-void
-rol(std::array<unsigned char, N>& v, std::size_t n)
-{
- auto v0 = v;
- for(std::size_t i = 0; i < v.size(); ++i )
- v[i] = v0[(i + n) % v.size()];
-}
-
-// Apply mask in place
-//
-inline
-void
-mask_inplace(boost::asio::mutable_buffer& b, prepared_key& key)
-{
- auto n = b.size();
- auto mask = key; // avoid aliasing
- auto p = reinterpret_cast<unsigned char*>(b.data());
- while(n >= 4)
- {
- for(int i = 0; i < 4; ++i)
- p[i] ^= mask[i];
- p += 4;
- n -= 4;
- }
- if(n > 0)
- {
- for(std::size_t i = 0; i < n; ++i)
- p[i] ^= mask[i];
- rol(key, n);
- }
-}
-
-// Apply mask in place
-//
-template<class MutableBuffers, class KeyType>
-void
-mask_inplace(MutableBuffers const& bs, KeyType& key)
-{
- for(boost::asio::mutable_buffer b :
- beast::detail::buffers_range(bs))
- mask_inplace(b, key);
-}
-
-} // detail
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/detail/pausation.hpp b/contrib/restricted/boost/boost/beast/websocket/detail/pausation.hpp
deleted file mode 100644
index e3870b038a..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/detail/pausation.hpp
+++ /dev/null
@@ -1,162 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_DETAIL_PAUSATION_HPP
-#define BOOST_BEAST_WEBSOCKET_DETAIL_PAUSATION_HPP
-
-#include <boost/beast/core/detail/allocator.hpp>
-#include <boost/asio/associated_allocator.hpp>
-#include <boost/assert.hpp>
-#include <memory>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-namespace detail {
-
-// A container that holds a suspended, asynchronous composed
-// operation. The contained object may be invoked later to
-// resume the operation, or the container may be destroyed.
-//
-class pausation
-{
- struct handler
- {
- handler() = default;
- handler(handler &&) = delete;
- handler(handler const&) = delete;
- virtual ~handler() = default;
- virtual void destroy() = 0;
- virtual void invoke() = 0;
- };
-
- template<class Handler>
- class impl : public handler
- {
- Handler h_;
-
- public:
- template<class DeducedHandler>
- impl(DeducedHandler&& h)
- : h_(std::forward<DeducedHandler>(h))
- {
- }
-
- void
- destroy() override
- {
- Handler h(std::move(h_));
- typename beast::detail::allocator_traits<
- boost::asio::associated_allocator_t<
- Handler>>::template rebind_alloc<impl> alloc{
- boost::asio::get_associated_allocator(h)};
- beast::detail::allocator_traits<
- decltype(alloc)>::destroy(alloc, this);
- beast::detail::allocator_traits<
- decltype(alloc)>::deallocate(alloc, this, 1);
- }
-
- void
- invoke() override
- {
- Handler h(std::move(h_));
- typename beast::detail::allocator_traits<
- boost::asio::associated_allocator_t<
- Handler>>::template rebind_alloc<impl> alloc{
- boost::asio::get_associated_allocator(h)};
- beast::detail::allocator_traits<
- decltype(alloc)>::destroy(alloc, this);
- beast::detail::allocator_traits<
- decltype(alloc)>::deallocate(alloc, this, 1);
- h();
- }
- };
-
- handler* h_ = nullptr;
-
-public:
- pausation() = default;
- pausation(pausation const&) = delete;
- pausation& operator=(pausation const&) = delete;
-
- ~pausation()
- {
- if(h_)
- h_->destroy();
- }
-
- pausation(pausation&& other)
- {
- boost::ignore_unused(other);
- BOOST_ASSERT(! other.h_);
- }
-
- pausation&
- operator=(pausation&& other)
- {
- boost::ignore_unused(other);
- BOOST_ASSERT(! h_);
- BOOST_ASSERT(! other.h_);
- return *this;
- }
-
- template<class CompletionHandler>
- void
- emplace(CompletionHandler&& handler);
-
- explicit
- operator bool() const
- {
- return h_ != nullptr;
- }
-
- bool
- maybe_invoke()
- {
- if(h_)
- {
- auto const h = h_;
- h_ = nullptr;
- h->invoke();
- return true;
- }
- return false;
- }
-};
-
-template<class CompletionHandler>
-void
-pausation::emplace(CompletionHandler&& handler)
-{
- BOOST_ASSERT(! h_);
- typename beast::detail::allocator_traits<
- boost::asio::associated_allocator_t<
- CompletionHandler>>::template rebind_alloc<
- impl<CompletionHandler>> alloc{
- boost::asio::get_associated_allocator(handler)};
- using A = decltype(alloc);
- auto const d =
- [&alloc](impl<CompletionHandler>* p)
- {
- beast::detail::allocator_traits<A>::deallocate(alloc, p, 1);
- };
- std::unique_ptr<impl<CompletionHandler>, decltype(d)> p{
- beast::detail::allocator_traits<A>::allocate(alloc, 1), d};
- beast::detail::allocator_traits<A>::construct(
- alloc, p.get(), std::forward<CompletionHandler>(handler));
- h_ = p.release();
-}
-
-} // detail
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/detail/pmd_extension.hpp b/contrib/restricted/boost/boost/beast/websocket/detail/pmd_extension.hpp
deleted file mode 100644
index ce4f2425cf..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/detail/pmd_extension.hpp
+++ /dev/null
@@ -1,364 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_DETAIL_PMD_EXTENSION_HPP
-#define BOOST_BEAST_WEBSOCKET_DETAIL_PMD_EXTENSION_HPP
-
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/core/buffers_suffix.hpp>
-#include <boost/beast/core/read_size.hpp>
-#include <boost/beast/zlib/deflate_stream.hpp>
-#include <boost/beast/zlib/inflate_stream.hpp>
-#include <boost/beast/websocket/option.hpp>
-#include <boost/beast/http/rfc7230.hpp>
-#include <boost/asio/buffer.hpp>
-#include <utility>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-namespace detail {
-
-// permessage-deflate offer parameters
-//
-// "context takeover" means:
-// preserve sliding window across messages
-//
-struct pmd_offer
-{
- bool accept;
-
- // 0 = absent, or 8..15
- int server_max_window_bits;
-
- // -1 = present, 0 = absent, or 8..15
- int client_max_window_bits;
-
- // `true` if server_no_context_takeover offered
- bool server_no_context_takeover;
-
- // `true` if client_no_context_takeover offered
- bool client_no_context_takeover;
-};
-
-template<class = void>
-int
-parse_bits(string_view s)
-{
- if(s.size() == 0)
- return -1;
- if(s.size() > 2)
- return -1;
- if(s[0] < '1' || s[0] > '9')
- return -1;
- unsigned i = 0;
- for(auto c : s)
- {
- if(c < '0' || c > '9')
- return -1;
- auto const i0 = i;
- i = 10 * i + (c - '0');
- if(i < i0)
- return -1;
- }
- return static_cast<int>(i);
-}
-
-// Parse permessage-deflate request fields
-//
-template<class Allocator>
-void
-pmd_read(pmd_offer& offer,
- http::basic_fields<Allocator> const& fields)
-{
- offer.accept = false;
- offer.server_max_window_bits= 0;
- offer.client_max_window_bits = 0;
- offer.server_no_context_takeover = false;
- offer.client_no_context_takeover = false;
-
- http::ext_list list{
- fields["Sec-WebSocket-Extensions"]};
- for(auto const& ext : list)
- {
- if(iequals(ext.first, "permessage-deflate"))
- {
- for(auto const& param : ext.second)
- {
- if(iequals(param.first,
- "server_max_window_bits"))
- {
- if(offer.server_max_window_bits != 0)
- {
- // The negotiation offer contains multiple
- // extension parameters with the same name.
- //
- return; // MUST decline
- }
- if(param.second.empty())
- {
- // The negotiation offer extension
- // parameter is missing the value.
- //
- return; // MUST decline
- }
- offer.server_max_window_bits =
- parse_bits(param.second);
- if( offer.server_max_window_bits < 8 ||
- offer.server_max_window_bits > 15)
- {
- // The negotiation offer contains an
- // extension parameter with an invalid value.
- //
- return; // MUST decline
- }
- }
- else if(iequals(param.first,
- "client_max_window_bits"))
- {
- if(offer.client_max_window_bits != 0)
- {
- // The negotiation offer contains multiple
- // extension parameters with the same name.
- //
- return; // MUST decline
- }
- if(! param.second.empty())
- {
- offer.client_max_window_bits =
- parse_bits(param.second);
- if( offer.client_max_window_bits < 8 ||
- offer.client_max_window_bits > 15)
- {
- // The negotiation offer contains an
- // extension parameter with an invalid value.
- //
- return; // MUST decline
- }
- }
- else
- {
- offer.client_max_window_bits = -1;
- }
- }
- else if(iequals(param.first,
- "server_no_context_takeover"))
- {
- if(offer.server_no_context_takeover)
- {
- // The negotiation offer contains multiple
- // extension parameters with the same name.
- //
- return; // MUST decline
- }
- if(! param.second.empty())
- {
- // The negotiation offer contains an
- // extension parameter with an invalid value.
- //
- return; // MUST decline
- }
- offer.server_no_context_takeover = true;
- }
- else if(iequals(param.first,
- "client_no_context_takeover"))
- {
- if(offer.client_no_context_takeover)
- {
- // The negotiation offer contains multiple
- // extension parameters with the same name.
- //
- return; // MUST decline
- }
- if(! param.second.empty())
- {
- // The negotiation offer contains an
- // extension parameter with an invalid value.
- //
- return; // MUST decline
- }
- offer.client_no_context_takeover = true;
- }
- else
- {
- // The negotiation offer contains an extension
- // parameter not defined for use in an offer.
- //
- return; // MUST decline
- }
- }
- offer.accept = true;
- return;
- }
- }
-}
-
-// Set permessage-deflate fields for a client offer
-//
-template<class Allocator>
-void
-pmd_write(http::basic_fields<Allocator>& fields,
- pmd_offer const& offer)
-{
- static_string<512> s;
- s = "permessage-deflate";
- if(offer.server_max_window_bits != 0)
- {
- if(offer.server_max_window_bits != -1)
- {
- s += "; server_max_window_bits=";
- s += to_static_string(
- offer.server_max_window_bits);
- }
- else
- {
- s += "; server_max_window_bits";
- }
- }
- if(offer.client_max_window_bits != 0)
- {
- if(offer.client_max_window_bits != -1)
- {
- s += "; client_max_window_bits=";
- s += to_static_string(
- offer.client_max_window_bits);
- }
- else
- {
- s += "; client_max_window_bits";
- }
- }
- if(offer.server_no_context_takeover)
- {
- s += "; server_no_context_takeover";
- }
- if(offer.client_no_context_takeover)
- {
- s += "; client_no_context_takeover";
- }
- fields.set(http::field::sec_websocket_extensions, s);
-}
-
-// Negotiate a permessage-deflate client offer
-//
-template<class Allocator>
-void
-pmd_negotiate(
- http::basic_fields<Allocator>& fields,
- pmd_offer& config,
- pmd_offer const& offer,
- permessage_deflate const& o)
-{
- if(! (offer.accept && o.server_enable))
- {
- config.accept = false;
- return;
- }
- config.accept = true;
-
- static_string<512> s = "permessage-deflate";
-
- config.server_no_context_takeover =
- offer.server_no_context_takeover ||
- o.server_no_context_takeover;
- if(config.server_no_context_takeover)
- s += "; server_no_context_takeover";
-
- config.client_no_context_takeover =
- o.client_no_context_takeover ||
- offer.client_no_context_takeover;
- if(config.client_no_context_takeover)
- s += "; client_no_context_takeover";
-
- if(offer.server_max_window_bits != 0)
- config.server_max_window_bits = (std::min)(
- offer.server_max_window_bits,
- o.server_max_window_bits);
- else
- config.server_max_window_bits =
- o.server_max_window_bits;
- if(config.server_max_window_bits < 15)
- {
- // ZLib's deflateInit silently treats 8 as
- // 9 due to a bug, so prevent 8 from being used.
- //
- if(config.server_max_window_bits < 9)
- config.server_max_window_bits = 9;
-
- s += "; server_max_window_bits=";
- s += to_static_string(
- config.server_max_window_bits);
- }
-
- switch(offer.client_max_window_bits)
- {
- case -1:
- // extension parameter is present with no value
- config.client_max_window_bits =
- o.client_max_window_bits;
- if(config.client_max_window_bits < 15)
- {
- s += "; client_max_window_bits=";
- s += to_static_string(
- config.client_max_window_bits);
- }
- break;
-
- case 0:
- /* extension parameter is absent.
-
- If a received extension negotiation offer doesn't have the
- "client_max_window_bits" extension parameter, the corresponding
- extension negotiation response to the offer MUST NOT include the
- "client_max_window_bits" extension parameter.
- */
- if(o.client_max_window_bits == 15)
- config.client_max_window_bits = 15;
- else
- config.accept = false;
- break;
-
- default:
- // extension parameter has value in [8..15]
- config.client_max_window_bits = (std::min)(
- o.client_max_window_bits,
- offer.client_max_window_bits);
- s += "; client_max_window_bits=";
- s += to_static_string(
- config.client_max_window_bits);
- break;
- }
- if(config.accept)
- fields.set(http::field::sec_websocket_extensions, s);
-}
-
-// Normalize the server's response
-//
-inline
-void
-pmd_normalize(pmd_offer& offer)
-{
- if(offer.accept)
- {
- if( offer.server_max_window_bits == 0)
- offer.server_max_window_bits = 15;
-
- if( offer.client_max_window_bits == 0 ||
- offer.client_max_window_bits == -1)
- offer.client_max_window_bits = 15;
- }
-}
-
-} // detail
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/detail/stream_base.hpp b/contrib/restricted/boost/boost/beast/websocket/detail/stream_base.hpp
deleted file mode 100644
index 2e93cce3d4..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/detail/stream_base.hpp
+++ /dev/null
@@ -1,221 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_STREAM_BASE_HPP
-#define BOOST_BEAST_WEBSOCKET_STREAM_BASE_HPP
-
-#include <boost/beast/websocket/option.hpp>
-#include <boost/beast/websocket/detail/pmd_extension.hpp>
-#include <boost/beast/zlib/deflate_stream.hpp>
-#include <boost/beast/zlib/inflate_stream.hpp>
-#include <boost/beast/core/buffers_suffix.hpp>
-#include <boost/beast/core/error.hpp>
-#include <boost/asio/buffer.hpp>
-#include <cstdint>
-#include <memory>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-namespace detail {
-
-// used to order reads and writes
-class soft_mutex
-{
- int id_ = 0;
-
-public:
- soft_mutex() = default;
- soft_mutex(soft_mutex const&) = delete;
- soft_mutex& operator=(soft_mutex const&) = delete;
-
- soft_mutex(soft_mutex&& other) noexcept
- : id_(other.id_)
- {
- other.id_ = 0;
- }
-
- soft_mutex& operator=(soft_mutex&& other) noexcept
- {
- id_ = other.id_;
- other.id_ = 0;
- return *this;
- }
-
- // VFALCO I'm not too happy that this function is needed
- void reset()
- {
- id_ = 0;
- }
-
- bool is_locked() const
- {
- return id_ != 0;
- }
-
- template<class T>
- bool is_locked(T const*) const
- {
- return id_ == T::id;
- }
-
- template<class T>
- void lock(T const*)
- {
- BOOST_ASSERT(id_ == 0);
- id_ = T::id;
- }
-
- template<class T>
- void unlock(T const*)
- {
- BOOST_ASSERT(id_ == T::id);
- id_ = 0;
- }
-
- template<class T>
- bool try_lock(T const*)
- {
- // If this assert goes off it means you are attempting to
- // simultaneously initiate more than one of same asynchronous
- // operation, which is not allowed. For example, you must wait
- // for an async_read to complete before performing another
- // async_read.
- //
- BOOST_ASSERT(id_ != T::id);
- if(id_ != 0)
- return false;
- id_ = T::id;
- return true;
- }
-
- template<class T>
- bool try_unlock(T const*)
- {
- if(id_ != T::id)
- return false;
- id_ = 0;
- return true;
- }
-};
-
-template<bool deflateSupported>
-struct stream_base
-{
- // State information for the permessage-deflate extension
- struct pmd_type
- {
- // `true` if current read message is compressed
- bool rd_set = false;
-
- zlib::deflate_stream zo;
- zlib::inflate_stream zi;
- };
-
- std::unique_ptr<pmd_type> pmd_; // pmd settings or nullptr
- permessage_deflate pmd_opts_; // local pmd options
- detail::pmd_offer pmd_config_; // offer (client) or negotiation (server)
-
- // return `true` if current message is deflated
- bool
- rd_deflated() const
- {
- return pmd_ && pmd_->rd_set;
- }
-
- // set whether current message is deflated
- // returns `false` on protocol violation
- bool
- rd_deflated(bool rsv1)
- {
- if(pmd_)
- {
- pmd_->rd_set = rsv1;
- return true;
- }
- return ! rsv1; // pmd not negotiated
- }
-
- template<class ConstBufferSequence>
- bool
- deflate(
- boost::asio::mutable_buffer& out,
- buffers_suffix<ConstBufferSequence>& cb,
- bool fin,
- std::size_t& total_in,
- error_code& ec);
-
- void
- do_context_takeover_write(role_type role);
-
- void
- inflate(
- zlib::z_params& zs,
- zlib::Flush flush,
- error_code& ec);
-
- void
- do_context_takeover_read(role_type role);
-};
-
-template<>
-struct stream_base<false>
-{
- // These stubs are for avoiding linking in the zlib
- // code when permessage-deflate is not enabled.
-
- bool
- rd_deflated() const
- {
- return false;
- }
-
- bool
- rd_deflated(bool rsv1)
- {
- return ! rsv1;
- }
-
- template<class ConstBufferSequence>
- bool
- deflate(
- boost::asio::mutable_buffer&,
- buffers_suffix<ConstBufferSequence>&,
- bool,
- std::size_t&,
- error_code&)
- {
- return false;
- }
-
- void
- do_context_takeover_write(role_type)
- {
- }
-
- void
- inflate(
- zlib::z_params&,
- zlib::Flush,
- error_code&)
- {
- }
-
- void
- do_context_takeover_read(role_type)
- {
- }
-};
-
-} // detail
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/detail/type_traits.hpp b/contrib/restricted/boost/boost/beast/websocket/detail/type_traits.hpp
deleted file mode 100644
index 6913174fd0..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/detail/type_traits.hpp
+++ /dev/null
@@ -1,36 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_DETAIL_TYPE_TRAITS_HPP
-#define BOOST_BEAST_WEBSOCKET_DETAIL_TYPE_TRAITS_HPP
-
-#include <boost/beast/websocket/rfc6455.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-namespace detail {
-
-template<class F>
-using is_request_decorator =
- typename beast::detail::is_invocable<F,
- void(request_type&)>::type;
-
-template<class F>
-using is_response_decorator =
- typename beast::detail::is_invocable<F,
- void(response_type&)>::type;
-
-} // detail
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/detail/utf8_checker.hpp b/contrib/restricted/boost/boost/beast/websocket/detail/utf8_checker.hpp
deleted file mode 100644
index 61c241bc19..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/detail/utf8_checker.hpp
+++ /dev/null
@@ -1,344 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_DETAIL_UTF8_CHECKER_HPP
-#define BOOST_BEAST_WEBSOCKET_DETAIL_UTF8_CHECKER_HPP
-
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/asio/buffer.hpp>
-#include <boost/assert.hpp>
-#include <algorithm>
-#include <cstdint>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-namespace detail {
-
-/** A UTF8 validator.
-
- This validator can be used to check if a buffer containing UTF8 text is
- valid. The write function may be called incrementally with segmented UTF8
- sequences. The finish function determines if all processed text is valid.
-*/
-template<class = void>
-class utf8_checker_t
-{
- std::size_t need_ = 0; // chars we need to finish the code point
- std::uint8_t* p_ = cp_; // current position in temp buffer
- std::uint8_t cp_[4]; // a temp buffer for the code point
-
-public:
- /** Prepare to process text as valid utf8
- */
- void
- reset();
-
- /** Check that all processed text is valid utf8
- */
- bool
- finish();
-
- /** Check if text is valid UTF8
-
- @return `true` if the text is valid utf8 or false otherwise.
- */
- bool
- write(std::uint8_t const* in, std::size_t size);
-
- /** Check if text is valid UTF8
-
- @return `true` if the text is valid utf8 or false otherwise.
- */
- template<class ConstBufferSequence>
- bool
- write(ConstBufferSequence const& bs);
-};
-
-template<class _>
-void
-utf8_checker_t<_>::
-reset()
-{
- need_ = 0;
- p_ = cp_;
-}
-
-template<class _>
-bool
-utf8_checker_t<_>::
-finish()
-{
- auto const success = need_ == 0;
- reset();
- return success;
-}
-
-template<class _>
-template<class ConstBufferSequence>
-bool
-utf8_checker_t<_>::
-write(ConstBufferSequence const& bs)
-{
- static_assert(boost::asio::is_const_buffer_sequence<ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- for(auto b : beast::detail::buffers_range(bs))
- if(! write(reinterpret_cast<
- std::uint8_t const*>(b.data()),
- b.size()))
- return false;
- return true;
-}
-
-template<class _>
-bool
-utf8_checker_t<_>::
-write(std::uint8_t const* in, std::size_t size)
-{
- auto const valid =
- [](std::uint8_t const*& p)
- {
- if(p[0] < 128)
- {
- ++p;
- return true;
- }
- if((p[0] & 0xe0) == 0xc0)
- {
- if( (p[1] & 0xc0) != 0x80 ||
- (p[0] & 0xfe) == 0xc0) // overlong
- return false;
- p += 2;
- return true;
- }
- if((p[0] & 0xf0) == 0xe0)
- {
- if( (p[1] & 0xc0) != 0x80
- || (p[2] & 0xc0) != 0x80
- || (p[0] == 0xe0 && (p[1] & 0xe0) == 0x80) // overlong
- || (p[0] == 0xed && (p[1] & 0xe0) == 0xa0) // surrogate
- //|| (p[0] == 0xef && p[1] == 0xbf && (p[2] & 0xfe) == 0xbe) // U+FFFE or U+FFFF
- )
- return false;
- p += 3;
- return true;
- }
- if((p[0] & 0xf8) == 0xf0)
- {
- if( (p[1] & 0xc0) != 0x80
- || (p[2] & 0xc0) != 0x80
- || (p[3] & 0xc0) != 0x80
- || (p[0] == 0xf0 && (p[1] & 0xf0) == 0x80) // overlong
- || (p[0] == 0xf4 && p[1] > 0x8f) || p[0] > 0xf4 // > U+10FFFF
- )
- return false;
- p += 4;
- return true;
- }
- return false;
- };
- auto const fail_fast =
- [&]()
- {
- auto const n = p_ - cp_;
- switch(n)
- {
- default:
- BOOST_ASSERT(false);
- BOOST_FALLTHROUGH;
- case 1:
- cp_[1] = 0x81;
- BOOST_FALLTHROUGH;
- case 2:
- cp_[2] = 0x81;
- BOOST_FALLTHROUGH;
- case 3:
- cp_[3] = 0x81;
- break;
- }
- std::uint8_t const* p = cp_;
- return ! valid(p);
- };
- auto const needed =
- [](std::uint8_t const v)
- {
- if(v < 128)
- return 1;
- if(v < 192)
- return 0;
- if(v < 224)
- return 2;
- if(v < 240)
- return 3;
- if(v < 248)
- return 4;
- return 0;
- };
-
- auto const end = in + size;
-
- // Finish up any incomplete code point
- if(need_ > 0)
- {
- // Calculate what we have
- auto n = (std::min)(size, need_);
- size -= n;
- need_ -= n;
-
- // Add characters to the code point
- while(n--)
- *p_++ = *in++;
- BOOST_ASSERT(p_ <= cp_ + 5);
-
- // Still incomplete?
- if(need_ > 0)
- {
- // Incomplete code point
- BOOST_ASSERT(in == end);
-
- // Do partial validation on the incomplete
- // code point, this is called "Fail fast"
- // in Autobahn|Testsuite parlance.
- return ! fail_fast();
- }
-
- // Complete code point, validate it
- std::uint8_t const* p = &cp_[0];
- if(! valid(p))
- return false;
- p_ = cp_;
- }
-
- if(size <= sizeof(std::size_t))
- goto slow;
-
- // Align `in` to sizeof(std::size_t) boundary
- {
- auto const in0 = in;
- auto last = reinterpret_cast<std::uint8_t const*>(
- ((reinterpret_cast<std::uintptr_t>(in) + sizeof(std::size_t) - 1) /
- sizeof(std::size_t)) * sizeof(std::size_t));
-
- // Check one character at a time for low-ASCII
- while(in < last)
- {
- if(*in & 0x80)
- {
- // Not low-ASCII so switch to slow loop
- size = size - (in - in0);
- goto slow;
- }
- ++in;
- }
- size = size - (in - in0);
- }
-
- // Fast loop: Process 4 or 8 low-ASCII characters at a time
- {
- auto const in0 = in;
- auto last = in + size - 7;
- auto constexpr mask = static_cast<
- std::size_t>(0x8080808080808080 & ~std::size_t{0});
- while(in < last)
- {
-#if 0
- std::size_t temp;
- std::memcpy(&temp, in, sizeof(temp));
- if((temp & mask) != 0)
-#else
- // Technically UB but works on all known platforms
- if((*reinterpret_cast<std::size_t const*>(in) & mask) != 0)
-#endif
- {
- size = size - (in - in0);
- goto slow;
- }
- in += sizeof(std::size_t);
- }
- // There's at least one more full code point left
- last += 4;
- while(in < last)
- if(! valid(in))
- return false;
- goto tail;
- }
-
-slow:
- // Slow loop: Full validation on one code point at a time
- {
- auto last = in + size - 3;
- while(in < last)
- if(! valid(in))
- return false;
- }
-
-tail:
- // Handle the remaining bytes. The last
- // characters could split a code point so
- // we save the partial code point for later.
- //
- // On entry to the loop, `in` points to the
- // beginning of a code point.
- //
- for(;;)
- {
- // Number of chars left
- auto n = end - in;
- if(! n)
- break;
-
- // Chars we need to finish this code point
- auto const need = needed(*in);
- if(need == 0)
- return false;
- if(need <= n)
- {
- // Check a whole code point
- if(! valid(in))
- return false;
- }
- else
- {
- // Calculate how many chars we need
- // to finish this partial code point
- need_ = need - n;
-
- // Save the partial code point
- while(n--)
- *p_++ = *in++;
- BOOST_ASSERT(in == end);
- BOOST_ASSERT(p_ <= cp_ + 5);
-
- // Do partial validation on the incomplete
- // code point, this is called "Fail fast"
- // in Autobahn|Testsuite parlance.
- return ! fail_fast();
- }
- }
- return true;
-}
-
-using utf8_checker = utf8_checker_t<>;
-
-template<class = void>
-bool
-check_utf8(char const* p, std::size_t n)
-{
- utf8_checker c;
- if(! c.write(reinterpret_cast<const uint8_t*>(p), n))
- return false;
- return c.finish();
-}
-
-} // detail
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/error.hpp b/contrib/restricted/boost/boost/beast/websocket/error.hpp
deleted file mode 100644
index d4e5197100..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/error.hpp
+++ /dev/null
@@ -1,254 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_ERROR_HPP
-#define BOOST_BEAST_WEBSOCKET_ERROR_HPP
-
-#include <boost/beast/websocket/detail/error.hpp>
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/error.hpp>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-/// Error codes returned from @ref beast::websocket::stream operations.
-enum class error
-{
- /** The WebSocket stream was gracefully closed at both endpoints
- */
- closed = 1,
-
-/* The error codes error::failed and error::handshake_failed
- are no longer in use. Please change your code to compare values
- of type error_code against condition::handshake_failed
- and condition::protocol_violation instead.
-
- Apologies for the inconvenience.
-
- - VFALCO
-*/
-#if ! BOOST_BEAST_DOXYGEN
- unused1 = 2, // failed
- unused2 = 3, // handshake_failed
-#endif
-
- /** The WebSocket operation caused a dynamic buffer overflow
- */
- buffer_overflow,
-
- /** The WebSocket stream produced an incomplete deflate block
- */
- partial_deflate_block,
-
- /** The WebSocket message exceeded the locally configured limit
- */
- message_too_big,
-
- //
- // Handshake failure errors
- //
- // These will compare equal to condition::handshake_failed
- //
-
- /** The WebSocket handshake was not HTTP/1.1
-
- Error codes with this value will compare equal to @ref condition::handshake_failed
- */
- bad_http_version,
-
- /** The WebSocket handshake method was not GET
-
- Error codes with this value will compare equal to @ref condition::handshake_failed
- */
- bad_method,
-
- /** The WebSocket handshake Host field is missing
-
- Error codes with this value will compare equal to @ref condition::handshake_failed
- */
- no_host,
-
- /** The WebSocket handshake Connection field is missing
-
- Error codes with this value will compare equal to @ref condition::handshake_failed
- */
- no_connection,
-
- /** The WebSocket handshake Connection field is missing the upgrade token
-
- Error codes with this value will compare equal to @ref condition::handshake_failed
- */
- no_connection_upgrade,
-
- /** The WebSocket handshake Upgrade field is missing
-
- Error codes with this value will compare equal to @ref condition::handshake_failed
- */
- no_upgrade,
-
- /** The WebSocket handshake Upgrade field is missing the websocket token
-
- Error codes with this value will compare equal to @ref condition::handshake_failed
- */
- no_upgrade_websocket,
-
- /** The WebSocket handshake Sec-WebSocket-Key field is missing
-
- Error codes with this value will compare equal to @ref condition::handshake_failed
- */
- no_sec_key,
-
- /** The WebSocket handshake Sec-WebSocket-Key field is invalid
-
- Error codes with this value will compare equal to @ref condition::handshake_failed
- */
- bad_sec_key,
-
- /** The WebSocket handshake Sec-WebSocket-Version field is missing
-
- Error codes with this value will compare equal to @ref condition::handshake_failed
- */
- no_sec_version,
-
- /** The WebSocket handshake Sec-WebSocket-Version field is invalid
-
- Error codes with this value will compare equal to @ref condition::handshake_failed
- */
- bad_sec_version,
-
- /** The WebSocket handshake Sec-WebSocket-Accept field is missing
-
- Error codes with this value will compare equal to @ref condition::handshake_failed
- */
- no_sec_accept,
-
- /** The WebSocket handshake Sec-WebSocket-Accept field is invalid
-
- Error codes with this value will compare equal to @ref condition::handshake_failed
- */
- bad_sec_accept,
-
- /** The WebSocket handshake was declined by the remote peer
-
- Error codes with this value will compare equal to @ref condition::handshake_failed
- */
- upgrade_declined,
-
- //
- // Protocol errors
- //
- // These will compare equal to condition::protocol_violation
- //
-
- /** The WebSocket frame contained an illegal opcode
-
- Error codes with this value will compare equal to @ref condition::protocol_violation
- */
- bad_opcode,
-
- /** The WebSocket data frame was unexpected
-
- Error codes with this value will compare equal to @ref condition::protocol_violation
- */
- bad_data_frame,
-
- /** The WebSocket continuation frame was unexpected
-
- Error codes with this value will compare equal to @ref condition::protocol_violation
- */
- bad_continuation,
-
- /** The WebSocket frame contained illegal reserved bits
-
- Error codes with this value will compare equal to @ref condition::protocol_violation
- */
- bad_reserved_bits,
-
- /** The WebSocket control frame was fragmented
-
- Error codes with this value will compare equal to @ref condition::protocol_violation
- */
- bad_control_fragment,
-
- /** The WebSocket control frame size was invalid
-
- Error codes with this value will compare equal to @ref condition::protocol_violation
- */
- bad_control_size,
-
- /** The WebSocket frame was unmasked
-
- Error codes with this value will compare equal to @ref condition::protocol_violation
- */
- bad_unmasked_frame,
-
- /** The WebSocket frame was masked
-
- Error codes with this value will compare equal to @ref condition::protocol_violation
- */
- bad_masked_frame,
-
- /** The WebSocket frame size was not canonical
-
- Error codes with this value will compare equal to @ref condition::protocol_violation
- */
- bad_size,
-
- /** The WebSocket frame payload was not valid utf8
-
- Error codes with this value will compare equal to @ref condition::protocol_violation
- */
- bad_frame_payload,
-
- /** The WebSocket close frame reason code was invalid
-
- Error codes with this value will compare equal to @ref condition::protocol_violation
- */
- bad_close_code,
-
- /** The WebSocket close frame payload size was invalid
-
- Error codes with this value will compare equal to @ref condition::protocol_violation
- */
- bad_close_size,
-
- /** The WebSocket close frame payload was not valid utf8
-
- Error codes with this value will compare equal to @ref condition::protocol_violation
- */
- bad_close_payload
-};
-
-/// Error conditions corresponding to sets of error codes.
-enum class condition
-{
- /** The WebSocket handshake failed
-
- This condition indicates that the WebSocket handshake failed. If
- the corresponding HTTP response indicates the keep-alive behavior,
- then the handshake may be reattempted.
- */
- handshake_failed = 1,
-
- /** A WebSocket protocol violation occurred
-
- This condition indicates that the remote peer on the WebSocket
- connection sent data which violated the protocol.
- */
- protocol_violation
- };
-
-} // websocket
-} // beast
-} // boost
-
-#include <boost/beast/websocket/impl/error.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/impl/accept.ipp b/contrib/restricted/boost/boost/beast/websocket/impl/accept.ipp
deleted file mode 100644
index 9daf7b311b..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/impl/accept.ipp
+++ /dev/null
@@ -1,782 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_IMPL_ACCEPT_IPP
-#define BOOST_BEAST_WEBSOCKET_IMPL_ACCEPT_IPP
-
-#include <boost/beast/websocket/detail/type_traits.hpp>
-#include <boost/beast/http/empty_body.hpp>
-#include <boost/beast/http/parser.hpp>
-#include <boost/beast/http/read.hpp>
-#include <boost/beast/http/string_body.hpp>
-#include <boost/beast/http/write.hpp>
-#include <boost/beast/core/buffers_prefix.hpp>
-#include <boost/beast/core/handler_ptr.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/asio/coroutine.hpp>
-#include <boost/asio/associated_allocator.hpp>
-#include <boost/asio/associated_executor.hpp>
-#include <boost/asio/handler_continuation_hook.hpp>
-#include <boost/asio/handler_invoke_hook.hpp>
-#include <boost/asio/post.hpp>
-#include <boost/assert.hpp>
-#include <boost/throw_exception.hpp>
-#include <memory>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-// Respond to an upgrade HTTP request
-template<class NextLayer, bool deflateSupported>
-template<class Handler>
-class stream<NextLayer, deflateSupported>::response_op
- : public boost::asio::coroutine
-{
- struct data
- {
- stream<NextLayer, deflateSupported>& ws;
- error_code result;
- response_type res;
-
- template<class Body, class Allocator, class Decorator>
- data(
- Handler const&,
- stream<NextLayer, deflateSupported>& ws_,
- http::request<Body,
- http::basic_fields<Allocator>> const& req,
- Decorator const& decorator)
- : ws(ws_)
- , res(ws_.build_response(req, decorator, result))
- {
- }
- };
-
- handler_ptr<data, Handler> d_;
-
-public:
- response_op(response_op&&) = default;
- response_op(response_op const&) = delete;
-
- template<class DeducedHandler, class... Args>
- response_op(DeducedHandler&& h,
- stream<NextLayer, deflateSupported>& ws, Args&&... args)
- : d_(std::forward<DeducedHandler>(h),
- ws, std::forward<Args>(args)...)
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(d_.handler());
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<
- stream<NextLayer, deflateSupported>&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- d_.handler(), d_->ws.get_executor());
- }
-
- void operator()(
- error_code ec = {},
- std::size_t bytes_transferred = 0);
-
- friend
- bool asio_handler_is_continuation(response_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return asio_handler_is_continuation(
- std::addressof(op->d_.handler()));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, response_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f, std::addressof(op->d_.handler()));
- }
-};
-
-template<class NextLayer, bool deflateSupported>
-template<class Handler>
-void
-stream<NextLayer, deflateSupported>::
-response_op<Handler>::
-operator()(
- error_code ec,
- std::size_t)
-{
- auto& d = *d_;
- BOOST_ASIO_CORO_REENTER(*this)
- {
- // Send response
- BOOST_ASIO_CORO_YIELD
- http::async_write(d.ws.next_layer(),
- d.res, std::move(*this));
- if(! ec)
- ec = d.result;
- if(! ec)
- {
- d.ws.do_pmd_config(d.res, is_deflate_supported{});
- d.ws.open(role_type::server);
- }
- d_.invoke(ec);
- }
-}
-
-//------------------------------------------------------------------------------
-
-// read and respond to an upgrade request
-//
-template<class NextLayer, bool deflateSupported>
-template<class Decorator, class Handler>
-class stream<NextLayer, deflateSupported>::accept_op
- : public boost::asio::coroutine
-{
- struct data
- {
- stream<NextLayer, deflateSupported>& ws;
- Decorator decorator;
- http::request_parser<http::empty_body> p;
- data(
- Handler const&,
- stream<NextLayer, deflateSupported>& ws_,
- Decorator const& decorator_)
- : ws(ws_)
- , decorator(decorator_)
- {
- }
- };
-
- handler_ptr<data, Handler> d_;
-
-public:
- accept_op(accept_op&&) = default;
- accept_op(accept_op const&) = delete;
-
- template<class DeducedHandler, class... Args>
- accept_op(DeducedHandler&& h,
- stream<NextLayer, deflateSupported>& ws, Args&&... args)
- : d_(std::forward<DeducedHandler>(h),
- ws, std::forward<Args>(args)...)
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(d_.handler());
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<stream<NextLayer, deflateSupported>&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- d_.handler(), d_->ws.get_executor());
- }
-
- template<class Buffers>
- void run(Buffers const& buffers);
-
- void operator()(
- error_code ec = {},
- std::size_t bytes_used = 0);
-
- friend
- bool asio_handler_is_continuation(accept_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return asio_handler_is_continuation(
- std::addressof(op->d_.handler()));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, accept_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f, std::addressof(op->d_.handler()));
- }
-};
-
-template<class NextLayer, bool deflateSupported>
-template<class Decorator, class Handler>
-template<class Buffers>
-void
-stream<NextLayer, deflateSupported>::
-accept_op<Decorator, Handler>::
-run(Buffers const& buffers)
-{
- using boost::asio::buffer_copy;
- using boost::asio::buffer_size;
- auto& d = *d_;
- error_code ec;
- boost::optional<typename
- static_buffer_base::mutable_buffers_type> mb;
- auto const len = buffer_size(buffers);
- try
- {
- mb.emplace(d.ws.rd_buf_.prepare(len));
- }
- catch(std::length_error const&)
- {
- ec = error::buffer_overflow;
- return (*this)(ec);
- }
- d.ws.rd_buf_.commit(
- buffer_copy(*mb, buffers));
- (*this)(ec);
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class Decorator, class Handler>
-void
-stream<NextLayer, deflateSupported>::
-accept_op<Decorator, Handler>::
-operator()(error_code ec, std::size_t)
-{
- auto& d = *d_;
- BOOST_ASIO_CORO_REENTER(*this)
- {
- if(ec)
- {
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(
- d.ws.get_executor(),
- bind_handler(std::move(*this), ec));
- }
- else
- {
- BOOST_ASIO_CORO_YIELD
- http::async_read(
- d.ws.next_layer(), d.ws.rd_buf_,
- d.p, std::move(*this));
- if(ec == http::error::end_of_stream)
- ec = error::closed;
- if(! ec)
- {
- // Arguments from our state must be
- // moved to the stack before releasing
- // the handler.
- auto& ws = d.ws;
- auto const req = d.p.release();
- auto const decorator = d.decorator;
- #if 1
- return response_op<Handler>{
- d_.release_handler(),
- ws, req, decorator}(ec);
- #else
- // VFALCO This *should* work but breaks
- // coroutine invariants in the unit test.
- // Also it calls reset() when it shouldn't.
- return ws.async_accept_ex(
- req, decorator, d_.release_handler());
- #endif
- }
- }
- d_.invoke(ec);
- }
-}
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-accept()
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- error_code ec;
- accept(ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class ResponseDecorator>
-void
-stream<NextLayer, deflateSupported>::
-accept_ex(ResponseDecorator const& decorator)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(detail::is_response_decorator<
- ResponseDecorator>::value,
- "ResponseDecorator requirements not met");
- error_code ec;
- accept_ex(decorator, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
-}
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-accept(error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- reset();
- do_accept(&default_decorate_res, ec);
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class ResponseDecorator>
-void
-stream<NextLayer, deflateSupported>::
-accept_ex(ResponseDecorator const& decorator, error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(detail::is_response_decorator<
- ResponseDecorator>::value,
- "ResponseDecorator requirements not met");
- reset();
- do_accept(decorator, ec);
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class ConstBufferSequence>
-typename std::enable_if<! http::detail::is_header<
- ConstBufferSequence>::value>::type
-stream<NextLayer, deflateSupported>::
-accept(ConstBufferSequence const& buffers)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- error_code ec;
- accept(buffers, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
-}
-
-template<class NextLayer, bool deflateSupported>
-template<
- class ConstBufferSequence,
- class ResponseDecorator>
-typename std::enable_if<! http::detail::is_header<
- ConstBufferSequence>::value>::type
-stream<NextLayer, deflateSupported>::
-accept_ex(
- ConstBufferSequence const& buffers,
- ResponseDecorator const &decorator)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- static_assert(detail::is_response_decorator<
- ResponseDecorator>::value,
- "ResponseDecorator requirements not met");
- error_code ec;
- accept_ex(buffers, decorator, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class ConstBufferSequence>
-typename std::enable_if<! http::detail::is_header<
- ConstBufferSequence>::value>::type
-stream<NextLayer, deflateSupported>::
-accept(
- ConstBufferSequence const& buffers, error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- using boost::asio::buffer_copy;
- using boost::asio::buffer_size;
- reset();
- boost::optional<typename
- static_buffer_base::mutable_buffers_type> mb;
- try
- {
- mb.emplace(rd_buf_.prepare(
- buffer_size(buffers)));
- }
- catch(std::length_error const&)
- {
- ec = error::buffer_overflow;
- return;
- }
- rd_buf_.commit(
- buffer_copy(*mb, buffers));
- do_accept(&default_decorate_res, ec);
-}
-
-template<class NextLayer, bool deflateSupported>
-template<
- class ConstBufferSequence,
- class ResponseDecorator>
-typename std::enable_if<! http::detail::is_header<
- ConstBufferSequence>::value>::type
-stream<NextLayer, deflateSupported>::
-accept_ex(
- ConstBufferSequence const& buffers,
- ResponseDecorator const& decorator,
- error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- using boost::asio::buffer_copy;
- using boost::asio::buffer_size;
- reset();
- boost::optional<typename
- static_buffer_base::mutable_buffers_type> mb;
- try
- {
- mb.emplace(rd_buf_.prepare(
- buffer_size(buffers)));
- }
- catch(std::length_error const&)
- {
- ec = error::buffer_overflow;
- return;
- }
- rd_buf_.commit(buffer_copy(*mb, buffers));
- do_accept(decorator, ec);
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class Body, class Allocator>
-void
-stream<NextLayer, deflateSupported>::
-accept(
- http::request<Body,
- http::basic_fields<Allocator>> const& req)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- error_code ec;
- accept(req, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
-}
-
-template<class NextLayer, bool deflateSupported>
-template<
- class Body, class Allocator,
- class ResponseDecorator>
-void
-stream<NextLayer, deflateSupported>::
-accept_ex(
- http::request<Body,
- http::basic_fields<Allocator>> const& req,
- ResponseDecorator const& decorator)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(detail::is_response_decorator<
- ResponseDecorator>::value,
- "ResponseDecorator requirements not met");
- error_code ec;
- accept_ex(req, decorator, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class Body, class Allocator>
-void
-stream<NextLayer, deflateSupported>::
-accept(
- http::request<Body,
- http::basic_fields<Allocator>> const& req,
- error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- reset();
- do_accept(req, &default_decorate_res, ec);
-}
-
-template<class NextLayer, bool deflateSupported>
-template<
- class Body, class Allocator,
- class ResponseDecorator>
-void
-stream<NextLayer, deflateSupported>::
-accept_ex(
- http::request<Body,
- http::basic_fields<Allocator>> const& req,
- ResponseDecorator const& decorator,
- error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(detail::is_response_decorator<
- ResponseDecorator>::value,
- "ResponseDecorator requirements not met");
- reset();
- do_accept(req, decorator, ec);
-}
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-template<
- class AcceptHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- AcceptHandler, void(error_code))
-stream<NextLayer, deflateSupported>::
-async_accept(
- AcceptHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- AcceptHandler, void(error_code));
- reset();
- accept_op<
- decltype(&default_decorate_res),
- BOOST_ASIO_HANDLER_TYPE(
- AcceptHandler, void(error_code))>{
- std::move(init.completion_handler),
- *this,
- &default_decorate_res}({});
- return init.result.get();
-}
-
-template<class NextLayer, bool deflateSupported>
-template<
- class ResponseDecorator,
- class AcceptHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- AcceptHandler, void(error_code))
-stream<NextLayer, deflateSupported>::
-async_accept_ex(
- ResponseDecorator const& decorator,
- AcceptHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- static_assert(detail::is_response_decorator<
- ResponseDecorator>::value,
- "ResponseDecorator requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- AcceptHandler, void(error_code));
- reset();
- accept_op<
- ResponseDecorator,
- BOOST_ASIO_HANDLER_TYPE(
- AcceptHandler, void(error_code))>{
- std::move(init.completion_handler),
- *this,
- decorator}({});
- return init.result.get();
-}
-
-template<class NextLayer, bool deflateSupported>
-template<
- class ConstBufferSequence,
- class AcceptHandler>
-typename std::enable_if<
- ! http::detail::is_header<ConstBufferSequence>::value,
- BOOST_ASIO_INITFN_RESULT_TYPE(
- AcceptHandler, void(error_code))>::type
-stream<NextLayer, deflateSupported>::
-async_accept(
- ConstBufferSequence const& buffers,
- AcceptHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- AcceptHandler, void(error_code));
- reset();
- accept_op<
- decltype(&default_decorate_res),
- BOOST_ASIO_HANDLER_TYPE(
- AcceptHandler, void(error_code))>{
- std::move(init.completion_handler),
- *this,
- &default_decorate_res}.run(buffers);
- return init.result.get();
-}
-
-template<class NextLayer, bool deflateSupported>
-template<
- class ConstBufferSequence,
- class ResponseDecorator,
- class AcceptHandler>
-typename std::enable_if<
- ! http::detail::is_header<ConstBufferSequence>::value,
- BOOST_ASIO_INITFN_RESULT_TYPE(
- AcceptHandler, void(error_code))>::type
-stream<NextLayer, deflateSupported>::
-async_accept_ex(
- ConstBufferSequence const& buffers,
- ResponseDecorator const& decorator,
- AcceptHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- static_assert(detail::is_response_decorator<
- ResponseDecorator>::value,
- "ResponseDecorator requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- AcceptHandler, void(error_code));
- reset();
- accept_op<
- ResponseDecorator,
- BOOST_ASIO_HANDLER_TYPE(
- AcceptHandler, void(error_code))>{
- std::move(init.completion_handler),
- *this,
- decorator}.run(buffers);
- return init.result.get();
-}
-
-template<class NextLayer, bool deflateSupported>
-template<
- class Body, class Allocator,
- class AcceptHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- AcceptHandler, void(error_code))
-stream<NextLayer, deflateSupported>::
-async_accept(
- http::request<Body, http::basic_fields<Allocator>> const& req,
- AcceptHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- AcceptHandler, void(error_code));
- reset();
- using boost::asio::asio_handler_is_continuation;
- response_op<
- BOOST_ASIO_HANDLER_TYPE(
- AcceptHandler, void(error_code))>{
- std::move(init.completion_handler),
- *this,
- req,
- &default_decorate_res}();
- return init.result.get();
-}
-
-template<class NextLayer, bool deflateSupported>
-template<
- class Body, class Allocator,
- class ResponseDecorator,
- class AcceptHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- AcceptHandler, void(error_code))
-stream<NextLayer, deflateSupported>::
-async_accept_ex(
- http::request<Body, http::basic_fields<Allocator>> const& req,
- ResponseDecorator const& decorator,
- AcceptHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- static_assert(detail::is_response_decorator<
- ResponseDecorator>::value,
- "ResponseDecorator requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- AcceptHandler, void(error_code));
- reset();
- using boost::asio::asio_handler_is_continuation;
- response_op<
- BOOST_ASIO_HANDLER_TYPE(
- AcceptHandler, void(error_code))>{
- std::move(init.completion_handler),
- *this,
- req,
- decorator}();
- return init.result.get();
-}
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-template<class Decorator>
-void
-stream<NextLayer, deflateSupported>::
-do_accept(
- Decorator const& decorator,
- error_code& ec)
-{
- http::request_parser<http::empty_body> p;
- http::read(next_layer(), rd_buf_, p, ec);
- if(ec == http::error::end_of_stream)
- ec = error::closed;
- if(ec)
- return;
- do_accept(p.get(), decorator, ec);
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class Body, class Allocator,
- class Decorator>
-void
-stream<NextLayer, deflateSupported>::
-do_accept(
- http::request<Body,
- http::basic_fields<Allocator>> const& req,
- Decorator const& decorator,
- error_code& ec)
-{
- error_code result;
- auto const res = build_response(req, decorator, result);
- http::write(stream_, res, ec);
- if(ec)
- return;
- ec = result;
- if(ec)
- {
- // VFALCO TODO Respect keep alive setting, perform
- // teardown if Connection: close.
- return;
- }
- do_pmd_config(res, is_deflate_supported{});
- open(role_type::server);
-}
-
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/impl/close.ipp b/contrib/restricted/boost/boost/beast/websocket/impl/close.ipp
deleted file mode 100644
index 7b0e1ff648..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/impl/close.ipp
+++ /dev/null
@@ -1,446 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_IMPL_CLOSE_IPP
-#define BOOST_BEAST_WEBSOCKET_IMPL_CLOSE_IPP
-
-#include <boost/beast/websocket/teardown.hpp>
-#include <boost/beast/core/handler_ptr.hpp>
-#include <boost/beast/core/flat_static_buffer.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/asio/associated_allocator.hpp>
-#include <boost/asio/associated_executor.hpp>
-#include <boost/asio/coroutine.hpp>
-#include <boost/asio/handler_continuation_hook.hpp>
-#include <boost/asio/handler_invoke_hook.hpp>
-#include <boost/asio/post.hpp>
-#include <boost/throw_exception.hpp>
-#include <memory>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-/* Close the WebSocket Connection
-
- This composed operation sends the close frame if it hasn't already
- been sent, then reads and discards frames until receiving a close
- frame. Finally it invokes the teardown operation to shut down the
- underlying connection.
-*/
-template<class NextLayer, bool deflateSupported>
-template<class Handler>
-class stream<NextLayer, deflateSupported>::close_op
- : public boost::asio::coroutine
-{
- struct state
- {
- stream<NextLayer, deflateSupported>& ws;
- detail::frame_buffer fb;
- error_code ev;
- bool cont = false;
-
- state(
- Handler const&,
- stream<NextLayer, deflateSupported>& ws_,
- close_reason const& cr)
- : ws(ws_)
- {
- // Serialize the close frame
- ws.template write_close<
- flat_static_buffer_base>(fb, cr);
- }
- };
-
- handler_ptr<state, Handler> d_;
-
-public:
- static constexpr int id = 4; // for soft_mutex
-
- close_op(close_op&&) = default;
- close_op(close_op const&) = delete;
-
- template<class DeducedHandler>
- close_op(
- DeducedHandler&& h,
- stream<NextLayer, deflateSupported>& ws,
- close_reason const& cr)
- : d_(std::forward<DeducedHandler>(h), ws, cr)
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(d_.handler());
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<stream<NextLayer, deflateSupported>&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- d_.handler(), d_->ws.get_executor());
- }
-
- void
- operator()(
- error_code ec = {},
- std::size_t bytes_transferred = 0,
- bool cont = true);
-
- friend
- bool asio_handler_is_continuation(close_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return op->d_->cont || asio_handler_is_continuation(
- std::addressof(op->d_.handler()));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, close_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f,
- std::addressof(op->d_.handler()));
- }
-};
-
-template<class NextLayer, bool deflateSupported>
-template<class Handler>
-void
-stream<NextLayer, deflateSupported>::
-close_op<Handler>::
-operator()(
- error_code ec,
- std::size_t bytes_transferred,
- bool cont)
-{
- using beast::detail::clamp;
- auto& d = *d_;
- d.cont = cont;
- BOOST_ASIO_CORO_REENTER(*this)
- {
- // Maybe suspend
- if(d.ws.wr_block_.try_lock(this))
- {
- // Make sure the stream is open
- if(! d.ws.check_open(ec))
- goto upcall;
- }
- else
- {
- // Suspend
- BOOST_ASIO_CORO_YIELD
- d.ws.paused_close_.emplace(std::move(*this));
-
- // Acquire the write block
- d.ws.wr_block_.lock(this);
-
- // Resume
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(
- d.ws.get_executor(), std::move(*this));
- BOOST_ASSERT(d.ws.wr_block_.is_locked(this));
-
- // Make sure the stream is open
- if(! d.ws.check_open(ec))
- goto upcall;
- }
-
- // Can't call close twice
- BOOST_ASSERT(! d.ws.wr_close_);
-
- // Change status to closing
- BOOST_ASSERT(d.ws.status_ == status::open);
- d.ws.status_ = status::closing;
-
- // Send close frame
- d.ws.wr_close_ = true;
- BOOST_ASIO_CORO_YIELD
- boost::asio::async_write(d.ws.stream_,
- d.fb.data(), std::move(*this));
- if(! d.ws.check_ok(ec))
- goto upcall;
-
- if(d.ws.rd_close_)
- {
- // This happens when the read_op gets a close frame
- // at the same time close_op is sending the close frame.
- // The read_op will be suspended on the write block.
- goto teardown;
- }
-
- // Maybe suspend
- if(! d.ws.rd_block_.try_lock(this))
- {
- // Suspend
- BOOST_ASIO_CORO_YIELD
- d.ws.paused_r_close_.emplace(std::move(*this));
-
- // Acquire the read block
- d.ws.rd_block_.lock(this);
-
- // Resume
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(
- d.ws.get_executor(), std::move(*this));
- BOOST_ASSERT(d.ws.rd_block_.is_locked(this));
-
- // Make sure the stream is open
- BOOST_ASSERT(d.ws.status_ != status::open);
- BOOST_ASSERT(d.ws.status_ != status::closed);
- if( d.ws.status_ == status::failed)
- goto upcall;
-
- BOOST_ASSERT(! d.ws.rd_close_);
- }
-
- // Drain
- if(d.ws.rd_remain_ > 0)
- goto read_payload;
- for(;;)
- {
- // Read frame header
- while(! d.ws.parse_fh(
- d.ws.rd_fh_, d.ws.rd_buf_, d.ev))
- {
- if(d.ev)
- goto teardown;
- BOOST_ASIO_CORO_YIELD
- d.ws.stream_.async_read_some(
- d.ws.rd_buf_.prepare(read_size(d.ws.rd_buf_,
- d.ws.rd_buf_.max_size())),
- std::move(*this));
- if(! d.ws.check_ok(ec))
- goto upcall;
- d.ws.rd_buf_.commit(bytes_transferred);
- }
- if(detail::is_control(d.ws.rd_fh_.op))
- {
- // Process control frame
- if(d.ws.rd_fh_.op == detail::opcode::close)
- {
- BOOST_ASSERT(! d.ws.rd_close_);
- d.ws.rd_close_ = true;
- auto const mb = buffers_prefix(
- clamp(d.ws.rd_fh_.len),
- d.ws.rd_buf_.mutable_data());
- if(d.ws.rd_fh_.len > 0 && d.ws.rd_fh_.mask)
- detail::mask_inplace(mb, d.ws.rd_key_);
- detail::read_close(d.ws.cr_, mb, d.ev);
- if(d.ev)
- goto teardown;
- d.ws.rd_buf_.consume(clamp(d.ws.rd_fh_.len));
- goto teardown;
- }
- d.ws.rd_buf_.consume(clamp(d.ws.rd_fh_.len));
- }
- else
- {
- read_payload:
- while(d.ws.rd_buf_.size() < d.ws.rd_remain_)
- {
- d.ws.rd_remain_ -= d.ws.rd_buf_.size();
- d.ws.rd_buf_.consume(d.ws.rd_buf_.size());
- BOOST_ASIO_CORO_YIELD
- d.ws.stream_.async_read_some(
- d.ws.rd_buf_.prepare(read_size(d.ws.rd_buf_,
- d.ws.rd_buf_.max_size())),
- std::move(*this));
- if(! d.ws.check_ok(ec))
- goto upcall;
- d.ws.rd_buf_.commit(bytes_transferred);
- }
- BOOST_ASSERT(d.ws.rd_buf_.size() >= d.ws.rd_remain_);
- d.ws.rd_buf_.consume(clamp(d.ws.rd_remain_));
- d.ws.rd_remain_ = 0;
- }
- }
-
- teardown:
- // Teardown
- BOOST_ASSERT(d.ws.wr_block_.is_locked(this));
- using beast::websocket::async_teardown;
- BOOST_ASIO_CORO_YIELD
- async_teardown(d.ws.role_,
- d.ws.stream_, std::move(*this));
- BOOST_ASSERT(d.ws.wr_block_.is_locked(this));
- if(ec == boost::asio::error::eof)
- {
- // Rationale:
- // http://stackoverflow.com/questions/25587403/boost-asio-ssl-async-shutdown-always-finishes-with-an-error
- ec.assign(0, ec.category());
- }
- if(! ec)
- ec = d.ev;
- if(ec)
- d.ws.status_ = status::failed;
- else
- d.ws.status_ = status::closed;
- d.ws.close();
-
- upcall:
- BOOST_ASSERT(d.ws.wr_block_.is_locked(this));
- d.ws.wr_block_.unlock(this);
- if(d.ws.rd_block_.try_unlock(this))
- d.ws.paused_r_rd_.maybe_invoke();
- d.ws.paused_rd_.maybe_invoke() ||
- d.ws.paused_ping_.maybe_invoke() ||
- d.ws.paused_wr_.maybe_invoke();
- if(! d.cont)
- {
- auto& ws = d.ws;
- return boost::asio::post(
- ws.stream_.get_executor(),
- bind_handler(d_.release_handler(), ec));
- }
- d_.invoke(ec);
- }
-}
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-close(close_reason const& cr)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- error_code ec;
- close(cr, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
-}
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-close(close_reason const& cr, error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- using beast::detail::clamp;
- ec.assign(0, ec.category());
- // Make sure the stream is open
- if(! check_open(ec))
- return;
- // If rd_close_ is set then we already sent a close
- BOOST_ASSERT(! rd_close_);
- BOOST_ASSERT(! wr_close_);
- wr_close_ = true;
- {
- detail::frame_buffer fb;
- write_close<flat_static_buffer_base>(fb, cr);
- boost::asio::write(stream_, fb.data(), ec);
- }
- if(! check_ok(ec))
- return;
- status_ = status::closing;
- error_code result;
- // Drain the connection
- if(rd_remain_ > 0)
- goto read_payload;
- for(;;)
- {
- // Read frame header
- while(! parse_fh(rd_fh_, rd_buf_, result))
- {
- if(result)
- return do_fail(
- close_code::none, result, ec);
- auto const bytes_transferred =
- stream_.read_some(
- rd_buf_.prepare(read_size(rd_buf_,
- rd_buf_.max_size())), ec);
- if(! check_ok(ec))
- return;
- rd_buf_.commit(bytes_transferred);
- }
- if(detail::is_control(rd_fh_.op))
- {
- // Process control frame
- if(rd_fh_.op == detail::opcode::close)
- {
- BOOST_ASSERT(! rd_close_);
- rd_close_ = true;
- auto const mb = buffers_prefix(
- clamp(rd_fh_.len),
- rd_buf_.mutable_data());
- if(rd_fh_.len > 0 && rd_fh_.mask)
- detail::mask_inplace(mb, rd_key_);
- detail::read_close(cr_, mb, result);
- if(result)
- {
- // Protocol violation
- return do_fail(
- close_code::none, result, ec);
- }
- rd_buf_.consume(clamp(rd_fh_.len));
- break;
- }
- rd_buf_.consume(clamp(rd_fh_.len));
- }
- else
- {
- read_payload:
- while(rd_buf_.size() < rd_remain_)
- {
- rd_remain_ -= rd_buf_.size();
- rd_buf_.consume(rd_buf_.size());
- auto const bytes_transferred =
- stream_.read_some(
- rd_buf_.prepare(read_size(rd_buf_,
- rd_buf_.max_size())), ec);
- if(! check_ok(ec))
- return;
- rd_buf_.commit(bytes_transferred);
- }
- BOOST_ASSERT(rd_buf_.size() >= rd_remain_);
- rd_buf_.consume(clamp(rd_remain_));
- rd_remain_ = 0;
- }
- }
- // _Close the WebSocket Connection_
- do_fail(close_code::none, error::closed, ec);
- if(ec == error::closed)
- ec.assign(0, ec.category());
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class CloseHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- CloseHandler, void(error_code))
-stream<NextLayer, deflateSupported>::
-async_close(close_reason const& cr, CloseHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- CloseHandler, void(error_code));
- close_op<BOOST_ASIO_HANDLER_TYPE(
- CloseHandler, void(error_code))>{
- std::move(init.completion_handler), *this, cr}(
- {}, 0, false);
- return init.result.get();
-}
-
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/impl/error.ipp b/contrib/restricted/boost/boost/beast/websocket/impl/error.ipp
deleted file mode 100644
index 56a20e2551..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/impl/error.ipp
+++ /dev/null
@@ -1,162 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_IMPL_ERROR_IPP
-#define BOOST_BEAST_WEBSOCKET_IMPL_ERROR_IPP
-
-namespace boost {
-namespace beast {
-namespace websocket {
-namespace detail {
-
-inline
-const char*
-error_codes::
-name() const noexcept
-{
- return "boost.beast.websocket";
-}
-
-inline
-std::string
-error_codes::
-message(int ev) const
-{
- switch(static_cast<error>(ev))
- {
- default:
- case error::closed: return "The WebSocket stream was gracefully closed at both endpoints";
- case error::buffer_overflow: return "The WebSocket operation caused a dynamic buffer overflow";
- case error::partial_deflate_block: return "The WebSocket stream produced an incomplete deflate block";
- case error::message_too_big: return "The WebSocket message exceeded the locally configured limit";
-
- case error::bad_http_version: return "The WebSocket handshake was not HTTP/1.1";
- case error::bad_method: return "The WebSocket handshake method was not GET";
- case error::no_host: return "The WebSocket handshake Host field is missing";
- case error::no_connection: return "The WebSocket handshake Connection field is missing";
- case error::no_connection_upgrade: return "The WebSocket handshake Connection field is missing the upgrade token";
- case error::no_upgrade: return "The WebSocket handshake Upgrade field is missing";
- case error::no_upgrade_websocket: return "The WebSocket handshake Upgrade field is missing the websocket token";
- case error::no_sec_key: return "The WebSocket handshake Sec-WebSocket-Key field is missing";
- case error::bad_sec_key: return "The WebSocket handshake Sec-WebSocket-Key field is invalid";
- case error::no_sec_version: return "The WebSocket handshake Sec-WebSocket-Version field is missing";
- case error::bad_sec_version: return "The WebSocket handshake Sec-WebSocket-Version field is invalid";
- case error::no_sec_accept: return "The WebSocket handshake Sec-WebSocket-Accept field is missing";
- case error::bad_sec_accept: return "The WebSocket handshake Sec-WebSocket-Accept field is invalid";
- case error::upgrade_declined: return "The WebSocket handshake was declined by the remote peer";
-
- case error::bad_opcode: return "The WebSocket frame contained an illegal opcode";
- case error::bad_data_frame: return "The WebSocket data frame was unexpected";
- case error::bad_continuation: return "The WebSocket continuation frame was unexpected";
- case error::bad_reserved_bits: return "The WebSocket frame contained illegal reserved bits";
- case error::bad_control_fragment: return "The WebSocket control frame was fragmented";
- case error::bad_control_size: return "The WebSocket control frame size was invalid";
- case error::bad_unmasked_frame: return "The WebSocket frame was unmasked";
- case error::bad_masked_frame: return "The WebSocket frame was masked";
- case error::bad_size: return "The WebSocket frame size was not canonical";
- case error::bad_frame_payload: return "The WebSocket frame payload was not valid utf8";
- case error::bad_close_code: return "The WebSocket close frame reason code was invalid";
- case error::bad_close_size: return "The WebSocket close frame payload size was invalid";
- case error::bad_close_payload: return "The WebSocket close frame payload was not valid utf8";
- }
-}
-
-inline
-error_condition
-error_codes::
-default_error_condition(int ev) const noexcept
-{
- switch(static_cast<error>(ev))
- {
- default:
- case error::closed:
- case error::buffer_overflow:
- case error::partial_deflate_block:
- case error::message_too_big:
- return {ev, *this};
-
- case error::bad_http_version:
- case error::bad_method:
- case error::no_host:
- case error::no_connection:
- case error::no_connection_upgrade:
- case error::no_upgrade:
- case error::no_upgrade_websocket:
- case error::no_sec_key:
- case error::bad_sec_key:
- case error::no_sec_version:
- case error::bad_sec_version:
- case error::no_sec_accept:
- case error::bad_sec_accept:
- case error::upgrade_declined:
- return condition::handshake_failed;
-
- case error::bad_opcode:
- case error::bad_data_frame:
- case error::bad_continuation:
- case error::bad_reserved_bits:
- case error::bad_control_fragment:
- case error::bad_control_size:
- case error::bad_unmasked_frame:
- case error::bad_masked_frame:
- case error::bad_size:
- case error::bad_frame_payload:
- case error::bad_close_code:
- case error::bad_close_size:
- case error::bad_close_payload:
- return condition::protocol_violation;
- }
-}
-
-inline
-const char*
-error_conditions::
-name() const noexcept
-{
- return "boost.beast.websocket";
-}
-
-inline
-std::string
-error_conditions::
-message(int cv) const
-{
- switch(static_cast<condition>(cv))
- {
- default:
- case condition::handshake_failed: return "The WebSocket handshake failed";
- case condition::protocol_violation: return "A WebSocket protocol violation occurred";
- }
-}
-
-} // detail
-
-inline
-error_code
-make_error_code(error e)
-{
- static detail::error_codes const cat{};
- return error_code{static_cast<
- std::underlying_type<error>::type>(e), cat};
-}
-
-inline
-error_condition
-make_error_condition(condition c)
-{
- static detail::error_conditions const cat{};
- return error_condition{static_cast<
- std::underlying_type<condition>::type>(c), cat};
-}
-
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/impl/handshake.ipp b/contrib/restricted/boost/boost/beast/websocket/impl/handshake.ipp
deleted file mode 100644
index 8e33e1a890..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/impl/handshake.ipp
+++ /dev/null
@@ -1,420 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_IMPL_HANDSHAKE_IPP
-#define BOOST_BEAST_WEBSOCKET_IMPL_HANDSHAKE_IPP
-
-#include <boost/beast/websocket/detail/type_traits.hpp>
-#include <boost/beast/http/empty_body.hpp>
-#include <boost/beast/http/message.hpp>
-#include <boost/beast/http/read.hpp>
-#include <boost/beast/http/write.hpp>
-#include <boost/beast/core/handler_ptr.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/asio/associated_allocator.hpp>
-#include <boost/asio/associated_executor.hpp>
-#include <boost/asio/coroutine.hpp>
-#include <boost/asio/handler_continuation_hook.hpp>
-#include <boost/asio/handler_invoke_hook.hpp>
-#include <boost/assert.hpp>
-#include <boost/throw_exception.hpp>
-#include <memory>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-//------------------------------------------------------------------------------
-
-// send the upgrade request and process the response
-//
-template<class NextLayer, bool deflateSupported>
-template<class Handler>
-class stream<NextLayer, deflateSupported>::handshake_op
- : public boost::asio::coroutine
-{
- struct data
- {
- stream<NextLayer, deflateSupported>& ws;
- response_type* res_p;
- detail::sec_ws_key_type key;
- http::request<http::empty_body> req;
- response_type res;
-
- template<class Decorator>
- data(
- Handler const&,
- stream<NextLayer, deflateSupported>& ws_,
- response_type* res_p_,
- string_view host,
- string_view target,
- Decorator const& decorator)
- : ws(ws_)
- , res_p(res_p_)
- , req(ws.build_request(key,
- host, target, decorator))
- {
- ws.reset();
- }
- };
-
- handler_ptr<data, Handler> d_;
-
-public:
- handshake_op(handshake_op&&) = default;
- handshake_op(handshake_op const&) = delete;
-
- template<class DeducedHandler, class... Args>
- handshake_op(DeducedHandler&& h,
- stream<NextLayer, deflateSupported>& ws, Args&&... args)
- : d_(std::forward<DeducedHandler>(h),
- ws, std::forward<Args>(args)...)
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(d_.handler());
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<stream<NextLayer, deflateSupported>&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- d_.handler(), d_->ws.get_executor());
- }
-
- void
- operator()(
- error_code ec = {},
- std::size_t bytes_used = 0);
-
- friend
- bool asio_handler_is_continuation(handshake_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return asio_handler_is_continuation(
- std::addressof(op->d_.handler()));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, handshake_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f,
- std::addressof(op->d_.handler()));
- }
-};
-
-template<class NextLayer, bool deflateSupported>
-template<class Handler>
-void
-stream<NextLayer, deflateSupported>::
-handshake_op<Handler>::
-operator()(error_code ec, std::size_t)
-{
- auto& d = *d_;
- BOOST_ASIO_CORO_REENTER(*this)
- {
- // Send HTTP Upgrade
- d.ws.do_pmd_config(d.req, is_deflate_supported{});
- BOOST_ASIO_CORO_YIELD
- http::async_write(d.ws.stream_,
- d.req, std::move(*this));
- if(ec)
- goto upcall;
-
- // VFALCO We could pre-serialize the request to
- // a single buffer, send that instead,
- // and delete the buffer here. The buffer
- // could be a variable block at the end
- // of handler_ptr's allocation.
-
- // Read HTTP response
- BOOST_ASIO_CORO_YIELD
- http::async_read(d.ws.next_layer(),
- d.ws.rd_buf_, d.res,
- std::move(*this));
- if(ec)
- goto upcall;
- d.ws.on_response(d.res, d.key, ec);
- if(d.res_p)
- swap(d.res, *d.res_p);
- upcall:
- d_.invoke(ec);
- }
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class HandshakeHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- HandshakeHandler, void(error_code))
-stream<NextLayer, deflateSupported>::
-async_handshake(string_view host,
- string_view target,
- HandshakeHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- HandshakeHandler, void(error_code));
- handshake_op<BOOST_ASIO_HANDLER_TYPE(
- HandshakeHandler, void(error_code))>{
- std::move(init.completion_handler), *this, nullptr, host,
- target, &default_decorate_req}();
- return init.result.get();
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class HandshakeHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- HandshakeHandler, void(error_code))
-stream<NextLayer, deflateSupported>::
-async_handshake(response_type& res,
- string_view host,
- string_view target,
- HandshakeHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- HandshakeHandler, void(error_code));
- handshake_op<BOOST_ASIO_HANDLER_TYPE(
- HandshakeHandler, void(error_code))>{
- std::move(init.completion_handler), *this, &res, host,
- target, &default_decorate_req}();
- return init.result.get();
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class RequestDecorator, class HandshakeHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- HandshakeHandler, void(error_code))
-stream<NextLayer, deflateSupported>::
-async_handshake_ex(string_view host,
- string_view target,
- RequestDecorator const& decorator,
- HandshakeHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- static_assert(detail::is_request_decorator<
- RequestDecorator>::value,
- "RequestDecorator requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- HandshakeHandler, void(error_code));
- handshake_op<BOOST_ASIO_HANDLER_TYPE(
- HandshakeHandler, void(error_code))>{
- std::move(init.completion_handler), *this, nullptr, host,
- target, decorator}();
- return init.result.get();
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class RequestDecorator, class HandshakeHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- HandshakeHandler, void(error_code))
-stream<NextLayer, deflateSupported>::
-async_handshake_ex(response_type& res,
- string_view host,
- string_view target,
- RequestDecorator const& decorator,
- HandshakeHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- static_assert(detail::is_request_decorator<
- RequestDecorator>::value,
- "RequestDecorator requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- HandshakeHandler, void(error_code));
- handshake_op<BOOST_ASIO_HANDLER_TYPE(
- HandshakeHandler, void(error_code))>{
- std::move(init.completion_handler), *this, &res, host,
- target, decorator}();
- return init.result.get();
-}
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-handshake(string_view host,
- string_view target)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- error_code ec;
- handshake(
- host, target, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
-}
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-handshake(response_type& res,
- string_view host,
- string_view target)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- error_code ec;
- handshake(res, host, target, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class RequestDecorator>
-void
-stream<NextLayer, deflateSupported>::
-handshake_ex(string_view host,
- string_view target,
- RequestDecorator const& decorator)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(detail::is_request_decorator<
- RequestDecorator>::value,
- "RequestDecorator requirements not met");
- error_code ec;
- handshake_ex(host, target, decorator, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class RequestDecorator>
-void
-stream<NextLayer, deflateSupported>::
-handshake_ex(response_type& res,
- string_view host,
- string_view target,
- RequestDecorator const& decorator)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(detail::is_request_decorator<
- RequestDecorator>::value,
- "RequestDecorator requirements not met");
- error_code ec;
- handshake_ex(res, host, target, decorator, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
-}
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-handshake(string_view host,
- string_view target, error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- do_handshake(nullptr,
- host, target, &default_decorate_req, ec);
-}
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-handshake(response_type& res,
- string_view host,
- string_view target,
- error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- do_handshake(&res,
- host, target, &default_decorate_req, ec);
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class RequestDecorator>
-void
-stream<NextLayer, deflateSupported>::
-handshake_ex(string_view host,
- string_view target,
- RequestDecorator const& decorator,
- error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(detail::is_request_decorator<
- RequestDecorator>::value,
- "RequestDecorator requirements not met");
- do_handshake(nullptr,
- host, target, decorator, ec);
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class RequestDecorator>
-void
-stream<NextLayer, deflateSupported>::
-handshake_ex(response_type& res,
- string_view host,
- string_view target,
- RequestDecorator const& decorator,
- error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(detail::is_request_decorator<
- RequestDecorator>::value,
- "RequestDecorator requirements not met");
- do_handshake(&res,
- host, target, decorator, ec);
-}
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-template<class RequestDecorator>
-void
-stream<NextLayer, deflateSupported>::
-do_handshake(
- response_type* res_p,
- string_view host,
- string_view target,
- RequestDecorator const& decorator,
- error_code& ec)
-{
- response_type res;
- reset();
- detail::sec_ws_key_type key;
- {
- auto const req = build_request(
- key, host, target, decorator);
- do_pmd_config(req, is_deflate_supported{});
- http::write(stream_, req, ec);
- }
- if(ec)
- return;
- http::read(next_layer(), rd_buf_, res, ec);
- if(ec)
- return;
- on_response(res, key, ec);
- if(res_p)
- *res_p = std::move(res);
-}
-
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/impl/ping.ipp b/contrib/restricted/boost/boost/beast/websocket/impl/ping.ipp
deleted file mode 100644
index c7deb9c37c..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/impl/ping.ipp
+++ /dev/null
@@ -1,275 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_IMPL_PING_IPP
-#define BOOST_BEAST_WEBSOCKET_IMPL_PING_IPP
-
-#include <boost/beast/core/bind_handler.hpp>
-#include <boost/beast/core/handler_ptr.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/websocket/detail/frame.hpp>
-#include <boost/asio/associated_allocator.hpp>
-#include <boost/asio/associated_executor.hpp>
-#include <boost/asio/coroutine.hpp>
-#include <boost/asio/handler_continuation_hook.hpp>
-#include <boost/asio/handler_invoke_hook.hpp>
-#include <boost/asio/post.hpp>
-#include <boost/throw_exception.hpp>
-#include <memory>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-/*
- This composed operation handles sending ping and pong frames.
- It only sends the frames it does not make attempts to read
- any frame data.
-*/
-template<class NextLayer, bool deflateSupported>
-template<class Handler>
-class stream<NextLayer, deflateSupported>::ping_op
- : public boost::asio::coroutine
-{
- struct state
- {
- stream<NextLayer, deflateSupported>& ws;
- detail::frame_buffer fb;
-
- state(
- Handler const&,
- stream<NextLayer, deflateSupported>& ws_,
- detail::opcode op,
- ping_data const& payload)
- : ws(ws_)
- {
- // Serialize the control frame
- ws.template write_ping<
- flat_static_buffer_base>(
- fb, op, payload);
- }
- };
-
- handler_ptr<state, Handler> d_;
-
-public:
- static constexpr int id = 3; // for soft_mutex
-
- ping_op(ping_op&&) = default;
- ping_op(ping_op const&) = delete;
-
- template<class DeducedHandler>
- ping_op(
- DeducedHandler&& h,
- stream<NextLayer, deflateSupported>& ws,
- detail::opcode op,
- ping_data const& payload)
- : d_(std::forward<DeducedHandler>(h),
- ws, op, payload)
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(d_.handler());
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<stream<NextLayer, deflateSupported>&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- d_.handler(), d_->ws.get_executor());
- }
-
- void operator()(
- error_code ec = {},
- std::size_t bytes_transferred = 0);
-
- friend
- bool asio_handler_is_continuation(ping_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return asio_handler_is_continuation(
- std::addressof(op->d_.handler()));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, ping_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(
- f, std::addressof(op->d_.handler()));
- }
-};
-
-template<class NextLayer, bool deflateSupported>
-template<class Handler>
-void
-stream<NextLayer, deflateSupported>::
-ping_op<Handler>::
-operator()(error_code ec, std::size_t)
-{
- auto& d = *d_;
- BOOST_ASIO_CORO_REENTER(*this)
- {
- // Maybe suspend
- if(d.ws.wr_block_.try_lock(this))
- {
- // Make sure the stream is open
- if(! d.ws.check_open(ec))
- {
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(
- d.ws.get_executor(),
- bind_handler(std::move(*this), ec));
- goto upcall;
- }
- }
- else
- {
- // Suspend
- BOOST_ASIO_CORO_YIELD
- d.ws.paused_ping_.emplace(std::move(*this));
-
- // Acquire the write block
- d.ws.wr_block_.lock(this);
-
- // Resume
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(
- d.ws.get_executor(), std::move(*this));
- BOOST_ASSERT(d.ws.wr_block_.is_locked(this));
-
- // Make sure the stream is open
- if(! d.ws.check_open(ec))
- goto upcall;
- }
-
- // Send ping frame
- BOOST_ASIO_CORO_YIELD
- boost::asio::async_write(d.ws.stream_,
- d.fb.data(), std::move(*this));
- if(! d.ws.check_ok(ec))
- goto upcall;
-
- upcall:
- d.ws.wr_block_.unlock(this);
- d.ws.paused_close_.maybe_invoke() ||
- d.ws.paused_rd_.maybe_invoke() ||
- d.ws.paused_wr_.maybe_invoke();
- d_.invoke(ec);
- }
-}
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-ping(ping_data const& payload)
-{
- error_code ec;
- ping(payload, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
-}
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-ping(ping_data const& payload, error_code& ec)
-{
- // Make sure the stream is open
- if(! check_open(ec))
- return;
- detail::frame_buffer fb;
- write_ping<flat_static_buffer_base>(
- fb, detail::opcode::ping, payload);
- boost::asio::write(stream_, fb.data(), ec);
- if(! check_ok(ec))
- return;
-}
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-pong(ping_data const& payload)
-{
- error_code ec;
- pong(payload, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
-}
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-pong(ping_data const& payload, error_code& ec)
-{
- // Make sure the stream is open
- if(! check_open(ec))
- return;
- detail::frame_buffer fb;
- write_ping<flat_static_buffer_base>(
- fb, detail::opcode::pong, payload);
- boost::asio::write(stream_, fb.data(), ec);
- if(! check_ok(ec))
- return;
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code))
-stream<NextLayer, deflateSupported>::
-async_ping(ping_data const& payload, WriteHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- WriteHandler, void(error_code));
- ping_op<BOOST_ASIO_HANDLER_TYPE(
- WriteHandler, void(error_code))>{
- std::move(init.completion_handler), *this,
- detail::opcode::ping, payload}();
- return init.result.get();
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code))
-stream<NextLayer, deflateSupported>::
-async_pong(ping_data const& payload, WriteHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- WriteHandler, void(error_code));
- ping_op<BOOST_ASIO_HANDLER_TYPE(
- WriteHandler, void(error_code))>{
- std::move(init.completion_handler), *this,
- detail::opcode::pong, payload}();
- return init.result.get();
-}
-
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/impl/read.ipp b/contrib/restricted/boost/boost/beast/websocket/impl/read.ipp
deleted file mode 100644
index 1dfbd01e72..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/impl/read.ipp
+++ /dev/null
@@ -1,1376 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_IMPL_READ_IPP
-#define BOOST_BEAST_WEBSOCKET_IMPL_READ_IPP
-
-#include <boost/beast/websocket/teardown.hpp>
-#include <boost/beast/core/bind_handler.hpp>
-#include <boost/beast/core/buffers_prefix.hpp>
-#include <boost/beast/core/buffers_suffix.hpp>
-#include <boost/beast/core/flat_static_buffer.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/core/detail/clamp.hpp>
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/asio/associated_allocator.hpp>
-#include <boost/asio/associated_executor.hpp>
-#include <boost/asio/coroutine.hpp>
-#include <boost/asio/handler_continuation_hook.hpp>
-#include <boost/asio/handler_invoke_hook.hpp>
-#include <boost/asio/post.hpp>
-#include <boost/assert.hpp>
-#include <boost/config.hpp>
-#include <boost/optional.hpp>
-#include <boost/throw_exception.hpp>
-#include <algorithm>
-#include <limits>
-#include <memory>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-namespace detail {
-
-template<>
-inline
-void
-stream_base<true>::
-inflate(
- zlib::z_params& zs,
- zlib::Flush flush,
- error_code& ec)
-{
- this->pmd_->zi.write(zs, flush, ec);
-}
-
-template<>
-inline
-void
-stream_base<true>::
-do_context_takeover_read(role_type role)
-{
- if((role == role_type::client &&
- pmd_config_.server_no_context_takeover) ||
- (role == role_type::server &&
- pmd_config_.client_no_context_takeover))
- {
- pmd_->zi.reset();
- }
-}
-
-} // detail
-
-//------------------------------------------------------------------------------
-
-/* Read some message frame data.
-
- Also reads and handles control frames.
-*/
-template<class NextLayer, bool deflateSupported>
-template<
- class MutableBufferSequence,
- class Handler>
-class stream<NextLayer, deflateSupported>::read_some_op
- : public boost::asio::coroutine
-{
- Handler h_;
- stream<NextLayer, deflateSupported>& ws_;
- MutableBufferSequence bs_;
- buffers_suffix<MutableBufferSequence> cb_;
- std::size_t bytes_written_ = 0;
- error_code result_;
- close_code code_;
- bool did_read_ = false;
- bool cont_ = false;
-
-public:
- static constexpr int id = 1; // for soft_mutex
-
- read_some_op(read_some_op&&) = default;
- read_some_op(read_some_op const&) = delete;
-
- template<class DeducedHandler>
- read_some_op(
- DeducedHandler&& h,
- stream<NextLayer, deflateSupported>& ws,
- MutableBufferSequence const& bs)
- : h_(std::forward<DeducedHandler>(h))
- , ws_(ws)
- , bs_(bs)
- , cb_(bs)
- , code_(close_code::none)
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(h_);
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<stream<NextLayer, deflateSupported>&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- h_, ws_.get_executor());
- }
-
- Handler&
- handler()
- {
- return h_;
- }
-
- void operator()(
- error_code ec = {},
- std::size_t bytes_transferred = 0,
- bool cont = true);
-
- friend
- bool asio_handler_is_continuation(read_some_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return op->cont_ || asio_handler_is_continuation(
- std::addressof(op->h_));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, read_some_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f, std::addressof(op->h_));
- }
-};
-
-template<class NextLayer, bool deflateSupported>
-template<class MutableBufferSequence, class Handler>
-void
-stream<NextLayer, deflateSupported>::
-read_some_op<MutableBufferSequence, Handler>::
-operator()(
- error_code ec,
- std::size_t bytes_transferred,
- bool cont)
-{
- using beast::detail::clamp;
- using boost::asio::buffer;
- using boost::asio::buffer_size;
- cont_ = cont;
- BOOST_ASIO_CORO_REENTER(*this)
- {
- // Maybe suspend
- do_maybe_suspend:
- if(ws_.rd_block_.try_lock(this))
- {
- // Make sure the stream is not closed
- if( ws_.status_ == status::closed ||
- ws_.status_ == status::failed)
- {
- ec = boost::asio::error::operation_aborted;
- goto upcall;
- }
- }
- else
- {
- do_suspend:
- // Suspend
- BOOST_ASIO_CORO_YIELD
- ws_.paused_r_rd_.emplace(std::move(*this));
-
- // Acquire the read block
- ws_.rd_block_.lock(this);
-
- // Resume
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(
- ws_.get_executor(), std::move(*this));
- BOOST_ASSERT(ws_.rd_block_.is_locked(this));
-
- // The only way to get read blocked is if
- // a `close_op` wrote a close frame
- BOOST_ASSERT(ws_.wr_close_);
- BOOST_ASSERT(ws_.status_ != status::open);
- ec = boost::asio::error::operation_aborted;
- goto upcall;
- }
-
- // if status_ == status::closing, we want to suspend
- // the read operation until the close completes,
- // then finish the read with operation_aborted.
-
- loop:
- BOOST_ASSERT(ws_.rd_block_.is_locked(this));
- // See if we need to read a frame header. This
- // condition is structured to give the decompressor
- // a chance to emit the final empty deflate block
- //
- if(ws_.rd_remain_ == 0 &&
- (! ws_.rd_fh_.fin || ws_.rd_done_))
- {
- // Read frame header
- while(! ws_.parse_fh(
- ws_.rd_fh_, ws_.rd_buf_, result_))
- {
- if(result_)
- {
- // _Fail the WebSocket Connection_
- if(result_ == error::message_too_big)
- code_ = close_code::too_big;
- else
- code_ = close_code::protocol_error;
- goto close;
- }
- BOOST_ASSERT(ws_.rd_block_.is_locked(this));
- BOOST_ASIO_CORO_YIELD
- ws_.stream_.async_read_some(
- ws_.rd_buf_.prepare(read_size(
- ws_.rd_buf_, ws_.rd_buf_.max_size())),
- std::move(*this));
- BOOST_ASSERT(ws_.rd_block_.is_locked(this));
- if(! ws_.check_ok(ec))
- goto upcall;
- ws_.rd_buf_.commit(bytes_transferred);
-
- // Allow a close operation
- // to acquire the read block
- ws_.rd_block_.unlock(this);
- if( ws_.paused_r_close_.maybe_invoke())
- {
- // Suspend
- BOOST_ASSERT(ws_.rd_block_.is_locked());
- goto do_suspend;
- }
- // Acquire read block
- ws_.rd_block_.lock(this);
- }
- // Immediately apply the mask to the portion
- // of the buffer holding payload data.
- if(ws_.rd_fh_.len > 0 && ws_.rd_fh_.mask)
- detail::mask_inplace(buffers_prefix(
- clamp(ws_.rd_fh_.len),
- ws_.rd_buf_.mutable_data()),
- ws_.rd_key_);
- if(detail::is_control(ws_.rd_fh_.op))
- {
- // Clear this otherwise the next
- // frame will be considered final.
- ws_.rd_fh_.fin = false;
-
- // Handle ping frame
- if(ws_.rd_fh_.op == detail::opcode::ping)
- {
- if(ws_.ctrl_cb_)
- {
- if(! cont_)
- {
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(
- ws_.get_executor(),
- std::move(*this));
- BOOST_ASSERT(cont_);
- }
- }
- {
- auto const b = buffers_prefix(
- clamp(ws_.rd_fh_.len),
- ws_.rd_buf_.data());
- auto const len = buffer_size(b);
- BOOST_ASSERT(len == ws_.rd_fh_.len);
- ping_data payload;
- detail::read_ping(payload, b);
- ws_.rd_buf_.consume(len);
- // Ignore ping when closing
- if(ws_.status_ == status::closing)
- goto loop;
- if(ws_.ctrl_cb_)
- ws_.ctrl_cb_(
- frame_type::ping, payload);
- ws_.rd_fb_.reset();
- ws_.template write_ping<
- flat_static_buffer_base>(ws_.rd_fb_,
- detail::opcode::pong, payload);
- }
-
- // Allow a close operation
- // to acquire the read block
- ws_.rd_block_.unlock(this);
- ws_.paused_r_close_.maybe_invoke();
-
- // Maybe suspend
- if(! ws_.wr_block_.try_lock(this))
- {
- // Suspend
- BOOST_ASIO_CORO_YIELD
- ws_.paused_rd_.emplace(std::move(*this));
-
- // Acquire the write block
- ws_.wr_block_.lock(this);
-
- // Resume
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(
- ws_.get_executor(), std::move(*this));
- BOOST_ASSERT(ws_.wr_block_.is_locked(this));
-
- // Make sure the stream is open
- if(! ws_.check_open(ec))
- goto upcall;
- }
-
- // Send pong
- BOOST_ASSERT(ws_.wr_block_.is_locked(this));
- BOOST_ASIO_CORO_YIELD
- boost::asio::async_write(ws_.stream_,
- ws_.rd_fb_.data(), std::move(*this));
- BOOST_ASSERT(ws_.wr_block_.is_locked(this));
- if(! ws_.check_ok(ec))
- goto upcall;
- ws_.wr_block_.unlock(this);
- ws_.paused_close_.maybe_invoke() ||
- ws_.paused_ping_.maybe_invoke() ||
- ws_.paused_wr_.maybe_invoke();
- goto do_maybe_suspend;
- }
- // Handle pong frame
- if(ws_.rd_fh_.op == detail::opcode::pong)
- {
- // Ignore pong when closing
- if(! ws_.wr_close_ && ws_.ctrl_cb_)
- {
- if(! cont_)
- {
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(
- ws_.get_executor(),
- std::move(*this));
- BOOST_ASSERT(cont_);
- }
- }
- auto const cb = buffers_prefix(clamp(
- ws_.rd_fh_.len), ws_.rd_buf_.data());
- auto const len = buffer_size(cb);
- BOOST_ASSERT(len == ws_.rd_fh_.len);
- ping_data payload;
- detail::read_ping(payload, cb);
- ws_.rd_buf_.consume(len);
- // Ignore pong when closing
- if(! ws_.wr_close_ && ws_.ctrl_cb_)
- ws_.ctrl_cb_(frame_type::pong, payload);
- goto loop;
- }
- // Handle close frame
- BOOST_ASSERT(ws_.rd_fh_.op == detail::opcode::close);
- {
- if(ws_.ctrl_cb_)
- {
- if(! cont_)
- {
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(
- ws_.get_executor(),
- std::move(*this));
- BOOST_ASSERT(cont_);
- }
- }
- auto const cb = buffers_prefix(clamp(
- ws_.rd_fh_.len), ws_.rd_buf_.data());
- auto const len = buffer_size(cb);
- BOOST_ASSERT(len == ws_.rd_fh_.len);
- BOOST_ASSERT(! ws_.rd_close_);
- ws_.rd_close_ = true;
- close_reason cr;
- detail::read_close(cr, cb, result_);
- if(result_)
- {
- // _Fail the WebSocket Connection_
- code_ = close_code::protocol_error;
- goto close;
- }
- ws_.cr_ = cr;
- ws_.rd_buf_.consume(len);
- if(ws_.ctrl_cb_)
- ws_.ctrl_cb_(frame_type::close,
- ws_.cr_.reason);
- // See if we are already closing
- if(ws_.status_ == status::closing)
- {
- // _Close the WebSocket Connection_
- BOOST_ASSERT(ws_.wr_close_);
- code_ = close_code::none;
- result_ = error::closed;
- goto close;
- }
- // _Start the WebSocket Closing Handshake_
- code_ = cr.code == close_code::none ?
- close_code::normal :
- static_cast<close_code>(cr.code);
- result_ = error::closed;
- goto close;
- }
- }
- if(ws_.rd_fh_.len == 0 && ! ws_.rd_fh_.fin)
- {
- // Empty non-final frame
- goto loop;
- }
- ws_.rd_done_ = false;
- }
- if(! ws_.rd_deflated())
- {
- if(ws_.rd_remain_ > 0)
- {
- if(ws_.rd_buf_.size() == 0 && ws_.rd_buf_.max_size() >
- (std::min)(clamp(ws_.rd_remain_),
- buffer_size(cb_)))
- {
- // Fill the read buffer first, otherwise we
- // get fewer bytes at the cost of one I/O.
- BOOST_ASIO_CORO_YIELD
- ws_.stream_.async_read_some(
- ws_.rd_buf_.prepare(read_size(
- ws_.rd_buf_, ws_.rd_buf_.max_size())),
- std::move(*this));
- if(! ws_.check_ok(ec))
- goto upcall;
- ws_.rd_buf_.commit(bytes_transferred);
- if(ws_.rd_fh_.mask)
- detail::mask_inplace(buffers_prefix(clamp(
- ws_.rd_remain_), ws_.rd_buf_.mutable_data()),
- ws_.rd_key_);
- }
- if(ws_.rd_buf_.size() > 0)
- {
- // Copy from the read buffer.
- // The mask was already applied.
- bytes_transferred = buffer_copy(cb_,
- ws_.rd_buf_.data(), clamp(ws_.rd_remain_));
- auto const mb = buffers_prefix(
- bytes_transferred, cb_);
- ws_.rd_remain_ -= bytes_transferred;
- if(ws_.rd_op_ == detail::opcode::text)
- {
- if(! ws_.rd_utf8_.write(mb) ||
- (ws_.rd_remain_ == 0 && ws_.rd_fh_.fin &&
- ! ws_.rd_utf8_.finish()))
- {
- // _Fail the WebSocket Connection_
- code_ = close_code::bad_payload;
- result_ = error::bad_frame_payload;
- goto close;
- }
- }
- bytes_written_ += bytes_transferred;
- ws_.rd_size_ += bytes_transferred;
- ws_.rd_buf_.consume(bytes_transferred);
- }
- else
- {
- // Read into caller's buffer
- BOOST_ASSERT(ws_.rd_remain_ > 0);
- BOOST_ASSERT(buffer_size(cb_) > 0);
- BOOST_ASSERT(buffer_size(buffers_prefix(
- clamp(ws_.rd_remain_), cb_)) > 0);
- BOOST_ASIO_CORO_YIELD
- ws_.stream_.async_read_some(buffers_prefix(
- clamp(ws_.rd_remain_), cb_), std::move(*this));
- if(! ws_.check_ok(ec))
- goto upcall;
- BOOST_ASSERT(bytes_transferred > 0);
- auto const mb = buffers_prefix(
- bytes_transferred, cb_);
- ws_.rd_remain_ -= bytes_transferred;
- if(ws_.rd_fh_.mask)
- detail::mask_inplace(mb, ws_.rd_key_);
- if(ws_.rd_op_ == detail::opcode::text)
- {
- if(! ws_.rd_utf8_.write(mb) ||
- (ws_.rd_remain_ == 0 && ws_.rd_fh_.fin &&
- ! ws_.rd_utf8_.finish()))
- {
- // _Fail the WebSocket Connection_
- code_ = close_code::bad_payload;
- result_ = error::bad_frame_payload;
- goto close;
- }
- }
- bytes_written_ += bytes_transferred;
- ws_.rd_size_ += bytes_transferred;
- }
- }
- ws_.rd_done_ = ws_.rd_remain_ == 0 && ws_.rd_fh_.fin;
- }
- else
- {
- // Read compressed message frame payload:
- // inflate even if rd_fh_.len == 0, otherwise we
- // never emit the end-of-stream deflate block.
- while(buffer_size(cb_) > 0)
- {
- if( ws_.rd_remain_ > 0 &&
- ws_.rd_buf_.size() == 0 &&
- ! did_read_)
- {
- // read new
- BOOST_ASIO_CORO_YIELD
- ws_.stream_.async_read_some(
- ws_.rd_buf_.prepare(read_size(
- ws_.rd_buf_, ws_.rd_buf_.max_size())),
- std::move(*this));
- if(! ws_.check_ok(ec))
- goto upcall;
- BOOST_ASSERT(bytes_transferred > 0);
- ws_.rd_buf_.commit(bytes_transferred);
- if(ws_.rd_fh_.mask)
- detail::mask_inplace(
- buffers_prefix(clamp(ws_.rd_remain_),
- ws_.rd_buf_.mutable_data()), ws_.rd_key_);
- did_read_ = true;
- }
- zlib::z_params zs;
- {
- auto const out = buffers_front(cb_);
- zs.next_out = out.data();
- zs.avail_out = out.size();
- BOOST_ASSERT(zs.avail_out > 0);
- }
- if(ws_.rd_remain_ > 0)
- {
- if(ws_.rd_buf_.size() > 0)
- {
- // use what's there
- auto const in = buffers_prefix(
- clamp(ws_.rd_remain_), buffers_front(
- ws_.rd_buf_.data()));
- zs.avail_in = in.size();
- zs.next_in = in.data();
- }
- else
- {
- break;
- }
- }
- else if(ws_.rd_fh_.fin)
- {
- // append the empty block codes
- static std::uint8_t constexpr
- empty_block[4] = {
- 0x00, 0x00, 0xff, 0xff };
- zs.next_in = empty_block;
- zs.avail_in = sizeof(empty_block);
- ws_.inflate(zs, zlib::Flush::sync, ec);
- if(! ec)
- {
- // https://github.com/madler/zlib/issues/280
- if(zs.total_out > 0)
- ec = error::partial_deflate_block;
- }
- if(! ws_.check_ok(ec))
- goto upcall;
- ws_.do_context_takeover_read(ws_.role_);
- ws_.rd_done_ = true;
- break;
- }
- else
- {
- break;
- }
- ws_.inflate(zs, zlib::Flush::sync, ec);
- if(! ws_.check_ok(ec))
- goto upcall;
- if(ws_.rd_msg_max_ && beast::detail::sum_exceeds(
- ws_.rd_size_, zs.total_out, ws_.rd_msg_max_))
- {
- // _Fail the WebSocket Connection_
- code_ = close_code::too_big;
- result_ = error::message_too_big;
- goto close;
- }
- cb_.consume(zs.total_out);
- ws_.rd_size_ += zs.total_out;
- ws_.rd_remain_ -= zs.total_in;
- ws_.rd_buf_.consume(zs.total_in);
- bytes_written_ += zs.total_out;
- }
- if(ws_.rd_op_ == detail::opcode::text)
- {
- // check utf8
- if(! ws_.rd_utf8_.write(
- buffers_prefix(bytes_written_, bs_)) || (
- ws_.rd_done_ && ! ws_.rd_utf8_.finish()))
- {
- // _Fail the WebSocket Connection_
- code_ = close_code::bad_payload;
- result_ = error::bad_frame_payload;
- goto close;
- }
- }
- }
- goto upcall;
-
- close:
- if(ws_.wr_block_.try_lock(this))
- {
- // Make sure the stream is open
- BOOST_ASSERT(ws_.status_ == status::open);
- }
- else
- {
- // Suspend
- BOOST_ASIO_CORO_YIELD
- ws_.paused_rd_.emplace(std::move(*this));
-
- // Acquire the write block
- ws_.wr_block_.lock(this);
-
- // Resume
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(
- ws_.get_executor(), std::move(*this));
- BOOST_ASSERT(ws_.wr_block_.is_locked(this));
-
- // Make sure the stream is open
- if(! ws_.check_open(ec))
- goto upcall;
- }
-
- // Set the status
- ws_.status_ = status::closing;
-
- if(! ws_.wr_close_)
- {
- ws_.wr_close_ = true;
-
- // Serialize close frame
- ws_.rd_fb_.reset();
- ws_.template write_close<
- flat_static_buffer_base>(
- ws_.rd_fb_, code_);
-
- // Send close frame
- BOOST_ASSERT(ws_.wr_block_.is_locked(this));
- BOOST_ASIO_CORO_YIELD
- boost::asio::async_write(
- ws_.stream_, ws_.rd_fb_.data(),
- std::move(*this));
- BOOST_ASSERT(ws_.wr_block_.is_locked(this));
- if(! ws_.check_ok(ec))
- goto upcall;
- }
-
- // Teardown
- using beast::websocket::async_teardown;
- BOOST_ASSERT(ws_.wr_block_.is_locked(this));
- BOOST_ASIO_CORO_YIELD
- async_teardown(ws_.role_,
- ws_.stream_, std::move(*this));
- BOOST_ASSERT(ws_.wr_block_.is_locked(this));
- if(ec == boost::asio::error::eof)
- {
- // Rationale:
- // http://stackoverflow.com/questions/25587403/boost-asio-ssl-async-shutdown-always-finishes-with-an-error
- ec.assign(0, ec.category());
- }
- if(! ec)
- ec = result_;
- if(ec && ec != error::closed)
- ws_.status_ = status::failed;
- else
- ws_.status_ = status::closed;
- ws_.close();
-
- upcall:
- ws_.rd_block_.try_unlock(this);
- ws_.paused_r_close_.maybe_invoke();
- if(ws_.wr_block_.try_unlock(this))
- ws_.paused_close_.maybe_invoke() ||
- ws_.paused_ping_.maybe_invoke() ||
- ws_.paused_wr_.maybe_invoke();
- if(! cont_)
- return boost::asio::post(
- ws_.stream_.get_executor(),
- bind_handler(std::move(h_),
- ec, bytes_written_));
- h_(ec, bytes_written_);
- }
-}
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-template<
- class DynamicBuffer,
- class Handler>
-class stream<NextLayer, deflateSupported>::read_op
- : public boost::asio::coroutine
-{
- Handler h_;
- stream<NextLayer, deflateSupported>& ws_;
- DynamicBuffer& b_;
- std::size_t limit_;
- std::size_t bytes_written_ = 0;
- bool some_;
-
-public:
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- read_op(read_op&&) = default;
- read_op(read_op const&) = delete;
-
- template<class DeducedHandler>
- read_op(
- DeducedHandler&& h,
- stream<NextLayer, deflateSupported>& ws,
- DynamicBuffer& b,
- std::size_t limit,
- bool some)
- : h_(std::forward<DeducedHandler>(h))
- , ws_(ws)
- , b_(b)
- , limit_(limit ? limit : (
- std::numeric_limits<std::size_t>::max)())
- , some_(some)
- {
- }
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(h_);
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<stream<NextLayer, deflateSupported>&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- h_, ws_.get_executor());
- }
-
- void operator()(
- error_code ec = {},
- std::size_t bytes_transferred = 0);
-
- friend
- bool asio_handler_is_continuation(read_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return asio_handler_is_continuation(
- std::addressof(op->h_));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, read_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f, std::addressof(op->h_));
- }
-};
-
-template<class NextLayer, bool deflateSupported>
-template<class DynamicBuffer, class Handler>
-void
-stream<NextLayer, deflateSupported>::
-read_op<DynamicBuffer, Handler>::
-operator()(
- error_code ec,
- std::size_t bytes_transferred)
-{
- using beast::detail::clamp;
- using buffers_type = typename
- DynamicBuffer::mutable_buffers_type;
- boost::optional<buffers_type> mb;
- BOOST_ASIO_CORO_REENTER(*this)
- {
- do
- {
- try
- {
- mb.emplace(b_.prepare(clamp(
- ws_.read_size_hint(b_), limit_)));
- }
- catch(std::length_error const&)
- {
- ec = error::buffer_overflow;
- }
- if(ec)
- {
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(
- ws_.get_executor(),
- bind_handler(std::move(*this),
- error::buffer_overflow, 0));
- break;
- }
- BOOST_ASIO_CORO_YIELD
- read_some_op<buffers_type, read_op>{
- std::move(*this), ws_, *mb}(
- {}, 0, false);
- if(ec)
- break;
- b_.commit(bytes_transferred);
- bytes_written_ += bytes_transferred;
- }
- while(! some_ && ! ws_.is_message_done());
- h_(ec, bytes_written_);
- }
-}
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-template<class DynamicBuffer>
-std::size_t
-stream<NextLayer, deflateSupported>::
-read(DynamicBuffer& buffer)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- error_code ec;
- auto const bytes_written = read(buffer, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
- return bytes_written;
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class DynamicBuffer>
-std::size_t
-stream<NextLayer, deflateSupported>::
-read(DynamicBuffer& buffer, error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- std::size_t bytes_written = 0;
- do
- {
- bytes_written += read_some(buffer, 0, ec);
- if(ec)
- return bytes_written;
- }
- while(! is_message_done());
- return bytes_written;
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class DynamicBuffer, class ReadHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
-stream<NextLayer, deflateSupported>::
-async_read(DynamicBuffer& buffer, ReadHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- ReadHandler, void(error_code, std::size_t));
- read_op<
- DynamicBuffer,
- BOOST_ASIO_HANDLER_TYPE(
- ReadHandler, void(error_code, std::size_t))>{
- std::move(init.completion_handler),
- *this,
- buffer,
- 0,
- false}();
- return init.result.get();
-}
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-template<class DynamicBuffer>
-std::size_t
-stream<NextLayer, deflateSupported>::
-read_some(
- DynamicBuffer& buffer,
- std::size_t limit)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- error_code ec;
- auto const bytes_written =
- read_some(buffer, limit, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
- return bytes_written;
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class DynamicBuffer>
-std::size_t
-stream<NextLayer, deflateSupported>::
-read_some(
- DynamicBuffer& buffer,
- std::size_t limit,
- error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- using beast::detail::clamp;
- if(! limit)
- limit = (std::numeric_limits<std::size_t>::max)();
- auto const size =
- clamp(read_size_hint(buffer), limit);
- BOOST_ASSERT(size > 0);
- boost::optional<typename
- DynamicBuffer::mutable_buffers_type> mb;
- try
- {
- mb.emplace(buffer.prepare(size));
- }
- catch(std::length_error const&)
- {
- ec = error::buffer_overflow;
- return 0;
- }
- auto const bytes_written = read_some(*mb, ec);
- buffer.commit(bytes_written);
- return bytes_written;
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class DynamicBuffer, class ReadHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
-stream<NextLayer, deflateSupported>::
-async_read_some(
- DynamicBuffer& buffer,
- std::size_t limit,
- ReadHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- ReadHandler, void(error_code, std::size_t));
- read_op<
- DynamicBuffer,
- BOOST_ASIO_HANDLER_TYPE(
- ReadHandler, void(error_code, std::size_t))>{
- std::move(init.completion_handler),
- *this,
- buffer,
- limit,
- true}({}, 0);
- return init.result.get();
-}
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-template<class MutableBufferSequence>
-std::size_t
-stream<NextLayer, deflateSupported>::
-read_some(
- MutableBufferSequence const& buffers)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(boost::asio::is_mutable_buffer_sequence<
- MutableBufferSequence>::value,
- "MutableBufferSequence requirements not met");
- error_code ec;
- auto const bytes_written = read_some(buffers, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
- return bytes_written;
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class MutableBufferSequence>
-std::size_t
-stream<NextLayer, deflateSupported>::
-read_some(
- MutableBufferSequence const& buffers,
- error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(boost::asio::is_mutable_buffer_sequence<
- MutableBufferSequence>::value,
- "MutableBufferSequence requirements not met");
- using beast::detail::clamp;
- using boost::asio::buffer;
- using boost::asio::buffer_size;
- close_code code{};
- std::size_t bytes_written = 0;
- ec.assign(0, ec.category());
- // Make sure the stream is open
- if(! check_open(ec))
- return 0;
-loop:
- // See if we need to read a frame header. This
- // condition is structured to give the decompressor
- // a chance to emit the final empty deflate block
- //
- if(rd_remain_ == 0 && (! rd_fh_.fin || rd_done_))
- {
- // Read frame header
- error_code result;
- while(! parse_fh(rd_fh_, rd_buf_, result))
- {
- if(result)
- {
- // _Fail the WebSocket Connection_
- if(result == error::message_too_big)
- code = close_code::too_big;
- else
- code = close_code::protocol_error;
- do_fail(code, result, ec);
- return bytes_written;
- }
- auto const bytes_transferred =
- stream_.read_some(
- rd_buf_.prepare(read_size(
- rd_buf_, rd_buf_.max_size())),
- ec);
- if(! check_ok(ec))
- return bytes_written;
- rd_buf_.commit(bytes_transferred);
- }
- // Immediately apply the mask to the portion
- // of the buffer holding payload data.
- if(rd_fh_.len > 0 && rd_fh_.mask)
- detail::mask_inplace(buffers_prefix(
- clamp(rd_fh_.len), rd_buf_.mutable_data()),
- rd_key_);
- if(detail::is_control(rd_fh_.op))
- {
- // Get control frame payload
- auto const b = buffers_prefix(
- clamp(rd_fh_.len), rd_buf_.data());
- auto const len = buffer_size(b);
- BOOST_ASSERT(len == rd_fh_.len);
-
- // Clear this otherwise the next
- // frame will be considered final.
- rd_fh_.fin = false;
-
- // Handle ping frame
- if(rd_fh_.op == detail::opcode::ping)
- {
- ping_data payload;
- detail::read_ping(payload, b);
- rd_buf_.consume(len);
- if(wr_close_)
- {
- // Ignore ping when closing
- goto loop;
- }
- if(ctrl_cb_)
- ctrl_cb_(frame_type::ping, payload);
- detail::frame_buffer fb;
- write_ping<flat_static_buffer_base>(fb,
- detail::opcode::pong, payload);
- boost::asio::write(stream_, fb.data(), ec);
- if(! check_ok(ec))
- return bytes_written;
- goto loop;
- }
- // Handle pong frame
- if(rd_fh_.op == detail::opcode::pong)
- {
- ping_data payload;
- detail::read_ping(payload, b);
- rd_buf_.consume(len);
- if(ctrl_cb_)
- ctrl_cb_(frame_type::pong, payload);
- goto loop;
- }
- // Handle close frame
- BOOST_ASSERT(rd_fh_.op == detail::opcode::close);
- {
- BOOST_ASSERT(! rd_close_);
- rd_close_ = true;
- close_reason cr;
- detail::read_close(cr, b, result);
- if(result)
- {
- // _Fail the WebSocket Connection_
- do_fail(close_code::protocol_error,
- result, ec);
- return bytes_written;
- }
- cr_ = cr;
- rd_buf_.consume(len);
- if(ctrl_cb_)
- ctrl_cb_(frame_type::close, cr_.reason);
- BOOST_ASSERT(! wr_close_);
- // _Start the WebSocket Closing Handshake_
- do_fail(
- cr.code == close_code::none ?
- close_code::normal :
- static_cast<close_code>(cr.code),
- error::closed, ec);
- return bytes_written;
- }
- }
- if(rd_fh_.len == 0 && ! rd_fh_.fin)
- {
- // Empty non-final frame
- goto loop;
- }
- rd_done_ = false;
- }
- else
- {
- ec.assign(0, ec.category());
- }
- if(! this->rd_deflated())
- {
- if(rd_remain_ > 0)
- {
- if(rd_buf_.size() == 0 && rd_buf_.max_size() >
- (std::min)(clamp(rd_remain_),
- buffer_size(buffers)))
- {
- // Fill the read buffer first, otherwise we
- // get fewer bytes at the cost of one I/O.
- rd_buf_.commit(stream_.read_some(
- rd_buf_.prepare(read_size(rd_buf_,
- rd_buf_.max_size())), ec));
- if(! check_ok(ec))
- return bytes_written;
- if(rd_fh_.mask)
- detail::mask_inplace(
- buffers_prefix(clamp(rd_remain_),
- rd_buf_.mutable_data()), rd_key_);
- }
- if(rd_buf_.size() > 0)
- {
- // Copy from the read buffer.
- // The mask was already applied.
- auto const bytes_transferred =
- buffer_copy(buffers, rd_buf_.data(),
- clamp(rd_remain_));
- auto const mb = buffers_prefix(
- bytes_transferred, buffers);
- rd_remain_ -= bytes_transferred;
- if(rd_op_ == detail::opcode::text)
- {
- if(! rd_utf8_.write(mb) ||
- (rd_remain_ == 0 && rd_fh_.fin &&
- ! rd_utf8_.finish()))
- {
- // _Fail the WebSocket Connection_
- do_fail(close_code::bad_payload,
- error::bad_frame_payload, ec);
- return bytes_written;
- }
- }
- bytes_written += bytes_transferred;
- rd_size_ += bytes_transferred;
- rd_buf_.consume(bytes_transferred);
- }
- else
- {
- // Read into caller's buffer
- BOOST_ASSERT(rd_remain_ > 0);
- BOOST_ASSERT(buffer_size(buffers) > 0);
- BOOST_ASSERT(buffer_size(buffers_prefix(
- clamp(rd_remain_), buffers)) > 0);
- auto const bytes_transferred =
- stream_.read_some(buffers_prefix(
- clamp(rd_remain_), buffers), ec);
- if(! check_ok(ec))
- return bytes_written;
- BOOST_ASSERT(bytes_transferred > 0);
- auto const mb = buffers_prefix(
- bytes_transferred, buffers);
- rd_remain_ -= bytes_transferred;
- if(rd_fh_.mask)
- detail::mask_inplace(mb, rd_key_);
- if(rd_op_ == detail::opcode::text)
- {
- if(! rd_utf8_.write(mb) ||
- (rd_remain_ == 0 && rd_fh_.fin &&
- ! rd_utf8_.finish()))
- {
- // _Fail the WebSocket Connection_
- do_fail(close_code::bad_payload,
- error::bad_frame_payload, ec);
- return bytes_written;
- }
- }
- bytes_written += bytes_transferred;
- rd_size_ += bytes_transferred;
- }
- }
- rd_done_ = rd_remain_ == 0 && rd_fh_.fin;
- }
- else
- {
- // Read compressed message frame payload:
- // inflate even if rd_fh_.len == 0, otherwise we
- // never emit the end-of-stream deflate block.
- //
- bool did_read = false;
- buffers_suffix<MutableBufferSequence> cb{buffers};
- while(buffer_size(cb) > 0)
- {
- zlib::z_params zs;
- {
- auto const out = buffers_front(cb);
- zs.next_out = out.data();
- zs.avail_out = out.size();
- BOOST_ASSERT(zs.avail_out > 0);
- }
- if(rd_remain_ > 0)
- {
- if(rd_buf_.size() > 0)
- {
- // use what's there
- auto const in = buffers_prefix(
- clamp(rd_remain_), buffers_front(
- rd_buf_.data()));
- zs.avail_in = in.size();
- zs.next_in = in.data();
- }
- else if(! did_read)
- {
- // read new
- auto const bytes_transferred =
- stream_.read_some(
- rd_buf_.prepare(read_size(
- rd_buf_, rd_buf_.max_size())),
- ec);
- if(! check_ok(ec))
- return bytes_written;
- BOOST_ASSERT(bytes_transferred > 0);
- rd_buf_.commit(bytes_transferred);
- if(rd_fh_.mask)
- detail::mask_inplace(
- buffers_prefix(clamp(rd_remain_),
- rd_buf_.mutable_data()), rd_key_);
- auto const in = buffers_prefix(
- clamp(rd_remain_), buffers_front(
- rd_buf_.data()));
- zs.avail_in = in.size();
- zs.next_in = in.data();
- did_read = true;
- }
- else
- {
- break;
- }
- }
- else if(rd_fh_.fin)
- {
- // append the empty block codes
- static std::uint8_t constexpr
- empty_block[4] = {
- 0x00, 0x00, 0xff, 0xff };
- zs.next_in = empty_block;
- zs.avail_in = sizeof(empty_block);
- this->inflate(zs, zlib::Flush::sync, ec);
- if(! ec)
- {
- // https://github.com/madler/zlib/issues/280
- if(zs.total_out > 0)
- ec = error::partial_deflate_block;
- }
- if(! check_ok(ec))
- return bytes_written;
- this->do_context_takeover_read(role_);
- rd_done_ = true;
- break;
- }
- else
- {
- break;
- }
- this->inflate(zs, zlib::Flush::sync, ec);
- if(! check_ok(ec))
- return bytes_written;
- if(rd_msg_max_ && beast::detail::sum_exceeds(
- rd_size_, zs.total_out, rd_msg_max_))
- {
- do_fail(close_code::too_big,
- error::message_too_big, ec);
- return bytes_written;
- }
- cb.consume(zs.total_out);
- rd_size_ += zs.total_out;
- rd_remain_ -= zs.total_in;
- rd_buf_.consume(zs.total_in);
- bytes_written += zs.total_out;
- }
- if(rd_op_ == detail::opcode::text)
- {
- // check utf8
- if(! rd_utf8_.write(
- buffers_prefix(bytes_written, buffers)) || (
- rd_done_ && ! rd_utf8_.finish()))
- {
- // _Fail the WebSocket Connection_
- do_fail(close_code::bad_payload,
- error::bad_frame_payload, ec);
- return bytes_written;
- }
- }
- }
- return bytes_written;
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class MutableBufferSequence, class ReadHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
-stream<NextLayer, deflateSupported>::
-async_read_some(
- MutableBufferSequence const& buffers,
- ReadHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- static_assert(boost::asio::is_mutable_buffer_sequence<
- MutableBufferSequence>::value,
- "MutableBufferSequence requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- ReadHandler, void(error_code, std::size_t));
- read_some_op<MutableBufferSequence, BOOST_ASIO_HANDLER_TYPE(
- ReadHandler, void(error_code, std::size_t))>{
- std::move(init.completion_handler), *this, buffers}(
- {}, 0, false);
- return init.result.get();
-}
-
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/impl/rfc6455.ipp b/contrib/restricted/boost/boost/beast/websocket/impl/rfc6455.ipp
deleted file mode 100644
index 07fdc30686..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/impl/rfc6455.ipp
+++ /dev/null
@@ -1,40 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_IMPL_RFC6455_IPP
-#define BOOST_BEAST_WEBSOCKET_IMPL_RFC6455_IPP
-
-#include <boost/beast/http/fields.hpp>
-#include <boost/beast/http/rfc7230.hpp>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-template<class Allocator>
-bool
-is_upgrade(http::header<true,
- http::basic_fields<Allocator>> const& req)
-{
- if(req.version() < 11)
- return false;
- if(req.method() != http::verb::get)
- return false;
- if(! http::token_list{req[http::field::connection]}.exists("upgrade"))
- return false;
- if(! http::token_list{req[http::field::upgrade]}.exists("websocket"))
- return false;
- return true;
-}
-
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/impl/ssl.ipp b/contrib/restricted/boost/boost/beast/websocket/impl/ssl.ipp
deleted file mode 100644
index 442b45086a..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/impl/ssl.ipp
+++ /dev/null
@@ -1,61 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_IMPL_SSL_IPP_INCLUDED
-#define BOOST_BEAST_WEBSOCKET_IMPL_SSL_IPP_INCLUDED
-
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-/*
-
-See
-http://stackoverflow.com/questions/32046034/what-is-the-proper-way-to-securely-disconnect-an-asio-ssl-socket/32054476#32054476
-
-Behavior of ssl::stream regarding close_
-
- If the remote host calls async_shutdown then the
- local host's async_read will complete with eof.
-
- If both hosts call async_shutdown then the calls
- to async_shutdown will complete with eof.
-
-*/
-
-template<class AsyncStream>
-void
-teardown(
- role_type,
- boost::asio::ssl::stream<AsyncStream>& stream,
- error_code& ec)
-{
- stream.shutdown(ec);
-}
-
-template<
- class AsyncStream,
- class TeardownHandler>
-void
-async_teardown(
- role_type,
- boost::asio::ssl::stream<AsyncStream>& stream,
- TeardownHandler&& handler)
-{
- stream.async_shutdown(
- std::forward<TeardownHandler>(handler));
-}
-
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/impl/stream.ipp b/contrib/restricted/boost/boost/beast/websocket/impl/stream.ipp
deleted file mode 100644
index cf747c230d..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/impl/stream.ipp
+++ /dev/null
@@ -1,894 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_IMPL_STREAM_IPP
-#define BOOST_BEAST_WEBSOCKET_IMPL_STREAM_IPP
-
-#include <boost/beast/websocket/rfc6455.hpp>
-#include <boost/beast/websocket/teardown.hpp>
-#include <boost/beast/websocket/detail/hybi13.hpp>
-#include <boost/beast/websocket/detail/pmd_extension.hpp>
-#include <boost/beast/version.hpp>
-#include <boost/beast/http/read.hpp>
-#include <boost/beast/http/write.hpp>
-#include <boost/beast/http/rfc7230.hpp>
-#include <boost/beast/core/buffers_cat.hpp>
-#include <boost/beast/core/buffers_prefix.hpp>
-#include <boost/beast/core/buffers_suffix.hpp>
-#include <boost/beast/core/flat_static_buffer.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/core/detail/clamp.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/assert.hpp>
-#include <boost/endian/buffers.hpp>
-#include <boost/make_unique.hpp>
-#include <boost/throw_exception.hpp>
-#include <algorithm>
-#include <memory>
-#include <stdexcept>
-#include <utility>
-
-#include <iostream>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-template<class NextLayer, bool deflateSupported>
-template<class... Args>
-stream<NextLayer, deflateSupported>::
-stream(Args&&... args)
- : stream_(std::forward<Args>(args)...)
-{
- BOOST_ASSERT(rd_buf_.max_size() >=
- max_control_frame_size);
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class DynamicBuffer, class>
-std::size_t
-stream<NextLayer, deflateSupported>::
-read_size_hint(DynamicBuffer& buffer) const
-{
- static_assert(
- boost::asio::is_dynamic_buffer<DynamicBuffer>::value,
- "DynamicBuffer requirements not met");
- auto const initial_size = (std::min)(
- +tcp_frame_size,
- buffer.max_size() - buffer.size());
- if(initial_size == 0)
- return 1; // buffer is full
- return read_size_hint(initial_size);
-}
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-set_option(permessage_deflate const& o, std::true_type)
-{
- if( o.server_max_window_bits > 15 ||
- o.server_max_window_bits < 9)
- BOOST_THROW_EXCEPTION(std::invalid_argument{
- "invalid server_max_window_bits"});
- if( o.client_max_window_bits > 15 ||
- o.client_max_window_bits < 9)
- BOOST_THROW_EXCEPTION(std::invalid_argument{
- "invalid client_max_window_bits"});
- if( o.compLevel < 0 ||
- o.compLevel > 9)
- BOOST_THROW_EXCEPTION(std::invalid_argument{
- "invalid compLevel"});
- if( o.memLevel < 1 ||
- o.memLevel > 9)
- BOOST_THROW_EXCEPTION(std::invalid_argument{
- "invalid memLevel"});
- this->pmd_opts_ = o;
-}
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-set_option(permessage_deflate const& o, std::false_type)
-{
- if(o.client_enable || o.server_enable)
- {
- // Can't enable permessage-deflate
- // when deflateSupported == false.
- //
- BOOST_THROW_EXCEPTION(std::invalid_argument{
- "deflateSupported == false"});
- }
-}
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-open(role_type role)
-{
- // VFALCO TODO analyze and remove dupe code in reset()
- role_ = role;
- status_ = status::open;
- rd_remain_ = 0;
- rd_cont_ = false;
- rd_done_ = true;
- // Can't clear this because accept uses it
- //rd_buf_.reset();
- rd_fh_.fin = false;
- rd_close_ = false;
- wr_close_ = false;
- // These should not be necessary, because all completion
- // handlers must be allowed to execute otherwise the
- // stream exhibits undefined behavior.
- wr_block_.reset();
- rd_block_.reset();
- cr_.code = close_code::none;
-
- wr_cont_ = false;
- wr_buf_size_ = 0;
-
- open_pmd(is_deflate_supported{});
-}
-
-template<class NextLayer, bool deflateSupported>
-inline
-void
-stream<NextLayer, deflateSupported>::
-open_pmd(std::true_type)
-{
- if(((role_ == role_type::client &&
- this->pmd_opts_.client_enable) ||
- (role_ == role_type::server &&
- this->pmd_opts_.server_enable)) &&
- this->pmd_config_.accept)
- {
- pmd_normalize(this->pmd_config_);
- this->pmd_.reset(new typename
- detail::stream_base<deflateSupported>::pmd_type);
- if(role_ == role_type::client)
- {
- this->pmd_->zi.reset(
- this->pmd_config_.server_max_window_bits);
- this->pmd_->zo.reset(
- this->pmd_opts_.compLevel,
- this->pmd_config_.client_max_window_bits,
- this->pmd_opts_.memLevel,
- zlib::Strategy::normal);
- }
- else
- {
- this->pmd_->zi.reset(
- this->pmd_config_.client_max_window_bits);
- this->pmd_->zo.reset(
- this->pmd_opts_.compLevel,
- this->pmd_config_.server_max_window_bits,
- this->pmd_opts_.memLevel,
- zlib::Strategy::normal);
- }
- }
-}
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-close()
-{
- wr_buf_.reset();
- close_pmd(is_deflate_supported{});
-}
-
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-reset()
-{
- BOOST_ASSERT(status_ != status::open);
- rd_remain_ = 0;
- rd_cont_ = false;
- rd_done_ = true;
- rd_buf_.consume(rd_buf_.size());
- rd_fh_.fin = false;
- rd_close_ = false;
- wr_close_ = false;
- wr_cont_ = false;
- // These should not be necessary, because all completion
- // handlers must be allowed to execute otherwise the
- // stream exhibits undefined behavior.
- wr_block_.reset();
- rd_block_.reset();
- cr_.code = close_code::none;
-}
-
-// Called before each write frame
-template<class NextLayer, bool deflateSupported>
-inline
-void
-stream<NextLayer, deflateSupported>::
-begin_msg(std::true_type)
-{
- wr_frag_ = wr_frag_opt_;
- wr_compress_ = static_cast<bool>(this->pmd_);
-
- // Maintain the write buffer
- if( wr_compress_ ||
- role_ == role_type::client)
- {
- if(! wr_buf_ || wr_buf_size_ != wr_buf_opt_)
- {
- wr_buf_size_ = wr_buf_opt_;
- wr_buf_ = boost::make_unique_noinit<
- std::uint8_t[]>(wr_buf_size_);
- }
- }
- else
- {
- wr_buf_size_ = wr_buf_opt_;
- wr_buf_.reset();
- }
-}
-
-// Called before each write frame
-template<class NextLayer, bool deflateSupported>
-inline
-void
-stream<NextLayer, deflateSupported>::
-begin_msg(std::false_type)
-{
- wr_frag_ = wr_frag_opt_;
-
- // Maintain the write buffer
- if(role_ == role_type::client)
- {
- if(! wr_buf_ || wr_buf_size_ != wr_buf_opt_)
- {
- wr_buf_size_ = wr_buf_opt_;
- wr_buf_ = boost::make_unique_noinit<
- std::uint8_t[]>(wr_buf_size_);
- }
- }
- else
- {
- wr_buf_size_ = wr_buf_opt_;
- wr_buf_.reset();
- }
-}
-
-template<class NextLayer, bool deflateSupported>
-std::size_t
-stream<NextLayer, deflateSupported>::
-read_size_hint(
- std::size_t initial_size,
- std::true_type) const
-{
- using beast::detail::clamp;
- std::size_t result;
- BOOST_ASSERT(initial_size > 0);
- if(! this->pmd_ || (! rd_done_ && ! this->pmd_->rd_set))
- {
- // current message is uncompressed
-
- if(rd_done_)
- {
- // first message frame
- result = initial_size;
- goto done;
- }
- else if(rd_fh_.fin)
- {
- // last message frame
- BOOST_ASSERT(rd_remain_ > 0);
- result = clamp(rd_remain_);
- goto done;
- }
- }
- result = (std::max)(
- initial_size, clamp(rd_remain_));
-done:
- BOOST_ASSERT(result != 0);
- return result;
-}
-
-template<class NextLayer, bool deflateSupported>
-std::size_t
-stream<NextLayer, deflateSupported>::
-read_size_hint(
- std::size_t initial_size,
- std::false_type) const
-{
- using beast::detail::clamp;
- std::size_t result;
- BOOST_ASSERT(initial_size > 0);
- // compression is not supported
- if(rd_done_)
- {
- // first message frame
- result = initial_size;
- }
- else if(rd_fh_.fin)
- {
- // last message frame
- BOOST_ASSERT(rd_remain_ > 0);
- result = clamp(rd_remain_);
- }
- else
- {
- result = (std::max)(
- initial_size, clamp(rd_remain_));
- }
- BOOST_ASSERT(result != 0);
- return result;
-}
-
-//------------------------------------------------------------------------------
-
-// Attempt to read a complete frame header.
-// Returns `false` if more bytes are needed
-template<class NextLayer, bool deflateSupported>
-template<class DynamicBuffer>
-bool
-stream<NextLayer, deflateSupported>::
-parse_fh(
- detail::frame_header& fh,
- DynamicBuffer& b,
- error_code& ec)
-{
- using boost::asio::buffer;
- using boost::asio::buffer_copy;
- using boost::asio::buffer_size;
- if(buffer_size(b.data()) < 2)
- {
- // need more bytes
- ec.assign(0, ec.category());
- return false;
- }
- buffers_suffix<typename
- DynamicBuffer::const_buffers_type> cb{
- b.data()};
- std::size_t need;
- {
- std::uint8_t tmp[2];
- cb.consume(buffer_copy(buffer(tmp), cb));
- fh.len = tmp[1] & 0x7f;
- switch(fh.len)
- {
- case 126: need = 2; break;
- case 127: need = 8; break;
- default:
- need = 0;
- }
- fh.mask = (tmp[1] & 0x80) != 0;
- if(fh.mask)
- need += 4;
- if(buffer_size(cb) < need)
- {
- // need more bytes
- ec.assign(0, ec.category());
- return false;
- }
- fh.op = static_cast<
- detail::opcode>(tmp[0] & 0x0f);
- fh.fin = (tmp[0] & 0x80) != 0;
- fh.rsv1 = (tmp[0] & 0x40) != 0;
- fh.rsv2 = (tmp[0] & 0x20) != 0;
- fh.rsv3 = (tmp[0] & 0x10) != 0;
- }
- switch(fh.op)
- {
- case detail::opcode::binary:
- case detail::opcode::text:
- if(rd_cont_)
- {
- // new data frame when continuation expected
- ec = error::bad_data_frame;
- return false;
- }
- if(fh.rsv2 || fh.rsv3 ||
- ! this->rd_deflated(fh.rsv1))
- {
- // reserved bits not cleared
- ec = error::bad_reserved_bits;
- return false;
- }
- break;
-
- case detail::opcode::cont:
- if(! rd_cont_)
- {
- // continuation without an active message
- ec = error::bad_continuation;
- return false;
- }
- if(fh.rsv1 || fh.rsv2 || fh.rsv3)
- {
- // reserved bits not cleared
- ec = error::bad_reserved_bits;
- return false;
- }
- break;
-
- default:
- if(detail::is_reserved(fh.op))
- {
- // reserved opcode
- ec = error::bad_opcode;
- return false;
- }
- if(! fh.fin)
- {
- // fragmented control message
- ec = error::bad_control_fragment;
- return false;
- }
- if(fh.len > 125)
- {
- // invalid length for control message
- ec = error::bad_control_size;
- return false;
- }
- if(fh.rsv1 || fh.rsv2 || fh.rsv3)
- {
- // reserved bits not cleared
- ec = error::bad_reserved_bits;
- return false;
- }
- break;
- }
- if(role_ == role_type::server && ! fh.mask)
- {
- // unmasked frame from client
- ec = error::bad_unmasked_frame;
- return false;
- }
- if(role_ == role_type::client && fh.mask)
- {
- // masked frame from server
- ec = error::bad_masked_frame;
- return false;
- }
- if(detail::is_control(fh.op) &&
- buffer_size(cb) < need + fh.len)
- {
- // Make the entire control frame payload
- // get read in before we return `true`
- return false;
- }
- switch(fh.len)
- {
- case 126:
- {
- std::uint8_t tmp[2];
- BOOST_ASSERT(buffer_size(cb) >= sizeof(tmp));
- cb.consume(buffer_copy(buffer(tmp), cb));
- fh.len = detail::big_uint16_to_native(&tmp[0]);
- if(fh.len < 126)
- {
- // length not canonical
- ec = error::bad_size;
- return false;
- }
- break;
- }
- case 127:
- {
- std::uint8_t tmp[8];
- BOOST_ASSERT(buffer_size(cb) >= sizeof(tmp));
- cb.consume(buffer_copy(buffer(tmp), cb));
- fh.len = detail::big_uint64_to_native(&tmp[0]);
- if(fh.len < 65536)
- {
- // length not canonical
- ec = error::bad_size;
- return false;
- }
- break;
- }
- }
- if(fh.mask)
- {
- std::uint8_t tmp[4];
- BOOST_ASSERT(buffer_size(cb) >= sizeof(tmp));
- cb.consume(buffer_copy(buffer(tmp), cb));
- fh.key = detail::little_uint32_to_native(&tmp[0]);
- detail::prepare_key(rd_key_, fh.key);
- }
- else
- {
- // initialize this otherwise operator== breaks
- fh.key = 0;
- }
- if(! detail::is_control(fh.op))
- {
- if(fh.op != detail::opcode::cont)
- {
- rd_size_ = 0;
- rd_op_ = fh.op;
- }
- else
- {
- if(rd_size_ > (std::numeric_limits<
- std::uint64_t>::max)() - fh.len)
- {
- // message size exceeds configured limit
- ec = error::message_too_big;
- return false;
- }
- }
- if(! this->rd_deflated())
- {
- if(rd_msg_max_ && beast::detail::sum_exceeds(
- rd_size_, fh.len, rd_msg_max_))
- {
- // message size exceeds configured limit
- ec = error::message_too_big;
- return false;
- }
- }
- rd_cont_ = ! fh.fin;
- rd_remain_ = fh.len;
- }
- b.consume(b.size() - buffer_size(cb));
- ec.assign(0, ec.category());
- return true;
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class DynamicBuffer>
-void
-stream<NextLayer, deflateSupported>::
-write_close(DynamicBuffer& db, close_reason const& cr)
-{
- using namespace boost::endian;
- detail::frame_header fh;
- fh.op = detail::opcode::close;
- fh.fin = true;
- fh.rsv1 = false;
- fh.rsv2 = false;
- fh.rsv3 = false;
- fh.len = cr.code == close_code::none ?
- 0 : 2 + cr.reason.size();
- if(role_ == role_type::client)
- {
- fh.mask = true;
- fh.key = wr_gen_();
- }
- else
- {
- fh.mask = false;
- }
- detail::write(db, fh);
- if(cr.code != close_code::none)
- {
- detail::prepared_key key;
- if(fh.mask)
- detail::prepare_key(key, fh.key);
- {
- std::uint8_t tmp[2];
- ::new(&tmp[0]) big_uint16_buf_t{
- (std::uint16_t)cr.code};
- auto mb = db.prepare(2);
- boost::asio::buffer_copy(mb,
- boost::asio::buffer(tmp));
- if(fh.mask)
- detail::mask_inplace(mb, key);
- db.commit(2);
- }
- if(! cr.reason.empty())
- {
- auto mb = db.prepare(cr.reason.size());
- boost::asio::buffer_copy(mb,
- boost::asio::const_buffer(
- cr.reason.data(), cr.reason.size()));
- if(fh.mask)
- detail::mask_inplace(mb, key);
- db.commit(cr.reason.size());
- }
- }
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class DynamicBuffer>
-void
-stream<NextLayer, deflateSupported>::
-write_ping(DynamicBuffer& db,
- detail::opcode code, ping_data const& data)
-{
- detail::frame_header fh;
- fh.op = code;
- fh.fin = true;
- fh.rsv1 = false;
- fh.rsv2 = false;
- fh.rsv3 = false;
- fh.len = data.size();
- fh.mask = role_ == role_type::client;
- if(fh.mask)
- fh.key = wr_gen_();
- detail::write(db, fh);
- if(data.empty())
- return;
- detail::prepared_key key;
- if(fh.mask)
- detail::prepare_key(key, fh.key);
- auto mb = db.prepare(data.size());
- boost::asio::buffer_copy(mb,
- boost::asio::const_buffer(
- data.data(), data.size()));
- if(fh.mask)
- detail::mask_inplace(mb, key);
- db.commit(data.size());
-}
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-template<class Decorator>
-request_type
-stream<NextLayer, deflateSupported>::
-build_request(detail::sec_ws_key_type& key,
- string_view host, string_view target,
- Decorator const& decorator)
-{
- request_type req;
- req.target(target);
- req.version(11);
- req.method(http::verb::get);
- req.set(http::field::host, host);
- req.set(http::field::upgrade, "websocket");
- req.set(http::field::connection, "upgrade");
- detail::make_sec_ws_key(key, wr_gen_);
- req.set(http::field::sec_websocket_key, key);
- req.set(http::field::sec_websocket_version, "13");
- build_request_pmd(req, is_deflate_supported{});
- decorator(req);
- if(! req.count(http::field::user_agent))
- req.set(http::field::user_agent,
- BOOST_BEAST_VERSION_STRING);
- return req;
-}
-
-template<class NextLayer, bool deflateSupported>
-inline
-void
-stream<NextLayer, deflateSupported>::
-build_request_pmd(request_type& req, std::true_type)
-{
- if(this->pmd_opts_.client_enable)
- {
- detail::pmd_offer config;
- config.accept = true;
- config.server_max_window_bits =
- this->pmd_opts_.server_max_window_bits;
- config.client_max_window_bits =
- this->pmd_opts_.client_max_window_bits;
- config.server_no_context_takeover =
- this->pmd_opts_.server_no_context_takeover;
- config.client_no_context_takeover =
- this->pmd_opts_.client_no_context_takeover;
- detail::pmd_write(req, config);
- }
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class Body, class Allocator, class Decorator>
-response_type
-stream<NextLayer, deflateSupported>::
-build_response(
- http::request<Body,
- http::basic_fields<Allocator>> const& req,
- Decorator const& decorator,
- error_code& result)
-{
- auto const decorate =
- [&decorator](response_type& res)
- {
- decorator(res);
- if(! res.count(http::field::server))
- {
- BOOST_STATIC_ASSERT(sizeof(BOOST_BEAST_VERSION_STRING) < 20);
- static_string<20> s(BOOST_BEAST_VERSION_STRING);
- res.set(http::field::server, s);
- }
- };
- auto err =
- [&](error e)
- {
- result = e;
- response_type res;
- res.version(req.version());
- res.result(http::status::bad_request);
- res.body() = result.message();
- res.prepare_payload();
- decorate(res);
- return res;
- };
- if(req.version() != 11)
- return err(error::bad_http_version);
- if(req.method() != http::verb::get)
- return err(error::bad_method);
- if(! req.count(http::field::host))
- return err(error::no_host);
- {
- auto const it = req.find(http::field::connection);
- if(it == req.end())
- return err(error::no_connection);
- if(! http::token_list{it->value()}.exists("upgrade"))
- return err(error::no_connection_upgrade);
- }
- {
- auto const it = req.find(http::field::upgrade);
- if(it == req.end())
- return err(error::no_upgrade);
- if(! http::token_list{it->value()}.exists("websocket"))
- return err(error::no_upgrade_websocket);
- }
- string_view key;
- {
- auto const it = req.find(http::field::sec_websocket_key);
- if(it == req.end())
- return err(error::no_sec_key);
- key = it->value();
- if(key.size() > detail::sec_ws_key_type::max_size_n)
- return err(error::bad_sec_key);
- }
- {
- auto const it = req.find(http::field::sec_websocket_version);
- if(it == req.end())
- return err(error::no_sec_version);
- if(it->value() != "13")
- {
- response_type res;
- res.result(http::status::upgrade_required);
- res.version(req.version());
- res.set(http::field::sec_websocket_version, "13");
- result = error::bad_sec_version;
- res.body() = result.message();
- res.prepare_payload();
- decorate(res);
- return res;
- }
- }
-
- response_type res;
- res.result(http::status::switching_protocols);
- res.version(req.version());
- res.set(http::field::upgrade, "websocket");
- res.set(http::field::connection, "upgrade");
- {
- detail::sec_ws_accept_type acc;
- detail::make_sec_ws_accept(acc, key);
- res.set(http::field::sec_websocket_accept, acc);
- }
- build_response_pmd(res, req, is_deflate_supported{});
- decorate(res);
- result = {};
- return res;
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class Body, class Allocator>
-inline
-void
-stream<NextLayer, deflateSupported>::
-build_response_pmd(
- response_type& res,
- http::request<Body,
- http::basic_fields<Allocator>> const& req,
- std::true_type)
-{
- detail::pmd_offer offer;
- detail::pmd_offer unused;
- pmd_read(offer, req);
- pmd_negotiate(res, unused, offer, this->pmd_opts_);
-}
-
-// Called when the WebSocket Upgrade response is received
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-on_response(
- response_type const& res,
- detail::sec_ws_key_type const& key,
- error_code& ec)
-{
- auto const err =
- [&](error e)
- {
- ec = e;
- };
- if(res.result() != http::status::switching_protocols)
- return err(error::upgrade_declined);
- if(res.version() != 11)
- return err(error::bad_http_version);
- {
- auto const it = res.find(http::field::connection);
- if(it == res.end())
- return err(error::no_connection);
- if(! http::token_list{it->value()}.exists("upgrade"))
- return err(error::no_connection_upgrade);
- }
- {
- auto const it = res.find(http::field::upgrade);
- if(it == res.end())
- return err(error::no_upgrade);
- if(! http::token_list{it->value()}.exists("websocket"))
- return err(error::no_upgrade_websocket);
- }
- {
- auto const it = res.find(http::field::sec_websocket_accept);
- if(it == res.end())
- return err(error::no_sec_accept);
- detail::sec_ws_accept_type acc;
- detail::make_sec_ws_accept(acc, key);
- if(acc.compare(it->value()) != 0)
- return err(error::bad_sec_accept);
- }
-
- ec.assign(0, ec.category());
- on_response_pmd(res, is_deflate_supported{});
- open(role_type::client);
-}
-
-template<class NextLayer, bool deflateSupported>
-inline
-void
-stream<NextLayer, deflateSupported>::
-on_response_pmd(
- response_type const& res,
- std::true_type)
-{
- detail::pmd_offer offer;
- pmd_read(offer, res);
- // VFALCO see if offer satisfies pmd_config_,
- // return an error if not.
- this->pmd_config_ = offer; // overwrite for now
-}
-
-// _Fail the WebSocket Connection_
-template<class NextLayer, bool deflateSupported>
-void
-stream<NextLayer, deflateSupported>::
-do_fail(
- std::uint16_t code, // if set, send a close frame first
- error_code ev, // error code to use upon success
- error_code& ec) // set to the error, else set to ev
-{
- BOOST_ASSERT(ev);
- status_ = status::closing;
- if(code != close_code::none && ! wr_close_)
- {
- wr_close_ = true;
- detail::frame_buffer fb;
- write_close<
- flat_static_buffer_base>(fb, code);
- boost::asio::write(stream_, fb.data(), ec);
- if(! check_ok(ec))
- return;
- }
- using beast::websocket::teardown;
- teardown(role_, stream_, ec);
- if(ec == boost::asio::error::eof)
- {
- // Rationale:
- // http://stackoverflow.com/questions/25587403/boost-asio-ssl-async-shutdown-always-finishes-with-an-error
- ec.assign(0, ec.category());
- }
- if(! ec)
- ec = ev;
- if(ec && ec != error::closed)
- status_ = status::failed;
- else
- status_ = status::closed;
- close();
-}
-
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/impl/teardown.ipp b/contrib/restricted/boost/boost/beast/websocket/impl/teardown.ipp
deleted file mode 100644
index add6b2773d..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/impl/teardown.ipp
+++ /dev/null
@@ -1,226 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_IMPL_TEARDOWN_IPP
-#define BOOST_BEAST_WEBSOCKET_IMPL_TEARDOWN_IPP
-
-#include <boost/beast/core/bind_handler.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/asio/associated_allocator.hpp>
-#include <boost/asio/associated_executor.hpp>
-#include <boost/asio/coroutine.hpp>
-#include <boost/asio/handler_continuation_hook.hpp>
-#include <boost/asio/handler_invoke_hook.hpp>
-#include <boost/asio/post.hpp>
-#include <memory>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-namespace detail {
-
-template<class Handler>
-class teardown_tcp_op : public boost::asio::coroutine
-{
- using socket_type =
- boost::asio::ip::tcp::socket;
-
- Handler h_;
- socket_type& s_;
- role_type role_;
- bool nb_;
-
-public:
- teardown_tcp_op(teardown_tcp_op&& other) = default;
- teardown_tcp_op(teardown_tcp_op const& other) = default;
-
- template<class DeducedHandler>
- teardown_tcp_op(
- DeducedHandler&& h,
- socket_type& s,
- role_type role)
- : h_(std::forward<DeducedHandler>(h))
- , s_(s)
- , role_(role)
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(h_);
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<socket_type&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- h_, s_.get_executor());
- }
-
- void
- operator()(
- error_code ec = {},
- std::size_t bytes_transferred = 0);
-
- friend
- bool asio_handler_is_continuation(teardown_tcp_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return asio_handler_is_continuation(
- std::addressof(op->h_));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, teardown_tcp_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(f, std::addressof(op->h_));
- }
-};
-
-template<class Handler>
-void
-teardown_tcp_op<Handler>::
-operator()(error_code ec, std::size_t bytes_transferred)
-{
- using boost::asio::buffer;
- using tcp = boost::asio::ip::tcp;
- BOOST_ASIO_CORO_REENTER(*this)
- {
- nb_ = s_.non_blocking();
- s_.non_blocking(true, ec);
- if(! ec)
- {
- if(role_ == role_type::server)
- s_.shutdown(tcp::socket::shutdown_send, ec);
- }
- if(ec)
- {
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(
- s_.get_executor(),
- bind_handler(std::move(*this), ec, 0));
- goto upcall;
- }
- for(;;)
- {
- {
- char buf[2048];
- s_.read_some(
- boost::asio::buffer(buf), ec);
- }
- if(ec == boost::asio::error::would_block)
- {
- BOOST_ASIO_CORO_YIELD
- s_.async_wait(
- boost::asio::ip::tcp::socket::wait_read,
- std::move(*this));
- continue;
- }
- if(ec)
- {
- if(ec != boost::asio::error::eof)
- goto upcall;
- ec = {};
- break;
- }
- if(bytes_transferred == 0)
- {
- // happens sometimes
- break;
- }
- }
- if(role_ == role_type::client)
- s_.shutdown(tcp::socket::shutdown_send, ec);
- if(ec)
- goto upcall;
- s_.close(ec);
- upcall:
- {
- error_code ignored;
- s_.non_blocking(nb_, ignored);
- }
- h_(ec);
- }
-}
-
-} // detail
-
-//------------------------------------------------------------------------------
-
-inline
-void
-teardown(
- role_type role,
- boost::asio::ip::tcp::socket& socket,
- error_code& ec)
-{
- using boost::asio::buffer;
- if(role == role_type::server)
- socket.shutdown(
- boost::asio::ip::tcp::socket::shutdown_send, ec);
- if(ec)
- return;
- for(;;)
- {
- char buf[2048];
- auto const bytes_transferred =
- socket.read_some(buffer(buf), ec);
- if(ec)
- {
- if(ec != boost::asio::error::eof)
- return;
- ec = {};
- break;
- }
- if(bytes_transferred == 0)
- {
- // happens sometimes
- break;
- }
- }
- if(role == role_type::client)
- socket.shutdown(
- boost::asio::ip::tcp::socket::shutdown_send, ec);
- if(ec)
- return;
- socket.close(ec);
-}
-
-template<class TeardownHandler>
-inline
-void
-async_teardown(
- role_type role,
- boost::asio::ip::tcp::socket& socket,
- TeardownHandler&& handler)
-{
- static_assert(beast::is_completion_handler<
- TeardownHandler, void(error_code)>::value,
- "TeardownHandler requirements not met");
- detail::teardown_tcp_op<typename std::decay<
- TeardownHandler>::type>{std::forward<
- TeardownHandler>(handler), socket,
- role}();
-}
-
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/impl/write.ipp b/contrib/restricted/boost/boost/beast/websocket/impl/write.ipp
deleted file mode 100644
index d12f2f9e12..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/impl/write.ipp
+++ /dev/null
@@ -1,890 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_IMPL_WRITE_IPP
-#define BOOST_BEAST_WEBSOCKET_IMPL_WRITE_IPP
-
-#include <boost/beast/core/bind_handler.hpp>
-#include <boost/beast/core/buffers_cat.hpp>
-#include <boost/beast/core/buffers_prefix.hpp>
-#include <boost/beast/core/buffers_suffix.hpp>
-#include <boost/beast/core/flat_static_buffer.hpp>
-#include <boost/beast/core/type_traits.hpp>
-#include <boost/beast/core/detail/clamp.hpp>
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/websocket/detail/frame.hpp>
-#include <boost/asio/associated_allocator.hpp>
-#include <boost/asio/associated_executor.hpp>
-#include <boost/asio/coroutine.hpp>
-#include <boost/asio/handler_continuation_hook.hpp>
-#include <boost/asio/handler_invoke_hook.hpp>
-#include <boost/assert.hpp>
-#include <boost/config.hpp>
-#include <boost/throw_exception.hpp>
-#include <algorithm>
-#include <memory>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-namespace detail {
-
-// Compress a buffer sequence
-// Returns: `true` if more calls are needed
-//
-template<>
-template<class ConstBufferSequence>
-bool
-stream_base<true>::
-deflate(
- boost::asio::mutable_buffer& out,
- buffers_suffix<ConstBufferSequence>& cb,
- bool fin,
- std::size_t& total_in,
- error_code& ec)
-{
- using boost::asio::buffer;
- BOOST_ASSERT(out.size() >= 6);
- auto& zo = this->pmd_->zo;
- zlib::z_params zs;
- zs.avail_in = 0;
- zs.next_in = nullptr;
- zs.avail_out = out.size();
- zs.next_out = out.data();
- for(auto in : beast::detail::buffers_range(cb))
- {
- zs.avail_in = in.size();
- if(zs.avail_in == 0)
- continue;
- zs.next_in = in.data();
- zo.write(zs, zlib::Flush::none, ec);
- if(ec)
- {
- if(ec != zlib::error::need_buffers)
- return false;
- BOOST_ASSERT(zs.avail_out == 0);
- BOOST_ASSERT(zs.total_out == out.size());
- ec.assign(0, ec.category());
- break;
- }
- if(zs.avail_out == 0)
- {
- BOOST_ASSERT(zs.total_out == out.size());
- break;
- }
- BOOST_ASSERT(zs.avail_in == 0);
- }
- total_in = zs.total_in;
- cb.consume(zs.total_in);
- if(zs.avail_out > 0 && fin)
- {
- auto const remain = boost::asio::buffer_size(cb);
- if(remain == 0)
- {
- // Inspired by Mark Adler
- // https://github.com/madler/zlib/issues/149
- //
- // VFALCO We could do this flush twice depending
- // on how much space is in the output.
- zo.write(zs, zlib::Flush::block, ec);
- BOOST_ASSERT(! ec || ec == zlib::error::need_buffers);
- if(ec == zlib::error::need_buffers)
- ec.assign(0, ec.category());
- if(ec)
- return false;
- if(zs.avail_out >= 6)
- {
- zo.write(zs, zlib::Flush::full, ec);
- BOOST_ASSERT(! ec);
- // remove flush marker
- zs.total_out -= 4;
- out = buffer(out.data(), zs.total_out);
- return false;
- }
- }
- }
- ec.assign(0, ec.category());
- out = buffer(out.data(), zs.total_out);
- return true;
-}
-
-template<>
-inline
-void
-stream_base<true>::
-do_context_takeover_write(role_type role)
-{
- if((role == role_type::client &&
- this->pmd_config_.client_no_context_takeover) ||
- (role == role_type::server &&
- this->pmd_config_.server_no_context_takeover))
- {
- this->pmd_->zo.reset();
- }
-}
-
-} // detail
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-template<class Buffers, class Handler>
-class stream<NextLayer, deflateSupported>::write_some_op
- : public boost::asio::coroutine
-{
- Handler h_;
- stream<NextLayer, deflateSupported>& ws_;
- buffers_suffix<Buffers> cb_;
- detail::frame_header fh_;
- detail::prepared_key key_;
- std::size_t bytes_transferred_ = 0;
- std::size_t remain_;
- std::size_t in_;
- int how_;
- bool fin_;
- bool more_;
- bool cont_ = false;
-
-public:
- static constexpr int id = 2; // for soft_mutex
-
- write_some_op(write_some_op&&) = default;
- write_some_op(write_some_op const&) = delete;
-
- template<class DeducedHandler>
- write_some_op(
- DeducedHandler&& h,
- stream<NextLayer, deflateSupported>& ws,
- bool fin,
- Buffers const& bs)
- : h_(std::forward<DeducedHandler>(h))
- , ws_(ws)
- , cb_(bs)
- , fin_(fin)
- {
- }
-
- using allocator_type =
- boost::asio::associated_allocator_t<Handler>;
-
- allocator_type
- get_allocator() const noexcept
- {
- return (boost::asio::get_associated_allocator)(h_);
- }
-
- using executor_type = boost::asio::associated_executor_t<
- Handler, decltype(std::declval<stream<NextLayer, deflateSupported>&>().get_executor())>;
-
- executor_type
- get_executor() const noexcept
- {
- return (boost::asio::get_associated_executor)(
- h_, ws_.get_executor());
- }
-
- Handler&
- handler()
- {
- return h_;
- }
-
- void operator()(
- error_code ec = {},
- std::size_t bytes_transferred = 0,
- bool cont = true);
-
- friend
- bool asio_handler_is_continuation(write_some_op* op)
- {
- using boost::asio::asio_handler_is_continuation;
- return op->cont_ || asio_handler_is_continuation(
- std::addressof(op->h_));
- }
-
- template<class Function>
- friend
- void asio_handler_invoke(Function&& f, write_some_op* op)
- {
- using boost::asio::asio_handler_invoke;
- asio_handler_invoke(
- f, std::addressof(op->h_));
- }
-};
-
-template<class NextLayer, bool deflateSupported>
-template<class Buffers, class Handler>
-void
-stream<NextLayer, deflateSupported>::
-write_some_op<Buffers, Handler>::
-operator()(
- error_code ec,
- std::size_t bytes_transferred,
- bool cont)
-{
- using beast::detail::clamp;
- using boost::asio::buffer;
- using boost::asio::buffer_copy;
- using boost::asio::buffer_size;
- using boost::asio::mutable_buffer;
- enum
- {
- do_nomask_nofrag,
- do_nomask_frag,
- do_mask_nofrag,
- do_mask_frag,
- do_deflate
- };
- std::size_t n;
- boost::asio::mutable_buffer b;
- cont_ = cont;
- BOOST_ASIO_CORO_REENTER(*this)
- {
- // Set up the outgoing frame header
- if(! ws_.wr_cont_)
- {
- ws_.begin_msg();
- fh_.rsv1 = ws_.wr_compress_;
- }
- else
- {
- fh_.rsv1 = false;
- }
- fh_.rsv2 = false;
- fh_.rsv3 = false;
- fh_.op = ws_.wr_cont_ ?
- detail::opcode::cont : ws_.wr_opcode_;
- fh_.mask =
- ws_.role_ == role_type::client;
-
- // Choose a write algorithm
- if(ws_.wr_compress_)
- {
- how_ = do_deflate;
- }
- else if(! fh_.mask)
- {
- if(! ws_.wr_frag_)
- {
- how_ = do_nomask_nofrag;
- }
- else
- {
- BOOST_ASSERT(ws_.wr_buf_size_ != 0);
- remain_ = buffer_size(cb_);
- if(remain_ > ws_.wr_buf_size_)
- how_ = do_nomask_frag;
- else
- how_ = do_nomask_nofrag;
- }
- }
- else
- {
- if(! ws_.wr_frag_)
- {
- how_ = do_mask_nofrag;
- }
- else
- {
- BOOST_ASSERT(ws_.wr_buf_size_ != 0);
- remain_ = buffer_size(cb_);
- if(remain_ > ws_.wr_buf_size_)
- how_ = do_mask_frag;
- else
- how_ = do_mask_nofrag;
- }
- }
-
- // Maybe suspend
- if(ws_.wr_block_.try_lock(this))
- {
- // Make sure the stream is open
- if(! ws_.check_open(ec))
- goto upcall;
- }
- else
- {
- do_suspend:
- // Suspend
- BOOST_ASIO_CORO_YIELD
- ws_.paused_wr_.emplace(std::move(*this));
-
- // Acquire the write block
- ws_.wr_block_.lock(this);
-
- // Resume
- BOOST_ASIO_CORO_YIELD
- boost::asio::post(
- ws_.get_executor(), std::move(*this));
- BOOST_ASSERT(ws_.wr_block_.is_locked(this));
-
- // Make sure the stream is open
- if(! ws_.check_open(ec))
- goto upcall;
- }
-
- //------------------------------------------------------------------
-
- if(how_ == do_nomask_nofrag)
- {
- fh_.fin = fin_;
- fh_.len = buffer_size(cb_);
- ws_.wr_fb_.reset();
- detail::write<flat_static_buffer_base>(
- ws_.wr_fb_, fh_);
- ws_.wr_cont_ = ! fin_;
- // Send frame
- BOOST_ASIO_CORO_YIELD
- boost::asio::async_write(ws_.stream_,
- buffers_cat(ws_.wr_fb_.data(), cb_),
- std::move(*this));
- if(! ws_.check_ok(ec))
- goto upcall;
- bytes_transferred_ += clamp(fh_.len);
- goto upcall;
- }
-
- //------------------------------------------------------------------
-
- else if(how_ == do_nomask_frag)
- {
- for(;;)
- {
- n = clamp(remain_, ws_.wr_buf_size_);
- fh_.len = n;
- remain_ -= n;
- fh_.fin = fin_ ? remain_ == 0 : false;
- ws_.wr_fb_.reset();
- detail::write<flat_static_buffer_base>(
- ws_.wr_fb_, fh_);
- ws_.wr_cont_ = ! fin_;
- // Send frame
- BOOST_ASIO_CORO_YIELD
- boost::asio::async_write(
- ws_.stream_, buffers_cat(
- ws_.wr_fb_.data(), buffers_prefix(
- clamp(fh_.len), cb_)),
- std::move(*this));
- if(! ws_.check_ok(ec))
- goto upcall;
- n = clamp(fh_.len); // because yield
- bytes_transferred_ += n;
- if(remain_ == 0)
- break;
- cb_.consume(n);
- fh_.op = detail::opcode::cont;
- // Allow outgoing control frames to
- // be sent in between message frames
- ws_.wr_block_.unlock(this);
- if( ws_.paused_close_.maybe_invoke() ||
- ws_.paused_rd_.maybe_invoke() ||
- ws_.paused_ping_.maybe_invoke())
- {
- BOOST_ASSERT(ws_.wr_block_.is_locked());
- goto do_suspend;
- }
- ws_.wr_block_.lock(this);
- }
- goto upcall;
- }
-
- //------------------------------------------------------------------
-
- else if(how_ == do_mask_nofrag)
- {
- remain_ = buffer_size(cb_);
- fh_.fin = fin_;
- fh_.len = remain_;
- fh_.key = ws_.wr_gen_();
- detail::prepare_key(key_, fh_.key);
- ws_.wr_fb_.reset();
- detail::write<flat_static_buffer_base>(
- ws_.wr_fb_, fh_);
- n = clamp(remain_, ws_.wr_buf_size_);
- buffer_copy(buffer(
- ws_.wr_buf_.get(), n), cb_);
- detail::mask_inplace(buffer(
- ws_.wr_buf_.get(), n), key_);
- remain_ -= n;
- ws_.wr_cont_ = ! fin_;
- // Send frame header and partial payload
- BOOST_ASIO_CORO_YIELD
- boost::asio::async_write(
- ws_.stream_, buffers_cat(ws_.wr_fb_.data(),
- buffer(ws_.wr_buf_.get(), n)),
- std::move(*this));
- if(! ws_.check_ok(ec))
- goto upcall;
- bytes_transferred_ +=
- bytes_transferred - ws_.wr_fb_.size();
- while(remain_ > 0)
- {
- cb_.consume(ws_.wr_buf_size_);
- n = clamp(remain_, ws_.wr_buf_size_);
- buffer_copy(buffer(
- ws_.wr_buf_.get(), n), cb_);
- detail::mask_inplace(buffer(
- ws_.wr_buf_.get(), n), key_);
- remain_ -= n;
- // Send partial payload
- BOOST_ASIO_CORO_YIELD
- boost::asio::async_write(ws_.stream_,
- buffer(ws_.wr_buf_.get(), n),
- std::move(*this));
- if(! ws_.check_ok(ec))
- goto upcall;
- bytes_transferred_ += bytes_transferred;
- }
- goto upcall;
- }
-
- //------------------------------------------------------------------
-
- else if(how_ == do_mask_frag)
- {
- for(;;)
- {
- n = clamp(remain_, ws_.wr_buf_size_);
- remain_ -= n;
- fh_.len = n;
- fh_.key = ws_.wr_gen_();
- fh_.fin = fin_ ? remain_ == 0 : false;
- detail::prepare_key(key_, fh_.key);
- buffer_copy(buffer(
- ws_.wr_buf_.get(), n), cb_);
- detail::mask_inplace(buffer(
- ws_.wr_buf_.get(), n), key_);
- ws_.wr_fb_.reset();
- detail::write<flat_static_buffer_base>(
- ws_.wr_fb_, fh_);
- ws_.wr_cont_ = ! fin_;
- // Send frame
- BOOST_ASIO_CORO_YIELD
- boost::asio::async_write(ws_.stream_,
- buffers_cat(ws_.wr_fb_.data(),
- buffer(ws_.wr_buf_.get(), n)),
- std::move(*this));
- if(! ws_.check_ok(ec))
- goto upcall;
- n = bytes_transferred - ws_.wr_fb_.size();
- bytes_transferred_ += n;
- if(remain_ == 0)
- break;
- cb_.consume(n);
- fh_.op = detail::opcode::cont;
- // Allow outgoing control frames to
- // be sent in between message frames:
- ws_.wr_block_.unlock(this);
- if( ws_.paused_close_.maybe_invoke() ||
- ws_.paused_rd_.maybe_invoke() ||
- ws_.paused_ping_.maybe_invoke())
- {
- BOOST_ASSERT(ws_.wr_block_.is_locked());
- goto do_suspend;
- }
- ws_.wr_block_.lock(this);
- }
- goto upcall;
- }
-
- //------------------------------------------------------------------
-
- else if(how_ == do_deflate)
- {
- for(;;)
- {
- b = buffer(ws_.wr_buf_.get(),
- ws_.wr_buf_size_);
- more_ = ws_.deflate(b, cb_, fin_, in_, ec);
- if(! ws_.check_ok(ec))
- goto upcall;
- n = buffer_size(b);
- if(n == 0)
- {
- // The input was consumed, but there
- // is no output due to compression
- // latency.
- BOOST_ASSERT(! fin_);
- BOOST_ASSERT(buffer_size(cb_) == 0);
- goto upcall;
- }
- if(fh_.mask)
- {
- fh_.key = ws_.wr_gen_();
- detail::prepared_key key;
- detail::prepare_key(key, fh_.key);
- detail::mask_inplace(b, key);
- }
- fh_.fin = ! more_;
- fh_.len = n;
- ws_.wr_fb_.reset();
- detail::write<
- flat_static_buffer_base>(ws_.wr_fb_, fh_);
- ws_.wr_cont_ = ! fin_;
- // Send frame
- BOOST_ASIO_CORO_YIELD
- boost::asio::async_write(ws_.stream_,
- buffers_cat(ws_.wr_fb_.data(), b),
- std::move(*this));
- if(! ws_.check_ok(ec))
- goto upcall;
- bytes_transferred_ += in_;
- if(more_)
- {
- fh_.op = detail::opcode::cont;
- fh_.rsv1 = false;
- // Allow outgoing control frames to
- // be sent in between message frames:
- ws_.wr_block_.unlock(this);
- if( ws_.paused_close_.maybe_invoke() ||
- ws_.paused_rd_.maybe_invoke() ||
- ws_.paused_ping_.maybe_invoke())
- {
- BOOST_ASSERT(ws_.wr_block_.is_locked());
- goto do_suspend;
- }
- ws_.wr_block_.lock(this);
- }
- else
- {
- if(fh_.fin)
- ws_.do_context_takeover_write(ws_.role_);
- goto upcall;
- }
- }
- }
-
- //--------------------------------------------------------------------------
-
- upcall:
- ws_.wr_block_.unlock(this);
- ws_.paused_close_.maybe_invoke() ||
- ws_.paused_rd_.maybe_invoke() ||
- ws_.paused_ping_.maybe_invoke();
- if(! cont_)
- return boost::asio::post(
- ws_.stream_.get_executor(),
- bind_handler(std::move(h_), ec, bytes_transferred_));
- h_(ec, bytes_transferred_);
- }
-}
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-template<class ConstBufferSequence>
-std::size_t
-stream<NextLayer, deflateSupported>::
-write_some(bool fin, ConstBufferSequence const& buffers)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- error_code ec;
- auto const bytes_transferred =
- write_some(fin, buffers, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
- return bytes_transferred;
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class ConstBufferSequence>
-std::size_t
-stream<NextLayer, deflateSupported>::
-write_some(bool fin,
- ConstBufferSequence const& buffers, error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- using beast::detail::clamp;
- using boost::asio::buffer;
- using boost::asio::buffer_copy;
- using boost::asio::buffer_size;
- std::size_t bytes_transferred = 0;
- ec.assign(0, ec.category());
- // Make sure the stream is open
- if(! check_open(ec))
- return bytes_transferred;
- detail::frame_header fh;
- if(! wr_cont_)
- {
- begin_msg();
- fh.rsv1 = wr_compress_;
- }
- else
- {
- fh.rsv1 = false;
- }
- fh.rsv2 = false;
- fh.rsv3 = false;
- fh.op = wr_cont_ ?
- detail::opcode::cont : wr_opcode_;
- fh.mask = role_ == role_type::client;
- auto remain = buffer_size(buffers);
- if(wr_compress_)
- {
- buffers_suffix<
- ConstBufferSequence> cb{buffers};
- for(;;)
- {
- auto b = buffer(
- wr_buf_.get(), wr_buf_size_);
- auto const more = this->deflate(
- b, cb, fin, bytes_transferred, ec);
- if(! check_ok(ec))
- return bytes_transferred;
- auto const n = buffer_size(b);
- if(n == 0)
- {
- // The input was consumed, but there
- // is no output due to compression
- // latency.
- BOOST_ASSERT(! fin);
- BOOST_ASSERT(buffer_size(cb) == 0);
- fh.fin = false;
- break;
- }
- if(fh.mask)
- {
- fh.key = wr_gen_();
- detail::prepared_key key;
- detail::prepare_key(key, fh.key);
- detail::mask_inplace(b, key);
- }
- fh.fin = ! more;
- fh.len = n;
- detail::fh_buffer fh_buf;
- detail::write<
- flat_static_buffer_base>(fh_buf, fh);
- wr_cont_ = ! fin;
- boost::asio::write(stream_,
- buffers_cat(fh_buf.data(), b), ec);
- if(! check_ok(ec))
- return bytes_transferred;
- if(! more)
- break;
- fh.op = detail::opcode::cont;
- fh.rsv1 = false;
- }
- if(fh.fin)
- this->do_context_takeover_write(role_);
- }
- else if(! fh.mask)
- {
- if(! wr_frag_)
- {
- // no mask, no autofrag
- fh.fin = fin;
- fh.len = remain;
- detail::fh_buffer fh_buf;
- detail::write<
- flat_static_buffer_base>(fh_buf, fh);
- wr_cont_ = ! fin;
- boost::asio::write(stream_,
- buffers_cat(fh_buf.data(), buffers), ec);
- if(! check_ok(ec))
- return bytes_transferred;
- bytes_transferred += remain;
- }
- else
- {
- // no mask, autofrag
- BOOST_ASSERT(wr_buf_size_ != 0);
- buffers_suffix<
- ConstBufferSequence> cb{buffers};
- for(;;)
- {
- auto const n = clamp(remain, wr_buf_size_);
- remain -= n;
- fh.len = n;
- fh.fin = fin ? remain == 0 : false;
- detail::fh_buffer fh_buf;
- detail::write<
- flat_static_buffer_base>(fh_buf, fh);
- wr_cont_ = ! fin;
- boost::asio::write(stream_,
- buffers_cat(fh_buf.data(),
- buffers_prefix(n, cb)), ec);
- if(! check_ok(ec))
- return bytes_transferred;
- bytes_transferred += n;
- if(remain == 0)
- break;
- fh.op = detail::opcode::cont;
- cb.consume(n);
- }
- }
- }
- else if(! wr_frag_)
- {
- // mask, no autofrag
- fh.fin = fin;
- fh.len = remain;
- fh.key = wr_gen_();
- detail::prepared_key key;
- detail::prepare_key(key, fh.key);
- detail::fh_buffer fh_buf;
- detail::write<
- flat_static_buffer_base>(fh_buf, fh);
- buffers_suffix<
- ConstBufferSequence> cb{buffers};
- {
- auto const n = clamp(remain, wr_buf_size_);
- auto const b = buffer(wr_buf_.get(), n);
- buffer_copy(b, cb);
- cb.consume(n);
- remain -= n;
- detail::mask_inplace(b, key);
- wr_cont_ = ! fin;
- boost::asio::write(stream_,
- buffers_cat(fh_buf.data(), b), ec);
- if(! check_ok(ec))
- return bytes_transferred;
- bytes_transferred += n;
- }
- while(remain > 0)
- {
- auto const n = clamp(remain, wr_buf_size_);
- auto const b = buffer(wr_buf_.get(), n);
- buffer_copy(b, cb);
- cb.consume(n);
- remain -= n;
- detail::mask_inplace(b, key);
- boost::asio::write(stream_, b, ec);
- if(! check_ok(ec))
- return bytes_transferred;
- bytes_transferred += n;
- }
- }
- else
- {
- // mask, autofrag
- BOOST_ASSERT(wr_buf_size_ != 0);
- buffers_suffix<
- ConstBufferSequence> cb{buffers};
- for(;;)
- {
- fh.key = wr_gen_();
- detail::prepared_key key;
- detail::prepare_key(key, fh.key);
- auto const n = clamp(remain, wr_buf_size_);
- auto const b = buffer(wr_buf_.get(), n);
- buffer_copy(b, cb);
- detail::mask_inplace(b, key);
- fh.len = n;
- remain -= n;
- fh.fin = fin ? remain == 0 : false;
- wr_cont_ = ! fh.fin;
- detail::fh_buffer fh_buf;
- detail::write<
- flat_static_buffer_base>(fh_buf, fh);
- boost::asio::write(stream_,
- buffers_cat(fh_buf.data(), b), ec);
- if(! check_ok(ec))
- return bytes_transferred;
- bytes_transferred += n;
- if(remain == 0)
- break;
- fh.op = detail::opcode::cont;
- cb.consume(n);
- }
- }
- return bytes_transferred;
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class ConstBufferSequence, class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
-stream<NextLayer, deflateSupported>::
-async_write_some(bool fin,
- ConstBufferSequence const& bs, WriteHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- WriteHandler, void(error_code, std::size_t));
- write_some_op<ConstBufferSequence, BOOST_ASIO_HANDLER_TYPE(
- WriteHandler, void(error_code, std::size_t))>{
- std::move(init.completion_handler), *this, fin, bs}(
- {}, 0, false);
- return init.result.get();
-}
-
-//------------------------------------------------------------------------------
-
-template<class NextLayer, bool deflateSupported>
-template<class ConstBufferSequence>
-std::size_t
-stream<NextLayer, deflateSupported>::
-write(ConstBufferSequence const& buffers)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- error_code ec;
- auto const bytes_transferred = write(buffers, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(system_error{ec});
- return bytes_transferred;
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class ConstBufferSequence>
-std::size_t
-stream<NextLayer, deflateSupported>::
-write(ConstBufferSequence const& buffers, error_code& ec)
-{
- static_assert(is_sync_stream<next_layer_type>::value,
- "SyncStream requirements not met");
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- return write_some(true, buffers, ec);
-}
-
-template<class NextLayer, bool deflateSupported>
-template<class ConstBufferSequence, class WriteHandler>
-BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
-stream<NextLayer, deflateSupported>::
-async_write(
- ConstBufferSequence const& bs, WriteHandler&& handler)
-{
- static_assert(is_async_stream<next_layer_type>::value,
- "AsyncStream requirements not met");
- static_assert(boost::asio::is_const_buffer_sequence<
- ConstBufferSequence>::value,
- "ConstBufferSequence requirements not met");
- BOOST_BEAST_HANDLER_INIT(
- WriteHandler, void(error_code, std::size_t));
- write_some_op<ConstBufferSequence, BOOST_ASIO_HANDLER_TYPE(
- WriteHandler, void(error_code, std::size_t))>{
- std::move(init.completion_handler), *this, true, bs}(
- {}, 0, false);
- return init.result.get();
-}
-
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/option.hpp b/contrib/restricted/boost/boost/beast/websocket/option.hpp
deleted file mode 100644
index 83788994d1..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/option.hpp
+++ /dev/null
@@ -1,73 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_OPTION_HPP
-#define BOOST_BEAST_WEBSOCKET_OPTION_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/websocket/rfc6455.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/throw_exception.hpp>
-#include <algorithm>
-#include <cstdint>
-#include <functional>
-#include <stdexcept>
-#include <type_traits>
-#include <utility>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-/** permessage-deflate extension options.
-
- These settings control the permessage-deflate extension,
- which allows messages to be compressed.
-
- @note Objects of this type are used with
- @ref beast::websocket::stream::set_option.
-*/
-struct permessage_deflate
-{
- /// `true` to offer the extension in the server role
- bool server_enable = false;
-
- /// `true` to offer the extension in the client role
- bool client_enable = false;
-
- /** Maximum server window bits to offer
-
- @note Due to a bug in ZLib, this value must be greater than 8.
- */
- int server_max_window_bits = 15;
-
- /** Maximum client window bits to offer
-
- @note Due to a bug in ZLib, this value must be greater than 8.
- */
- int client_max_window_bits = 15;
-
- /// `true` if server_no_context_takeover desired
- bool server_no_context_takeover = false;
-
- /// `true` if client_no_context_takeover desired
- bool client_no_context_takeover = false;
-
- /// Deflate compression level 0..9
- int compLevel = 8;
-
- /// Deflate memory level, 1..9
- int memLevel = 4;
-};
-
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/rfc6455.hpp b/contrib/restricted/boost/boost/beast/websocket/rfc6455.hpp
deleted file mode 100644
index 921f896351..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/rfc6455.hpp
+++ /dev/null
@@ -1,215 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_RFC6455_HPP
-#define BOOST_BEAST_WEBSOCKET_RFC6455_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/static_string.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/http/message.hpp>
-#include <array>
-#include <cstdint>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-/** Returns `true` if the specified HTTP request is a WebSocket Upgrade.
-
- This function returns `true` when the passed HTTP Request
- indicates a WebSocket Upgrade. It does not validate the
- contents of the fields: it just trivially accepts requests
- which could only possibly be a valid or invalid WebSocket
- Upgrade message.
-
- Callers who wish to manually read HTTP requests in their
- server implementation can use this function to determine if
- the request should be routed to an instance of
- @ref websocket::stream.
-
- @par Example
- @code
- void handle_connection(boost::asio::ip::tcp::socket& sock)
- {
- boost::beast::flat_buffer buffer;
- boost::beast::http::request<boost::beast::http::string_body> req;
- boost::beast::http::read(sock, buffer, req);
- if(boost::beast::websocket::is_upgrade(req))
- {
- boost::beast::websocket::stream<decltype(sock)> ws{std::move(sock)};
- ws.accept(req);
- }
- }
- @endcode
-
- @param req The HTTP Request object to check.
-
- @return `true` if the request is a WebSocket Upgrade.
-*/
-template<class Allocator>
-bool
-is_upgrade(beast::http::header<true,
- http::basic_fields<Allocator>> const& req);
-
-/** Close status codes.
-
- These codes accompany close frames.
-
- @see <a href="https://tools.ietf.org/html/rfc6455#section-7.4.1">RFC 6455 7.4.1 Defined Status Codes</a>
-*/
-enum close_code : std::uint16_t
-{
- /// Normal closure; the connection successfully completed whatever purpose for which it was created.
- normal = 1000,
-
- /// The endpoint is going away, either because of a server failure or because the browser is navigating away from the page that opened the connection.
- going_away = 1001,
-
- /// The endpoint is terminating the connection due to a protocol error.
- protocol_error = 1002,
-
- /// The connection is being terminated because the endpoint received data of a type it cannot accept (for example, a text-only endpoint received binary data).
- unknown_data = 1003,
-
- /// The endpoint is terminating the connection because a message was received that contained inconsistent data (e.g., non-UTF-8 data within a text message).
- bad_payload = 1007,
-
- /// The endpoint is terminating the connection because it received a message that violates its policy. This is a generic status code, used when codes 1003 and 1009 are not suitable.
- policy_error = 1008,
-
- /// The endpoint is terminating the connection because a data frame was received that is too large.
- too_big = 1009,
-
- /// The client is terminating the connection because it expected the server to negotiate one or more extension, but the server didn't.
- needs_extension = 1010,
-
- /// The server is terminating the connection because it encountered an unexpected condition that prevented it from fulfilling the request.
- internal_error = 1011,
-
- /// The server is terminating the connection because it is restarting.
- service_restart = 1012,
-
- /// The server is terminating the connection due to a temporary condition, e.g. it is overloaded and is casting off some of its clients.
- try_again_later = 1013,
-
- //----
- //
- // The following are illegal on the wire
- //
-
- /** Used internally to mean "no error"
-
- This code is reserved and may not be sent.
- */
- none = 0,
-
- /** Reserved for future use by the WebSocket standard.
-
- This code is reserved and may not be sent.
- */
- reserved1 = 1004,
-
- /** No status code was provided even though one was expected.
-
- This code is reserved and may not be sent.
- */
- no_status = 1005,
-
- /** Connection was closed without receiving a close frame
-
- This code is reserved and may not be sent.
- */
- abnormal = 1006,
-
- /** Reserved for future use by the WebSocket standard.
-
- This code is reserved and may not be sent.
- */
- reserved2 = 1014,
-
- /** Reserved for future use by the WebSocket standard.
-
- This code is reserved and may not be sent.
- */
- reserved3 = 1015
-
- //
- //----
-
- //last = 5000 // satisfy warnings
-};
-
-/// The type representing the reason string in a close frame.
-using reason_string = static_string<123, char>;
-
-/// The type representing the payload of ping and pong messages.
-using ping_data = static_string<125, char>;
-
-/** Description of the close reason.
-
- This object stores the close code (if any) and the optional
- utf-8 encoded implementation defined reason string.
-*/
-struct close_reason
-{
- /// The close code.
- std::uint16_t code = close_code::none;
-
- /// The optional utf8-encoded reason string.
- reason_string reason;
-
- /** Default constructor.
-
- The code will be none. Default constructed objects
- will explicitly convert to bool as `false`.
- */
- close_reason() = default;
-
- /// Construct from a code.
- close_reason(std::uint16_t code_)
- : code(code_)
- {
- }
-
- /// Construct from a reason string. code is @ref close_code::normal.
- close_reason(string_view s)
- : code(close_code::normal)
- , reason(s)
- {
- }
-
- /// Construct from a reason string literal. code is @ref close_code::normal.
- close_reason(char const* s)
- : code(close_code::normal)
- , reason(s)
- {
- }
-
- /// Construct from a close code and reason string.
- close_reason(close_code code_, string_view s)
- : code(code_)
- , reason(s)
- {
- }
-
- /// Returns `true` if a code was specified
- operator bool() const
- {
- return code != close_code::none;
- }
-};
-
-} // websocket
-} // beast
-} // boost
-
-#include <boost/beast/websocket/impl/rfc6455.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/role.hpp b/contrib/restricted/boost/boost/beast/websocket/role.hpp
deleted file mode 100644
index d886936585..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/role.hpp
+++ /dev/null
@@ -1,59 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_ROLE_HPP
-#define BOOST_BEAST_WEBSOCKET_ROLE_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-/** The role of the websocket stream endpoint.
-
- Whether the endpoint is a client or server affects the
- behavior of the <em>Close the WebSocket Connection</em>
- operation described in rfc6455 section 7.1.1.
- The shutdown behavior depends on the type of the next
- layer template parameter used to construct the @ref stream.
- Other next layer types including user-defined types
- may implement different role-based behavior when
- performing the close operation.
-
- The default implementation for @ref stream when the next
- layer type is a `boost::asio::ip::tcp::socket` behaves
- as follows:
-
- @li In the client role, a TCP/IP shutdown is sent after
- reading all remaining data on the connection.
-
- @li In the server role, a TCP/IP shutdown is sent before
- reading all remaining data on the connection.
-
- When the next layer type is a `boost::asio::ssl::stream`,
- the connection is closed by performing the SSL closing
- handshake corresponding to the role type, client or server.
-
- @see https://tools.ietf.org/html/rfc6455#section-7.1.1
-*/
-enum class role_type
-{
- /// The stream is operating as a client.
- client,
-
- /// The stream is operating as a server.
- server
-};
-
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/ssl.hpp b/contrib/restricted/boost/boost/beast/websocket/ssl.hpp
deleted file mode 100644
index d51921a481..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/ssl.hpp
+++ /dev/null
@@ -1,84 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_SSL_HPP
-#define BOOST_BEAST_WEBSOCKET_SSL_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/websocket/teardown.hpp>
-#include <boost/asio/ip/tcp.hpp>
-#include <boost/asio/ssl/stream.hpp>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-/** Tear down a `boost::asio::ssl::stream`.
-
- This tears down a connection. The implementation will call
- the overload of this function based on the `Stream` parameter
- used to consruct the socket. When `Stream` is a user defined
- type, and not a `boost::asio::ip::tcp::socket` or any
- `boost::asio::ssl::stream`, callers are responsible for
- providing a suitable overload of this function.
-
- @param role The role of the local endpoint
-
- @param stream The stream to tear down.
-
- @param ec Set to the error if any occurred.
-*/
-template<class SyncStream>
-void
-teardown(
- role_type role,
- boost::asio::ssl::stream<SyncStream>& stream,
- error_code& ec);
-
-/** Start tearing down a `boost::asio::ssl::stream`.
-
- This begins tearing down a connection asynchronously.
- The implementation will call the overload of this function
- based on the `Stream` parameter used to consruct the socket.
- When `Stream` is a user defined type, and not a
- `boost::asio::ip::tcp::socket` or any `boost::asio::ssl::stream`,
- callers are responsible for providing a suitable overload
- of this function.
-
- @param role The role of the local endpoint
-
- @param stream The stream to tear down.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& error // result of operation
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using boost::asio::io_context::post().
-
-*/
-template<class AsyncStream, class TeardownHandler>
-inline
-void
-async_teardown(
- role_type role,
- boost::asio::ssl::stream<AsyncStream>& stream,
- TeardownHandler&& handler);
-
-} // websocket
-} // beast
-} // boost
-
-#include <boost/beast/websocket/impl/ssl.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/stream.hpp b/contrib/restricted/boost/boost/beast/websocket/stream.hpp
deleted file mode 100644
index 90cb753294..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/stream.hpp
+++ /dev/null
@@ -1,3578 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_STREAM_HPP
-#define BOOST_BEAST_WEBSOCKET_STREAM_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/websocket/error.hpp>
-#include <boost/beast/websocket/option.hpp>
-#include <boost/beast/websocket/role.hpp>
-#include <boost/beast/websocket/rfc6455.hpp>
-#include <boost/beast/websocket/stream_fwd.hpp>
-#include <boost/beast/websocket/detail/frame.hpp>
-#include <boost/beast/websocket/detail/hybi13.hpp>
-#include <boost/beast/websocket/detail/mask.hpp>
-#include <boost/beast/websocket/detail/pausation.hpp>
-#include <boost/beast/websocket/detail/pmd_extension.hpp>
-#include <boost/beast/websocket/detail/stream_base.hpp>
-#include <boost/beast/websocket/detail/utf8_checker.hpp>
-#include <boost/beast/core/static_buffer.hpp>
-#include <boost/beast/core/string.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/beast/http/empty_body.hpp>
-#include <boost/beast/http/message.hpp>
-#include <boost/beast/http/string_body.hpp>
-#include <boost/beast/http/detail/type_traits.hpp>
-#include <boost/asio/async_result.hpp>
-#include <boost/asio/error.hpp>
-#include <algorithm>
-#include <cstdint>
-#include <functional>
-#include <limits>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-/// The type of object holding HTTP Upgrade requests
-using request_type = http::request<http::empty_body>;
-
-/// The type of object holding HTTP Upgrade responses
-using response_type = http::response<http::string_body>;
-
-/** The type of received control frame.
-
- Values of this type are passed to the control frame
- callback set using @ref stream::control_callback.
-*/
-enum class frame_type
-{
- /// A close frame was received
- close,
-
- /// A ping frame was received
- ping,
-
- /// A pong frame was received
- pong
-};
-
-namespace detail {
-class frame_test;
-} // detail
-
-//--------------------------------------------------------------------
-
-/** Provides message-oriented functionality using WebSocket.
-
- The @ref stream class template provides asynchronous and blocking
- message-oriented functionality necessary for clients and servers
- to utilize the WebSocket protocol.
-
- For asynchronous operations, the application must ensure
- that they are are all performed within the same implicit
- or explicit strand.
-
- @par Thread Safety
- @e Distinct @e objects: Safe.@n
- @e Shared @e objects: Unsafe.
- The application must also ensure that all asynchronous
- operations are performed within the same implicit or explicit strand.
-
- @par Example
-
- To use the @ref stream template with an `ip::tcp::socket`,
- you would write:
-
- @code
- websocket::stream<ip::tcp::socket> ws{io_context};
- @endcode
- Alternatively, you can write:
- @code
- ip::tcp::socket sock{io_context};
- websocket::stream<ip::tcp::socket&> ws{sock};
- @endcode
-
- @tparam NextLayer The type representing the next layer, to which
- data will be read and written during operations. For synchronous
- operations, the type must support the @b SyncStream concept.
- For asynchronous operations, the type must support the
- @b AsyncStream concept.
-
- @tparam deflateSupported A `bool` indicating whether or not the
- stream will be capable of negotiating the permessage-deflate websocket
- extension. Note that even if this is set to `true`, the permessage
- deflate options (set by the caller at runtime) must still have the
- feature enabled for a successful negotiation to occur.
-
- @note A stream object must not be moved or destroyed while there
- are pending asynchronous operations associated with it.
-
- @par Concepts
- @b AsyncStream,
- @b DynamicBuffer,
- @b SyncStream
-*/
-template<
- class NextLayer,
- bool deflateSupported>
-class stream
-#ifndef BOOST_BEAST_DOXYGEN
- : private detail::stream_base<deflateSupported>
-#endif
-{
- friend class close_test;
- friend class frame_test;
- friend class ping_test;
- friend class read1_test;
- friend class read2_test;
- friend class stream_test;
- friend class write_test;
-
- /* The read buffer has to be at least as large
- as the largest possible control frame including
- the frame header.
- */
- static std::size_t constexpr max_control_frame_size = 2 + 8 + 4 + 125;
- static std::size_t constexpr tcp_frame_size = 1536;
-
- using control_cb_type =
- std::function<void(frame_type, string_view)>;
-
- enum class status
- {
- open,
- closing,
- closed,
- failed
- };
-
- NextLayer stream_; // the wrapped stream
- close_reason cr_; // set from received close frame
- control_cb_type ctrl_cb_; // control callback
-
- std::size_t rd_msg_max_ // max message size
- = 16 * 1024 * 1024;
- std::uint64_t rd_size_ // total size of current message so far
- = 0;
- std::uint64_t rd_remain_ // message frame bytes left in current frame
- = 0;
- detail::frame_header rd_fh_; // current frame header
- detail::prepared_key rd_key_; // current stateful mask key
- detail::frame_buffer rd_fb_; // to write control frames (during reads)
- detail::utf8_checker rd_utf8_; // to validate utf8
- static_buffer<
- +tcp_frame_size> rd_buf_; // buffer for reads
- detail::opcode rd_op_ // current message binary or text
- = detail::opcode::text;
- bool rd_cont_ // `true` if the next frame is a continuation
- = false;
- bool rd_done_ // set when a message is done
- = true;
- bool rd_close_ // did we read a close frame?
- = false;
- detail::soft_mutex rd_block_; // op currently reading
-
- role_type role_ // server or client
- = role_type::client;
- status status_
- = status::closed;
-
- detail::soft_mutex wr_block_; // op currently writing
- bool wr_close_ // did we write a close frame?
- = false;
- bool wr_cont_ // next write is a continuation
- = false;
- bool wr_frag_ // autofrag the current message
- = false;
- bool wr_frag_opt_ // autofrag option setting
- = true;
- bool wr_compress_ // compress current message
- = false;
- detail::opcode wr_opcode_ // message type
- = detail::opcode::text;
- std::unique_ptr<
- std::uint8_t[]> wr_buf_; // write buffer
- std::size_t wr_buf_size_ // write buffer size (current message)
- = 0;
- std::size_t wr_buf_opt_ // write buffer size option setting
- = 4096;
- detail::fh_buffer wr_fb_; // header buffer used for writes
- detail::maskgen wr_gen_; // source of mask keys
-
- detail::pausation paused_rd_; // paused read op
- detail::pausation paused_wr_; // paused write op
- detail::pausation paused_ping_; // paused ping op
- detail::pausation paused_close_; // paused close op
- detail::pausation paused_r_rd_; // paused read op (async read)
- detail::pausation paused_r_close_;// paused close op (async read)
-
-public:
- /// Indicates if the permessage-deflate extension is supported
- using is_deflate_supported =
- std::integral_constant<bool, deflateSupported>;
-
- /// The type of the next layer.
- using next_layer_type =
- typename std::remove_reference<NextLayer>::type;
-
- /// The type of the lowest layer.
- using lowest_layer_type = get_lowest_layer<next_layer_type>;
-
- /// The type of the executor associated with the object.
- using executor_type = typename next_layer_type::executor_type;
-
- /** Destructor
-
- Destroys the stream and all associated resources.
-
- @note A stream object must not be destroyed while there
- are pending asynchronous operations associated with it.
- */
- ~stream() = default;
-
- /** Constructor
-
- If `NextLayer` is move constructible, this function
- will move-construct a new stream from the existing stream.
-
- @note The behavior of move assignment on or from streams
- with active or pending operations is undefined.
- */
- stream(stream&&) = default;
-
- /** Assignment
-
- If `NextLayer` is move assignable, this function
- will move-assign a new stream from the existing stream.
-
- @note The behavior of move assignment on or from streams
- with active or pending operations is undefined.
- */
- stream& operator=(stream&&) = default;
-
- /** Constructor
-
- This constructor creates a websocket stream and initializes
- the next layer object.
-
- @throws Any exceptions thrown by the NextLayer constructor.
-
- @param args The arguments to be passed to initialize the
- next layer object. The arguments are forwarded to the next
- layer's constructor.
- */
- template<class... Args>
- explicit
- stream(Args&&... args);
-
- //--------------------------------------------------------------------------
-
- /** Get the executor associated with the object.
-
- This function may be used to obtain the executor object that the
- stream uses to dispatch handlers for asynchronous operations.
-
- @return A copy of the executor that stream will use to dispatch handlers.
- */
- executor_type
- get_executor() noexcept
- {
- return stream_.get_executor();
- }
-
- /** Get a reference to the next layer
-
- This function returns a reference to the next layer
- in a stack of stream layers.
-
- @return A reference to the next layer in the stack of
- stream layers.
- */
- next_layer_type&
- next_layer()
- {
- return stream_;
- }
-
- /** Get a reference to the next layer
-
- This function returns a reference to the next layer in a
- stack of stream layers.
-
- @return A reference to the next layer in the stack of
- stream layers.
- */
- next_layer_type const&
- next_layer() const
- {
- return stream_;
- }
-
- /** Get a reference to the lowest layer
-
- This function returns a reference to the lowest layer
- in a stack of stream layers.
-
- @return A reference to the lowest layer in the stack of
- stream layers.
- */
- lowest_layer_type&
- lowest_layer()
- {
- return stream_.lowest_layer();
- }
-
- /** Get a reference to the lowest layer
-
- This function returns a reference to the lowest layer
- in a stack of stream layers.
-
- @return A reference to the lowest layer in the stack of
- stream layers. Ownership is not transferred to the caller.
- */
- lowest_layer_type const&
- lowest_layer() const
- {
- return stream_.lowest_layer();
- }
-
- //--------------------------------------------------------------------------
- //
- // Observers
- //
- //--------------------------------------------------------------------------
-
- /** Returns `true` if the stream is open.
-
- The stream is open after a successful handshake, and when
- no error has occurred.
- */
- bool
- is_open() const
- {
- return status_ == status::open;
- }
-
- /** Returns `true` if the latest message data indicates binary.
-
- This function informs the caller of whether the last
- received message frame represents a message with the
- binary opcode.
-
- If there is no last message frame, the return value is
- undefined.
- */
- bool
- got_binary() const
- {
- return rd_op_ == detail::opcode::binary;
- }
-
- /** Returns `true` if the latest message data indicates text.
-
- This function informs the caller of whether the last
- received message frame represents a message with the
- text opcode.
-
- If there is no last message frame, the return value is
- undefined.
- */
- bool
- got_text() const
- {
- return ! got_binary();
- }
-
- /// Returns `true` if the last completed read finished the current message.
- bool
- is_message_done() const
- {
- return rd_done_;
- }
-
- /** Returns the close reason received from the peer.
-
- This is only valid after a read completes with error::closed.
- */
- close_reason const&
- reason() const
- {
- return cr_;
- }
-
- /** Returns a suggested maximum buffer size for the next call to read.
-
- This function returns a reasonable upper limit on the number
- of bytes for the size of the buffer passed in the next call
- to read. The number is determined by the state of the current
- frame and whether or not the permessage-deflate extension is
- enabled.
-
- @param initial_size A non-zero size representing the caller's
- desired buffer size for when there is no information which may
- be used to calculate a more specific value. For example, when
- reading the first frame header of a message.
- */
- std::size_t
- read_size_hint(
- std::size_t initial_size = +tcp_frame_size) const
- {
- return read_size_hint(initial_size,
- is_deflate_supported{});
- }
-
- /** Returns a suggested maximum buffer size for the next call to read.
-
- This function returns a reasonable upper limit on the number
- of bytes for the size of the buffer passed in the next call
- to read. The number is determined by the state of the current
- frame and whether or not the permessage-deflate extension is
- enabled.
-
- @param buffer The buffer which will be used for reading. The
- implementation will query the buffer to obtain the optimum
- size of a subsequent call to `buffer.prepare` based on the
- state of the current frame, if any.
- */
- template<class DynamicBuffer
-#if ! BOOST_BEAST_DOXYGEN
- , class = typename std::enable_if<
- ! std::is_integral<DynamicBuffer>::value>::type
-#endif
- >
- std::size_t
- read_size_hint(
- DynamicBuffer& buffer) const;
-
- //--------------------------------------------------------------------------
- //
- // Settings
- //
- //--------------------------------------------------------------------------
-
- /** Set the permessage-deflate extension options
-
- @throws invalid_argument if `deflateSupported == false`, and either
- `client_enable` or `server_enable` is `true`.
- */
- void
- set_option(permessage_deflate const& o)
- {
- set_option(o, is_deflate_supported{});
- }
-
- /// Get the permessage-deflate extension options
- void
- get_option(permessage_deflate& o)
- {
- get_option(o, is_deflate_supported{});
- }
-
- /** Set the automatic fragmentation option.
-
- Determines if outgoing message payloads are broken up into
- multiple pieces.
-
- When the automatic fragmentation size is turned on, outgoing
- message payloads are broken up into multiple frames no larger
- than the write buffer size.
-
- The default setting is to fragment messages.
-
- @param value A `bool` indicating if auto fragmentation should be on.
-
- @par Example
- Setting the automatic fragmentation option:
- @code
- ws.auto_fragment(true);
- @endcode
- */
- void
- auto_fragment(bool value)
- {
- wr_frag_opt_ = value;
- }
-
- /// Returns `true` if the automatic fragmentation option is set.
- bool
- auto_fragment() const
- {
- return wr_frag_opt_;
- }
-
- /** Set the binary message option.
-
- This controls whether or not outgoing message opcodes
- are set to binary or text. The setting is only applied
- at the start when a caller begins a new message. Changing
- the opcode after a message is started will only take effect
- after the current message being sent is complete.
-
- The default setting is to send text messages.
-
- @param value `true` if outgoing messages should indicate
- binary, or `false` if they should indicate text.
-
- @par Example
- Setting the message type to binary.
- @code
- ws.binary(true);
- @endcode
- */
- void
- binary(bool value)
- {
- wr_opcode_ = value ?
- detail::opcode::binary :
- detail::opcode::text;
- }
-
- /// Returns `true` if the binary message option is set.
- bool
- binary() const
- {
- return wr_opcode_ == detail::opcode::binary;
- }
-
- /** Set a callback to be invoked on each incoming control frame.
-
- Sets the callback to be invoked whenever a ping, pong,
- or close control frame is received during a call to one
- of the following functions:
-
- @li @ref beast::websocket::stream::read
- @li @ref beast::websocket::stream::read_some
- @li @ref beast::websocket::stream::async_read
- @li @ref beast::websocket::stream::async_read_some
-
- Unlike completion handlers, the callback will be invoked
- for each control frame during a call to any synchronous
- or asynchronous read function. The operation is passive,
- with no associated error code, and triggered by reads.
-
- For close frames, the close reason code may be obtained by
- calling the function @ref reason.
-
- @param cb The function object to call, which must be
- invocable with this equivalent signature:
- @code
- void
- callback(
- frame_type kind, // The type of frame
- string_view payload // The payload in the frame
- );
- @endcode
- The implementation type-erases the callback which may require
- a dynamic allocation. To prevent the possiblity of a dynamic
- allocation, use `std::ref` to wrap the callback.
- If the read operation which receives the control frame is
- an asynchronous operation, the callback will be invoked using
- the same method as that used to invoke the final handler.
-
- @note Incoming ping and close frames are automatically
- handled. Pings are responded to with pongs, and a close frame
- is responded to with a close frame leading to the closure of
- the stream. It is not necessary to manually send pings, pongs,
- or close frames from inside the control callback.
- Attempting to manually send a close frame from inside the
- control callback after receiving a close frame will result
- in undefined behavior.
- */
- void
- control_callback(std::function<void(frame_type, string_view)> cb)
- {
- ctrl_cb_ = std::move(cb);
- }
-
- /** Reset the control frame callback.
-
- This function removes any previously set control frame callback.
- */
- void
- control_callback()
- {
- ctrl_cb_ = {};
- }
-
- /** Set the maximum incoming message size option.
-
- Sets the largest permissible incoming message size. Message
- frame fields indicating a size that would bring the total
- message size over this limit will cause a protocol failure.
-
- The default setting is 16 megabytes. A value of zero indicates
- a limit of the maximum value of a `std::uint64_t`.
-
- @par Example
- Setting the maximum read message size.
- @code
- ws.read_message_max(65536);
- @endcode
-
- @param amount The limit on the size of incoming messages.
- */
- void
- read_message_max(std::size_t amount)
- {
- rd_msg_max_ = amount;
- }
-
- /// Returns the maximum incoming message size setting.
- std::size_t
- read_message_max() const
- {
- return rd_msg_max_;
- }
-
- /** Set the write buffer size option.
-
- Sets the size of the write buffer used by the implementation to
- send frames. The write buffer is needed when masking payload data
- in the client role, compressing frames, or auto-fragmenting message
- data.
-
- Lowering the size of the buffer can decrease the memory requirements
- for each connection, while increasing the size of the buffer can reduce
- the number of calls made to the next layer to write data.
-
- The default setting is 4096. The minimum value is 8.
-
- The write buffer size can only be changed when the stream is not
- open. Undefined behavior results if the option is modified after a
- successful WebSocket handshake.
-
- @par Example
- Setting the write buffer size.
- @code
- ws.write_buffer_size(8192);
- @endcode
-
- @param amount The size of the write buffer in bytes.
- */
- void
- write_buffer_size(std::size_t amount)
- {
- if(amount < 8)
- BOOST_THROW_EXCEPTION(std::invalid_argument{
- "write buffer size underflow"});
- wr_buf_opt_ = amount;
- };
-
- /// Returns the size of the write buffer.
- std::size_t
- write_buffer_size() const
- {
- return wr_buf_opt_;
- }
-
- /** Set the text message option.
-
- This controls whether or not outgoing message opcodes
- are set to binary or text. The setting is only applied
- at the start when a caller begins a new message. Changing
- the opcode after a message is started will only take effect
- after the current message being sent is complete.
-
- The default setting is to send text messages.
-
- @param value `true` if outgoing messages should indicate
- text, or `false` if they should indicate binary.
-
- @par Example
- Setting the message type to text.
- @code
- ws.text(true);
- @endcode
- */
- void
- text(bool value)
- {
- wr_opcode_ = value ?
- detail::opcode::text :
- detail::opcode::binary;
- }
-
- /// Returns `true` if the text message option is set.
- bool
- text() const
- {
- return wr_opcode_ == detail::opcode::text;
- }
-
- //--------------------------------------------------------------------------
- //
- // Handshaking (Client)
- //
- //--------------------------------------------------------------------------
-
- /** Send an HTTP WebSocket Upgrade request and receive the response.
-
- This function is used to synchronously send the WebSocket
- upgrade HTTP request. The call blocks until one of the
- following conditions is true:
-
- @li The request is sent and the response is received.
-
- @li An error occurs on the stream
-
- This function is implemented in terms of one or more calls to the
- next layer's `read_some` and `write_some` functions.
-
- The operation is successful if the received HTTP response indicates
- a successful HTTP Upgrade (represented by a Status-Code of 101,
- "switching protocols").
-
- @param host The name of the remote host,
- required by the HTTP protocol.
-
- @param target The Request Target, which may not be empty,
- required by the HTTP protocol.
-
- @throws system_error Thrown on failure.
-
- @par Example
- @code
- websocket::stream<ip::tcp::socket> ws{io_context};
- ...
- try
- {
- ws.handshake("localhost", "/");
- }
- catch(...)
- {
- // An error occurred.
- }
- @endcode
- */
- void
- handshake(
- string_view host,
- string_view target);
-
- /** Send an HTTP WebSocket Upgrade request and receive the response.
-
- This function is used to synchronously send the WebSocket
- upgrade HTTP request. The call blocks until one of the
- following conditions is true:
-
- @li The request is sent and the response is received.
-
- @li An error occurs on the stream
-
- This function is implemented in terms of one or more calls to the
- next layer's `read_some` and `write_some` functions.
-
- The operation is successful if the received HTTP response indicates
- a successful HTTP Upgrade (represented by a Status-Code of 101,
- "switching protocols").
-
- @param res The HTTP Upgrade response returned by the remote
- endpoint.
-
- @param host The name of the remote host,
- required by the HTTP protocol.
-
- @param target The Request Target, which may not be empty,
- required by the HTTP protocol.
-
- @throws system_error Thrown on failure.
-
- @par Example
- @code
- websocket::stream<ip::tcp::socket> ws{io_context};
- ...
- try
- {
- response_type res;
- ws.handshake(res, "localhost", "/");
- }
- catch(...)
- {
- // An error occurred.
- }
- @endcode
- */
- void
- handshake(
- response_type& res,
- string_view host,
- string_view target);
-
- /** Send an HTTP WebSocket Upgrade request and receive the response.
-
- This function is used to synchronously send the WebSocket
- upgrade HTTP request. The call blocks until one of the
- following conditions is true:
-
- @li The request is sent and the response is received.
-
- @li An error occurs on the stream
-
- This function is implemented in terms of one or more calls to the
- next layer's `read_some` and `write_some` functions.
-
- The operation is successful if the received HTTP response indicates
- a successful HTTP Upgrade (represented by a Status-Code of 101,
- "switching protocols").
-
- @param host The name of the remote host,
- required by the HTTP protocol.
-
- @param target The Request Target, which may not be empty,
- required by the HTTP protocol.
-
- @param decorator A function object which will be called to modify
- the HTTP request object generated by the implementation. This
- could be used to set the User-Agent field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- request_type& req
- ); @endcode
-
- @throws system_error Thrown on failure.
-
- @par Example
- @code
- websocket::stream<ip::tcp::socket> ws{io_context};
- ...
- try
- {
- ws.handshake("localhost", "/",
- [](request_type& req)
- {
- req.set(field::user_agent, "Beast");
- });
- }
- catch(...)
- {
- // An error occurred.
- }
- @endcode
- */
- template<class RequestDecorator>
- void
- handshake_ex(
- string_view host,
- string_view target,
- RequestDecorator const& decorator);
-
- /** Send an HTTP WebSocket Upgrade request and receive the response.
-
- This function is used to synchronously send the WebSocket
- upgrade HTTP request. The call blocks until one of the
- following conditions is true:
-
- @li The request is sent and the response is received.
-
- @li An error occurs on the stream
-
- This function is implemented in terms of one or more calls to the
- next layer's `read_some` and `write_some` functions.
-
- The operation is successful if the received HTTP response indicates
- a successful HTTP Upgrade (represented by a Status-Code of 101,
- "switching protocols").
-
- @param res The HTTP Upgrade response returned by the remote
- endpoint.
-
- @param host The name of the remote host,
- required by the HTTP protocol.
-
- @param target The Request Target, which may not be empty,
- required by the HTTP protocol.
-
- @param decorator A function object which will be called to modify
- the HTTP request object generated by the implementation. This
- could be used to set the User-Agent field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- request_type& req
- ); @endcode
-
- @throws system_error Thrown on failure.
-
- @par Example
- @code
- websocket::stream<ip::tcp::socket> ws{io_context};
- ...
- try
- {
- response_type res;
- ws.handshake(res, "localhost", "/",
- [](request_type& req)
- {
- req.set(field::user_agent, "Beast");
- });
- }
- catch(...)
- {
- // An error occurred.
- }
- @endcode
- */
- template<class RequestDecorator>
- void
- handshake_ex(
- response_type& res,
- string_view host,
- string_view target,
- RequestDecorator const& decorator);
-
- /** Send an HTTP WebSocket Upgrade request and receive the response.
-
- This function is used to synchronously send the WebSocket
- upgrade HTTP request. The call blocks until one of the
- following conditions is true:
-
- @li The request is sent and the response is received.
-
- @li An error occurs on the stream
-
- This function is implemented in terms of one or more calls to the
- next layer's `read_some` and `write_some` functions.
-
- The operation is successful if the received HTTP response indicates
- a successful HTTP Upgrade (represented by a Status-Code of 101,
- "switching protocols").
-
- @param host The name of the remote host,
- required by the HTTP protocol.
-
- @param target The Request Target, which may not be empty,
- required by the HTTP protocol.
-
- @param ec Set to indicate what error occurred, if any.
-
- @par Example
- @code
- websocket::stream<ip::tcp::socket> ws{io_context};
- ...
- error_code ec;
- ws.handshake(host, target, ec);
- if(ec)
- {
- // An error occurred.
- }
- @endcode
- */
- void
- handshake(
- string_view host,
- string_view target,
- error_code& ec);
-
- /** Send an HTTP WebSocket Upgrade request and receive the response.
-
- This function is used to synchronously send the WebSocket
- upgrade HTTP request. The call blocks until one of the
- following conditions is true:
-
- @li The request is sent and the response is received.
-
- @li An error occurs on the stream
-
- This function is implemented in terms of one or more calls to the
- next layer's `read_some` and `write_some` functions.
-
- The operation is successful if the received HTTP response indicates
- a successful HTTP Upgrade (represented by a Status-Code of 101,
- "switching protocols").
-
- @param res The HTTP Upgrade response returned by the remote
- endpoint. If `ec` is set, the returned value is undefined.
-
- @param host The name of the remote host,
- required by the HTTP protocol.
-
- @param target The Request Target, which may not be empty,
- required by the HTTP protocol.
-
- @param ec Set to indicate what error occurred, if any.
-
- @par Example
- @code
- websocket::stream<ip::tcp::socket> ws{io_context};
- ...
- error_code ec;
- response_type res;
- ws.handshake(res, host, target, ec);
- if(ec)
- {
- // An error occurred.
- }
- @endcode
- */
- void
- handshake(
- response_type& res,
- string_view host,
- string_view target,
- error_code& ec);
-
- /** Send an HTTP WebSocket Upgrade request and receive the response.
-
- This function is used to synchronously send the WebSocket
- upgrade HTTP request. The call blocks until one of the
- following conditions is true:
-
- @li The request is sent and the response is received.
-
- @li An error occurs on the stream
-
- This function is implemented in terms of one or more calls to the
- next layer's `read_some` and `write_some` functions.
-
- The operation is successful if the received HTTP response indicates
- a successful HTTP Upgrade (represented by a Status-Code of 101,
- "switching protocols").
-
- @param host The name of the remote host,
- required by the HTTP protocol.
-
- @param target The Request Target, which may not be empty,
- required by the HTTP protocol.
-
- @param decorator A function object which will be called to modify
- the HTTP request object generated by the implementation. This
- could be used to set the User-Agent field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- request_type& req
- ); @endcode
-
- @param ec Set to indicate what error occurred, if any.
-
- @par Example
- @code
- websocket::stream<ip::tcp::socket> ws{io_context};
- ...
- error_code ec;
- ws.handshake("localhost", "/",
- [](request_type& req)
- {
- req.set(field::user_agent, "Beast");
- },
- ec);
- if(ec)
- {
- // An error occurred.
- }
- @endcode
- */
- template<class RequestDecorator>
- void
- handshake_ex(
- string_view host,
- string_view target,
- RequestDecorator const& decorator,
- error_code& ec);
-
- /** Send an HTTP WebSocket Upgrade request and receive the response.
-
- This function is used to synchronously send the WebSocket
- upgrade HTTP request. The call blocks until one of the
- following conditions is true:
-
- @li The request is sent and the response is received.
-
- @li An error occurs on the stream
-
- This function is implemented in terms of one or more calls to the
- next layer's `read_some` and `write_some` functions.
-
- The operation is successful if the received HTTP response indicates
- a successful HTTP Upgrade (represented by a Status-Code of 101,
- "switching protocols").
-
- @param res The HTTP Upgrade response returned by the remote
- endpoint.
-
- @param host The name of the remote host,
- required by the HTTP protocol.
-
- @param target The Request Target, which may not be empty,
- required by the HTTP protocol.
-
- @param decorator A function object which will be called to modify
- the HTTP request object generated by the implementation. This
- could be used to set the User-Agent field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- request_type& req
- ); @endcode
-
- @param ec Set to indicate what error occurred, if any.
-
- @par Example
- @code
- websocket::stream<ip::tcp::socket> ws{io_context};
- ...
- error_code ec;
- response_type res;
- ws.handshake(res, "localhost", "/",
- [](request_type& req)
- {
- req.set(field::user_agent, "Beast");
- },
- ec);
- if(ec)
- {
- // An error occurred.
- }
- @endcode
- */
- template<class RequestDecorator>
- void
- handshake_ex(
- response_type& res,
- string_view host,
- string_view target,
- RequestDecorator const& decorator,
- error_code& ec);
-
- /** Start an asynchronous operation to send an upgrade request and receive the response.
-
- This function is used to asynchronously send the HTTP WebSocket
- upgrade request and receive the HTTP WebSocket Upgrade response.
- This function call always returns immediately. The asynchronous
- operation will continue until one of the following conditions is
- true:
-
- @li The request is sent and the response is received.
-
- @li An error occurs on the stream
-
- This operation is implemented in terms of one or more calls to the
- next layer's `async_read_some` and `async_write_some` functions, and
- is known as a <em>composed operation</em>. The program must ensure
- that the stream performs no other operations until this operation
- completes.
-
- The operation is successful if the received HTTP response indicates
- a successful HTTP Upgrade (represented by a Status-Code of 101,
- "switching protocols").
-
- @param host The name of the remote host, required by
- the HTTP protocol. Copies may be made as needed.
-
- @param target The Request Target, which may not be empty,
- required by the HTTP protocol. Copies of this parameter may
- be made as needed.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& ec // Result of operation
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<class HandshakeHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- HandshakeHandler, void(error_code))
- async_handshake(
- string_view host,
- string_view target,
- HandshakeHandler&& handler);
-
- /** Start an asynchronous operation to send an upgrade request and receive the response.
-
- This function is used to asynchronously send the HTTP WebSocket
- upgrade request and receive the HTTP WebSocket Upgrade response.
- This function call always returns immediately. The asynchronous
- operation will continue until one of the following conditions is
- true:
-
- @li The request is sent and the response is received.
-
- @li An error occurs on the stream
-
- This operation is implemented in terms of one or more calls to the
- next layer's `async_read_some` and `async_write_some` functions, and
- is known as a <em>composed operation</em>. The program must ensure
- that the stream performs no other operations until this operation
- completes.
-
- The operation is successful if the received HTTP response indicates
- a successful HTTP Upgrade (represented by a Status-Code of 101,
- "switching protocols").
-
- @param res The HTTP Upgrade response returned by the remote
- endpoint. The caller must ensure this object is valid for at
- least until the completion handler is invoked.
-
- @param host The name of the remote host, required by
- the HTTP protocol. Copies may be made as needed.
-
- @param target The Request Target, which may not be empty,
- required by the HTTP protocol. Copies of this parameter may
- be made as needed.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& ec // Result of operation
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<class HandshakeHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- HandshakeHandler, void(error_code))
- async_handshake(
- response_type& res,
- string_view host,
- string_view target,
- HandshakeHandler&& handler);
-
- /** Start an asynchronous operation to send an upgrade request and receive the response.
-
- This function is used to asynchronously send the HTTP WebSocket
- upgrade request and receive the HTTP WebSocket Upgrade response.
- This function call always returns immediately. The asynchronous
- operation will continue until one of the following conditions is
- true:
-
- @li The request is sent and the response is received.
-
- @li An error occurs on the stream
-
- This operation is implemented in terms of one or more calls to the
- next layer's `async_read_some` and `async_write_some` functions, and
- is known as a <em>composed operation</em>. The program must ensure
- that the stream performs no other operations until this operation
- completes.
-
- The operation is successful if the received HTTP response indicates
- a successful HTTP Upgrade (represented by a Status-Code of 101,
- "switching protocols").
-
- @param host The name of the remote host, required by
- the HTTP protocol. Copies may be made as needed.
-
- @param target The Request Target, which may not be empty,
- required by the HTTP protocol. Copies of this parameter may
- be made as needed.
-
- @param decorator A function object which will be called to modify
- the HTTP request object generated by the implementation. This
- could be used to set the User-Agent field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- request_type& req
- ); @endcode
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& ec // Result of operation
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<class RequestDecorator, class HandshakeHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- HandshakeHandler, void(error_code))
- async_handshake_ex(
- string_view host,
- string_view target,
- RequestDecorator const& decorator,
- HandshakeHandler&& handler);
-
- /** Start an asynchronous operation to send an upgrade request and receive the response.
-
- This function is used to asynchronously send the HTTP WebSocket
- upgrade request and receive the HTTP WebSocket Upgrade response.
- This function call always returns immediately. The asynchronous
- operation will continue until one of the following conditions is
- true:
-
- @li The request is sent and the response is received.
-
- @li An error occurs on the stream
-
- This operation is implemented in terms of one or more calls to the
- next layer's `async_read_some` and `async_write_some` functions, and
- is known as a <em>composed operation</em>. The program must ensure
- that the stream performs no other operations until this operation
- completes.
-
- The operation is successful if the received HTTP response indicates
- a successful HTTP Upgrade (represented by a Status-Code of 101,
- "switching protocols").
-
- @param res The HTTP Upgrade response returned by the remote
- endpoint. The caller must ensure this object is valid for at
- least until the completion handler is invoked.
-
- @param host The name of the remote host, required by
- the HTTP protocol. Copies may be made as needed.
-
- @param target The Request Target, which may not be empty,
- required by the HTTP protocol. Copies of this parameter may
- be made as needed.
-
- @param decorator A function object which will be called to modify
- the HTTP request object generated by the implementation. This
- could be used to set the User-Agent field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- request_type& req
- ); @endcode
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& ec // Result of operation
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<class RequestDecorator, class HandshakeHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- HandshakeHandler, void(error_code))
- async_handshake_ex(
- response_type& res,
- string_view host,
- string_view target,
- RequestDecorator const& decorator,
- HandshakeHandler&& handler);
-
- //--------------------------------------------------------------------------
- //
- // Handshaking (Server)
- //
- //--------------------------------------------------------------------------
-
- /** Read and respond to a WebSocket HTTP Upgrade request.
-
- This function is used to synchronously read an HTTP WebSocket
- Upgrade request and send the HTTP response. The call blocks
- until one of the following conditions is true:
-
- @li The request is received and the response finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to
- the next layer's `read_some` and `write_some` functions.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When this call returns, the stream is then ready to send and
- receive WebSocket protocol frames and messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure.
-
- The implementation uses fixed size internal storage to
- receive the request. If the request is too large, the error
- @ref error::buffer_overflow will be indicated. Applications
- that wish to receive larger requests should first read the
- request using their own buffer and a suitable overload of
- @ref http::read or @ref http::async_read, then call @ref accept
- or @ref async_accept with the request.
-
- @throws system_error Thrown on failure.
- */
- void
- accept();
-
- /** Read and respond to a WebSocket HTTP Upgrade request.
-
- This function is used to synchronously read an HTTP WebSocket
- Upgrade request and send the HTTP response. The call blocks
- until one of the following conditions is true:
-
- @li The request is received and the response finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to
- the next layer's `read_some` and `write_some` functions.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When this call returns, the stream is then ready to send and
- receive WebSocket protocol frames and messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure.
-
- The implementation uses fixed size internal storage to
- receive the request. If the request is too large, the error
- @ref error::buffer_overflow will be indicated. Applications
- that wish to receive larger requests should first read the
- request using their own buffer and a suitable overload of
- @ref http::read or @ref http::async_read, then call @ref accept
- or @ref async_accept with the request.
-
- @param decorator A function object which will be called to modify
- the HTTP response object delivered by the implementation. This
- could be used to set the Server field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- response_type& res
- ); @endcode
-
- @throws system_error Thrown on failure.
- */
- template<class ResponseDecorator>
- void
- accept_ex(ResponseDecorator const& decorator);
-
- /** Read and respond to a WebSocket HTTP Upgrade request.
-
- This function is used to synchronously read an HTTP WebSocket
- Upgrade request and send the HTTP response. The call blocks
- until one of the following conditions is true:
-
- @li The request is received and the response finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to
- the next layer's `read_some` and `write_some` functions.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When this call returns, the stream is then ready to send and
- receive WebSocket protocol frames and messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure.
-
- The implementation uses fixed size internal storage to
- receive the request. If the request is too large, the error
- @ref error::buffer_overflow will be indicated. Applications
- that wish to receive larger requests should first read the
- request using their own buffer and a suitable overload of
- @ref http::read or @ref http::async_read, then call @ref accept
- or @ref async_accept with the request.
-
- @param ec Set to indicate what error occurred, if any.
- */
- void
- accept(error_code& ec);
-
- /** Read and respond to a WebSocket HTTP Upgrade request.
-
- This function is used to synchronously read an HTTP WebSocket
- Upgrade request and send the HTTP response. The call blocks
- until one of the following conditions is true:
-
- @li The request is received and the response finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to
- the next layer's `read_some` and `write_some` functions.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When this call returns, the stream is then ready to send and
- receive WebSocket protocol frames and messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure.
-
- The implementation uses fixed size internal storage to
- receive the request. If the request is too large, the error
- @ref error::buffer_overflow will be indicated. Applications
- that wish to receive larger requests should first read the
- request using their own buffer and a suitable overload of
- @ref http::read or @ref http::async_read, then call @ref accept
- or @ref async_accept with the request.
-
- @param decorator A function object which will be called to modify
- the HTTP response object delivered by the implementation. This
- could be used to set the Server field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- response_type& res
- ); @endcode
-
- @param ec Set to indicate what error occurred, if any.
- */
- template<class ResponseDecorator>
- void
- accept_ex(
- ResponseDecorator const& decorator,
- error_code& ec);
-
- /** Read and respond to a WebSocket HTTP Upgrade request.
-
- This function is used to synchronously read an HTTP WebSocket
- Upgrade request and send the HTTP response. The call blocks
- until one of the following conditions is true:
-
- @li The request is received and the response finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to
- the next layer's `read_some` and `write_some` functions.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When this call returns, the stream is then ready to send and
- receive WebSocket protocol frames and messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure.
-
- The implementation uses fixed size internal storage to
- receive the request. If the request is too large, the error
- @ref error::buffer_overflow will be indicated. Applications
- that wish to receive larger requests should first read the
- request using their own buffer and a suitable overload of
- @ref http::read or @ref http::async_read, then call @ref accept
- or @ref async_accept with the request.
-
- @param buffers Caller provided data that has already been
- received on the stream. The implementation will copy the
- caller provided data before the function returns.
-
- @throws system_error Thrown on failure.
- */
- template<class ConstBufferSequence>
-#if BOOST_BEAST_DOXYGEN
- void
-#else
- typename std::enable_if<! http::detail::is_header<
- ConstBufferSequence>::value>::type
-#endif
- accept(ConstBufferSequence const& buffers);
-
- /** Read and respond to a WebSocket HTTP Upgrade request.
-
- This function is used to synchronously read an HTTP WebSocket
- Upgrade request and send the HTTP response. The call blocks
- until one of the following conditions is true:
-
- @li The request is received and the response finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to
- the next layer's `read_some` and `write_some` functions.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When this call returns, the stream is then ready to send and
- receive WebSocket protocol frames and messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure.
-
- The implementation uses fixed size internal storage to
- receive the request. If the request is too large, the error
- @ref error::buffer_overflow will be indicated. Applications
- that wish to receive larger requests should first read the
- request using their own buffer and a suitable overload of
- @ref http::read or @ref http::async_read, then call @ref accept
- or @ref async_accept with the request.
-
- @param buffers Caller provided data that has already been
- received on the stream. The implementation will copy the
- caller provided data before the function returns.
-
- @param decorator A function object which will be called to modify
- the HTTP response object delivered by the implementation. This
- could be used to set the Server field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- response_type& res
- ); @endcode
-
- @throws system_error Thrown on failure.
- */
- template<class ConstBufferSequence,
- class ResponseDecorator>
-#if BOOST_BEAST_DOXYGEN
- void
-#else
- typename std::enable_if<! http::detail::is_header<
- ConstBufferSequence>::value>::type
-#endif
- accept_ex(
- ConstBufferSequence const& buffers,
- ResponseDecorator const& decorator);
-
- /** Read and respond to a WebSocket HTTP Upgrade request.
-
- This function is used to synchronously read an HTTP WebSocket
- Upgrade request and send the HTTP response. The call blocks
- until one of the following conditions is true:
-
- @li The request is received and the response finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to
- the next layer's `read_some` and `write_some` functions.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When this call returns, the stream is then ready to send and
- receive WebSocket protocol frames and messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure.
-
- The implementation uses fixed size internal storage to
- receive the request. If the request is too large, the error
- @ref error::buffer_overflow will be indicated. Applications
- that wish to receive larger requests should first read the
- request using their own buffer and a suitable overload of
- @ref http::read or @ref http::async_read, then call @ref accept
- or @ref async_accept with the request.
-
- @param buffers Caller provided data that has already been
- received on the stream. The implementation will copy the
- caller provided data before the function returns.
-
- @param ec Set to indicate what error occurred, if any.
- */
- template<class ConstBufferSequence>
-#if BOOST_BEAST_DOXYGEN
- void
-#else
- typename std::enable_if<! http::detail::is_header<
- ConstBufferSequence>::value>::type
-#endif
- accept(
- ConstBufferSequence const& buffers,
- error_code& ec);
-
- /** Read and respond to a WebSocket HTTP Upgrade request.
-
- This function is used to synchronously read an HTTP WebSocket
- Upgrade request and send the HTTP response. The call blocks
- until one of the following conditions is true:
-
- @li The request is received and the response finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to
- the next layer's `read_some` and `write_some` functions.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When this call returns, the stream is then ready to send and
- receive WebSocket protocol frames and messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure.
-
- The implementation uses fixed size internal storage to
- receive the request. If the request is too large, the error
- @ref error::buffer_overflow will be indicated. Applications
- that wish to receive larger requests should first read the
- request using their own buffer and a suitable overload of
- @ref http::read or @ref http::async_read, then call @ref accept
- or @ref async_accept with the request.
-
- @param buffers Caller provided data that has already been
- received on the stream. The implementation will copy the
- caller provided data before the function returns.
-
- @param decorator A function object which will be called to modify
- the HTTP response object delivered by the implementation. This
- could be used to set the Server field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- response_type& res
- ); @endcode
-
- @param ec Set to indicate what error occurred, if any.
- */
- template<class ConstBufferSequence, class ResponseDecorator>
-#if BOOST_BEAST_DOXYGEN
- void
-#else
- typename std::enable_if<! http::detail::is_header<
- ConstBufferSequence>::value>::type
-#endif
- accept_ex(
- ConstBufferSequence const& buffers,
- ResponseDecorator const& decorator,
- error_code& ec);
-
- /** Respond to a WebSocket HTTP Upgrade request
-
- This function is used to synchronously send the HTTP response
- to an HTTP request possibly containing a WebSocket Upgrade.
- The call blocks until one of the following conditions is true:
-
- @li The response finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to
- the next layer's `read_some` and `write_some` functions.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When this call returns, the stream is then ready to send and
- receive WebSocket protocol frames and messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure.
-
- @param req An object containing the HTTP Upgrade request.
- Ownership is not transferred, the implementation will not
- access this object from other threads.
-
- @throws system_error Thrown on failure.
- */
- template<class Body, class Allocator>
- void
- accept(http::request<Body,
- http::basic_fields<Allocator>> const& req);
-
- /** Respond to a WebSocket HTTP Upgrade request
-
- This function is used to synchronously send the HTTP response
- to an HTTP request possibly containing a WebSocket Upgrade.
- The call blocks until one of the following conditions is true:
-
- @li The response finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to
- the next layer's `read_some` and `write_some` functions.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When this call returns, the stream is then ready to send and
- receive WebSocket protocol frames and messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure.
-
- @param req An object containing the HTTP Upgrade request.
- Ownership is not transferred, the implementation will not
- access this object from other threads.
-
- @param decorator A function object which will be called to modify
- the HTTP response object delivered by the implementation. This
- could be used to set the Server field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- response_type& res
- ); @endcode
-
- @throws system_error Thrown on failure.
- */
- template<class Body, class Allocator,
- class ResponseDecorator>
- void
- accept_ex(http::request<Body,
- http::basic_fields<Allocator>> const& req,
- ResponseDecorator const& decorator);
-
- /** Respond to a WebSocket HTTP Upgrade request
-
- This function is used to synchronously send the HTTP response
- to an HTTP request possibly containing a WebSocket Upgrade.
- The call blocks until one of the following conditions is true:
-
- @li The response finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to
- the next layer's `read_some` and `write_some` functions.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When this call returns, the stream is then ready to send and
- receive WebSocket protocol frames and messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure.
-
- @param req An object containing the HTTP Upgrade request.
- Ownership is not transferred, the implementation will not
- access this object from other threads.
-
- @param ec Set to indicate what error occurred, if any.
- */
- template<class Body, class Allocator>
- void
- accept(http::request<Body,
- http::basic_fields<Allocator>> const& req,
- error_code& ec);
-
- /** Respond to a WebSocket HTTP Upgrade request
-
- This function is used to synchronously send the HTTP response
- to an HTTP request possibly containing a WebSocket Upgrade.
- The call blocks until one of the following conditions is true:
-
- @li The response finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to
- the next layer's `read_some` and `write_some` functions.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When this call returns, the stream is then ready to send and
- receive WebSocket protocol frames and messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure.
-
- @param req An object containing the HTTP Upgrade request.
- Ownership is not transferred, the implementation will not
- access this object from other threads.
-
- @param decorator A function object which will be called to modify
- the HTTP response object delivered by the implementation. This
- could be used to set the Server field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- response_type& res
- ); @endcode
-
- @param ec Set to indicate what error occurred, if any.
- */
- template<class Body, class Allocator,
- class ResponseDecorator>
- void
- accept_ex(http::request<Body,
- http::basic_fields<Allocator>> const& req,
- ResponseDecorator const& decorator,
- error_code& ec);
-
- /** Start reading and responding to a WebSocket HTTP Upgrade request.
-
- This function is used to asynchronously read an HTTP WebSocket
- Upgrade request and send the HTTP response. The function call
- always returns immediately. The asynchronous operation will
- continue until one of the following conditions is true:
-
- @li The request is received and the response finishes sending.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to
- the next layer's `async_read_some` and `async_write_some`
- functions, and is known as a <em>composed operation</em>. The
- program must ensure that the stream performs no other
- asynchronous operations until this operation completes.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When the completion handler is invoked, the stream is then
- ready to send and receive WebSocket protocol frames and
- messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure, and
- the completion handler will be invoked with a suitable error
- code set.
-
- The implementation uses fixed size internal storage to
- receive the request. If the request is too large, the error
- @ref error::buffer_overflow will be indicated. Applications
- that wish to receive larger requests should first read the
- request using their own buffer and a suitable overload of
- @ref http::read or @ref http::async_read, then call @ref accept
- or @ref async_accept with the request.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& ec // Result of operation
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<class AcceptHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- AcceptHandler, void(error_code))
- async_accept(AcceptHandler&& handler);
-
- /** Start reading and responding to a WebSocket HTTP Upgrade request.
-
- This function is used to asynchronously read an HTTP WebSocket
- Upgrade request and send the HTTP response. The function call
- always returns immediately. The asynchronous operation will
- continue until one of the following conditions is true:
-
- @li The request is received and the response finishes sending.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to
- the next layer's `async_read_some` and `async_write_some`
- functions, and is known as a <em>composed operation</em>. The
- program must ensure that the stream performs no other
- asynchronous operations until this operation completes.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When the completion handler is invoked, the stream is then
- ready to send and receive WebSocket protocol frames and
- messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure, and
- the completion handler will be invoked with a suitable error
- code set.
-
- The implementation uses fixed size internal storage to
- receive the request. If the request is too large, the error
- @ref error::buffer_overflow will be indicated. Applications
- that wish to receive larger requests should first read the
- request using their own buffer and a suitable overload of
- @ref http::read or @ref http::async_read, then call @ref accept
- or @ref async_accept with the request.
-
- @param decorator A function object which will be called to modify
- the HTTP response object delivered by the implementation. This
- could be used to set the Server field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- response_type& res
- ); @endcode
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& ec // Result of operation
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<
- class ResponseDecorator,
- class AcceptHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- AcceptHandler, void(error_code))
- async_accept_ex(
- ResponseDecorator const& decorator,
- AcceptHandler&& handler);
-
- /** Start reading and responding to a WebSocket HTTP Upgrade request.
-
- This function is used to asynchronously read an HTTP WebSocket
- Upgrade request and send the HTTP response. The function call
- always returns immediately. The asynchronous operation will
- continue until one of the following conditions is true:
-
- @li The request is received and the response finishes sending.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to
- the next layer's `async_read_some` and `async_write_some`
- functions, and is known as a <em>composed operation</em>. The
- program must ensure that the stream performs no other
- asynchronous operations until this operation completes.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When the completion handler is invoked, the stream is then
- ready to send and receive WebSocket protocol frames and
- messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure, and
- the completion handler will be invoked with a suitable error
- code set.
-
- The implementation uses fixed size internal storage to
- receive the request. If the request is too large, the error
- @ref error::buffer_overflow will be indicated. Applications
- that wish to receive larger requests should first read the
- request using their own buffer and a suitable overload of
- @ref http::read or @ref http::async_read, then call @ref accept
- or @ref async_accept with the request.
-
- @param buffers Caller provided data that has already been
- received on the stream. This may be used for implementations
- allowing multiple protocols on the same stream. The
- buffered data will first be applied to the handshake, and
- then to received WebSocket frames. The implementation will
- copy the caller provided data before the function returns.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& ec // Result of operation
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<
- class ConstBufferSequence,
- class AcceptHandler>
-#if BOOST_BEAST_DOXYGEN
- void_or_deduced
-#else
- typename std::enable_if<
- ! http::detail::is_header<ConstBufferSequence>::value,
- BOOST_ASIO_INITFN_RESULT_TYPE(
- AcceptHandler, void(error_code))>::type
-#endif
- async_accept(
- ConstBufferSequence const& buffers,
- AcceptHandler&& handler);
-
- /** Start reading and responding to a WebSocket HTTP Upgrade request.
-
- This function is used to asynchronously read an HTTP WebSocket
- Upgrade request and send the HTTP response. The function call
- always returns immediately. The asynchronous operation will
- continue until one of the following conditions is true:
-
- @li The request is received and the response finishes sending.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to
- the next layer's `async_read_some` and `async_write_some`
- functions, and is known as a <em>composed operation</em>. The
- program must ensure that the stream performs no other
- asynchronous operations until this operation completes.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When the completion handler is invoked, the stream is then
- ready to send and receive WebSocket protocol frames and
- messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure, and
- the completion handler will be invoked with a suitable error
- code set.
-
- The implementation uses fixed size internal storage to
- receive the request. If the request is too large, the error
- @ref error::buffer_overflow will be indicated. Applications
- that wish to receive larger requests should first read the
- request using their own buffer and a suitable overload of
- @ref http::read or @ref http::async_read, then call @ref accept
- or @ref async_accept with the request.
-
- @param buffers Caller provided data that has already been
- received on the stream. This may be used for implementations
- allowing multiple protocols on the same stream. The
- buffered data will first be applied to the handshake, and
- then to received WebSocket frames. The implementation will
- copy the caller provided data before the function returns.
-
- @param decorator A function object which will be called to modify
- the HTTP response object delivered by the implementation. This
- could be used to set the Server field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- response_type& res
- ); @endcode
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& ec // Result of operation
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<
- class ConstBufferSequence,
- class ResponseDecorator,
- class AcceptHandler>
-#if BOOST_BEAST_DOXYGEN
- void_or_deduced
-#else
- typename std::enable_if<
- ! http::detail::is_header<ConstBufferSequence>::value,
- BOOST_ASIO_INITFN_RESULT_TYPE(
- AcceptHandler, void(error_code))>::type
-#endif
- async_accept_ex(
- ConstBufferSequence const& buffers,
- ResponseDecorator const& decorator,
- AcceptHandler&& handler);
-
- /** Start responding to a WebSocket HTTP Upgrade request.
-
- This function is used to asynchronously send the HTTP response
- to an HTTP request possibly containing a WebSocket Upgrade
- request. The function call always returns immediately. The
- asynchronous operation will continue until one of the following
- conditions is true:
-
- @li The response finishes sending.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to
- the next layer's `async_write_some` functions, and is known as
- a <em>composed operation</em>. The program must ensure that the
- stream performs no other operations until this operation
- completes.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When the completion handler is invoked, the stream is then
- ready to send and receive WebSocket protocol frames and
- messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure, and
- the completion handler will be invoked with a suitable error
- code set.
-
- @param req An object containing the HTTP Upgrade request.
- Ownership is not transferred, the implementation will not access
- this object from other threads.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& ec // Result of operation
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<
- class Body, class Allocator,
- class AcceptHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- AcceptHandler, void(error_code))
- async_accept(
- http::request<Body,
- http::basic_fields<Allocator>> const& req,
- AcceptHandler&& handler);
-
- /** Start responding to a WebSocket HTTP Upgrade request.
-
- This function is used to asynchronously send the HTTP response
- to an HTTP request possibly containing a WebSocket Upgrade
- request. The function call always returns immediately. The
- asynchronous operation will continue until one of the following
- conditions is true:
-
- @li The response finishes sending.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to
- the next layer's `async_write_some` functions, and is known as
- a <em>composed operation</em>. The program must ensure that the
- stream performs no other operations until this operation
- completes.
-
- If the stream receives a valid HTTP WebSocket Upgrade request,
- an HTTP response is sent back indicating a successful upgrade.
- When the completion handler is invoked, the stream is then
- ready to send and receive WebSocket protocol frames and
- messages.
- If the HTTP Upgrade request is invalid or cannot be satisfied,
- an HTTP response is sent indicating the reason and status code
- (typically 400, "Bad Request"). This counts as a failure, and
- the completion handler will be invoked with a suitable error
- code set.
-
- @param req An object containing the HTTP Upgrade request.
- Ownership is not transferred, the implementation will not access
- this object from other threads.
-
- @param decorator A function object which will be called to modify
- the HTTP response object delivered by the implementation. This
- could be used to set the Server field, subprotocols, or other
- application or HTTP specific fields. The object will be called
- with this equivalent signature:
- @code void decorator(
- response_type& res
- ); @endcode
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& ec // Result of operation
- ); @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<
- class Body, class Allocator,
- class ResponseDecorator,
- class AcceptHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- AcceptHandler, void(error_code))
- async_accept_ex(
- http::request<Body,
- http::basic_fields<Allocator>> const& req,
- ResponseDecorator const& decorator,
- AcceptHandler&& handler);
-
- //--------------------------------------------------------------------------
- //
- // Control Frames
- //
- //--------------------------------------------------------------------------
-
- /** Send a WebSocket close frame.
-
- This function is used to synchronously send a close frame on
- the stream. The call blocks until one of the following is true:
-
- @li The close frame finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls
- to the next layer's `write_some` functions.
-
- If the close reason specifies a close code other than
- @ref beast::websocket::close_code::none, the close frame is
- sent with the close code and optional reason string. Otherwise,
- the close frame is sent with no payload.
-
- Callers should not attempt to write WebSocket data after
- initiating the close. Instead, callers should continue
- reading until an error occurs. A read returning @ref error::closed
- indicates a successful connection closure.
-
- @param cr The reason for the close.
-
- @throws system_error Thrown on failure.
- */
- void
- close(close_reason const& cr);
-
- /** Send a WebSocket close frame.
-
- This function is used to synchronously send a close frame on
- the stream. The call blocks until one of the following is true:
-
- @li The close frame finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls
- to the next layer's `write_some` functions.
-
- If the close reason specifies a close code other than
- @ref beast::websocket::close_code::none, the close frame is
- sent with the close code and optional reason string. Otherwise,
- the close frame is sent with no payload.
-
- Callers should not attempt to write WebSocket data after
- initiating the close. Instead, callers should continue
- reading until an error occurs. A read returning @ref error::closed
- indicates a successful connection closure.
-
- @param cr The reason for the close.
-
- @param ec Set to indicate what error occurred, if any.
- */
- void
- close(close_reason const& cr, error_code& ec);
-
- /** Start an asynchronous operation to send a WebSocket close frame.
-
- This function is used to asynchronously send a close frame on
- the stream. This function call always returns immediately. The
- asynchronous operation will continue until one of the following
- conditions is true:
-
- @li The close frame finishes sending.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to the
- next layer's `async_write_some` functions, and is known as a
- <em>composed operation</em>. The program must ensure that the
- stream performs no other write operations (such as @ref async_ping,
- @ref async_write, @ref async_write_some, or @ref async_close)
- until this operation completes.
-
- If the close reason specifies a close code other than
- @ref beast::websocket::close_code::none, the close frame is
- sent with the close code and optional reason string. Otherwise,
- the close frame is sent with no payload.
-
- Callers should not attempt to write WebSocket data after
- initiating the close. Instead, callers should continue
- reading until an error occurs. A read returning @ref error::closed
- indicates a successful connection closure.
-
- @param cr The reason for the close.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The function signature of the handler must be:
- @code
- void handler(
- error_code const& ec // Result of operation
- );
- @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<class CloseHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- CloseHandler, void(error_code))
- async_close(close_reason const& cr, CloseHandler&& handler);
-
- /** Send a WebSocket ping frame.
-
- This function is used to synchronously send a ping frame on
- the stream. The call blocks until one of the following is true:
-
- @li The ping frame finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to the
- next layer's `write_some` functions.
-
- @param payload The payload of the ping message, which may be empty.
-
- @throws system_error Thrown on failure.
- */
- void
- ping(ping_data const& payload);
-
- /** Send a WebSocket ping frame.
-
- This function is used to synchronously send a ping frame on
- the stream. The call blocks until one of the following is true:
-
- @li The ping frame finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to the
- next layer's `write_some` functions.
-
- @param payload The payload of the ping message, which may be empty.
-
- @param ec Set to indicate what error occurred, if any.
- */
- void
- ping(ping_data const& payload, error_code& ec);
-
- /** Start an asynchronous operation to send a WebSocket ping frame.
-
- This function is used to asynchronously send a ping frame to
- the stream. The function call always returns immediately. The
- asynchronous operation will continue until one of the following
- is true:
-
- @li The entire ping frame is sent.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to the
- next layer's `async_write_some` functions, and is known as a
- <em>composed operation</em>. The program must ensure that the
- stream performs no other writes until this operation completes.
-
- If a close frame is sent or received before the ping frame is
- sent, the completion handler will be called with the error
- set to `boost::asio::error::operation_aborted`.
-
- @param payload The payload of the ping message, which may be empty.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The function signature of the handler must be:
- @code
- void handler(
- error_code const& ec // Result of operation
- );
- @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<class WriteHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code))
- async_ping(ping_data const& payload, WriteHandler&& handler);
-
- /** Send a WebSocket pong frame.
-
- This function is used to synchronously send a pong frame on
- the stream. The call blocks until one of the following is true:
-
- @li The pong frame finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to the
- next layer's `write_some` functions.
-
- The WebSocket protocol allows pong frames to be sent from either
- end at any time. It is not necessary to first receive a ping in
- order to send a pong. The remote peer may use the receipt of a
- pong frame as an indication that the connection is not dead.
-
- @param payload The payload of the pong message, which may be empty.
-
- @throws system_error Thrown on failure.
- */
- void
- pong(ping_data const& payload);
-
- /** Send a WebSocket pong frame.
-
- This function is used to synchronously send a pong frame on
- the stream. The call blocks until one of the following is true:
-
- @li The pong frame finishes sending.
-
- @li An error occurs on the stream.
-
- This function is implemented in terms of one or more calls to the
- next layer's `write_some` functions.
-
- The WebSocket protocol allows pong frames to be sent from either
- end at any time. It is not necessary to first receive a ping in
- order to send a pong. The remote peer may use the receipt of a
- pong frame as an indication that the connection is not dead.
-
- @param payload The payload of the pong message, which may be empty.
-
- @param ec Set to indicate what error occurred, if any.
- */
- void
- pong(ping_data const& payload, error_code& ec);
-
- /** Start an asynchronous operation to send a WebSocket pong frame.
-
- This function is used to asynchronously send a pong frame to
- the stream. The function call always returns immediately. The
- asynchronous operation will continue until one of the following
- is true:
-
- @li The entire pong frame is sent.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to the
- next layer's `async_write_some` functions, and is known as a
- <em>composed operation</em>. The program must ensure that the
- stream performs no other writes until this operation completes.
-
- The WebSocket protocol allows pong frames to be sent from either
- end at any time. It is not necessary to first receive a ping in
- order to send a pong. The remote peer may use the receipt of a
- pong frame as an indication that the connection is not dead.
-
- If a close frame is sent or received before the pong frame is
- sent, the completion handler will be called with the error
- set to `boost::asio::error::operation_aborted`.
-
- @param payload The payload of the pong message, which may be empty.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The function signature of the handler must be:
- @code
- void handler(
- error_code const& ec // Result of operation
- );
- @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<class WriteHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code))
- async_pong(ping_data const& payload, WriteHandler&& handler);
-
- //--------------------------------------------------------------------------
- //
- // Reading
- //
- //--------------------------------------------------------------------------
-
- /** Read a message
-
- This function is used to synchronously read a complete
- message from the stream.
- The call blocks until one of the following is true:
-
- @li A complete message is received.
-
- @li A close frame is received. In this case the error indicated by
- the function will be @ref error::closed.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to the next
- layer's `read_some` and `write_some` functions.
-
- Received message data, if any, is appended to the input area of the
- buffer. The functions @ref got_binary and @ref got_text may be used
- to query the stream and determine the type of the last received message.
-
- While this operation is active, the implementation will read incoming
- control frames and handle them automatically as follows:
-
- @li The @ref control_callback will be invoked for each control frame.
-
- @li For each received ping frame, a pong frame will be
- automatically sent.
-
- @li If a close frame is received, the WebSocket close procedure is
- performed. In this case, when the function returns, the error
- @ref error::closed will be indicated.
-
- @return The number of message payload bytes appended to the buffer.
-
- @param buffer A dynamic buffer to hold the message data after any
- masking or decompression has been applied.
-
- @throws system_error Thrown to indicate an error. The corresponding
- error code may be retrieved from the exception object for inspection.
- */
- template<class DynamicBuffer>
- std::size_t
- read(DynamicBuffer& buffer);
-
- /** Read a message
-
- This function is used to synchronously read a complete
- message from the stream.
- The call blocks until one of the following is true:
-
- @li A complete message is received.
-
- @li A close frame is received. In this case the error indicated by
- the function will be @ref error::closed.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to the next
- layer's `read_some` and `write_some` functions.
-
- Received message data, if any, is appended to the input area of the
- buffer. The functions @ref got_binary and @ref got_text may be used
- to query the stream and determine the type of the last received message.
-
- While this operation is active, the implementation will read incoming
- control frames and handle them automatically as follows:
-
- @li The @ref control_callback will be invoked for each control frame.
-
- @li For each received ping frame, a pong frame will be
- automatically sent.
-
- @li If a close frame is received, the WebSocket close procedure is
- performed. In this case, when the function returns, the error
- @ref error::closed will be indicated.
-
- @return The number of message payload bytes appended to the buffer.
-
- @param buffer A dynamic buffer to hold the message data after any
- masking or decompression has been applied.
-
- @param ec Set to indicate what error occurred, if any.
- */
- template<class DynamicBuffer>
- std::size_t
- read(DynamicBuffer& buffer, error_code& ec);
-
- /** Read a message asynchronously
-
- This function is used to asynchronously read a complete
- message from the stream.
- The function call always returns immediately.
- The asynchronous operation will continue until one of the
- following is true:
-
- @li A complete message is received.
-
- @li A close frame is received. In this case the error indicated by
- the function will be @ref error::closed.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to the
- next layer's `async_read_some` and `async_write_some` functions,
- and is known as a <em>composed operation</em>. The program must
- ensure that the stream performs no other reads until this operation
- completes.
-
- Received message data, if any, is appended to the input area of the
- buffer. The functions @ref got_binary and @ref got_text may be used
- to query the stream and determine the type of the last received message.
-
- While this operation is active, the implementation will read incoming
- control frames and handle them automatically as follows:
-
- @li The @ref control_callback will be invoked for each control frame.
-
- @li For each received ping frame, a pong frame will be
- automatically sent.
-
- @li If a close frame is received, the WebSocket close procedure is
- performed. In this case, when the function returns, the error
- @ref error::closed will be indicated.
-
- Because of the need to handle control frames, asynchronous read
- operations can cause writes to take place. These writes are managed
- transparently; callers can still have one active asynchronous
- read and asynchronous write operation pending simultaneously
- (a user initiated call to @ref async_close counts as a write).
-
- @param buffer A dynamic buffer to hold the message data after
- any masking or decompression has been applied. This object must
- remain valid until the handler is called.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code
- void handler(
- error_code const& ec, // Result of operation
- std::size_t bytes_written // Number of bytes appended to buffer
- );
- @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<class DynamicBuffer, class ReadHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
- async_read(
- DynamicBuffer& buffer,
- ReadHandler&& handler);
-
- //--------------------------------------------------------------------------
-
- /** Read part of a message
-
- This function is used to synchronously read some
- message data from the stream.
- The call blocks until one of the following is true:
-
- @li Some or all of the message is received.
-
- @li A close frame is received. In this case the error indicated by
- the function will be @ref error::closed.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to the next
- layer's `read_some` and `write_some` functions.
-
- Received message data, if any, is appended to the input area of the
- buffer. The functions @ref got_binary and @ref got_text may be used
- to query the stream and determine the type of the last received message.
- The function @ref is_message_done may be called to determine if the
- message received by the last read operation is complete.
-
- While this operation is active, the implementation will read incoming
- control frames and handle them automatically as follows:
-
- @li The @ref control_callback will be invoked for each control frame.
-
- @li For each received ping frame, a pong frame will be
- automatically sent.
-
- @li If a close frame is received, the WebSocket close procedure is
- performed. In this case, when the function returns, the error
- @ref error::closed will be indicated.
-
- @return The number of message payload bytes appended to the buffer.
-
- @param buffer A dynamic buffer to hold the message data after any
- masking or decompression has been applied.
-
- @param limit An upper limit on the number of bytes this function
- will append into the buffer. If this value is zero, then a reasonable
- size will be chosen automatically.
-
- @throws system_error Thrown to indicate an error. The corresponding
- error code may be retrieved from the exception object for inspection.
- */
- template<class DynamicBuffer>
- std::size_t
- read_some(
- DynamicBuffer& buffer,
- std::size_t limit);
-
- /** Read part of a message
-
- This function is used to synchronously read some
- message data from the stream.
- The call blocks until one of the following is true:
-
- @li Some or all of the message is received.
-
- @li A close frame is received. In this case the error indicated by
- the function will be @ref error::closed.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to the next
- layer's `read_some` and `write_some` functions.
-
- Received message data, if any, is appended to the input area of the
- buffer. The functions @ref got_binary and @ref got_text may be used
- to query the stream and determine the type of the last received message.
- The function @ref is_message_done may be called to determine if the
- message received by the last read operation is complete.
-
- While this operation is active, the implementation will read incoming
- control frames and handle them automatically as follows:
-
- @li The @ref control_callback will be invoked for each control frame.
-
- @li For each received ping frame, a pong frame will be
- automatically sent.
-
- @li If a close frame is received, the WebSocket close procedure is
- performed. In this case, when the function returns, the error
- @ref error::closed will be indicated.
-
- @return The number of message payload bytes appended to the buffer.
-
- @param buffer A dynamic buffer to hold the message data after any
- masking or decompression has been applied.
-
- @param limit An upper limit on the number of bytes this function
- will append into the buffer. If this value is zero, then a reasonable
- size will be chosen automatically.
-
- @param ec Set to indicate what error occurred, if any.
- */
- template<class DynamicBuffer>
- std::size_t
- read_some(
- DynamicBuffer& buffer,
- std::size_t limit,
- error_code& ec);
-
- /** Read part of a message asynchronously
-
- This function is used to asynchronously read part of a
- message from the stream.
- The function call always returns immediately.
- The asynchronous operation will continue until one of the
- following is true:
-
- @li Some or all of the message is received.
-
- @li A close frame is received. In this case the error indicated by
- the function will be @ref error::closed.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to the
- next layer's `async_read_some` and `async_write_some` functions,
- and is known as a <em>composed operation</em>. The program must
- ensure that the stream performs no other reads until this operation
- completes.
-
- Received message data, if any, is appended to the input area of the
- buffer. The functions @ref got_binary and @ref got_text may be used
- to query the stream and determine the type of the last received message.
- The function @ref is_message_done may be called to determine if the
- message received by the last read operation is complete.
-
- While this operation is active, the implementation will read incoming
- control frames and handle them automatically as follows:
-
- @li The @ref control_callback will be invoked for each control frame.
-
- @li For each received ping frame, a pong frame will be
- automatically sent.
-
- @li If a close frame is received, the WebSocket close procedure is
- performed. In this case, when the function returns, the error
- @ref error::closed will be indicated.
-
- Because of the need to handle control frames, asynchronous read
- operations can cause writes to take place. These writes are managed
- transparently; callers can still have one active asynchronous
- read and asynchronous write operation pending simultaneously
- (a user initiated call to @ref async_close counts as a write).
-
- @param buffer A dynamic buffer to hold the message data after
- any masking or decompression has been applied. This object must
- remain valid until the handler is called.
-
- @param limit An upper limit on the number of bytes this function
- will append into the buffer. If this value is zero, then a reasonable
- size will be chosen automatically.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code
- void handler(
- error_code const& ec, // Result of operation
- std::size_t bytes_written // Number of bytes appended to buffer
- );
- @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<class DynamicBuffer, class ReadHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
- async_read_some(
- DynamicBuffer& buffer,
- std::size_t limit,
- ReadHandler&& handler);
-
- //--------------------------------------------------------------------------
-
- /** Read part of a message
-
- This function is used to synchronously read some
- message data from the stream.
- The call blocks until one of the following is true:
-
- @li Some or all of the message is received.
-
- @li A close frame is received. In this case the error indicated by
- the function will be @ref error::closed.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to the next
- layer's `read_some` and `write_some` functions.
-
- Received message data, if any, is written to the buffer sequence.
- The functions @ref got_binary and @ref got_text may be used
- to query the stream and determine the type of the last received message.
- The function @ref is_message_done may be called to determine if the
- message received by the last read operation is complete.
-
- While this operation is active, the implementation will read incoming
- control frames and handle them automatically as follows:
-
- @li The @ref control_callback will be invoked for each control frame.
-
- @li For each received ping frame, a pong frame will be
- automatically sent.
-
- @li If a close frame is received, the WebSocket close procedure is
- performed. In this case, when the function returns, the error
- @ref error::closed will be indicated.
-
- @return The number of message payload bytes written to the
- buffer sequence.
-
- @param buffers A buffer sequence to hold the message data after any
- masking or decompression has been applied.
-
- @throws system_error Thrown to indicate an error. The corresponding
- error code may be retrieved from the exception object for inspection.
- */
- template<class MutableBufferSequence>
- std::size_t
- read_some(
- MutableBufferSequence const& buffers);
-
- /** Read part of a message
-
- This function is used to synchronously read some
- message data from the stream.
- The call blocks until one of the following is true:
-
- @li Some or all of the message is received.
-
- @li A close frame is received. In this case the error indicated by
- the function will be @ref error::closed.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to the next
- layer's `read_some` and `write_some` functions.
-
- Received message data, if any, is written to the buffer sequence.
- The functions @ref got_binary and @ref got_text may be used
- to query the stream and determine the type of the last received message.
- The function @ref is_message_done may be called to determine if the
- message received by the last read operation is complete.
-
- While this operation is active, the implementation will read incoming
- control frames and handle them automatically as follows:
-
- @li The @ref control_callback will be invoked for each control frame.
-
- @li For each received ping frame, a pong frame will be
- automatically sent.
-
- @li If a close frame is received, the WebSocket close procedure is
- performed. In this case, when the function returns, the error
- @ref error::closed will be indicated.
-
- @return The number of message payload bytes written to the
- buffer sequence.
-
- @param buffers A buffer sequence to hold the message data after any
- masking or decompression has been applied.
-
- @param ec Set to indicate what error occurred, if any.
- */
- template<class MutableBufferSequence>
- std::size_t
- read_some(
- MutableBufferSequence const& buffers,
- error_code& ec);
-
- /** Read part of a message asynchronously
-
- This function is used to asynchronously read part of a
- message from the stream.
- The function call always returns immediately.
- The asynchronous operation will continue until one of the
- following is true:
-
- @li Some or all of the message is received.
-
- @li A close frame is received. In this case the error indicated by
- the function will be @ref error::closed.
-
- @li An error occurs on the stream.
-
- This operation is implemented in terms of one or more calls to the
- next layer's `async_read_some` and `async_write_some` functions,
- and is known as a <em>composed operation</em>. The program must
- ensure that the stream performs no other reads until this operation
- completes.
-
- Received message data, if any, is written to the buffer sequence.
- The functions @ref got_binary and @ref got_text may be used
- to query the stream and determine the type of the last received message.
- The function @ref is_message_done may be called to determine if the
- message received by the last read operation is complete.
-
- While this operation is active, the implementation will read incoming
- control frames and handle them automatically as follows:
-
- @li The @ref control_callback will be invoked for each control frame.
-
- @li For each received ping frame, a pong frame will be
- automatically sent.
-
- @li If a close frame is received, the WebSocket close procedure is
- performed. In this case, when the function returns, the error
- @ref error::closed will be indicated.
-
- Because of the need to handle control frames, asynchronous read
- operations can cause writes to take place. These writes are managed
- transparently; callers can still have one active asynchronous
- read and asynchronous write operation pending simultaneously
- (a user initiated call to @ref async_close counts as a write).
-
- @param buffers The buffer sequence into which message data will
- be placed after any masking or decompresison has been applied.
- The implementation will make copies of this object as needed,
- but ownership of the underlying memory is not transferred.
- The caller is responsible for ensuring that the memory
- locations pointed to by the buffer sequence remains valid
- until the completion handler is called.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code
- void handler(
- error_code const& ec, // Result of operation
- std::size_t bytes_written // Number of bytes written to the buffer sequence
- );
- @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<class MutableBufferSequence, class ReadHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- ReadHandler, void(error_code, std::size_t))
- async_read_some(
- MutableBufferSequence const& buffers,
- ReadHandler&& handler);
-
- //--------------------------------------------------------------------------
- //
- // Writing
- //
- //--------------------------------------------------------------------------
-
- /** Write a message to the stream.
-
- This function is used to synchronously write a message to
- the stream. The call blocks until one of the following conditions
- is met:
-
- @li The entire message is sent.
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls to the
- next layer's `write_some` function.
-
- The current setting of the @ref binary option controls
- whether the message opcode is set to text or binary. If the
- @ref auto_fragment option is set, the message will be split
- into one or more frames as necessary. The actual payload contents
- sent may be transformed as per the WebSocket protocol settings.
-
- @param buffers The buffers containing the entire message
- payload. The implementation will make copies of this object
- as needed, but ownership of the underlying memory is not
- transferred. The caller is responsible for ensuring that
- the memory locations pointed to by buffers remains valid
- until the completion handler is called.
-
- @return The number of bytes written from the buffers.
- If an error occurred, this will be less than the sum
- of the buffer sizes.
-
- @throws system_error Thrown on failure.
-
- @note This function always sends an entire message. To
- send a message in fragments, use @ref write_some.
- */
- template<class ConstBufferSequence>
- std::size_t
- write(ConstBufferSequence const& buffers);
-
- /** Write a message to the stream.
-
- This function is used to synchronously write a message to
- the stream. The call blocks until one of the following conditions
- is met:
-
- @li The entire message is sent.
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls to the
- next layer's `write_some` function.
-
- The current setting of the @ref binary option controls
- whether the message opcode is set to text or binary. If the
- @ref auto_fragment option is set, the message will be split
- into one or more frames as necessary. The actual payload contents
- sent may be transformed as per the WebSocket protocol settings.
-
- @param buffers The buffers containing the entire message
- payload. The implementation will make copies of this object
- as needed, but ownership of the underlying memory is not
- transferred. The caller is responsible for ensuring that
- the memory locations pointed to by buffers remains valid
- until the completion handler is called.
-
- @return The number of bytes written from the buffers.
- If an error occurred, this will be less than the sum
- of the buffer sizes.
-
- @param ec Set to indicate what error occurred, if any.
-
- @throws system_error Thrown on failure.
-
- @note This function always sends an entire message. To
- send a message in fragments, use @ref write_some.
- */
- template<class ConstBufferSequence>
- std::size_t
- write(ConstBufferSequence const& buffers, error_code& ec);
-
- /** Start an asynchronous operation to write a message to the stream.
-
- This function is used to asynchronously write a message to
- the stream. The function call always returns immediately.
- The asynchronous operation will continue until one of the
- following conditions is true:
-
- @li The entire message is sent.
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls
- to the next layer's `async_write_some` functions, and is known
- as a <em>composed operation</em>. The program must ensure that
- the stream performs no other write operations (such as
- @ref async_write, @ref async_write_some, or
- @ref async_close).
-
- The current setting of the @ref binary option controls
- whether the message opcode is set to text or binary. If the
- @ref auto_fragment option is set, the message will be split
- into one or more frames as necessary. The actual payload contents
- sent may be transformed as per the WebSocket protocol settings.
-
- @param buffers The buffers containing the entire message
- payload. The implementation will make copies of this object
- as needed, but ownership of the underlying memory is not
- transferred. The caller is responsible for ensuring that
- the memory locations pointed to by buffers remains valid
- until the completion handler is called.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The function signature of the handler must be:
- @code
- void handler(
- error_code const& ec, // Result of operation
- std::size_t bytes_transferred // Number of bytes written from the
- // buffers. If an error occurred,
- // this will be less than the sum
- // of the buffer sizes.
- );
- @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using `boost::asio::io_context::post`.
- */
- template<
- class ConstBufferSequence,
- class WriteHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
- async_write(
- ConstBufferSequence const& buffers,
- WriteHandler&& handler);
-
- /** Write partial message data on the stream.
-
- This function is used to write some or all of a message's
- payload to the stream. The call will block until one of the
- following conditions is true:
-
- @li A frame is sent.
-
- @li Message data is transferred to the write buffer.
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls
- to the stream's `write_some` function.
-
- If this is the beginning of a new message, the message opcode
- will be set to text or binary as per the current setting of
- the @ref binary option. The actual payload sent may be
- transformed as per the WebSocket protocol settings.
-
- @param fin `true` if this is the last part of the message.
-
- @param buffers The input buffer sequence holding the data to write.
-
- @return The number of bytes written from the buffers.
- If an error occurred, this will be less than the sum
- of the buffer sizes.
-
- @throws system_error Thrown on failure.
- */
- template<class ConstBufferSequence>
- std::size_t
- write_some(bool fin, ConstBufferSequence const& buffers);
-
- /** Write partial message data on the stream.
-
- This function is used to write some or all of a message's
- payload to the stream. The call will block until one of the
- following conditions is true:
-
- @li A frame is sent.
-
- @li Message data is transferred to the write buffer.
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls
- to the stream's `write_some` function.
-
- If this is the beginning of a new message, the message opcode
- will be set to text or binary as per the current setting of
- the @ref binary option. The actual payload sent may be
- transformed as per the WebSocket protocol settings.
-
- @param fin `true` if this is the last part of the message.
-
- @param buffers The input buffer sequence holding the data to write.
-
- @param ec Set to indicate what error occurred, if any.
-
- @return The number of bytes written from the buffers.
- If an error occurred, this will be less than the sum
- of the buffer sizes.
-
- @return The number of bytes consumed in the input buffers.
- */
- template<class ConstBufferSequence>
- std::size_t
- write_some(bool fin,
- ConstBufferSequence const& buffers, error_code& ec);
-
- /** Start an asynchronous operation to send a message frame on the stream.
-
- This function is used to asynchronously write a message frame
- on the stream. This function call always returns immediately.
- The asynchronous operation will continue until one of the following
- conditions is true:
-
- @li The entire frame is sent.
-
- @li An error occurs.
-
- This operation is implemented in terms of one or more calls
- to the next layer's `async_write_some` functions, and is known
- as a <em>composed operation</em>. The actual payload sent
- may be transformed as per the WebSocket protocol settings. The
- program must ensure that the stream performs no other write
- operations (such as @ref async_write, @ref async_write_some,
- or @ref async_close).
-
- If this is the beginning of a new message, the message opcode
- will be set to text or binary as per the current setting of
- the @ref binary option. The actual payload sent may be
- transformed as per the WebSocket protocol settings.
-
- @param fin `true` if this is the last part of the message.
-
- @param buffers A object meeting the requirements of
- ConstBufferSequence which holds the payload data before any
- masking or compression. Although the buffers object may be copied
- as necessary, ownership of the underlying buffers is retained by
- the caller, which must guarantee that they remain valid until
- the handler is called.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& ec, // Result of operation
- std::size_t bytes_transferred // Number of bytes written from the
- // buffers. If an error occurred,
- // this will be less than the sum
- // of the buffer sizes.
- ); @endcode
- */
- template<class ConstBufferSequence, class WriteHandler>
- BOOST_ASIO_INITFN_RESULT_TYPE(
- WriteHandler, void(error_code, std::size_t))
- async_write_some(bool fin,
- ConstBufferSequence const& buffers, WriteHandler&& handler);
-
-private:
- template<class, class> class accept_op;
- template<class> class close_op;
- template<class> class handshake_op;
- template<class> class ping_op;
- template<class, class> class read_some_op;
- template<class, class> class read_op;
- template<class> class response_op;
- template<class, class> class write_some_op;
- template<class, class> class write_op;
-
- static void default_decorate_req(request_type&) {}
- static void default_decorate_res(response_type&) {}
-
- void
- set_option(permessage_deflate const& o, std::true_type);
-
- void
- set_option(permessage_deflate const&, std::false_type);
-
- void
- get_option(permessage_deflate& o, std::true_type)
- {
- o = this->pmd_opts_;
- }
-
- void
- get_option(permessage_deflate& o, std::false_type)
- {
- o = {};
- o.client_enable = false;
- o.server_enable = false;
- }
-
- void open(role_type role);
-
- void open_pmd(std::true_type);
-
- void open_pmd(std::false_type)
- {
- }
-
- void close();
-
- void close_pmd(std::true_type)
- {
- this->pmd_.reset();
- }
-
- void close_pmd(std::false_type)
- {
- }
-
- void reset();
-
- void begin_msg()
- {
- begin_msg(is_deflate_supported{});
- }
-
- void begin_msg(std::true_type);
-
- void begin_msg(std::false_type);
-
- std::size_t
- read_size_hint(
- std::size_t initial_size,
- std::true_type) const;
-
- std::size_t
- read_size_hint(
- std::size_t initial_size,
- std::false_type) const;
-
- bool
- check_open(error_code& ec)
- {
- if(status_ != status::open)
- {
- ec = boost::asio::error::operation_aborted;
- return false;
- }
- ec.assign(0, ec.category());
- return true;
- }
-
- bool
- check_ok(error_code& ec)
- {
- if(ec)
- {
- if(status_ != status::closed)
- status_ = status::failed;
- return false;
- }
- return true;
- }
-
- template<class DynamicBuffer>
- bool
- parse_fh(
- detail::frame_header& fh,
- DynamicBuffer& b,
- error_code& ec);
-
- template<class DynamicBuffer>
- void
- write_close(DynamicBuffer& b, close_reason const& rc);
-
- template<class DynamicBuffer>
- void
- write_ping(DynamicBuffer& b,
- detail::opcode op, ping_data const& data);
-
- //
- // upgrade
- //
-
- template<class Decorator>
- request_type
- build_request(detail::sec_ws_key_type& key,
- string_view host,
- string_view target,
- Decorator const& decorator);
-
- void
- build_request_pmd(request_type& req, std::true_type);
-
- void
- build_request_pmd(request_type&, std::false_type)
- {
- }
-
- template<
- class Body, class Allocator, class Decorator>
- response_type
- build_response(
- http::request<Body,
- http::basic_fields<Allocator>> const& req,
- Decorator const& decorator,
- error_code& ec);
-
- template<class Body, class Allocator>
- void
- build_response_pmd(
- response_type& res,
- http::request<Body,
- http::basic_fields<Allocator>> const& req,
- std::true_type);
-
- template<class Body, class Allocator>
- void
- build_response_pmd(
- response_type&,
- http::request<Body,
- http::basic_fields<Allocator>> const&,
- std::false_type)
- {
- }
-
- void
- on_response(
- response_type const& res,
- detail::sec_ws_key_type const& key,
- error_code& ec);
-
- void
- on_response_pmd(
- response_type const& res,
- std::true_type);
-
- void
- on_response_pmd(
- response_type const&,
- std::false_type)
- {
- }
-
- //
- // accept / handshake
- //
-
- template<class Allocator>
- void
- do_pmd_config(
- http::basic_fields<Allocator> const& h,
- std::true_type)
- {
- pmd_read(this->pmd_config_, h);
- }
-
- template<class Allocator>
- void
- do_pmd_config(
- http::basic_fields<Allocator> const&,
- std::false_type)
- {
- }
-
- template<class Decorator>
- void
- do_accept(
- Decorator const& decorator,
- error_code& ec);
-
- template<
- class Body, class Allocator,
- class Decorator>
- void
- do_accept(
- http::request<Body,
- http::basic_fields<Allocator>> const& req,
- Decorator const& decorator,
- error_code& ec);
-
- template<class RequestDecorator>
- void
- do_handshake(response_type* res_p,
- string_view host, string_view target,
- RequestDecorator const& decorator,
- error_code& ec);
-
- //
- // fail
- //
-
- void
- do_fail(
- std::uint16_t code,
- error_code ev,
- error_code& ec);
-};
-
-} // websocket
-} // beast
-} // boost
-
-#include <boost/beast/websocket/impl/accept.ipp>
-#include <boost/beast/websocket/impl/close.ipp>
-#include <boost/beast/websocket/impl/handshake.ipp>
-#include <boost/beast/websocket/impl/ping.ipp>
-#include <boost/beast/websocket/impl/read.ipp>
-#include <boost/beast/websocket/impl/stream.ipp>
-#include <boost/beast/websocket/impl/write.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/stream_fwd.hpp b/contrib/restricted/boost/boost/beast/websocket/stream_fwd.hpp
deleted file mode 100644
index 97ffcb49ed..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/stream_fwd.hpp
+++ /dev/null
@@ -1,28 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_STREAM_FWD_HPP
-#define BOOST_BEAST_WEBSOCKET_STREAM_FWD_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-template<
- class NextLayer,
- bool deflateSupported = true>
-class stream;
-
-} // websocket
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/websocket/teardown.hpp b/contrib/restricted/boost/boost/beast/websocket/teardown.hpp
deleted file mode 100644
index a255756dad..0000000000
--- a/contrib/restricted/boost/boost/beast/websocket/teardown.hpp
+++ /dev/null
@@ -1,174 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_WEBSOCKET_TEARDOWN_HPP
-#define BOOST_BEAST_WEBSOCKET_TEARDOWN_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/error.hpp>
-#include <boost/beast/websocket/role.hpp>
-#include <boost/asio/ip/tcp.hpp>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-namespace websocket {
-
-/** Tear down a connection.
-
- This tears down a connection. The implementation will call
- the overload of this function based on the `Socket` parameter
- used to consruct the socket. When `Socket` is a user defined
- type, and not a `boost::asio::ip::tcp::socket` or any
- `boost::asio::ssl::stream`, callers are responsible for
- providing a suitable overload of this function.
-
- @param role The role of the local endpoint
-
- @param socket The socket to tear down.
-
- @param ec Set to the error if any occurred.
-*/
-template<class Socket>
-void
-teardown(
- role_type role,
- Socket& socket,
- error_code& ec)
-{
- boost::ignore_unused(role, socket, ec);
-/*
- If you are trying to use OpenSSL and this goes off, you need to
- add an include for <boost/beast/websocket/ssl.hpp>.
-
- If you are creating an instance of beast::websocket::stream with your
- own user defined type, you must provide an overload of teardown with
- the corresponding signature (including the role_type).
-*/
- static_assert(sizeof(Socket)==-1,
- "Unknown Socket type in teardown.");
-}
-
-/** Start tearing down a connection.
-
- This begins tearing down a connection asynchronously.
- The implementation will call the overload of this function
- based on the `Socket` parameter used to consruct the socket.
- When `Stream` is a user defined type, and not a
- `boost::asio::ip::tcp::socket` or any `boost::asio::ssl::stream`,
- callers are responsible for providing a suitable overload
- of this function.
-
- @param role The role of the local endpoint
-
- @param socket The socket to tear down.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& error // result of operation
- );
- @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using boost::asio::io_context::post().
-
-*/
-template<
- class Socket,
- class TeardownHandler>
-void
-async_teardown(
- role_type role,
- Socket& socket,
- TeardownHandler&& handler)
-{
- boost::ignore_unused(role, socket, handler);
-/*
- If you are trying to use OpenSSL and this goes off, you need to
- add an include for <boost/beast/websocket/ssl.hpp>.
-
- If you are creating an instance of beast::websocket::stream with your
- own user defined type, you must provide an overload of teardown with
- the corresponding signature (including the role_type).
-*/
- static_assert(sizeof(Socket)==-1,
- "Unknown Socket type in async_teardown.");
-}
-
-} // websocket
-
-//------------------------------------------------------------------------------
-
-namespace websocket {
-
-/** Tear down a `boost::asio::ip::tcp::socket`.
-
- This tears down a connection. The implementation will call
- the overload of this function based on the `Stream` parameter
- used to consruct the socket. When `Stream` is a user defined
- type, and not a `boost::asio::ip::tcp::socket` or any
- `boost::asio::ssl::stream`, callers are responsible for
- providing a suitable overload of this function.
-
- @param role The role of the local endpoint
-
- @param socket The socket to tear down.
-
- @param ec Set to the error if any occurred.
-*/
-void
-teardown(
- role_type role,
- boost::asio::ip::tcp::socket& socket,
- error_code& ec);
-
-/** Start tearing down a `boost::asio::ip::tcp::socket`.
-
- This begins tearing down a connection asynchronously.
- The implementation will call the overload of this function
- based on the `Stream` parameter used to consruct the socket.
- When `Stream` is a user defined type, and not a
- `boost::asio::ip::tcp::socket` or any `boost::asio::ssl::stream`,
- callers are responsible for providing a suitable overload
- of this function.
-
- @param role The role of the local endpoint
-
- @param socket The socket to tear down.
-
- @param handler Invoked when the operation completes.
- The handler may be moved or copied as needed.
- The equivalent function signature of the handler must be:
- @code void handler(
- error_code const& error // result of operation
- );
- @endcode
- Regardless of whether the asynchronous operation completes
- immediately or not, the handler will not be invoked from within
- this function. Invocation of the handler will be performed in a
- manner equivalent to using boost::asio::io_context::post().
-
-*/
-template<class TeardownHandler>
-void
-async_teardown(
- role_type role,
- boost::asio::ip::tcp::socket& socket,
- TeardownHandler&& handler);
-
-} // websocket
-} // beast
-} // boost
-
-#include <boost/beast/websocket/impl/teardown.ipp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/zlib.hpp b/contrib/restricted/boost/boost/beast/zlib.hpp
deleted file mode 100644
index 87ce609625..0000000000
--- a/contrib/restricted/boost/boost/beast/zlib.hpp
+++ /dev/null
@@ -1,20 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_ZLIB_HPP
-#define BOOST_BEAST_ZLIB_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-
-#include <boost/beast/zlib/deflate_stream.hpp>
-#include <boost/beast/zlib/error.hpp>
-#include <boost/beast/zlib/inflate_stream.hpp>
-#include <boost/beast/zlib/zlib.hpp>
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/zlib/deflate_stream.hpp b/contrib/restricted/boost/boost/beast/zlib/deflate_stream.hpp
deleted file mode 100644
index f57a0a5042..0000000000
--- a/contrib/restricted/boost/boost/beast/zlib/deflate_stream.hpp
+++ /dev/null
@@ -1,404 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_ZLIB_DEFLATE_STREAM_HPP
-#define BOOST_BEAST_ZLIB_DEFLATE_STREAM_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/zlib/error.hpp>
-#include <boost/beast/zlib/zlib.hpp>
-#include <boost/beast/zlib/detail/deflate_stream.hpp>
-#include <algorithm>
-#include <cstdlib>
-#include <cstdint>
-#include <cstring>
-#include <memory>
-
-namespace boost {
-namespace beast {
-namespace zlib {
-
-// This is a derivative work based on Zlib, copyright below:
-/*
- Copyright (C) 1995-2013 Jean-loup Gailly and Mark Adler
-
- This software is provided 'as-is', without any express or implied
- warranty. In no event will the authors be held liable for any damages
- arising from the use of this software.
-
- Permission is granted to anyone to use this software for any purpose,
- including commercial applications, and to alter it and redistribute it
- freely, subject to the following restrictions:
-
- 1. The origin of this software must not be misrepresented; you must not
- claim that you wrote the original software. If you use this software
- in a product, an acknowledgment in the product documentation would be
- appreciated but is not required.
- 2. Altered source versions must be plainly marked as such, and must not be
- misrepresented as being the original software.
- 3. This notice may not be removed or altered from any source distribution.
-
- Jean-loup Gailly Mark Adler
- jloup@gzip.org madler@alumni.caltech.edu
-
- The data format used by the zlib library is described by RFCs (Request for
- Comments) 1950 to 1952 in the files http://tools.ietf.org/html/rfc1950
- (zlib format), rfc1951 (deflate format) and rfc1952 (gzip format).
-*/
-
-/** Raw deflate compressor.
-
- This is a port of zlib's "deflate" functionality to C++.
-*/
-class deflate_stream
- : private detail::deflate_stream
-{
-public:
- /** Construct a default deflate stream.
-
- Upon construction, the stream settings will be set
- to these default values:
-
- @li `level = 6`
-
- @li `windowBits = 15`
-
- @li `memLevel = 8`
-
- @li `strategy = Strategy::normal`
-
- Although the stream is ready to be used immediately
- after construction, any required internal buffers are
- not dynamically allocated until needed.
- */
- deflate_stream()
- {
- reset(6, 15, DEF_MEM_LEVEL, Strategy::normal);
- }
-
- /** Reset the stream and compression settings.
-
- This function initializes the stream to the specified
- compression settings.
-
- Although the stream is ready to be used immediately
- after a reset, any required internal buffers are not
- dynamically allocated until needed.
-
- @note Any unprocessed input or pending output from
- previous calls are discarded.
- */
- void
- reset(
- int level,
- int windowBits,
- int memLevel,
- Strategy strategy)
- {
- doReset(level, windowBits, memLevel, strategy);
- }
-
- /** Reset the stream without deallocating memory.
-
- This function performs the equivalent of calling `clear`
- followed by `reset` with the same compression settings,
- without deallocating the internal buffers.
-
- @note Any unprocessed input or pending output from
- previous calls are discarded.
- */
- void
- reset()
- {
- doReset();
- }
-
- /** Clear the stream.
-
- This function resets the stream and frees all dynamically
- allocated internal buffers. The compression settings are
- left unchanged.
-
- @note Any unprocessed input or pending output from
- previous calls are discarded.
- */
- void
- clear()
- {
- doClear();
- }
-
- /** Returns the upper limit on the size of a compressed block.
-
- This function makes a conservative estimate of the maximum number
- of bytes needed to store the result of compressing a block of
- data based on the current compression level and strategy.
-
- @param sourceLen The size of the uncompressed data.
-
- @return The maximum number of resulting compressed bytes.
- */
- std::size_t
- upper_bound(std::size_t sourceLen) const
- {
- return doUpperBound(sourceLen);
- }
-
- /** Fine tune internal compression parameters.
-
- Compression parameters should only be tuned by someone who
- understands the algorithm used by zlib's deflate for searching
- for the best matching string, and even then only by the most
- fanatic optimizer trying to squeeze out the last compressed bit
- for their specific input data. Read the deflate.c source code
- (ZLib) for the meaning of the max_lazy, good_length, nice_length,
- and max_chain parameters.
- */
- void
- tune(
- int good_length,
- int max_lazy,
- int nice_length,
- int max_chain)
- {
- doTune(good_length, max_lazy, nice_length, max_chain);
- }
-
- /** Compress input and write output.
-
- This function compresses as much data as possible, and stops when
- the input buffer becomes empty or the output buffer becomes full.
- It may introduce some output latency (reading input without
- producing any output) except when forced to flush.
-
- In each call, one or both of these actions are performed:
-
- @li Compress more input starting at `zs.next_in` and update
- `zs.next_in` and `zs.avail_in` accordingly. If not all
- input can be processed (because there is not enough room in
- the output buffer), `zs.next_in` and `zs.avail_in` are updated
- and processing will resume at this point for the next call.
-
- @li Provide more output starting at `zs.next_out` and update
- `zs.next_out` and `zs.avail_out` accordingly. This action is
- forced if the parameter flush is not `Flush::none`. Forcing
- flush frequently degrades the compression ratio, so this parameter
- should be set only when necessary (in interactive applications).
- Some output may be provided even if flush is not set.
-
- Before the call, the application must ensure that at least one
- of the actions is possible, by providing more input and/or
- consuming more output, and updating `zs.avail_in` or `zs.avail_out`
- accordingly; `zs.avail_out` should never be zero before the call.
- The application can consume the compressed output when it wants,
- for example when the output buffer is full (`zs.avail_out == 0`),
- or after each call of `write`. If `write` returns no error
- with zero `zs.avail_out`, it must be called again after making
- room in the output buffer because there might be more output
- pending.
-
- Normally the parameter flush is set to `Flush::none`, which allows
- deflate to decide how much data to accumulate before producing
- output, in order to maximize compression.
-
- If the parameter flush is set to `Flush::sync`, all pending output
- is flushed to the output buffer and the output is aligned on a
- byte boundary, so that the decompressor can get all input data
- available so far. In particular `zs.avail_in` is zero after the
- call if enough output space has been provided before the call.
- Flushing may degrade compression for some compression algorithms
- and so it should be used only when necessary. This completes the
- current deflate block and follows it with an empty stored block
- that is three bits plus filler bits to the next byte, followed
- by the four bytes `{ 0x00, 0x00 0xff 0xff }`.
-
- If flush is set to `Flush::partial`, all pending output is flushed
- to the output buffer, but the output is not aligned to a byte
- boundary. All of the input data so far will be available to the
- decompressor, as for Z_SYNC_FLUSH. This completes the current
- deflate block and follows it with an empty fixed codes block that
- is 10 bits long. This assures that enough bytes are output in order
- for the decompressor to finish the block before the empty fixed
- code block.
-
- If flush is set to `Flush::block`, a deflate block is completed
- and emitted, as for `Flush::sync`, but the output is not aligned
- on a byte boundary, and up to seven bits of the current block are
- held to be written as the next byte after the next deflate block
- is completed. In this case, the decompressor may not be provided
- enough bits at this point in order to complete decompression of
- the data provided so far to the compressor. It may need to wait
- for the next block to be emitted. This is for advanced applications
- that need to control the emission of deflate blocks.
-
- If flush is set to `Flush::full`, all output is flushed as with
- `Flush::sync`, and the compression state is reset so that
- decompression can restart from this point if previous compressed
- data has been damaged or if random access is desired. Using
- `Flush::full` too often can seriously degrade compression.
-
- If `write` returns with `zs.avail_out == 0`, this function must
- be called again with the same value of the flush parameter and
- more output space (updated `zs.avail_out`), until the flush is
- complete (`write` returns with non-zero `zs.avail_out`). In the
- case of a `Flush::full`or `Flush::sync`, make sure that
- `zs.avail_out` is greater than six to avoid repeated flush markers
- due to `zs.avail_out == 0` on return.
-
- If the parameter flush is set to `Flush::finish`, pending input
- is processed, pending output is flushed and deflate returns the
- error `error::end_of_stream` if there was enough output space;
- if deflate returns with no error, this function must be called
- again with `Flush::finish` and more output space (updated
- `zs.avail_out`) but no more input data, until it returns the
- error `error::end_of_stream` or another error. After `write` has
- returned the `error::end_of_stream` error, the only possible
- operations on the stream are to reset or destroy.
-
- `Flush::finish` can be used immediately after initialization
- if all the compression is to be done in a single step. In this
- case, `zs.avail_out` must be at least value returned by
- `upper_bound` (see below). Then `write` is guaranteed to return
- the `error::end_of_stream` error. If not enough output space
- is provided, deflate will not return `error::end_of_stream`,
- and it must be called again as described above.
-
- `write` returns no error if some progress has been made (more
- input processed or more output produced), `error::end_of_stream`
- if all input has been consumed and all output has been produced
- (only when flush is set to `Flush::finish`), `error::stream_error`
- if the stream state was inconsistent (for example if `zs.next_in`
- or `zs.next_out` was `nullptr`), `error::need_buffers` if no
- progress is possible (for example `zs.avail_in` or `zs.avail_out`
- was zero). Note that `error::need_buffers` is not fatal, and
- `write` can be called again with more input and more output space
- to continue compressing.
- */
- void
- write(
- z_params& zs,
- Flush flush,
- error_code& ec)
- {
- doWrite(zs, flush, ec);
- }
-
- /** Update the compression level and strategy.
-
- This function dynamically updates the compression level and
- compression strategy. The interpretation of level and strategy
- is as in @ref reset. This can be used to switch between compression
- and straight copy of the input data, or to switch to a different kind
- of input data requiring a different strategy. If the compression level
- is changed, the input available so far is compressed with the old level
- (and may be flushed); the new level will take effect only at the next
- call of @ref write.
-
- Before the call of `params`, the stream state must be set as for a
- call of @ref write, since the currently available input may have to be
- compressed and flushed. In particular, `zs.avail_out` must be non-zero.
-
- @return `Z_OK` if success, `Z_STREAM_ERROR` if the source stream state
- was inconsistent or if a parameter was invalid, `error::need_buffers`
- if `zs.avail_out` was zero.
- */
- void
- params(
- z_params& zs,
- int level,
- Strategy strategy,
- error_code& ec)
- {
- doParams(zs, level, strategy, ec);
- }
-
- /** Return bits pending in the output.
-
- This function returns the number of bytes and bits of output
- that have been generated, but not yet provided in the available
- output. The bytes not provided would be due to the available
- output space having being consumed. The number of bits of output
- not provided are between 0 and 7, where they await more bits to
- join them in order to fill out a full byte. If pending or bits
- are `nullptr`, then those values are not set.
-
- @return `Z_OK` if success, or `Z_STREAM_ERROR` if the source
- stream state was inconsistent.
- */
- void
- pending(unsigned *value, int *bits)
- {
- doPending(value, bits);
- }
-
- /** Insert bits into the compressed output stream.
-
- This function inserts bits in the deflate output stream. The
- intent is that this function is used to start off the deflate
- output with the bits leftover from a previous deflate stream when
- appending to it. As such, this function can only be used for raw
- deflate, and must be used before the first `write` call after an
- initialization. `bits` must be less than or equal to 16, and that
- many of the least significant bits of `value` will be inserted in
- the output.
-
- @return `error::need_buffers` if there was not enough room in
- the internal buffer to insert the bits.
- */
- void
- prime(int bits, int value, error_code& ec)
- {
- return doPrime(bits, value, ec);
- }
-};
-
-/** Returns the upper limit on the size of a compressed block.
-
- This function makes a conservative estimate of the maximum number
- of bytes needed to store the result of compressing a block of
- data.
-
- @param bytes The size of the uncompressed data.
-
- @return The maximum number of resulting compressed bytes.
-*/
-std::size_t
-deflate_upper_bound(std::size_t bytes);
-
-/* For the default windowBits of 15 and memLevel of 8, this function returns
- a close to exact, as well as small, upper bound on the compressed size.
- They are coded as constants here for a reason--if the #define's are
- changed, then this function needs to be changed as well. The return
- value for 15 and 8 only works for those exact settings.
-
- For any setting other than those defaults for windowBits and memLevel,
- the value returned is a conservative worst case for the maximum expansion
- resulting from using fixed blocks instead of stored blocks, which deflate
- can emit on compressed data for some combinations of the parameters.
-
- This function could be more sophisticated to provide closer upper bounds for
- every combination of windowBits and memLevel. But even the conservative
- upper bound of about 14% expansion does not seem onerous for output buffer
- allocation.
-*/
-inline
-std::size_t
-deflate_upper_bound(std::size_t bytes)
-{
- return bytes +
- ((bytes + 7) >> 3) +
- ((bytes + 63) >> 6) + 5 +
- 6;
-}
-
-} // zlib
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/zlib/detail/bitstream.hpp b/contrib/restricted/boost/boost/beast/zlib/detail/bitstream.hpp
deleted file mode 100644
index eca32bc424..0000000000
--- a/contrib/restricted/boost/boost/beast/zlib/detail/bitstream.hpp
+++ /dev/null
@@ -1,207 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-// This is a derivative work based on Zlib, copyright below:
-/*
- Copyright (C) 1995-2013 Jean-loup Gailly and Mark Adler
-
- This software is provided 'as-is', without any express or implied
- warranty. In no event will the authors be held liable for any damages
- arising from the use of this software.
-
- Permission is granted to anyone to use this software for any purpose,
- including commercial applications, and to alter it and redistribute it
- freely, subject to the following restrictions:
-
- 1. The origin of this software must not be misrepresented; you must not
- claim that you wrote the original software. If you use this software
- in a product, an acknowledgment in the product documentation would be
- appreciated but is not required.
- 2. Altered source versions must be plainly marked as such, and must not be
- misrepresented as being the original software.
- 3. This notice may not be removed or altered from any source distribution.
-
- Jean-loup Gailly Mark Adler
- jloup@gzip.org madler@alumni.caltech.edu
-
- The data format used by the zlib library is described by RFCs (Request for
- Comments) 1950 to 1952 in the files http://tools.ietf.org/html/rfc1950
- (zlib format), rfc1951 (deflate format) and rfc1952 (gzip format).
-*/
-
-#ifndef BOOST_BEAST_ZLIB_DETAIL_BITSTREAM_HPP
-#define BOOST_BEAST_ZLIB_DETAIL_BITSTREAM_HPP
-
-#include <boost/assert.hpp>
-#include <cstdint>
-#include <iterator>
-
-namespace boost {
-namespace beast {
-namespace zlib {
-namespace detail {
-
-class bitstream
-{
- using value_type = std::uint32_t;
-
- value_type v_ = 0;
- unsigned n_ = 0;
-
-public:
- // returns the number of bits in the reservoir
- unsigned
- size() const
- {
- return n_;
- }
-
- // discard n bits
- void
- drop(std::size_t n)
- {
- BOOST_ASSERT(n <= n_);
- n_ -= static_cast<unsigned>(n);
- v_ >>= n;
- }
-
- // flush everything
- void
- flush()
- {
- n_ = 0;
- v_ = 0;
- }
-
- // flush to the next byte boundary
- void
- flush_byte()
- {
- drop(n_ % 8);
- }
-
- // ensure at least n bits
- template<class FwdIt>
- bool
- fill(std::size_t n, FwdIt& first, FwdIt const& last);
-
- // fill 8 bits, unchecked
- template<class FwdIt>
- void
- fill_8(FwdIt& it);
-
- // fill 16 bits, unchecked
- template<class FwdIt>
- void
- fill_16(FwdIt& it);
-
- // return n bits
- template<class Unsigned>
- void
- peek(Unsigned& value, std::size_t n);
-
- // return everything in the reservoir
- value_type
- peek_fast() const
- {
- return v_;
- }
-
- // return n bits, and consume
- template<class Unsigned>
- void
- read(Unsigned& value, std::size_t n);
-
- // rewind by the number of whole bytes stored (unchecked)
- template<class BidirIt>
- void
- rewind(BidirIt& it);
-};
-
-template<class FwdIt>
-inline
-bool
-bitstream::
-fill(std::size_t n, FwdIt& first, FwdIt const& last)
-{
- while(n_ < n)
- {
- if(first == last)
- return false;
- v_ += static_cast<value_type>(*first++) << n_;
- n_ += 8;
- }
- return true;
-}
-
-template<class FwdIt>
-inline
-void
-bitstream::
-fill_8(FwdIt& it)
-{
- v_ += static_cast<value_type>(*it++) << n_;
- n_ += 8;
-}
-
-template<class FwdIt>
-inline
-void
-bitstream::
-fill_16(FwdIt& it)
-{
- v_ += static_cast<value_type>(*it++) << n_;
- n_ += 8;
- v_ += static_cast<value_type>(*it++) << n_;
- n_ += 8;
-}
-
-template<class Unsigned>
-inline
-void
-bitstream::
-peek(Unsigned& value, std::size_t n)
-{
- BOOST_ASSERT(n <= sizeof(value)*8);
- BOOST_ASSERT(n <= n_);
- value = static_cast<Unsigned>(
- v_ & ((1ULL << n) - 1));
-}
-
-template<class Unsigned>
-inline
-void
-bitstream::
-read(Unsigned& value, std::size_t n)
-{
- BOOST_ASSERT(n < sizeof(v_)*8);
- BOOST_ASSERT(n <= n_);
- value = static_cast<Unsigned>(
- v_ & ((1ULL << n) - 1));
- v_ >>= n;
- n_ -= static_cast<unsigned>(n);
-}
-
-template<class BidirIt>
-inline
-void
-bitstream::
-rewind(BidirIt& it)
-{
- auto len = n_ >> 3;
- it = std::prev(it, len);
- n_ &= 7;
- v_ &= (1U << n_) - 1;
-}
-
-} // detail
-} // zlib
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/zlib/detail/deflate_stream.hpp b/contrib/restricted/boost/boost/beast/zlib/detail/deflate_stream.hpp
deleted file mode 100644
index f0a91e8ad1..0000000000
--- a/contrib/restricted/boost/boost/beast/zlib/detail/deflate_stream.hpp
+++ /dev/null
@@ -1,3006 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-// This is a derivative work based on Zlib, copyright below:
-/*
- Copyright (C) 1995-2013 Jean-loup Gailly and Mark Adler
-
- This software is provided 'as-is', without any express or implied
- warranty. In no event will the authors be held liable for any damages
- arising from the use of this software.
-
- Permission is granted to anyone to use this software for any purpose,
- including commercial applications, and to alter it and redistribute it
- freely, subject to the following restrictions:
-
- 1. The origin of this software must not be misrepresented; you must not
- claim that you wrote the original software. If you use this software
- in a product, an acknowledgment in the product documentation would be
- appreciated but is not required.
- 2. Altered source versions must be plainly marked as such, and must not be
- misrepresented as being the original software.
- 3. This notice may not be removed or altered from any source distribution.
-
- Jean-loup Gailly Mark Adler
- jloup@gzip.org madler@alumni.caltech.edu
-
- The data format used by the zlib library is described by RFCs (Request for
- Comments) 1950 to 1952 in the files http://tools.ietf.org/html/rfc1950
- (zlib format), rfc1951 (deflate format) and rfc1952 (gzip format).
-*/
-
-#ifndef BOOST_BEAST_ZLIB_DETAIL_DEFLATE_STREAM_HPP
-#define BOOST_BEAST_ZLIB_DETAIL_DEFLATE_STREAM_HPP
-
-#include <boost/beast/zlib/zlib.hpp>
-#include <boost/beast/zlib/detail/ranges.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/assert.hpp>
-#include <boost/config.hpp>
-#include <boost/make_unique.hpp>
-#include <boost/optional.hpp>
-#include <boost/throw_exception.hpp>
-#include <cstdint>
-#include <cstdlib>
-#include <cstring>
-#include <memory>
-#include <stdexcept>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-namespace zlib {
-namespace detail {
-
-/*
- * ALGORITHM
- *
- * The "deflation" process depends on being able to identify portions
- * of the input text which are identical to earlier input (within a
- * sliding window trailing behind the input currently being processed).
- *
- * Each code tree is stored in a compressed form which is itself
- * a Huffman encoding of the lengths of all the code strings (in
- * ascending order by source values). The actual code strings are
- * reconstructed from the lengths in the inflate process, as described
- * in the deflate specification.
- *
- * The most straightforward technique turns out to be the fastest for
- * most input files: try all possible matches and select the longest.
- * The key feature of this algorithm is that insertions into the string
- * dictionary are very simple and thus fast, and deletions are avoided
- * completely. Insertions are performed at each input character, whereas
- * string matches are performed only when the previous match ends. So it
- * is preferable to spend more time in matches to allow very fast string
- * insertions and avoid deletions. The matching algorithm for small
- * strings is inspired from that of Rabin & Karp. A brute force approach
- * is used to find longer strings when a small match has been found.
- * A similar algorithm is used in comic (by Jan-Mark Wams) and freeze
- * (by Leonid Broukhis).
- * A previous version of this file used a more sophisticated algorithm
- * (by Fiala and Greene) which is guaranteed to run in linear amortized
- * time, but has a larger average cost, uses more memory and is patented.
- * However the F&G algorithm may be faster for some highly redundant
- * files if the parameter max_chain_length (described below) is too large.
- *
- * ACKNOWLEDGEMENTS
- *
- * The idea of lazy evaluation of matches is due to Jan-Mark Wams, and
- * I found it in 'freeze' written by Leonid Broukhis.
- * Thanks to many people for bug reports and testing.
- *
- * REFERENCES
- *
- * Deutsch, L.P.,"DEFLATE Compressed Data Format Specification".
- * Available in http://tools.ietf.org/html/rfc1951
- *
- * A description of the Rabin and Karp algorithm is given in the book
- * "Algorithms" by R. Sedgewick, Addison-Wesley, p252.
- *
- * Fiala,E.R., and Greene,D.H.
- * Data Compression with Finite Windows, Comm.ACM, 32,4 (1989) 490-595
- *
- */
-
-class deflate_stream
-{
-protected:
- // Upper limit on code length
- static std::uint8_t constexpr maxBits = 15;
-
- // Number of length codes, not counting the special END_BLOCK code
- static std::uint16_t constexpr lengthCodes = 29;
-
- // Number of literal bytes 0..255
- static std::uint16_t constexpr literals = 256;
-
- // Number of Literal or Length codes, including the END_BLOCK code
- static std::uint16_t constexpr lCodes = literals + 1 + lengthCodes;
-
- // Number of distance code lengths
- static std::uint16_t constexpr dCodes = 30;
-
- // Number of codes used to transfer the bit lengths
- static std::uint16_t constexpr blCodes = 19;
-
- // Number of distance codes
- static std::uint16_t constexpr distCodeLen = 512;
-
- // Size limit on bit length codes
- static std::uint8_t constexpr maxBlBits= 7;
-
- static std::uint16_t constexpr minMatch = 3;
- static std::uint16_t constexpr maxMatch = 258;
-
- // Can't change minMatch without also changing code, see original zlib
- BOOST_STATIC_ASSERT(minMatch == 3);
-
- // end of block literal code
- static std::uint16_t constexpr END_BLOCK = 256;
-
- // repeat previous bit length 3-6 times (2 bits of repeat count)
- static std::uint8_t constexpr REP_3_6 = 16;
-
- // repeat a zero length 3-10 times (3 bits of repeat count)
- static std::uint8_t constexpr REPZ_3_10 = 17;
-
- // repeat a zero length 11-138 times (7 bits of repeat count)
- static std::uint8_t constexpr REPZ_11_138 = 18;
-
- // The three kinds of block type
- static std::uint8_t constexpr STORED_BLOCK = 0;
- static std::uint8_t constexpr STATIC_TREES = 1;
- static std::uint8_t constexpr DYN_TREES = 2;
-
- // Maximum value for memLevel in deflateInit2
- static std::uint8_t constexpr max_mem_level = 9;
-
- // Default memLevel
- static std::uint8_t constexpr DEF_MEM_LEVEL = max_mem_level;
-
- /* Note: the deflate() code requires max_lazy >= minMatch and max_chain >= 4
- For deflate_fast() (levels <= 3) good is ignored and lazy has a different
- meaning.
- */
-
- // maximum heap size
- static std::uint16_t constexpr HEAP_SIZE = 2 * lCodes + 1;
-
- // size of bit buffer in bi_buf
- static std::uint8_t constexpr Buf_size = 16;
-
- // Matches of length 3 are discarded if their distance exceeds kTooFar
- static std::size_t constexpr kTooFar = 4096;
-
- /* Minimum amount of lookahead, except at the end of the input file.
- See deflate.c for comments about the minMatch+1.
- */
- static std::size_t constexpr kMinLookahead = maxMatch + minMatch+1;
-
- /* Number of bytes after end of data in window to initialize in order
- to avoid memory checker errors from longest match routines
- */
- static std::size_t constexpr kWinInit = maxMatch;
-
- // Describes a single value and its code string.
- struct ct_data
- {
- std::uint16_t fc; // frequency count or bit string
- std::uint16_t dl; // parent node in tree or length of bit string
-
- bool
- operator==(ct_data const& rhs) const
- {
- return fc == rhs.fc && dl == rhs.dl;
- }
- };
-
- struct static_desc
- {
- ct_data const* static_tree;// static tree or NULL
- std::uint8_t const* extra_bits; // extra bits for each code or NULL
- std::uint16_t extra_base; // base index for extra_bits
- std::uint16_t elems; // max number of elements in the tree
- std::uint8_t max_length; // max bit length for the codes
- };
-
- struct lut_type
- {
- // Number of extra bits for each length code
- std::uint8_t const extra_lbits[lengthCodes] = {
- 0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0
- };
-
- // Number of extra bits for each distance code
- std::uint8_t const extra_dbits[dCodes] = {
- 0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13
- };
-
- // Number of extra bits for each bit length code
- std::uint8_t const extra_blbits[blCodes] = {
- 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7
- };
-
- // The lengths of the bit length codes are sent in order
- // of decreasing probability, to avoid transmitting the
- // lengths for unused bit length codes.
- std::uint8_t const bl_order[blCodes] = {
- 16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15
- };
-
- ct_data ltree[lCodes + 2];
-
- ct_data dtree[dCodes];
-
- // Distance codes. The first 256 values correspond to the distances
- // 3 .. 258, the last 256 values correspond to the top 8 bits of
- // the 15 bit distances.
- std::uint8_t dist_code[distCodeLen];
-
- std::uint8_t length_code[maxMatch-minMatch+1];
-
- std::uint8_t base_length[lengthCodes];
-
- std::uint16_t base_dist[dCodes];
-
- static_desc l_desc = {
- ltree, extra_lbits, literals+1, lCodes, maxBits
- };
-
- static_desc d_desc = {
- dtree, extra_dbits, 0, dCodes, maxBits
- };
-
- static_desc bl_desc =
- {
- nullptr, extra_blbits, 0, blCodes, maxBlBits
- };
- };
-
- struct tree_desc
- {
- ct_data *dyn_tree; /* the dynamic tree */
- int max_code; /* largest code with non zero frequency */
- static_desc const* stat_desc; /* the corresponding static tree */
- };
-
- enum block_state
- {
- need_more, /* block not completed, need more input or more output */
- block_done, /* block flush performed */
- finish_started, /* finish started, need only more output at next deflate */
- finish_done /* finish done, accept no more input or output */
- };
-
- // VFALCO This might not be needed, e.g. for zip/gzip
- enum StreamStatus
- {
- EXTRA_STATE = 69,
- NAME_STATE = 73,
- COMMENT_STATE = 91,
- HCRC_STATE = 103,
- BUSY_STATE = 113,
- FINISH_STATE = 666
- };
-
- /* A std::uint16_t is an index in the character window. We use short instead of int to
- * save space in the various tables. IPos is used only for parameter passing.
- */
- using IPos = unsigned;
-
- using self = deflate_stream;
- typedef block_state(self::*compress_func)(z_params& zs, Flush flush);
-
- //--------------------------------------------------------------------------
-
- lut_type const& lut_;
-
- bool inited_ = false;
- std::size_t buf_size_;
- std::unique_ptr<std::uint8_t[]> buf_;
-
- int status_; // as the name implies
- Byte* pending_buf_; // output still pending
- std::uint32_t
- pending_buf_size_; // size of pending_buf
- Byte* pending_out_; // next pending byte to output to the stream
- uInt pending_; // nb of bytes in the pending buffer
- boost::optional<Flush>
- last_flush_; // value of flush param for previous deflate call
-
- uInt w_size_; // LZ77 window size (32K by default)
- uInt w_bits_; // log2(w_size) (8..16)
- uInt w_mask_; // w_size - 1
-
- /* Sliding window. Input bytes are read into the second half of the window,
- and move to the first half later to keep a dictionary of at least wSize
- bytes. With this organization, matches are limited to a distance of
- wSize-maxMatch bytes, but this ensures that IO is always
- performed with a length multiple of the block size. Also, it limits
- the window size to 64K.
- To do: use the user input buffer as sliding window.
- */
- Byte *window_ = nullptr;
-
- /* Actual size of window: 2*wSize, except when the user input buffer
- is directly used as sliding window.
- */
- std::uint32_t window_size_;
-
- /* Link to older string with same hash index. To limit the size of this
- array to 64K, this link is maintained only for the last 32K strings.
- An index in this array is thus a window index modulo 32K.
- */
- std::uint16_t* prev_;
-
- std::uint16_t* head_; // Heads of the hash chains or 0
-
- uInt ins_h_; // hash index of string to be inserted
- uInt hash_size_; // number of elements in hash table
- uInt hash_bits_; // log2(hash_size)
- uInt hash_mask_; // hash_size-1
-
- /* Number of bits by which ins_h must be shifted at each input
- step. It must be such that after minMatch steps,
- the oldest byte no longer takes part in the hash key, that is:
- hash_shift * minMatch >= hash_bits
- */
- uInt hash_shift_;
-
- /* Window position at the beginning of the current output block.
- Gets negative when the window is moved backwards.
- */
- long block_start_;
-
- uInt match_length_; // length of best match
- IPos prev_match_; // previous match
- int match_available_; // set if previous match exists
- uInt strstart_; // start of string to insert
- uInt match_start_; // start of matching string
- uInt lookahead_; // number of valid bytes ahead in window
-
- /* Length of the best match at previous step. Matches not greater
- than this are discarded. This is used in the lazy match evaluation.
- */
- uInt prev_length_;
-
- /* To speed up deflation, hash chains are never searched beyond
- this length. A higher limit improves compression ratio but
- degrades the speed.
- */
- uInt max_chain_length_;
-
- /* Attempt to find a better match only when the current match is strictly
- smaller than this value. This mechanism is used only for compression
- levels >= 4.
-
- OR Insert new strings in the hash table only if the match length is not
- greater than this length. This saves time but degrades compression.
- used only for compression levels <= 3.
- */
- uInt max_lazy_match_;
-
- int level_; // compression level (1..9)
- Strategy strategy_; // favor or force Huffman coding
-
- // Use a faster search when the previous match is longer than this
- uInt good_match_;
-
- int nice_match_; // Stop searching when current match exceeds this
-
- ct_data dyn_ltree_[
- HEAP_SIZE]; // literal and length tree
- ct_data dyn_dtree_[
- 2*dCodes+1]; // distance tree
- ct_data bl_tree_[
- 2*blCodes+1]; // Huffman tree for bit lengths
-
- tree_desc l_desc_; // desc. for literal tree
- tree_desc d_desc_; // desc. for distance tree
- tree_desc bl_desc_; // desc. for bit length tree
-
- // number of codes at each bit length for an optimal tree
- std::uint16_t bl_count_[maxBits+1];
-
- // Index within the heap array of least frequent node in the Huffman tree
- static std::size_t constexpr kSmallest = 1;
-
- /* The sons of heap[n] are heap[2*n] and heap[2*n+1].
- heap[0] is not used. The same heap array is used to build all trees.
- */
-
- int heap_[2*lCodes+1]; // heap used to build the Huffman trees
- int heap_len_; // number of elements in the heap
- int heap_max_; // element of largest frequency
-
- // Depth of each subtree used as tie breaker for trees of equal frequency
- std::uint8_t depth_[2*lCodes+1];
-
- std::uint8_t *l_buf_; // buffer for literals or lengths
-
- /* Size of match buffer for literals/lengths.
- There are 4 reasons for limiting lit_bufsize to 64K:
- - frequencies can be kept in 16 bit counters
- - if compression is not successful for the first block, all input
- data is still in the window so we can still emit a stored block even
- when input comes from standard input. (This can also be done for
- all blocks if lit_bufsize is not greater than 32K.)
- - if compression is not successful for a file smaller than 64K, we can
- even emit a stored file instead of a stored block (saving 5 bytes).
- This is applicable only for zip (not gzip or zlib).
- - creating new Huffman trees less frequently may not provide fast
- adaptation to changes in the input data statistics. (Take for
- example a binary file with poorly compressible code followed by
- a highly compressible string table.) Smaller buffer sizes give
- fast adaptation but have of course the overhead of transmitting
- trees more frequently.
- - I can't count above 4
- */
- uInt lit_bufsize_;
- uInt last_lit_; // running index in l_buf_
-
- /* Buffer for distances. To simplify the code, d_buf_ and l_buf_
- have the same number of elements. To use different lengths, an
- extra flag array would be necessary.
- */
- std::uint16_t* d_buf_;
-
- std::uint32_t opt_len_; // bit length of current block with optimal trees
- std::uint32_t static_len_; // bit length of current block with static trees
- uInt matches_; // number of string matches in current block
- uInt insert_; // bytes at end of window left to insert
-
- /* Output buffer.
- Bits are inserted starting at the bottom (least significant bits).
- */
- std::uint16_t bi_buf_;
-
- /* Number of valid bits in bi_buf._ All bits above the last valid
- bit are always zero.
- */
- int bi_valid_;
-
- /* High water mark offset in window for initialized bytes -- bytes
- above this are set to zero in order to avoid memory check warnings
- when longest match routines access bytes past the input. This is
- then updated to the new high water mark.
- */
- std::uint32_t high_water_;
-
- //--------------------------------------------------------------------------
-
- deflate_stream()
- : lut_(get_lut())
- {
- }
-
- /* In order to simplify the code, particularly on 16 bit machines, match
- distances are limited to MAX_DIST instead of WSIZE.
- */
- std::size_t
- max_dist() const
- {
- return w_size_ - kMinLookahead;
- }
-
- void
- put_byte(std::uint8_t c)
- {
- pending_buf_[pending_++] = c;
- }
-
- void
- put_short(std::uint16_t w)
- {
- put_byte(w & 0xff);
- put_byte(w >> 8);
- }
-
- /* Send a value on a given number of bits.
- IN assertion: length <= 16 and value fits in length bits.
- */
- void
- send_bits(int value, int length)
- {
- if(bi_valid_ > (int)Buf_size - length)
- {
- bi_buf_ |= (std::uint16_t)value << bi_valid_;
- put_short(bi_buf_);
- bi_buf_ = (std::uint16_t)value >> (Buf_size - bi_valid_);
- bi_valid_ += length - Buf_size;
- }
- else
- {
- bi_buf_ |= (std::uint16_t)(value) << bi_valid_;
- bi_valid_ += length;
- }
- }
-
- // Send a code of the given tree
- void
- send_code(int value, ct_data const* tree)
- {
- send_bits(tree[value].fc, tree[value].dl);
- }
-
- /* Mapping from a distance to a distance code. dist is the
- distance - 1 and must not have side effects. _dist_code[256]
- and _dist_code[257] are never used.
- */
- std::uint8_t
- d_code(unsigned dist)
- {
- if(dist < 256)
- return lut_.dist_code[dist];
- return lut_.dist_code[256+(dist>>7)];
- }
-
- /* Update a hash value with the given input byte
- IN assertion: all calls to to update_hash are made with
- consecutive input characters, so that a running hash
- key can be computed from the previous key instead of
- complete recalculation each time.
- */
- void
- update_hash(uInt& h, std::uint8_t c)
- {
- h = ((h << hash_shift_) ^ c) & hash_mask_;
- }
-
- /* Initialize the hash table (avoiding 64K overflow for 16
- bit systems). prev[] will be initialized on the fly.
- */
- void
- clear_hash()
- {
- head_[hash_size_-1] = 0;
- std::memset((Byte *)head_, 0,
- (unsigned)(hash_size_-1)*sizeof(*head_));
- }
-
- /* Compares two subtrees, using the tree depth as tie breaker
- when the subtrees have equal frequency. This minimizes the
- worst case length.
- */
- bool
- smaller(ct_data const* tree, int n, int m)
- {
- return tree[n].fc < tree[m].fc ||
- (tree[n].fc == tree[m].fc &&
- depth_[n] <= depth_[m]);
- }
-
- /* Insert string str in the dictionary and set match_head to the
- previous head of the hash chain (the most recent string with
- same hash key). Return the previous length of the hash chain.
- If this file is compiled with -DFASTEST, the compression level
- is forced to 1, and no hash chains are maintained.
- IN assertion: all calls to to INSERT_STRING are made with
- consecutive input characters and the first minMatch
- bytes of str are valid (except for the last minMatch-1
- bytes of the input file).
- */
- void
- insert_string(IPos& hash_head)
- {
- update_hash(ins_h_, window_[strstart_ + (minMatch-1)]);
- hash_head = prev_[strstart_ & w_mask_] = head_[ins_h_];
- head_[ins_h_] = (std::uint16_t)strstart_;
- }
-
- //--------------------------------------------------------------------------
-
- /* Values for max_lazy_match, good_match and max_chain_length, depending on
- * the desired pack level (0..9). The values given below have been tuned to
- * exclude worst case performance for pathological files. Better values may be
- * found for specific files.
- */
- struct config
- {
- std::uint16_t good_length; /* reduce lazy search above this match length */
- std::uint16_t max_lazy; /* do not perform lazy search above this match length */
- std::uint16_t nice_length; /* quit search above this match length */
- std::uint16_t max_chain;
- compress_func func;
-
- config(
- std::uint16_t good_length_,
- std::uint16_t max_lazy_,
- std::uint16_t nice_length_,
- std::uint16_t max_chain_,
- compress_func func_)
- : good_length(good_length_)
- , max_lazy(max_lazy_)
- , nice_length(nice_length_)
- , max_chain(max_chain_)
- , func(func_)
- {
- }
- };
-
- static
- config
- get_config(std::size_t level)
- {
- switch(level)
- {
- // good lazy nice chain
- case 0: return { 0, 0, 0, 0, &self::deflate_stored}; // store only
- case 1: return { 4, 4, 8, 4, &self::deflate_fast}; // max speed, no lazy matches
- case 2: return { 4, 5, 16, 8, &self::deflate_fast};
- case 3: return { 4, 6, 32, 32, &self::deflate_fast};
- case 4: return { 4, 4, 16, 16, &self::deflate_slow}; // lazy matches
- case 5: return { 8, 16, 32, 32, &self::deflate_slow};
- case 6: return { 8, 16, 128, 128, &self::deflate_slow};
- case 7: return { 8, 32, 128, 256, &self::deflate_slow};
- case 8: return { 32, 128, 258, 1024, &self::deflate_slow};
- default:
- case 9: return { 32, 258, 258, 4096, &self::deflate_slow}; // max compression
- }
- }
-
- void
- maybe_init()
- {
- if(! inited_)
- init();
- }
-
- template<class Unsigned>
- static
- Unsigned
- bi_reverse(Unsigned code, unsigned len);
-
- template<class = void>
- static
- void
- gen_codes(ct_data *tree, int max_code, std::uint16_t *bl_count);
-
- template<class = void>
- static
- lut_type const&
- get_lut();
-
- template<class = void> void doReset (int level, int windowBits, int memLevel, Strategy strategy);
- template<class = void> void doReset ();
- template<class = void> void doClear ();
- template<class = void> std::size_t doUpperBound (std::size_t sourceLen) const;
- template<class = void> void doTune (int good_length, int max_lazy, int nice_length, int max_chain);
- template<class = void> void doParams (z_params& zs, int level, Strategy strategy, error_code& ec);
- template<class = void> void doWrite (z_params& zs, boost::optional<Flush> flush, error_code& ec);
- template<class = void> void doDictionary (Byte const* dict, uInt dictLength, error_code& ec);
- template<class = void> void doPrime (int bits, int value, error_code& ec);
- template<class = void> void doPending (unsigned* value, int* bits);
-
- template<class = void> void init ();
- template<class = void> void lm_init ();
- template<class = void> void init_block ();
- template<class = void> void pqdownheap (ct_data const* tree, int k);
- template<class = void> void pqremove (ct_data const* tree, int& top);
- template<class = void> void gen_bitlen (tree_desc *desc);
- template<class = void> void build_tree (tree_desc *desc);
- template<class = void> void scan_tree (ct_data *tree, int max_code);
- template<class = void> void send_tree (ct_data *tree, int max_code);
- template<class = void> int build_bl_tree ();
- template<class = void> void send_all_trees (int lcodes, int dcodes, int blcodes);
- template<class = void> void compress_block (ct_data const* ltree, ct_data const* dtree);
- template<class = void> int detect_data_type ();
- template<class = void> void bi_windup ();
- template<class = void> void bi_flush ();
- template<class = void> void copy_block (char *buf, unsigned len, int header);
-
- template<class = void> void tr_init ();
- template<class = void> void tr_align ();
- template<class = void> void tr_flush_bits ();
- template<class = void> void tr_stored_block (char *bu, std::uint32_t stored_len, int last);
- template<class = void> void tr_tally_dist (std::uint16_t dist, std::uint8_t len, bool& flush);
- template<class = void> void tr_tally_lit (std::uint8_t c, bool& flush);
-
- template<class = void> void tr_flush_block (z_params& zs, char *buf, std::uint32_t stored_len, int last);
- template<class = void> void fill_window (z_params& zs);
- template<class = void> void flush_pending (z_params& zs);
- template<class = void> void flush_block (z_params& zs, bool last);
- template<class = void> int read_buf (z_params& zs, Byte *buf, unsigned size);
- template<class = void> uInt longest_match (IPos cur_match);
-
- template<class = void> block_state f_stored (z_params& zs, Flush flush);
- template<class = void> block_state f_fast (z_params& zs, Flush flush);
- template<class = void> block_state f_slow (z_params& zs, Flush flush);
- template<class = void> block_state f_rle (z_params& zs, Flush flush);
- template<class = void> block_state f_huff (z_params& zs, Flush flush);
-
- block_state
- deflate_stored(z_params& zs, Flush flush)
- {
- return f_stored(zs, flush);
- }
-
- block_state
- deflate_fast(z_params& zs, Flush flush)
- {
- return f_fast(zs, flush);
- }
-
- block_state
- deflate_slow(z_params& zs, Flush flush)
- {
- return f_slow(zs, flush);
- }
-
- block_state
- deflate_rle(z_params& zs, Flush flush)
- {
- return f_rle(zs, flush);
- }
-
- block_state
- deflate_huff(z_params& zs, Flush flush)
- {
- return f_huff(zs, flush);
- }
-};
-
-//--------------------------------------------------------------------------
-
-// Reverse the first len bits of a code
-template<class Unsigned>
-inline
-Unsigned
-deflate_stream::
-bi_reverse(Unsigned code, unsigned len)
-{
- BOOST_STATIC_ASSERT(std::is_unsigned<Unsigned>::value);
- BOOST_ASSERT(len <= 8 * sizeof(unsigned));
- Unsigned res = 0;
- do
- {
- res |= code & 1;
- code >>= 1;
- res <<= 1;
- }
- while(--len > 0);
- return res >> 1;
-}
-
-/* Generate the codes for a given tree and bit counts (which need not be optimal).
- IN assertion: the array bl_count contains the bit length statistics for
- the given tree and the field len is set for all tree elements.
- OUT assertion: the field code is set for all tree elements of non
- zero code length.
-*/
-template<class>
-void
-deflate_stream::
-gen_codes(ct_data *tree, int max_code, std::uint16_t *bl_count)
-{
- std::uint16_t next_code[maxBits+1]; /* next code value for each bit length */
- std::uint16_t code = 0; /* running code value */
- int bits; /* bit index */
- int n; /* code index */
-
- // The distribution counts are first used to
- // generate the code values without bit reversal.
- for(bits = 1; bits <= maxBits; bits++)
- {
- code = (code + bl_count[bits-1]) << 1;
- next_code[bits] = code;
- }
- // Check that the bit counts in bl_count are consistent.
- // The last code must be all ones.
- BOOST_ASSERT(code + bl_count[maxBits]-1 == (1<<maxBits)-1);
- for(n = 0; n <= max_code; n++)
- {
- int len = tree[n].dl;
- if(len == 0)
- continue;
- tree[n].fc = bi_reverse(next_code[len]++, len);
- }
-}
-
-template<class>
-auto
-deflate_stream::get_lut() ->
- lut_type const&
-{
- struct init
- {
- lut_type tables;
-
- init()
- {
- // number of codes at each bit length for an optimal tree
- //std::uint16_t bl_count[maxBits+1];
-
- // Initialize the mapping length (0..255) -> length code (0..28)
- std::uint8_t length = 0;
- for(std::uint8_t code = 0; code < lengthCodes-1; ++code)
- {
- tables.base_length[code] = length;
- auto const run = 1U << tables.extra_lbits[code];
- for(unsigned n = 0; n < run; ++n)
- tables.length_code[length++] = code;
- }
- BOOST_ASSERT(length == 0);
- // Note that the length 255 (match length 258) can be represented
- // in two different ways: code 284 + 5 bits or code 285, so we
- // overwrite length_code[255] to use the best encoding:
- tables.length_code[255] = lengthCodes-1;
-
- // Initialize the mapping dist (0..32K) -> dist code (0..29)
- {
- std::uint8_t code;
- std::uint16_t dist = 0;
- for(code = 0; code < 16; code++)
- {
- tables.base_dist[code] = dist;
- auto const run = 1U << tables.extra_dbits[code];
- for(unsigned n = 0; n < run; ++n)
- tables.dist_code[dist++] = code;
- }
- BOOST_ASSERT(dist == 256);
- // from now on, all distances are divided by 128
- dist >>= 7;
- for(; code < dCodes; ++code)
- {
- tables.base_dist[code] = dist << 7;
- auto const run = 1U << (tables.extra_dbits[code]-7);
- for(std::size_t n = 0; n < run; ++n)
- tables.dist_code[256 + dist++] = code;
- }
- BOOST_ASSERT(dist == 256);
- }
-
- // Construct the codes of the static literal tree
- std::uint16_t bl_count[maxBits+1];
- std::memset(bl_count, 0, sizeof(bl_count));
- unsigned n = 0;
- while (n <= 143)
- tables.ltree[n++].dl = 8;
- bl_count[8] += 144;
- while (n <= 255)
- tables.ltree[n++].dl = 9;
- bl_count[9] += 112;
- while (n <= 279)
- tables.ltree[n++].dl = 7;
- bl_count[7] += 24;
- while (n <= 287)
- tables.ltree[n++].dl = 8;
- bl_count[8] += 8;
- // Codes 286 and 287 do not exist, but we must include them in the tree
- // construction to get a canonical Huffman tree (longest code all ones)
- gen_codes(tables.ltree, lCodes+1, bl_count);
-
- for(n = 0; n < dCodes; ++n)
- {
- tables.dtree[n].dl = 5;
- tables.dtree[n].fc =
- static_cast<std::uint16_t>(bi_reverse(n, 5));
- }
- }
- };
- static init const data;
- return data.tables;
-}
-
-template<class>
-void
-deflate_stream::
-doReset(
- int level,
- int windowBits,
- int memLevel,
- Strategy strategy)
-{
- if(level == default_size)
- level = 6;
-
- // VFALCO What do we do about this?
- // until 256-byte window bug fixed
- if(windowBits == 8)
- windowBits = 9;
-
- if(level < 0 || level > 9)
- BOOST_THROW_EXCEPTION(std::invalid_argument{
- "invalid level"});
-
- if(windowBits < 8 || windowBits > 15)
- BOOST_THROW_EXCEPTION(std::invalid_argument{
- "invalid windowBits"});
-
- if(memLevel < 1 || memLevel > max_mem_level)
- BOOST_THROW_EXCEPTION(std::invalid_argument{
- "invalid memLevel"});
-
- w_bits_ = windowBits;
-
- hash_bits_ = memLevel + 7;
-
- // 16K elements by default
- lit_bufsize_ = 1 << (memLevel + 6);
-
- level_ = level;
- strategy_ = strategy;
- inited_ = false;
-}
-
-template<class>
-void
-deflate_stream::
-doReset()
-{
- inited_ = false;
-}
-
-template<class>
-void
-deflate_stream::
-doClear()
-{
- inited_ = false;
- buf_.reset();
-}
-
-template<class>
-std::size_t
-deflate_stream::
-doUpperBound(std::size_t sourceLen) const
-{
- std::size_t complen;
- std::size_t wraplen;
-
- /* conservative upper bound for compressed data */
- complen = sourceLen +
- ((sourceLen + 7) >> 3) + ((sourceLen + 63) >> 6) + 5;
-
- /* compute wrapper length */
- wraplen = 0;
-
- /* if not default parameters, return conservative bound */
- if(w_bits_ != 15 || hash_bits_ != 8 + 7)
- return complen + wraplen;
-
- /* default settings: return tight bound for that case */
- return sourceLen + (sourceLen >> 12) + (sourceLen >> 14) +
- (sourceLen >> 25) + 13 - 6 + wraplen;
-}
-
-template<class>
-void
-deflate_stream::
-doTune(
- int good_length,
- int max_lazy,
- int nice_length,
- int max_chain)
-{
- good_match_ = good_length;
- nice_match_ = nice_length;
- max_lazy_match_ = max_lazy;
- max_chain_length_ = max_chain;
-}
-
-template<class>
-void
-deflate_stream::
-doParams(z_params& zs, int level, Strategy strategy, error_code& ec)
-{
- compress_func func;
-
- if(level == default_size)
- level = 6;
- if(level < 0 || level > 9)
- {
- ec = error::stream_error;
- return;
- }
- func = get_config(level_).func;
-
- if((strategy != strategy_ || func != get_config(level).func) &&
- zs.total_in != 0)
- {
- // Flush the last buffer:
- doWrite(zs, Flush::block, ec);
- if(ec == error::need_buffers && pending_ == 0)
- ec.assign(0, ec.category());
- }
- if(level_ != level)
- {
- level_ = level;
- max_lazy_match_ = get_config(level).max_lazy;
- good_match_ = get_config(level).good_length;
- nice_match_ = get_config(level).nice_length;
- max_chain_length_ = get_config(level).max_chain;
- }
- strategy_ = strategy;
-}
-
-// VFALCO boost::optional param is a workaround for
-// gcc "maybe uninitialized" warning
-// https://github.com/boostorg/beast/issues/532
-//
-template<class>
-void
-deflate_stream::
-doWrite(z_params& zs, boost::optional<Flush> flush, error_code& ec)
-{
- maybe_init();
-
- if(zs.next_out == 0 || (zs.next_in == 0 && zs.avail_in != 0) ||
- (status_ == FINISH_STATE && flush != Flush::finish))
- {
- ec = error::stream_error;
- return;
- }
- if(zs.avail_out == 0)
- {
- ec = error::need_buffers;
- return;
- }
-
- // value of flush param for previous deflate call
- auto old_flush = boost::make_optional<Flush>(
- last_flush_.is_initialized(),
- last_flush_ ? *last_flush_ : Flush::none);
-
- last_flush_ = flush;
-
- // Flush as much pending output as possible
- if(pending_ != 0)
- {
- flush_pending(zs);
- if(zs.avail_out == 0)
- {
- /* Since avail_out is 0, deflate will be called again with
- * more output space, but possibly with both pending and
- * avail_in equal to zero. There won't be anything to do,
- * but this is not an error situation so make sure we
- * return OK instead of BUF_ERROR at next call of deflate:
- */
- last_flush_ = boost::none;
- return;
- }
- }
- else if(zs.avail_in == 0 && (
- old_flush && flush <= *old_flush
- ) && flush != Flush::finish)
- {
- /* Make sure there is something to do and avoid duplicate consecutive
- * flushes. For repeated and useless calls with Flush::finish, we keep
- * returning Z_STREAM_END instead of Z_BUF_ERROR.
- */
- ec = error::need_buffers;
- return;
- }
-
- // User must not provide more input after the first FINISH:
- if(status_ == FINISH_STATE && zs.avail_in != 0)
- {
- ec = error::need_buffers;
- return;
- }
-
- /* Start a new block or continue the current one.
- */
- if(zs.avail_in != 0 || lookahead_ != 0 ||
- (flush != Flush::none && status_ != FINISH_STATE))
- {
- block_state bstate;
-
- switch(strategy_)
- {
- case Strategy::huffman:
- bstate = deflate_huff(zs, flush.get());
- break;
- case Strategy::rle:
- bstate = deflate_rle(zs, flush.get());
- break;
- default:
- {
- bstate = (this->*(get_config(level_).func))(zs, flush.get());
- break;
- }
- }
-
- if(bstate == finish_started || bstate == finish_done)
- {
- status_ = FINISH_STATE;
- }
- if(bstate == need_more || bstate == finish_started)
- {
- if(zs.avail_out == 0)
- {
- last_flush_ = boost::none; /* avoid BUF_ERROR next call, see above */
- }
- return;
- /* If flush != Flush::none && avail_out == 0, the next call
- of deflate should use the same flush parameter to make sure
- that the flush is complete. So we don't have to output an
- empty block here, this will be done at next call. This also
- ensures that for a very small output buffer, we emit at most
- one empty block.
- */
- }
- if(bstate == block_done)
- {
- if(flush == Flush::partial)
- {
- tr_align();
- }
- else if(flush != Flush::block)
- {
- /* FULL_FLUSH or SYNC_FLUSH */
- tr_stored_block((char*)0, 0L, 0);
- /* For a full flush, this empty block will be recognized
- * as a special marker by inflate_sync().
- */
- if(flush == Flush::full)
- {
- clear_hash(); // forget history
- if(lookahead_ == 0)
- {
- strstart_ = 0;
- block_start_ = 0L;
- insert_ = 0;
- }
- }
- }
- flush_pending(zs);
- if(zs.avail_out == 0)
- {
- last_flush_ = boost::none; /* avoid BUF_ERROR at next call, see above */
- return;
- }
- }
- }
-
- if(flush == Flush::finish)
- {
- ec = error::end_of_stream;
- return;
- }
-}
-
-// VFALCO Warning: untested
-template<class>
-void
-deflate_stream::
-doDictionary(Byte const* dict, uInt dictLength, error_code& ec)
-{
- if(lookahead_)
- {
- ec = error::stream_error;
- return;
- }
-
- maybe_init();
-
- /* if dict would fill window, just replace the history */
- if(dictLength >= w_size_)
- {
- clear_hash();
- strstart_ = 0;
- block_start_ = 0L;
- insert_ = 0;
- dict += dictLength - w_size_; /* use the tail */
- dictLength = w_size_;
- }
-
- /* insert dict into window and hash */
- z_params zs;
- zs.avail_in = dictLength;
- zs.next_in = (const Byte *)dict;
- zs.avail_out = 0;
- zs.next_out = 0;
- fill_window(zs);
- while(lookahead_ >= minMatch)
- {
- uInt str = strstart_;
- uInt n = lookahead_ - (minMatch-1);
- do
- {
- update_hash(ins_h_, window_[str + minMatch-1]);
- prev_[str & w_mask_] = head_[ins_h_];
- head_[ins_h_] = (std::uint16_t)str;
- str++;
- }
- while(--n);
- strstart_ = str;
- lookahead_ = minMatch-1;
- fill_window(zs);
- }
- strstart_ += lookahead_;
- block_start_ = (long)strstart_;
- insert_ = lookahead_;
- lookahead_ = 0;
- match_length_ = prev_length_ = minMatch-1;
- match_available_ = 0;
-}
-
-template<class>
-void
-deflate_stream::
-doPrime(int bits, int value, error_code& ec)
-{
- maybe_init();
-
- if((Byte *)(d_buf_) < pending_out_ + ((Buf_size + 7) >> 3))
- {
- ec = error::need_buffers;
- return;
- }
-
- do
- {
- int put = Buf_size - bi_valid_;
- if(put > bits)
- put = bits;
- bi_buf_ |= (std::uint16_t)((value & ((1 << put) - 1)) << bi_valid_);
- bi_valid_ += put;
- tr_flush_bits();
- value >>= put;
- bits -= put;
- }
- while(bits);
-}
-
-template<class>
-void
-deflate_stream::
-doPending(unsigned* value, int* bits)
-{
- if(value != 0)
- *value = pending_;
- if(bits != 0)
- *bits = bi_valid_;
-}
-
-//--------------------------------------------------------------------------
-
-// Do lazy initialization
-template<class>
-void
-deflate_stream::
-init()
-{
- // Caller must set these:
- // w_bits_
- // hash_bits_
- // lit_bufsize_
- // level_
- // strategy_
-
- w_size_ = 1 << w_bits_;
- w_mask_ = w_size_ - 1;
-
- hash_size_ = 1 << hash_bits_;
- hash_mask_ = hash_size_ - 1;
- hash_shift_ = ((hash_bits_+minMatch-1)/minMatch);
-
- auto const nwindow = w_size_ * 2*sizeof(Byte);
- auto const nprev = w_size_ * sizeof(std::uint16_t);
- auto const nhead = hash_size_ * sizeof(std::uint16_t);
- auto const noverlay = lit_bufsize_ * (sizeof(std::uint16_t)+2);
- auto const needed = nwindow + nprev + nhead + noverlay;
-
- if(! buf_ || buf_size_ != needed)
- {
- buf_ = boost::make_unique_noinit<
- std::uint8_t[]>(needed);
- buf_size_ = needed;
- }
-
- window_ = reinterpret_cast<Byte*>(buf_.get());
- prev_ = reinterpret_cast<std::uint16_t*>(buf_.get() + nwindow);
- head_ = reinterpret_cast<std::uint16_t*>(buf_.get() + nwindow + nprev);
-
- /* We overlay pending_buf_ and d_buf_ + l_buf_. This works
- since the average output size for(length, distance)
- codes is <= 24 bits.
- */
- auto overlay = reinterpret_cast<std::uint16_t*>(
- buf_.get() + nwindow + nprev + nhead);
-
- // nothing written to window_ yet
- high_water_ = 0;
-
- pending_buf_ =
- reinterpret_cast<std::uint8_t*>(overlay);
- pending_buf_size_ =
- static_cast<std::uint32_t>(lit_bufsize_) *
- (sizeof(std::uint16_t) + 2L);
-
- d_buf_ = overlay + lit_bufsize_ / sizeof(std::uint16_t);
- l_buf_ = pending_buf_ + (1 + sizeof(std::uint16_t)) * lit_bufsize_;
-
- pending_ = 0;
- pending_out_ = pending_buf_;
-
- status_ = BUSY_STATE;
- last_flush_ = Flush::none;
-
- tr_init();
- lm_init();
-
- inited_ = true;
-}
-
-/* Initialize the "longest match" routines for a new zlib stream
-*/
-template<class>
-void
-deflate_stream::
-lm_init()
-{
- window_size_ = (std::uint32_t)2L*w_size_;
-
- clear_hash();
-
- /* Set the default configuration parameters:
- */
- // VFALCO TODO just copy the config struct
- max_lazy_match_ = get_config(level_).max_lazy;
- good_match_ = get_config(level_).good_length;
- nice_match_ = get_config(level_).nice_length;
- max_chain_length_ = get_config(level_).max_chain;
-
- strstart_ = 0;
- block_start_ = 0L;
- lookahead_ = 0;
- insert_ = 0;
- match_length_ = prev_length_ = minMatch-1;
- match_available_ = 0;
- ins_h_ = 0;
-}
-
-// Initialize a new block.
-//
-template<class>
-void
-deflate_stream::
-init_block()
-{
- for(int n = 0; n < lCodes; n++)
- dyn_ltree_[n].fc = 0;
- for(int n = 0; n < dCodes; n++)
- dyn_dtree_[n].fc = 0;
- for(int n = 0; n < blCodes; n++)
- bl_tree_[n].fc = 0;
- dyn_ltree_[END_BLOCK].fc = 1;
- opt_len_ = 0L;
- static_len_ = 0L;
- last_lit_ = 0;
- matches_ = 0;
-}
-
-/* Restore the heap property by moving down the tree starting at node k,
- exchanging a node with the smallest of its two sons if necessary,
- stopping when the heap property is re-established (each father smaller
- than its two sons).
-*/
-template<class>
-void
-deflate_stream::
-pqdownheap(
- ct_data const* tree, // the tree to restore
- int k) // node to move down
-{
- int v = heap_[k];
- int j = k << 1; // left son of k
- while(j <= heap_len_)
- {
- // Set j to the smallest of the two sons:
- if(j < heap_len_ &&
- smaller(tree, heap_[j+1], heap_[j]))
- j++;
- // Exit if v is smaller than both sons
- if(smaller(tree, v, heap_[j]))
- break;
-
- // Exchange v with the smallest son
- heap_[k] = heap_[j];
- k = j;
-
- // And continue down the tree,
- // setting j to the left son of k
- j <<= 1;
- }
- heap_[k] = v;
-}
-
-/* Remove the smallest element from the heap and recreate the heap
- with one less element. Updates heap and heap_len.
-*/
-template<class>
-inline
-void
-deflate_stream::
-pqremove(ct_data const* tree, int& top)
-{
- top = heap_[kSmallest];
- heap_[kSmallest] = heap_[heap_len_--];
- pqdownheap(tree, kSmallest);
-}
-
-/* Compute the optimal bit lengths for a tree and update the total bit length
- for the current block.
- IN assertion: the fields freq and dad are set, heap[heap_max] and
- above are the tree nodes sorted by increasing frequency.
- OUT assertions: the field len is set to the optimal bit length, the
- array bl_count contains the frequencies for each bit length.
- The length opt_len is updated; static_len is also updated if stree is
- not null.
-*/
-template<class>
-void
-deflate_stream::
-gen_bitlen(tree_desc *desc)
-{
- ct_data *tree = desc->dyn_tree;
- int max_code = desc->max_code;
- ct_data const* stree = desc->stat_desc->static_tree;
- std::uint8_t const *extra = desc->stat_desc->extra_bits;
- int base = desc->stat_desc->extra_base;
- int max_length = desc->stat_desc->max_length;
- int h; // heap index
- int n, m; // iterate over the tree elements
- int bits; // bit length
- int xbits; // extra bits
- std::uint16_t f; // frequency
- int overflow = 0; // number of elements with bit length too large
-
- std::fill(&bl_count_[0], &bl_count_[maxBits+1], std::uint16_t{0});
-
- /* In a first pass, compute the optimal bit lengths (which may
- * overflow in the case of the bit length tree).
- */
- tree[heap_[heap_max_]].dl = 0; // root of the heap
-
- for(h = heap_max_+1; h < HEAP_SIZE; h++) {
- n = heap_[h];
- bits = tree[tree[n].dl].dl + 1;
- if(bits > max_length) bits = max_length, overflow++;
- // We overwrite tree[n].dl which is no longer needed
- tree[n].dl = (std::uint16_t)bits;
-
- if(n > max_code)
- continue; // not a leaf node
-
- bl_count_[bits]++;
- xbits = 0;
- if(n >= base)
- xbits = extra[n-base];
- f = tree[n].fc;
- opt_len_ += (std::uint32_t)f * (bits + xbits);
- if(stree)
- static_len_ += (std::uint32_t)f * (stree[n].dl + xbits);
- }
- if(overflow == 0)
- return;
-
- // Find the first bit length which could increase:
- do
- {
- bits = max_length-1;
- while(bl_count_[bits] == 0)
- bits--;
- bl_count_[bits]--; // move one leaf down the tree
- bl_count_[bits+1] += 2; // move one overflow item as its brother
- bl_count_[max_length]--;
- /* The brother of the overflow item also moves one step up,
- * but this does not affect bl_count[max_length]
- */
- overflow -= 2;
- }
- while(overflow > 0);
-
- /* Now recompute all bit lengths, scanning in increasing frequency.
- * h is still equal to HEAP_SIZE. (It is simpler to reconstruct all
- * lengths instead of fixing only the wrong ones. This idea is taken
- * from 'ar' written by Haruhiko Okumura.)
- */
- for(bits = max_length; bits != 0; bits--)
- {
- n = bl_count_[bits];
- while(n != 0)
- {
- m = heap_[--h];
- if(m > max_code)
- continue;
- if((unsigned) tree[m].dl != (unsigned) bits)
- {
- opt_len_ += ((long)bits - (long)tree[m].dl) *(long)tree[m].fc;
- tree[m].dl = (std::uint16_t)bits;
- }
- n--;
- }
- }
-}
-
-/* Construct one Huffman tree and assigns the code bit strings and lengths.
- Update the total bit length for the current block.
- IN assertion: the field freq is set for all tree elements.
- OUT assertions: the fields len and code are set to the optimal bit length
- and corresponding code. The length opt_len is updated; static_len is
- also updated if stree is not null. The field max_code is set.
-*/
-template<class>
-void
-deflate_stream::
-build_tree(tree_desc *desc)
-{
- ct_data *tree = desc->dyn_tree;
- ct_data const* stree = desc->stat_desc->static_tree;
- int elems = desc->stat_desc->elems;
- int n, m; // iterate over heap elements
- int max_code = -1; // largest code with non zero frequency
- int node; // new node being created
-
- /* Construct the initial heap, with least frequent element in
- * heap[kSmallest]. The sons of heap[n] are heap[2*n] and heap[2*n+1].
- * heap[0] is not used.
- */
- heap_len_ = 0;
- heap_max_ = HEAP_SIZE;
-
- for(n = 0; n < elems; n++)
- {
- if(tree[n].fc != 0)
- {
- heap_[++(heap_len_)] = max_code = n;
- depth_[n] = 0;
- }
- else
- {
- tree[n].dl = 0;
- }
- }
-
- /* The pkzip format requires that at least one distance code exists,
- * and that at least one bit should be sent even if there is only one
- * possible code. So to avoid special checks later on we force at least
- * two codes of non zero frequency.
- */
- while(heap_len_ < 2)
- {
- node = heap_[++(heap_len_)] = (max_code < 2 ? ++max_code : 0);
- tree[node].fc = 1;
- depth_[node] = 0;
- opt_len_--;
- if(stree)
- static_len_ -= stree[node].dl;
- // node is 0 or 1 so it does not have extra bits
- }
- desc->max_code = max_code;
-
- /* The elements heap[heap_len/2+1 .. heap_len] are leaves of the tree,
- * establish sub-heaps of increasing lengths:
- */
- for(n = heap_len_/2; n >= 1; n--)
- pqdownheap(tree, n);
-
- /* Construct the Huffman tree by repeatedly combining the least two
- * frequent nodes.
- */
- node = elems; /* next internal node of the tree */
- do
- {
- pqremove(tree, n); /* n = node of least frequency */
- m = heap_[kSmallest]; /* m = node of next least frequency */
-
- heap_[--(heap_max_)] = n; /* keep the nodes sorted by frequency */
- heap_[--(heap_max_)] = m;
-
- /* Create a new node father of n and m */
- tree[node].fc = tree[n].fc + tree[m].fc;
- depth_[node] = (std::uint8_t)((depth_[n] >= depth_[m] ?
- depth_[n] : depth_[m]) + 1);
- tree[n].dl = tree[m].dl = (std::uint16_t)node;
- /* and insert the new node in the heap */
- heap_[kSmallest] = node++;
- pqdownheap(tree, kSmallest);
-
- }
- while(heap_len_ >= 2);
-
- heap_[--(heap_max_)] = heap_[kSmallest];
-
- /* At this point, the fields freq and dad are set. We can now
- * generate the bit lengths.
- */
- gen_bitlen((tree_desc *)desc);
-
- /* The field len is now set, we can generate the bit codes */
- gen_codes(tree, max_code, bl_count_);
-}
-
-/* Scan a literal or distance tree to determine the frequencies
- of the codes in the bit length tree.
-*/
-template<class>
-void
-deflate_stream::
-scan_tree(
- ct_data *tree, // the tree to be scanned
- int max_code) // and its largest code of non zero frequency
-{
- int n; // iterates over all tree elements
- int prevlen = -1; // last emitted length
- int curlen; // length of current code
- int nextlen = tree[0].dl; // length of next code
- std::uint16_t count = 0; // repeat count of the current code
- int max_count = 7; // max repeat count
- int min_count = 4; // min repeat count
-
- if(nextlen == 0)
- {
- max_count = 138;
- min_count = 3;
- }
- tree[max_code+1].dl = (std::uint16_t)0xffff; // guard
-
- for(n = 0; n <= max_code; n++)
- {
- curlen = nextlen; nextlen = tree[n+1].dl;
- if(++count < max_count && curlen == nextlen)
- {
- continue;
- }
- else if(count < min_count)
- {
- bl_tree_[curlen].fc += count;
- }
- else if(curlen != 0)
- {
- if(curlen != prevlen) bl_tree_[curlen].fc++;
- bl_tree_[REP_3_6].fc++;
- }
- else if(count <= 10)
- {
- bl_tree_[REPZ_3_10].fc++;
- }
- else
- {
- bl_tree_[REPZ_11_138].fc++;
- }
- count = 0;
- prevlen = curlen;
- if(nextlen == 0)
- {
- max_count = 138;
- min_count = 3;
- }
- else if(curlen == nextlen)
- {
- max_count = 6;
- min_count = 3;
- }
- else
- {
- max_count = 7;
- min_count = 4;
- }
- }
-}
-
-/* Send a literal or distance tree in compressed form,
- using the codes in bl_tree.
-*/
-template<class>
-void
-deflate_stream::
-send_tree(
- ct_data *tree, // the tree to be scanned
- int max_code) // and its largest code of non zero frequency
-{
- int n; // iterates over all tree elements
- int prevlen = -1; // last emitted length
- int curlen; // length of current code
- int nextlen = tree[0].dl; // length of next code
- int count = 0; // repeat count of the current code
- int max_count = 7; // max repeat count
- int min_count = 4; // min repeat count
-
- // tree[max_code+1].dl = -1; // guard already set
- if(nextlen == 0)
- {
- max_count = 138;
- min_count = 3;
- }
-
- for(n = 0; n <= max_code; n++)
- {
- curlen = nextlen;
- nextlen = tree[n+1].dl;
- if(++count < max_count && curlen == nextlen)
- {
- continue;
- }
- else if(count < min_count)
- {
- do
- {
- send_code(curlen, bl_tree_);
- }
- while (--count != 0);
- }
- else if(curlen != 0)
- {
- if(curlen != prevlen)
- {
- send_code(curlen, bl_tree_);
- count--;
- }
- BOOST_ASSERT(count >= 3 && count <= 6);
- send_code(REP_3_6, bl_tree_);
- send_bits(count-3, 2);
- }
- else if(count <= 10)
- {
- send_code(REPZ_3_10, bl_tree_);
- send_bits(count-3, 3);
- }
- else
- {
- send_code(REPZ_11_138, bl_tree_);
- send_bits(count-11, 7);
- }
- count = 0;
- prevlen = curlen;
- if(nextlen == 0)
- {
- max_count = 138;
- min_count = 3;
- }
- else if(curlen == nextlen)
- {
- max_count = 6;
- min_count = 3;
- }
- else
- {
- max_count = 7;
- min_count = 4;
- }
- }
-}
-
-/* Construct the Huffman tree for the bit lengths and return
- the index in bl_order of the last bit length code to send.
-*/
-template<class>
-int
-deflate_stream::
-build_bl_tree()
-{
- int max_blindex; // index of last bit length code of non zero freq
-
- // Determine the bit length frequencies for literal and distance trees
- scan_tree((ct_data *)dyn_ltree_, l_desc_.max_code);
- scan_tree((ct_data *)dyn_dtree_, d_desc_.max_code);
-
- // Build the bit length tree:
- build_tree((tree_desc *)(&(bl_desc_)));
- /* opt_len now includes the length of the tree representations, except
- * the lengths of the bit lengths codes and the 5+5+4 bits for the counts.
- */
-
- /* Determine the number of bit length codes to send. The pkzip format
- * requires that at least 4 bit length codes be sent. (appnote.txt says
- * 3 but the actual value used is 4.)
- */
- for(max_blindex = blCodes-1; max_blindex >= 3; max_blindex--)
- {
- if(bl_tree_[lut_.bl_order[max_blindex]].dl != 0)
- break;
- }
- // Update opt_len to include the bit length tree and counts
- opt_len_ += 3*(max_blindex+1) + 5+5+4;
- return max_blindex;
-}
-
-/* Send the header for a block using dynamic Huffman trees: the counts,
- the lengths of the bit length codes, the literal tree and the distance
- tree.
- IN assertion: lcodes >= 257, dcodes >= 1, blcodes >= 4.
-*/
-template<class>
-void
-deflate_stream::
-send_all_trees(
- int lcodes,
- int dcodes,
- int blcodes) // number of codes for each tree
-{
- int rank; // index in bl_order
-
- BOOST_ASSERT(lcodes >= 257 && dcodes >= 1 && blcodes >= 4);
- BOOST_ASSERT(lcodes <= lCodes && dcodes <= dCodes && blcodes <= blCodes);
- send_bits(lcodes-257, 5); // not +255 as stated in appnote.txt
- send_bits(dcodes-1, 5);
- send_bits(blcodes-4, 4); // not -3 as stated in appnote.txt
- for(rank = 0; rank < blcodes; rank++)
- send_bits(bl_tree_[lut_.bl_order[rank]].dl, 3);
- send_tree((ct_data *)dyn_ltree_, lcodes-1); // literal tree
- send_tree((ct_data *)dyn_dtree_, dcodes-1); // distance tree
-}
-
-/* Send the block data compressed using the given Huffman trees
-*/
-template<class>
-void
-deflate_stream::
-compress_block(
- ct_data const* ltree, // literal tree
- ct_data const* dtree) // distance tree
-{
- unsigned dist; /* distance of matched string */
- int lc; /* match length or unmatched char (if dist == 0) */
- unsigned lx = 0; /* running index in l_buf */
- unsigned code; /* the code to send */
- int extra; /* number of extra bits to send */
-
- if(last_lit_ != 0)
- {
- do
- {
- dist = d_buf_[lx];
- lc = l_buf_[lx++];
- if(dist == 0)
- {
- send_code(lc, ltree); /* send a literal byte */
- }
- else
- {
- /* Here, lc is the match length - minMatch */
- code = lut_.length_code[lc];
- send_code(code+literals+1, ltree); /* send the length code */
- extra = lut_.extra_lbits[code];
- if(extra != 0)
- {
- lc -= lut_.base_length[code];
- send_bits(lc, extra); /* send the extra length bits */
- }
- dist--; /* dist is now the match distance - 1 */
- code = d_code(dist);
- BOOST_ASSERT(code < dCodes);
-
- send_code(code, dtree); /* send the distance code */
- extra = lut_.extra_dbits[code];
- if(extra != 0)
- {
- dist -= lut_.base_dist[code];
- send_bits(dist, extra); /* send the extra distance bits */
- }
- } /* literal or match pair ? */
-
- /* Check that the overlay between pending_buf and d_buf+l_buf is ok: */
- BOOST_ASSERT((uInt)(pending_) < lit_bufsize_ + 2*lx);
- }
- while(lx < last_lit_);
- }
-
- send_code(END_BLOCK, ltree);
-}
-
-/* Check if the data type is TEXT or BINARY, using the following algorithm:
- - TEXT if the two conditions below are satisfied:
- a) There are no non-portable control characters belonging to the
- "black list" (0..6, 14..25, 28..31).
- b) There is at least one printable character belonging to the
- "white list" (9 {TAB}, 10 {LF}, 13 {CR}, 32..255).
- - BINARY otherwise.
- - The following partially-portable control characters form a
- "gray list" that is ignored in this detection algorithm:
- (7 {BEL}, 8 {BS}, 11 {VT}, 12 {FF}, 26 {SUB}, 27 {ESC}).
- IN assertion: the fields fc of dyn_ltree are set.
-*/
-template<class>
-int
-deflate_stream::
-detect_data_type()
-{
- /* black_mask is the bit mask of black-listed bytes
- * set bits 0..6, 14..25, and 28..31
- * 0xf3ffc07f = binary 11110011111111111100000001111111
- */
- unsigned long black_mask = 0xf3ffc07fUL;
- int n;
-
- // Check for non-textual ("black-listed") bytes.
- for(n = 0; n <= 31; n++, black_mask >>= 1)
- if((black_mask & 1) && (dyn_ltree_[n].fc != 0))
- return binary;
-
- // Check for textual ("white-listed") bytes. */
- if(dyn_ltree_[9].fc != 0 || dyn_ltree_[10].fc != 0
- || dyn_ltree_[13].fc != 0)
- return text;
- for(n = 32; n < literals; n++)
- if(dyn_ltree_[n].fc != 0)
- return text;
-
- /* There are no "black-listed" or "white-listed" bytes:
- * this stream either is empty or has tolerated ("gray-listed") bytes only.
- */
- return binary;
-}
-
-/* Flush the bit buffer and align the output on a byte boundary
-*/
-template<class>
-void
-deflate_stream::
-bi_windup()
-{
- if(bi_valid_ > 8)
- put_short(bi_buf_);
- else if(bi_valid_ > 0)
- put_byte((Byte)bi_buf_);
- bi_buf_ = 0;
- bi_valid_ = 0;
-}
-
-/* Flush the bit buffer, keeping at most 7 bits in it.
-*/
-template<class>
-void
-deflate_stream::
-bi_flush()
-{
- if(bi_valid_ == 16)
- {
- put_short(bi_buf_);
- bi_buf_ = 0;
- bi_valid_ = 0;
- }
- else if(bi_valid_ >= 8)
- {
- put_byte((Byte)bi_buf_);
- bi_buf_ >>= 8;
- bi_valid_ -= 8;
- }
-}
-
-/* Copy a stored block, storing first the length and its
- one's complement if requested.
-*/
-template<class>
-void
-deflate_stream::
-copy_block(
- char *buf, // the input data
- unsigned len, // its length
- int header) // true if block header must be written
-{
- bi_windup(); // align on byte boundary
-
- if(header)
- {
- put_short((std::uint16_t)len);
- put_short((std::uint16_t)~len);
- }
- // VFALCO Use memcpy?
- while (len--)
- put_byte(*buf++);
-}
-
-//------------------------------------------------------------------------------
-
-/* Initialize the tree data structures for a new zlib stream.
-*/
-template<class>
-void
-deflate_stream::
-tr_init()
-{
- l_desc_.dyn_tree = dyn_ltree_;
- l_desc_.stat_desc = &lut_.l_desc;
-
- d_desc_.dyn_tree = dyn_dtree_;
- d_desc_.stat_desc = &lut_.d_desc;
-
- bl_desc_.dyn_tree = bl_tree_;
- bl_desc_.stat_desc = &lut_.bl_desc;
-
- bi_buf_ = 0;
- bi_valid_ = 0;
-
- // Initialize the first block of the first file:
- init_block();
-}
-
-/* Send one empty static block to give enough lookahead for inflate.
- This takes 10 bits, of which 7 may remain in the bit buffer.
-*/
-template<class>
-void
-deflate_stream::
-tr_align()
-{
- send_bits(STATIC_TREES<<1, 3);
- send_code(END_BLOCK, lut_.ltree);
- bi_flush();
-}
-
-/* Flush the bits in the bit buffer to pending output (leaves at most 7 bits)
-*/
-template<class>
-void
-deflate_stream::
-tr_flush_bits()
-{
- bi_flush();
-}
-
-/* Send a stored block
-*/
-template<class>
-void
-deflate_stream::
-tr_stored_block(
- char *buf, // input block
- std::uint32_t stored_len, // length of input block
- int last) // one if this is the last block for a file
-{
- send_bits((STORED_BLOCK<<1)+last, 3); // send block type
- copy_block(buf, (unsigned)stored_len, 1); // with header
-}
-
-template<class>
-inline
-void
-deflate_stream::
-tr_tally_dist(std::uint16_t dist, std::uint8_t len, bool& flush)
-{
- d_buf_[last_lit_] = dist;
- l_buf_[last_lit_++] = len;
- dist--;
- dyn_ltree_[lut_.length_code[len]+literals+1].fc++;
- dyn_dtree_[d_code(dist)].fc++;
- flush = (last_lit_ == lit_bufsize_-1);
-}
-
-template<class>
-inline
-void
-deflate_stream::
-tr_tally_lit(std::uint8_t c, bool& flush)
-{
- d_buf_[last_lit_] = 0;
- l_buf_[last_lit_++] = c;
- dyn_ltree_[c].fc++;
- flush = (last_lit_ == lit_bufsize_-1);
-}
-
-//------------------------------------------------------------------------------
-
-/* Determine the best encoding for the current block: dynamic trees,
- static trees or store, and output the encoded block to the zip file.
-*/
-template<class>
-void
-deflate_stream::
-tr_flush_block(
- z_params& zs,
- char *buf, // input block, or NULL if too old
- std::uint32_t stored_len, // length of input block
- int last) // one if this is the last block for a file
-{
- std::uint32_t opt_lenb;
- std::uint32_t static_lenb; // opt_len and static_len in bytes
- int max_blindex = 0; // index of last bit length code of non zero freq
-
- // Build the Huffman trees unless a stored block is forced
- if(level_ > 0)
- {
- // Check if the file is binary or text
- if(zs.data_type == unknown)
- zs.data_type = detect_data_type();
-
- // Construct the literal and distance trees
- build_tree((tree_desc *)(&(l_desc_)));
-
- build_tree((tree_desc *)(&(d_desc_)));
- /* At this point, opt_len and static_len are the total bit lengths of
- * the compressed block data, excluding the tree representations.
- */
-
- /* Build the bit length tree for the above two trees, and get the index
- * in bl_order of the last bit length code to send.
- */
- max_blindex = build_bl_tree();
-
- /* Determine the best encoding. Compute the block lengths in bytes. */
- opt_lenb = (opt_len_+3+7)>>3;
- static_lenb = (static_len_+3+7)>>3;
-
- if(static_lenb <= opt_lenb)
- opt_lenb = static_lenb;
- }
- else
- {
- // VFALCO This assertion fails even in the original ZLib,
- // happens with strategy == Z_HUFFMAN_ONLY, see:
- // https://github.com/madler/zlib/issues/172
-
- #if 0
- BOOST_ASSERT(buf);
- #endif
- opt_lenb = static_lenb = stored_len + 5; // force a stored block
- }
-
-#ifdef FORCE_STORED
- if(buf != (char*)0) { /* force stored block */
-#else
- if(stored_len+4 <= opt_lenb && buf != (char*)0) {
- /* 4: two words for the lengths */
-#endif
- /* The test buf != NULL is only necessary if LIT_BUFSIZE > WSIZE.
- * Otherwise we can't have processed more than WSIZE input bytes since
- * the last block flush, because compression would have been
- * successful. If LIT_BUFSIZE <= WSIZE, it is never too late to
- * transform a block into a stored block.
- */
- tr_stored_block(buf, stored_len, last);
-
-#ifdef FORCE_STATIC
- }
- else if(static_lenb >= 0)
- {
- // force static trees
-#else
- }
- else if(strategy_ == Strategy::fixed || static_lenb == opt_lenb)
- {
-#endif
- send_bits((STATIC_TREES<<1)+last, 3);
- compress_block(lut_.ltree, lut_.dtree);
- }
- else
- {
- send_bits((DYN_TREES<<1)+last, 3);
- send_all_trees(l_desc_.max_code+1, d_desc_.max_code+1,
- max_blindex+1);
- compress_block((const ct_data *)dyn_ltree_,
- (const ct_data *)dyn_dtree_);
- }
- /* The above check is made mod 2^32, for files larger than 512 MB
- * and std::size_t implemented on 32 bits.
- */
- init_block();
-
- if(last)
- bi_windup();
-}
-
-template<class>
-void
-deflate_stream::
-fill_window(z_params& zs)
-{
- unsigned n, m;
- unsigned more; // Amount of free space at the end of the window.
- std::uint16_t *p;
- uInt wsize = w_size_;
-
- do
- {
- more = (unsigned)(window_size_ -
- (std::uint32_t)lookahead_ -(std::uint32_t)strstart_);
-
- // VFALCO We don't support systems below 32-bit
- #if 0
- // Deal with !@#$% 64K limit:
- if(sizeof(int) <= 2)
- {
- if(more == 0 && strstart_ == 0 && lookahead_ == 0)
- {
- more = wsize;
- }
- else if(more == (unsigned)(-1))
- {
- /* Very unlikely, but possible on 16 bit machine if
- * strstart == 0 && lookahead == 1 (input done a byte at time)
- */
- more--;
- }
- }
- #endif
-
- /* If the window is almost full and there is insufficient lookahead,
- move the upper half to the lower one to make room in the upper half.
- */
- if(strstart_ >= wsize+max_dist())
- {
- std::memcpy(window_, window_+wsize, (unsigned)wsize);
- match_start_ -= wsize;
- strstart_ -= wsize; // we now have strstart >= max_dist
- block_start_ -= (long) wsize;
-
- /* Slide the hash table (could be avoided with 32 bit values
- at the expense of memory usage). We slide even when level == 0
- to keep the hash table consistent if we switch back to level > 0
- later. (Using level 0 permanently is not an optimal usage of
- zlib, so we don't care about this pathological case.)
- */
- n = hash_size_;
- p = &head_[n];
- do
- {
- m = *--p;
- *p = (std::uint16_t)(m >= wsize ? m-wsize : 0);
- }
- while(--n);
-
- n = wsize;
- p = &prev_[n];
- do
- {
- m = *--p;
- *p = (std::uint16_t)(m >= wsize ? m-wsize : 0);
- /* If n is not on any hash chain, prev[n] is garbage but
- its value will never be used.
- */
- }
- while(--n);
- more += wsize;
- }
- if(zs.avail_in == 0)
- break;
-
- /* If there was no sliding:
- strstart <= WSIZE+max_dist-1 && lookahead <= kMinLookahead - 1 &&
- more == window_size - lookahead - strstart
- => more >= window_size - (kMinLookahead-1 + WSIZE + max_dist-1)
- => more >= window_size - 2*WSIZE + 2
- In the BIG_MEM or MMAP case (not yet supported),
- window_size == input_size + kMinLookahead &&
- strstart + lookahead_ <= input_size => more >= kMinLookahead.
- Otherwise, window_size == 2*WSIZE so more >= 2.
- If there was sliding, more >= WSIZE. So in all cases, more >= 2.
- */
- n = read_buf(zs, window_ + strstart_ + lookahead_, more);
- lookahead_ += n;
-
- // Initialize the hash value now that we have some input:
- if(lookahead_ + insert_ >= minMatch)
- {
- uInt str = strstart_ - insert_;
- ins_h_ = window_[str];
- update_hash(ins_h_, window_[str + 1]);
- while(insert_)
- {
- update_hash(ins_h_, window_[str + minMatch-1]);
- prev_[str & w_mask_] = head_[ins_h_];
- head_[ins_h_] = (std::uint16_t)str;
- str++;
- insert_--;
- if(lookahead_ + insert_ < minMatch)
- break;
- }
- }
- /* If the whole input has less than minMatch bytes, ins_h is garbage,
- but this is not important since only literal bytes will be emitted.
- */
- }
- while(lookahead_ < kMinLookahead && zs.avail_in != 0);
-
- /* If the kWinInit bytes after the end of the current data have never been
- written, then zero those bytes in order to avoid memory check reports of
- the use of uninitialized (or uninitialised as Julian writes) bytes by
- the longest match routines. Update the high water mark for the next
- time through here. kWinInit is set to maxMatch since the longest match
- routines allow scanning to strstart + maxMatch, ignoring lookahead.
- */
- if(high_water_ < window_size_)
- {
- std::uint32_t curr = strstart_ + (std::uint32_t)(lookahead_);
- std::uint32_t winit;
-
- if(high_water_ < curr)
- {
- /* Previous high water mark below current data -- zero kWinInit
- bytes or up to end of window, whichever is less.
- */
- winit = window_size_ - curr;
- if(winit > kWinInit)
- winit = kWinInit;
- std::memset(window_ + curr, 0, (unsigned)winit);
- high_water_ = curr + winit;
- }
- else if(high_water_ < (std::uint32_t)curr + kWinInit)
- {
- /* High water mark at or above current data, but below current data
- plus kWinInit -- zero out to current data plus kWinInit, or up
- to end of window, whichever is less.
- */
- winit = (std::uint32_t)curr + kWinInit - high_water_;
- if(winit > window_size_ - high_water_)
- winit = window_size_ - high_water_;
- std::memset(window_ + high_water_, 0, (unsigned)winit);
- high_water_ += winit;
- }
- }
-}
-
-/* Flush as much pending output as possible. All write() output goes
- through this function so some applications may wish to modify it
- to avoid allocating a large strm->next_out buffer and copying into it.
- (See also read_buf()).
-*/
-template<class>
-void
-deflate_stream::
-flush_pending(z_params& zs)
-{
- tr_flush_bits();
- auto len = clamp(pending_, zs.avail_out);
- if(len == 0)
- return;
-
- std::memcpy(zs.next_out, pending_out_, len);
- zs.next_out =
- static_cast<std::uint8_t*>(zs.next_out) + len;
- pending_out_ += len;
- zs.total_out += len;
- zs.avail_out -= len;
- pending_ -= len;
- if(pending_ == 0)
- pending_out_ = pending_buf_;
-}
-
-/* Flush the current block, with given end-of-file flag.
- IN assertion: strstart is set to the end of the current match.
-*/
-template<class>
-inline
-void
-deflate_stream::
-flush_block(z_params& zs, bool last)
-{
- tr_flush_block(zs,
- (block_start_ >= 0L ?
- (char *)&window_[(unsigned)block_start_] :
- (char *)0),
- (std::uint32_t)((long)strstart_ - block_start_),
- last);
- block_start_ = strstart_;
- flush_pending(zs);
-}
-
-/* Read a new buffer from the current input stream, update the adler32
- and total number of bytes read. All write() input goes through
- this function so some applications may wish to modify it to avoid
- allocating a large strm->next_in buffer and copying from it.
- (See also flush_pending()).
-*/
-template<class>
-int
-deflate_stream::
-read_buf(z_params& zs, Byte *buf, unsigned size)
-{
- auto len = clamp(zs.avail_in, size);
- if(len == 0)
- return 0;
-
- zs.avail_in -= len;
-
- std::memcpy(buf, zs.next_in, len);
- zs.next_in = static_cast<
- std::uint8_t const*>(zs.next_in) + len;
- zs.total_in += len;
- return (int)len;
-}
-
-/* Set match_start to the longest match starting at the given string and
- return its length. Matches shorter or equal to prev_length are discarded,
- in which case the result is equal to prev_length and match_start is
- garbage.
- IN assertions: cur_match is the head of the hash chain for the current
- string (strstart) and its distance is <= max_dist, and prev_length >= 1
- OUT assertion: the match length is not greater than s->lookahead_.
-
- For 80x86 and 680x0, an optimized version will be provided in match.asm or
- match.S. The code will be functionally equivalent.
-*/
-template<class>
-uInt
-deflate_stream::
-longest_match(IPos cur_match)
-{
- unsigned chain_length = max_chain_length_;/* max hash chain length */
- Byte *scan = window_ + strstart_; /* current string */
- Byte *match; /* matched string */
- int len; /* length of current match */
- int best_len = prev_length_; /* best match length so far */
- int nice_match = nice_match_; /* stop if match long enough */
- IPos limit = strstart_ > (IPos)max_dist() ?
- strstart_ - (IPos)max_dist() : 0;
- /* Stop when cur_match becomes <= limit. To simplify the code,
- * we prevent matches with the string of window index 0.
- */
- std::uint16_t *prev = prev_;
- uInt wmask = w_mask_;
-
- Byte *strend = window_ + strstart_ + maxMatch;
- Byte scan_end1 = scan[best_len-1];
- Byte scan_end = scan[best_len];
-
- /* The code is optimized for HASH_BITS >= 8 and maxMatch-2 multiple of 16.
- * It is easy to get rid of this optimization if necessary.
- */
- BOOST_ASSERT(hash_bits_ >= 8 && maxMatch == 258);
-
- /* Do not waste too much time if we already have a good match: */
- if(prev_length_ >= good_match_) {
- chain_length >>= 2;
- }
- /* Do not look for matches beyond the end of the input. This is necessary
- * to make deflate deterministic.
- */
- if((uInt)nice_match > lookahead_)
- nice_match = lookahead_;
-
- BOOST_ASSERT((std::uint32_t)strstart_ <= window_size_-kMinLookahead);
-
- do {
- BOOST_ASSERT(cur_match < strstart_);
- match = window_ + cur_match;
-
- /* Skip to next match if the match length cannot increase
- * or if the match length is less than 2. Note that the checks below
- * for insufficient lookahead only occur occasionally for performance
- * reasons. Therefore uninitialized memory will be accessed, and
- * conditional jumps will be made that depend on those values.
- * However the length of the match is limited to the lookahead, so
- * the output of deflate is not affected by the uninitialized values.
- */
- if( match[best_len] != scan_end ||
- match[best_len-1] != scan_end1 ||
- *match != *scan ||
- *++match != scan[1])
- continue;
-
- /* The check at best_len-1 can be removed because it will be made
- * again later. (This heuristic is not always a win.)
- * It is not necessary to compare scan[2] and match[2] since they
- * are always equal when the other bytes match, given that
- * the hash keys are equal and that HASH_BITS >= 8.
- */
- scan += 2, match++;
- BOOST_ASSERT(*scan == *match);
-
- /* We check for insufficient lookahead only every 8th comparison;
- * the 256th check will be made at strstart+258.
- */
- do
- {
- }
- while( *++scan == *++match && *++scan == *++match &&
- *++scan == *++match && *++scan == *++match &&
- *++scan == *++match && *++scan == *++match &&
- *++scan == *++match && *++scan == *++match &&
- scan < strend);
-
- BOOST_ASSERT(scan <= window_+(unsigned)(window_size_-1));
-
- len = maxMatch - (int)(strend - scan);
- scan = strend - maxMatch;
-
- if(len > best_len) {
- match_start_ = cur_match;
- best_len = len;
- if(len >= nice_match) break;
- scan_end1 = scan[best_len-1];
- scan_end = scan[best_len];
- }
- }
- while((cur_match = prev[cur_match & wmask]) > limit
- && --chain_length != 0);
-
- if((uInt)best_len <= lookahead_)
- return (uInt)best_len;
- return lookahead_;
-}
-
-//------------------------------------------------------------------------------
-
-/* Copy without compression as much as possible from the input stream, return
- the current block state.
- This function does not insert new strings in the dictionary since
- uncompressible data is probably not useful. This function is used
- only for the level=0 compression option.
- NOTE: this function should be optimized to avoid extra copying from
- window to pending_buf.
-*/
-template<class>
-inline
-auto
-deflate_stream::
-f_stored(z_params& zs, Flush flush) ->
- block_state
-{
- /* Stored blocks are limited to 0xffff bytes, pending_buf is limited
- * to pending_buf_size, and each stored block has a 5 byte header:
- */
- std::uint32_t max_block_size = 0xffff;
- std::uint32_t max_start;
-
- if(max_block_size > pending_buf_size_ - 5) {
- max_block_size = pending_buf_size_ - 5;
- }
-
- /* Copy as much as possible from input to output: */
- for(;;) {
- /* Fill the window as much as possible: */
- if(lookahead_ <= 1) {
-
- BOOST_ASSERT(strstart_ < w_size_+max_dist() ||
- block_start_ >= (long)w_size_);
-
- fill_window(zs);
- if(lookahead_ == 0 && flush == Flush::none)
- return need_more;
-
- if(lookahead_ == 0) break; /* flush the current block */
- }
- BOOST_ASSERT(block_start_ >= 0L);
-
- strstart_ += lookahead_;
- lookahead_ = 0;
-
- /* Emit a stored block if pending_buf will be full: */
- max_start = block_start_ + max_block_size;
- if(strstart_ == 0 || (std::uint32_t)strstart_ >= max_start) {
- /* strstart == 0 is possible when wraparound on 16-bit machine */
- lookahead_ = (uInt)(strstart_ - max_start);
- strstart_ = (uInt)max_start;
- flush_block(zs, false);
- if(zs.avail_out == 0)
- return need_more;
- }
- /* Flush if we may have to slide, otherwise block_start may become
- * negative and the data will be gone:
- */
- if(strstart_ - (uInt)block_start_ >= max_dist()) {
- flush_block(zs, false);
- if(zs.avail_out == 0)
- return need_more;
- }
- }
- insert_ = 0;
- if(flush == Flush::finish)
- {
- flush_block(zs, true);
- if(zs.avail_out == 0)
- return finish_started;
- return finish_done;
- }
- if((long)strstart_ > block_start_)
- {
- flush_block(zs, false);
- if(zs.avail_out == 0)
- return need_more;
- }
- return block_done;
-}
-
-/* Compress as much as possible from the input stream, return the current
- block state.
- This function does not perform lazy evaluation of matches and inserts
- new strings in the dictionary only for unmatched strings or for short
- matches. It is used only for the fast compression options.
-*/
-template<class>
-inline
-auto
-deflate_stream::
-f_fast(z_params& zs, Flush flush) ->
- block_state
-{
- IPos hash_head; /* head of the hash chain */
- bool bflush; /* set if current block must be flushed */
-
- for(;;)
- {
- /* Make sure that we always have enough lookahead, except
- * at the end of the input file. We need maxMatch bytes
- * for the next match, plus minMatch bytes to insert the
- * string following the next match.
- */
- if(lookahead_ < kMinLookahead)
- {
- fill_window(zs);
- if(lookahead_ < kMinLookahead && flush == Flush::none)
- return need_more;
- if(lookahead_ == 0)
- break; /* flush the current block */
- }
-
- /* Insert the string window[strstart .. strstart+2] in the
- * dictionary, and set hash_head to the head of the hash chain:
- */
- hash_head = 0;
- if(lookahead_ >= minMatch) {
- insert_string(hash_head);
- }
-
- /* Find the longest match, discarding those <= prev_length.
- * At this point we have always match_length < minMatch
- */
- if(hash_head != 0 && strstart_ - hash_head <= max_dist()) {
- /* To simplify the code, we prevent matches with the string
- * of window index 0 (in particular we have to avoid a match
- * of the string with itself at the start of the input file).
- */
- match_length_ = longest_match (hash_head);
- /* longest_match() sets match_start */
- }
- if(match_length_ >= minMatch)
- {
- tr_tally_dist(static_cast<std::uint16_t>(strstart_ - match_start_),
- static_cast<std::uint8_t>(match_length_ - minMatch), bflush);
-
- lookahead_ -= match_length_;
-
- /* Insert new strings in the hash table only if the match length
- * is not too large. This saves time but degrades compression.
- */
- if(match_length_ <= max_lazy_match_ &&
- lookahead_ >= minMatch) {
- match_length_--; /* string at strstart already in table */
- do
- {
- strstart_++;
- insert_string(hash_head);
- /* strstart never exceeds WSIZE-maxMatch, so there are
- * always minMatch bytes ahead.
- */
- }
- while(--match_length_ != 0);
- strstart_++;
- }
- else
- {
- strstart_ += match_length_;
- match_length_ = 0;
- ins_h_ = window_[strstart_];
- update_hash(ins_h_, window_[strstart_+1]);
- /* If lookahead < minMatch, ins_h is garbage, but it does not
- * matter since it will be recomputed at next deflate call.
- */
- }
- }
- else
- {
- /* No match, output a literal byte */
- tr_tally_lit(window_[strstart_], bflush);
- lookahead_--;
- strstart_++;
- }
- if(bflush)
- {
- flush_block(zs, false);
- if(zs.avail_out == 0)
- return need_more;
- }
- }
- insert_ = strstart_ < minMatch-1 ? strstart_ : minMatch-1;
- if(flush == Flush::finish)
- {
- flush_block(zs, true);
- if(zs.avail_out == 0)
- return finish_started;
- return finish_done;
- }
- if(last_lit_)
- {
- flush_block(zs, false);
- if(zs.avail_out == 0)
- return need_more;
- }
- return block_done;
-}
-
-/* Same as above, but achieves better compression. We use a lazy
- evaluation for matches: a match is finally adopted only if there is
- no better match at the next window position.
-*/
-template<class>
-inline
-auto
-deflate_stream::
-f_slow(z_params& zs, Flush flush) ->
- block_state
-{
- IPos hash_head; /* head of hash chain */
- bool bflush; /* set if current block must be flushed */
-
- /* Process the input block. */
- for(;;)
- {
- /* Make sure that we always have enough lookahead, except
- * at the end of the input file. We need maxMatch bytes
- * for the next match, plus minMatch bytes to insert the
- * string following the next match.
- */
- if(lookahead_ < kMinLookahead)
- {
- fill_window(zs);
- if(lookahead_ < kMinLookahead && flush == Flush::none)
- return need_more;
- if(lookahead_ == 0)
- break; /* flush the current block */
- }
-
- /* Insert the string window[strstart .. strstart+2] in the
- * dictionary, and set hash_head to the head of the hash chain:
- */
- hash_head = 0;
- if(lookahead_ >= minMatch)
- insert_string(hash_head);
-
- /* Find the longest match, discarding those <= prev_length.
- */
- prev_length_ = match_length_, prev_match_ = match_start_;
- match_length_ = minMatch-1;
-
- if(hash_head != 0 && prev_length_ < max_lazy_match_ &&
- strstart_ - hash_head <= max_dist())
- {
- /* To simplify the code, we prevent matches with the string
- * of window index 0 (in particular we have to avoid a match
- * of the string with itself at the start of the input file).
- */
- match_length_ = longest_match(hash_head);
- /* longest_match() sets match_start */
-
- if(match_length_ <= 5 && (strategy_ == Strategy::filtered
- || (match_length_ == minMatch &&
- strstart_ - match_start_ > kTooFar)
- ))
- {
- /* If prev_match is also minMatch, match_start is garbage
- * but we will ignore the current match anyway.
- */
- match_length_ = minMatch-1;
- }
- }
- /* If there was a match at the previous step and the current
- * match is not better, output the previous match:
- */
- if(prev_length_ >= minMatch && match_length_ <= prev_length_)
- {
- /* Do not insert strings in hash table beyond this. */
- uInt max_insert = strstart_ + lookahead_ - minMatch;
-
- tr_tally_dist(
- static_cast<std::uint16_t>(strstart_ -1 - prev_match_),
- static_cast<std::uint8_t>(prev_length_ - minMatch), bflush);
-
- /* Insert in hash table all strings up to the end of the match.
- * strstart-1 and strstart are already inserted. If there is not
- * enough lookahead, the last two strings are not inserted in
- * the hash table.
- */
- lookahead_ -= prev_length_-1;
- prev_length_ -= 2;
- do {
- if(++strstart_ <= max_insert)
- insert_string(hash_head);
- }
- while(--prev_length_ != 0);
- match_available_ = 0;
- match_length_ = minMatch-1;
- strstart_++;
-
- if(bflush)
- {
- flush_block(zs, false);
- if(zs.avail_out == 0)
- return need_more;
- }
-
- }
- else if(match_available_)
- {
- /* If there was no match at the previous position, output a
- * single literal. If there was a match but the current match
- * is longer, truncate the previous match to a single literal.
- */
- tr_tally_lit(window_[strstart_-1], bflush);
- if(bflush)
- flush_block(zs, false);
- strstart_++;
- lookahead_--;
- if(zs.avail_out == 0)
- return need_more;
- }
- else
- {
- /* There is no previous match to compare with, wait for
- * the next step to decide.
- */
- match_available_ = 1;
- strstart_++;
- lookahead_--;
- }
- }
- BOOST_ASSERT(flush != Flush::none);
- if(match_available_)
- {
- tr_tally_lit(window_[strstart_-1], bflush);
- match_available_ = 0;
- }
- insert_ = strstart_ < minMatch-1 ? strstart_ : minMatch-1;
- if(flush == Flush::finish)
- {
- flush_block(zs, true);
- if(zs.avail_out == 0)
- return finish_started;
- return finish_done;
- }
- if(last_lit_)
- {
- flush_block(zs, false);
- if(zs.avail_out == 0)
- return need_more;
- }
- return block_done;
-}
-
-/* For Strategy::rle, simply look for runs of bytes, generate matches only of distance
- one. Do not maintain a hash table. (It will be regenerated if this run of
- deflate switches away from Strategy::rle.)
-*/
-template<class>
-inline
-auto
-deflate_stream::
-f_rle(z_params& zs, Flush flush) ->
- block_state
-{
- bool bflush; // set if current block must be flushed
- uInt prev; // byte at distance one to match
- Byte *scan, *strend; // scan goes up to strend for length of run
-
- for(;;)
- {
- /* Make sure that we always have enough lookahead, except
- * at the end of the input file. We need maxMatch bytes
- * for the longest run, plus one for the unrolled loop.
- */
- if(lookahead_ <= maxMatch) {
- fill_window(zs);
- if(lookahead_ <= maxMatch && flush == Flush::none) {
- return need_more;
- }
- if(lookahead_ == 0) break; /* flush the current block */
- }
-
- /* See how many times the previous byte repeats */
- match_length_ = 0;
- if(lookahead_ >= minMatch && strstart_ > 0) {
- scan = window_ + strstart_ - 1;
- prev = *scan;
- if(prev == *++scan && prev == *++scan && prev == *++scan) {
- strend = window_ + strstart_ + maxMatch;
- do {
- } while(prev == *++scan && prev == *++scan &&
- prev == *++scan && prev == *++scan &&
- prev == *++scan && prev == *++scan &&
- prev == *++scan && prev == *++scan &&
- scan < strend);
- match_length_ = maxMatch - (int)(strend - scan);
- if(match_length_ > lookahead_)
- match_length_ = lookahead_;
- }
- BOOST_ASSERT(scan <= window_+(uInt)(window_size_-1));
- }
-
- /* Emit match if have run of minMatch or longer, else emit literal */
- if(match_length_ >= minMatch) {
- tr_tally_dist(std::uint16_t{1},
- static_cast<std::uint8_t>(match_length_ - minMatch),
- bflush);
-
- lookahead_ -= match_length_;
- strstart_ += match_length_;
- match_length_ = 0;
- } else {
- /* No match, output a literal byte */
- tr_tally_lit(window_[strstart_], bflush);
- lookahead_--;
- strstart_++;
- }
- if(bflush)
- {
- flush_block(zs, false);
- if(zs.avail_out == 0)
- return need_more;
- }
- }
- insert_ = 0;
- if(flush == Flush::finish)
- {
- flush_block(zs, true);
- if(zs.avail_out == 0)
- return finish_started;
- return finish_done;
- }
- if(last_lit_)
- {
- flush_block(zs, false);
- if(zs.avail_out == 0)
- return need_more;
- }
- return block_done;
-}
-
-/* ===========================================================================
- * For Strategy::huffman, do not look for matches. Do not maintain a hash table.
- * (It will be regenerated if this run of deflate switches away from Huffman.)
- */
-template<class>
-inline
-auto
-deflate_stream::
-f_huff(z_params& zs, Flush flush) ->
- block_state
-{
- bool bflush; // set if current block must be flushed
-
- for(;;)
- {
- // Make sure that we have a literal to write.
- if(lookahead_ == 0)
- {
- fill_window(zs);
- if(lookahead_ == 0)
- {
- if(flush == Flush::none)
- return need_more;
- break; // flush the current block
- }
- }
-
- // Output a literal byte
- match_length_ = 0;
- tr_tally_lit(window_[strstart_], bflush);
- lookahead_--;
- strstart_++;
- if(bflush)
- {
- flush_block(zs, false);
- if(zs.avail_out == 0)
- return need_more;
- }
- }
- insert_ = 0;
- if(flush == Flush::finish)
- {
- flush_block(zs, true);
- if(zs.avail_out == 0)
- return finish_started;
- return finish_done;
- }
- if(last_lit_)
- {
- flush_block(zs, false);
- if(zs.avail_out == 0)
- return need_more;
- }
- return block_done;
-}
-
-} // detail
-} // zlib
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/zlib/detail/inflate_stream.hpp b/contrib/restricted/boost/boost/beast/zlib/detail/inflate_stream.hpp
deleted file mode 100644
index 4b40ae11a4..0000000000
--- a/contrib/restricted/boost/boost/beast/zlib/detail/inflate_stream.hpp
+++ /dev/null
@@ -1,1310 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-// This is a derivative work based on Zlib, copyright below:
-/*
- Copyright (C) 1995-2013 Jean-loup Gailly and Mark Adler
-
- This software is provided 'as-is', without any express or implied
- warranty. In no event will the authors be held liable for any damages
- arising from the use of this software.
-
- Permission is granted to anyone to use this software for any purpose,
- including commercial applications, and to alter it and redistribute it
- freely, subject to the following restrictions:
-
- 1. The origin of this software must not be misrepresented; you must not
- claim that you wrote the original software. If you use this software
- in a product, an acknowledgment in the product documentation would be
- appreciated but is not required.
- 2. Altered source versions must be plainly marked as such, and must not be
- misrepresented as being the original software.
- 3. This notice may not be removed or altered from any source distribution.
-
- Jean-loup Gailly Mark Adler
- jloup@gzip.org madler@alumni.caltech.edu
-
- The data format used by the zlib library is described by RFCs (Request for
- Comments) 1950 to 1952 in the files http://tools.ietf.org/html/rfc1950
- (zlib format), rfc1951 (deflate format) and rfc1952 (gzip format).
-*/
-
-#ifndef BOOST_BEAST_ZLIB_DETAIL_INFLATE_STREAM_HPP
-#define BOOST_BEAST_ZLIB_DETAIL_INFLATE_STREAM_HPP
-
-#include <boost/beast/zlib/error.hpp>
-#include <boost/beast/zlib/zlib.hpp>
-#include <boost/beast/zlib/detail/bitstream.hpp>
-#include <boost/beast/zlib/detail/ranges.hpp>
-#include <boost/beast/zlib/detail/window.hpp>
-#include <boost/beast/core/detail/type_traits.hpp>
-#include <boost/throw_exception.hpp>
-#include <algorithm>
-#include <array>
-#include <cstdint>
-#include <cstring>
-#include <stdexcept>
-
-namespace boost {
-namespace beast {
-namespace zlib {
-namespace detail {
-
-class inflate_stream
-{
-protected:
- inflate_stream()
- {
- w_.reset(15);
- }
-
- template<class = void> void doClear();
- template<class = void> void doReset(int windowBits);
- template<class = void> void doWrite(z_params& zs, Flush flush, error_code& ec);
-
- void
- doReset()
- {
- doReset(w_.bits());
- }
-
-private:
- enum Mode
- {
- HEAD, // i: waiting for magic header
- FLAGS, // i: waiting for method and flags (gzip)
- TIME, // i: waiting for modification time (gzip)
- OS, // i: waiting for extra flags and operating system (gzip)
- EXLEN, // i: waiting for extra length (gzip)
- EXTRA, // i: waiting for extra bytes (gzip)
- NAME, // i: waiting for end of file name (gzip)
- COMMENT, // i: waiting for end of comment (gzip)
- HCRC, // i: waiting for header crc (gzip)
- TYPE, // i: waiting for type bits, including last-flag bit
- TYPEDO, // i: same, but skip check to exit inflate on new block
- STORED, // i: waiting for stored size (length and complement)
- COPY_, // i/o: same as COPY below, but only first time in
- COPY, // i/o: waiting for input or output to copy stored block
- TABLE, // i: waiting for dynamic block table lengths
- LENLENS, // i: waiting for code length code lengths
- CODELENS, // i: waiting for length/lit and distance code lengths
- LEN_, // i: same as LEN below, but only first time in
- LEN, // i: waiting for length/lit/eob code
- LENEXT, // i: waiting for length extra bits
- DIST, // i: waiting for distance code
- DISTEXT,// i: waiting for distance extra bits
- MATCH, // o: waiting for output space to copy string
- LIT, // o: waiting for output space to write literal
- CHECK, // i: waiting for 32-bit check value
- LENGTH, // i: waiting for 32-bit length (gzip)
- DONE, // finished check, done -- remain here until reset
- BAD, // got a data error -- remain here until reset
- SYNC // looking for synchronization bytes to restart inflate()
- };
-
- /* Structure for decoding tables. Each entry provides either the
- information needed to do the operation requested by the code that
- indexed that table entry, or it provides a pointer to another
- table that indexes more bits of the code. op indicates whether
- the entry is a pointer to another table, a literal, a length or
- distance, an end-of-block, or an invalid code. For a table
- pointer, the low four bits of op is the number of index bits of
- that table. For a length or distance, the low four bits of op
- is the number of extra bits to get after the code. bits is
- the number of bits in this code or part of the code to drop off
- of the bit buffer. val is the actual byte to output in the case
- of a literal, the base length or distance, or the offset from
- the current table to the next table. Each entry is four bytes.
-
- op values as set by inflate_table():
-
- 00000000 - literal
- 0000tttt - table link, tttt != 0 is the number of table index bits
- 0001eeee - length or distance, eeee is the number of extra bits
- 01100000 - end of block
- 01000000 - invalid code
- */
- struct code
- {
- std::uint8_t op; // operation, extra bits, table bits
- std::uint8_t bits; // bits in this part of the code
- std::uint16_t val; // offset in table or code value
- };
-
- /* Maximum size of the dynamic table. The maximum number of code
- structures is 1444, which is the sum of 852 for literal/length codes
- and 592 for distance codes. These values were found by exhaustive
- searches using the program examples/enough.c found in the zlib
- distribtution. The arguments to that program are the number of
- symbols, the initial root table size, and the maximum bit length
- of a code. "enough 286 9 15" for literal/length codes returns
- returns 852, and "enough 30 6 15" for distance codes returns 592.
- The initial root table size (9 or 6) is found in the fifth argument
- of the inflate_table() calls in inflate.c and infback.c. If the
- root table size is changed, then these maximum sizes would be need
- to be recalculated and updated.
- */
- static std::uint16_t constexpr kEnoughLens = 852;
- static std::uint16_t constexpr kEnoughDists = 592;
- static std::uint16_t constexpr kEnough = kEnoughLens + kEnoughDists;
-
- struct codes
- {
- code const* lencode;
- code const* distcode;
- unsigned lenbits; // VFALCO use std::uint8_t
- unsigned distbits;
- };
-
- // Type of code to build for inflate_table()
- enum class build
- {
- codes,
- lens,
- dists
- };
-
- template<class = void>
- static
- void
- inflate_table(
- build type,
- std::uint16_t* lens,
- std::size_t codes,
- code** table,
- unsigned *bits,
- std::uint16_t* work,
- error_code& ec);
-
- template<class = void>
- static
- codes const&
- get_fixed_tables();
-
- template<class = void>
- void
- fixedTables();
-
- template<class = void>
- void
- inflate_fast(ranges& r, error_code& ec);
-
- bitstream bi_;
-
- Mode mode_ = HEAD; // current inflate mode
- int last_ = 0; // true if processing last block
- unsigned dmax_ = 32768U; // zlib header max distance (INFLATE_STRICT)
-
- // sliding window
- window w_;
-
- // for string and stored block copying
- unsigned length_; // literal or length of data to copy
- unsigned offset_; // distance back to copy string from
-
- // for table and code decoding
- unsigned extra_; // extra bits needed
-
- // dynamic table building
- unsigned ncode_; // number of code length code lengths
- unsigned nlen_; // number of length code lengths
- unsigned ndist_; // number of distance code lengths
- unsigned have_; // number of code lengths in lens[]
- unsigned short lens_[320]; // temporary storage for code lengths
- unsigned short work_[288]; // work area for code table building
- code codes_[kEnough]; // space for code tables
- code *next_ = codes_; // next available space in codes[]
- int back_ = -1; // bits back of last unprocessed length/lit
- unsigned was_; // initial length of match
-
- // fixed and dynamic code tables
- code const* lencode_ = codes_ ; // starting table for length/literal codes
- code const* distcode_ = codes_; // starting table for distance codes
- unsigned lenbits_; // index bits for lencode
- unsigned distbits_; // index bits for distcode
-};
-
-//------------------------------------------------------------------------------
-
-template<class>
-void
-inflate_stream::
-doReset(int windowBits)
-{
- if(windowBits < 8 || windowBits > 15)
- BOOST_THROW_EXCEPTION(std::domain_error{
- "windowBits out of range"});
- w_.reset(windowBits);
-
- bi_.flush();
- mode_ = HEAD;
- last_ = 0;
- dmax_ = 32768U;
- lencode_ = codes_;
- distcode_ = codes_;
- next_ = codes_;
- back_ = -1;
-}
-
-template<class>
-void
-inflate_stream::
-doClear()
-{
-}
-
-template<class>
-void
-inflate_stream::
-doWrite(z_params& zs, Flush flush, error_code& ec)
-{
- ranges r;
- r.in.first = reinterpret_cast<
- std::uint8_t const*>(zs.next_in);
- r.in.last = r.in.first + zs.avail_in;
- r.in.next = r.in.first;
- r.out.first = reinterpret_cast<
- std::uint8_t*>(zs.next_out);
- r.out.last = r.out.first + zs.avail_out;
- r.out.next = r.out.first;
-
- auto const done =
- [&]
- {
- /*
- Return from inflate(), updating the total counts and the check value.
- If there was no progress during the inflate() call, return a buffer
- error. Call updatewindow() to create and/or update the window state.
- Note: a memory error from inflate() is non-recoverable.
- */
-
-
- // VFALCO TODO Don't allocate update the window unless necessary
- if(/*wsize_ ||*/ (r.out.used() && mode_ < BAD &&
- (mode_ < CHECK || flush != Flush::finish)))
- w_.write(r.out.first, r.out.used());
-
- zs.next_in = r.in.next;
- zs.avail_in = r.in.avail();
- zs.next_out = r.out.next;
- zs.avail_out = r.out.avail();
- zs.total_in += r.in.used();
- zs.total_out += r.out.used();
- zs.data_type = bi_.size() + (last_ ? 64 : 0) +
- (mode_ == TYPE ? 128 : 0) +
- (mode_ == LEN_ || mode_ == COPY_ ? 256 : 0);
-
- if(((! r.in.used() && ! r.out.used()) ||
- flush == Flush::finish) && ! ec)
- ec = error::need_buffers;
- };
- auto const err =
- [&](error e)
- {
- ec = e;
- mode_ = BAD;
- };
-
- if(mode_ == TYPE)
- mode_ = TYPEDO;
-
- for(;;)
- {
- switch(mode_)
- {
- case HEAD:
- mode_ = TYPEDO;
- break;
-
- case TYPE:
- if(flush == Flush::block || flush == Flush::trees)
- return done();
- // fall through
-
- case TYPEDO:
- {
- if(last_)
- {
- bi_.flush_byte();
- mode_ = CHECK;
- break;
- }
- if(! bi_.fill(3, r.in.next, r.in.last))
- return done();
- std::uint8_t v;
- bi_.read(v, 1);
- last_ = v != 0;
- bi_.read(v, 2);
- switch(v)
- {
- case 0:
- // uncompressed block
- mode_ = STORED;
- break;
- case 1:
- // fixed Huffman table
- fixedTables();
- mode_ = LEN_; /* decode codes */
- if(flush == Flush::trees)
- return done();
- break;
- case 2:
- // dynamic Huffman table
- mode_ = TABLE;
- break;
-
- default:
- return err(error::invalid_block_type);
- }
- break;
- }
-
- case STORED:
- {
- bi_.flush_byte();
- std::uint32_t v;
- if(! bi_.fill(32, r.in.next, r.in.last))
- return done();
- bi_.peek(v, 32);
- length_ = v & 0xffff;
- if(length_ != ((v >> 16) ^ 0xffff))
- return err(error::invalid_stored_length);
- // flush instead of read, otherwise
- // undefined right shift behavior.
- bi_.flush();
- mode_ = COPY_;
- if(flush == Flush::trees)
- return done();
- BOOST_FALLTHROUGH;
- }
-
- case COPY_:
- mode_ = COPY;
- BOOST_FALLTHROUGH;
-
- case COPY:
- {
- auto copy = length_;
- if(copy == 0)
- {
- mode_ = TYPE;
- break;
- }
- copy = clamp(copy, r.in.avail());
- copy = clamp(copy, r.out.avail());
- if(copy == 0)
- return done();
- std::memcpy(r.out.next, r.in.next, copy);
- r.in.next += copy;
- r.out.next += copy;
- length_ -= copy;
- break;
- }
-
- case TABLE:
- if(! bi_.fill(5 + 5 + 4, r.in.next, r.in.last))
- return done();
- bi_.read(nlen_, 5);
- nlen_ += 257;
- bi_.read(ndist_, 5);
- ndist_ += 1;
- bi_.read(ncode_, 4);
- ncode_ += 4;
- if(nlen_ > 286 || ndist_ > 30)
- return err(error::too_many_symbols);
- have_ = 0;
- mode_ = LENLENS;
- BOOST_FALLTHROUGH;
-
- case LENLENS:
- {
- static std::array<std::uint8_t, 19> constexpr order = {{
- 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15}};
- while(have_ < ncode_)
- {
- if(! bi_.fill(3, r.in.next, r.in.last))
- return done();
- bi_.read(lens_[order[have_]], 3);
- ++have_;
- }
- while(have_ < order.size())
- lens_[order[have_++]] = 0;
-
- next_ = &codes_[0];
- lencode_ = next_;
- lenbits_ = 7;
- inflate_table(build::codes, &lens_[0],
- order.size(), &next_, &lenbits_, work_, ec);
- if(ec)
- {
- mode_ = BAD;
- break;
- }
- have_ = 0;
- mode_ = CODELENS;
- BOOST_FALLTHROUGH;
- }
-
- case CODELENS:
- {
- while(have_ < nlen_ + ndist_)
- {
- std::uint16_t v;
- if(! bi_.fill(lenbits_, r.in.next, r.in.last))
- return done();
- bi_.peek(v, lenbits_);
- auto cp = &lencode_[v];
- if(cp->val < 16)
- {
- bi_.drop(cp->bits);
- lens_[have_++] = cp->val;
- }
- else
- {
- std::uint16_t len;
- std::uint16_t copy;
- if(cp->val == 16)
- {
- if(! bi_.fill(cp->bits + 2, r.in.next, r.in.last))
- return done();
- bi_.drop(cp->bits);
- if(have_ == 0)
- return err(error::invalid_bit_length_repeat);
- bi_.read(copy, 2);
- len = lens_[have_ - 1];
- copy += 3;
-
- }
- else if(cp->val == 17)
- {
- if(! bi_.fill(cp->bits + 3, r.in.next, r.in.last))
- return done();
- bi_.drop(cp->bits);
- bi_.read(copy, 3);
- len = 0;
- copy += 3;
- }
- else
- {
- if(! bi_.fill(cp->bits + 7, r.in.next, r.in.last))
- return done();
- bi_.drop(cp->bits);
- bi_.read(copy, 7);
- len = 0;
- copy += 11;
- }
- if(have_ + copy > nlen_ + ndist_)
- return err(error::invalid_bit_length_repeat);
- std::fill(&lens_[have_], &lens_[have_ + copy], len);
- have_ += copy;
- copy = 0;
- }
- }
- // handle error breaks in while
- if(mode_ == BAD)
- break;
- // check for end-of-block code (better have one)
- if(lens_[256] == 0)
- return err(error::missing_eob);
- /* build code tables -- note: do not change the lenbits or distbits
- values here (9 and 6) without reading the comments in inftrees.hpp
- concerning the kEnough constants, which depend on those values */
- next_ = &codes_[0];
- lencode_ = next_;
- lenbits_ = 9;
- inflate_table(build::lens, &lens_[0],
- nlen_, &next_, &lenbits_, work_, ec);
- if(ec)
- {
- mode_ = BAD;
- return;
- }
- distcode_ = next_;
- distbits_ = 6;
- inflate_table(build::dists, lens_ + nlen_,
- ndist_, &next_, &distbits_, work_, ec);
- if(ec)
- {
- mode_ = BAD;
- return;
- }
- mode_ = LEN_;
- if(flush == Flush::trees)
- return done();
- BOOST_FALLTHROUGH;
- }
-
- case LEN_:
- mode_ = LEN;
- BOOST_FALLTHROUGH;
-
- case LEN:
- {
- if(r.in.avail() >= 6 && r.out.avail() >= 258)
- {
- inflate_fast(r, ec);
- if(ec)
- {
- mode_ = BAD;
- return;
- }
- if(mode_ == TYPE)
- back_ = -1;
- break;
- }
- if(! bi_.fill(lenbits_, r.in.next, r.in.last))
- return done();
- std::uint16_t v;
- back_ = 0;
- bi_.peek(v, lenbits_);
- auto cp = &lencode_[v];
- if(cp->op && (cp->op & 0xf0) == 0)
- {
- auto prev = cp;
- if(! bi_.fill(prev->bits + prev->op, r.in.next, r.in.last))
- return done();
- bi_.peek(v, prev->bits + prev->op);
- cp = &lencode_[prev->val + (v >> prev->bits)];
- bi_.drop(prev->bits + cp->bits);
- back_ += prev->bits + cp->bits;
- }
- else
- {
- bi_.drop(cp->bits);
- back_ += cp->bits;
- }
- length_ = cp->val;
- if(cp->op == 0)
- {
- mode_ = LIT;
- break;
- }
- if(cp->op & 32)
- {
- back_ = -1;
- mode_ = TYPE;
- break;
- }
- if(cp->op & 64)
- return err(error::invalid_literal_length);
- extra_ = cp->op & 15;
- mode_ = LENEXT;
- BOOST_FALLTHROUGH;
- }
-
- case LENEXT:
- if(extra_)
- {
- if(! bi_.fill(extra_, r.in.next, r.in.last))
- return done();
- std::uint16_t v;
- bi_.read(v, extra_);
- length_ += v;
- back_ += extra_;
- }
- was_ = length_;
- mode_ = DIST;
- BOOST_FALLTHROUGH;
-
- case DIST:
- {
- if(! bi_.fill(distbits_, r.in.next, r.in.last))
- return done();
- std::uint16_t v;
- bi_.peek(v, distbits_);
- auto cp = &distcode_[v];
- if((cp->op & 0xf0) == 0)
- {
- auto prev = cp;
- if(! bi_.fill(prev->bits + prev->op, r.in.next, r.in.last))
- return done();
- bi_.peek(v, prev->bits + prev->op);
- cp = &distcode_[prev->val + (v >> prev->bits)];
- bi_.drop(prev->bits + cp->bits);
- back_ += prev->bits + cp->bits;
- }
- else
- {
- bi_.drop(cp->bits);
- back_ += cp->bits;
- }
- if(cp->op & 64)
- return err(error::invalid_distance_code);
- offset_ = cp->val;
- extra_ = cp->op & 15;
- mode_ = DISTEXT;
- BOOST_FALLTHROUGH;
- }
-
- case DISTEXT:
- if(extra_)
- {
- std::uint16_t v;
- if(! bi_.fill(extra_, r.in.next, r.in.last))
- return done();
- bi_.read(v, extra_);
- offset_ += v;
- back_ += extra_;
- }
-#ifdef INFLATE_STRICT
- if(offset_ > dmax_)
- return err(error::invalid_distance);
-#endif
- mode_ = MATCH;
- BOOST_FALLTHROUGH;
-
- case MATCH:
- {
- if(! r.out.avail())
- return done();
- if(offset_ > r.out.used())
- {
- // copy from window
- auto offset = static_cast<std::uint16_t>(
- offset_ - r.out.used());
- if(offset > w_.size())
- return err(error::invalid_distance);
- auto const n = clamp(clamp(
- length_, offset), r.out.avail());
- w_.read(r.out.next, offset, n);
- r.out.next += n;
- length_ -= n;
- }
- else
- {
- // copy from output
- auto in = r.out.next - offset_;
- auto n = clamp(length_, r.out.avail());
- length_ -= n;
- while(n--)
- *r.out.next++ = *in++;
- }
- if(length_ == 0)
- mode_ = LEN;
- break;
- }
-
- case LIT:
- {
- if(! r.out.avail())
- return done();
- auto const v = static_cast<std::uint8_t>(length_);
- *r.out.next++ = v;
- mode_ = LEN;
- break;
- }
-
- case CHECK:
- mode_ = DONE;
- BOOST_FALLTHROUGH;
-
- case DONE:
- ec = error::end_of_stream;
- return done();
-
- case BAD:
- return done();
-
- case SYNC:
- default:
- BOOST_THROW_EXCEPTION(std::logic_error{
- "stream error"});
- }
- }
-}
-
-//------------------------------------------------------------------------------
-
-/* Build a set of tables to decode the provided canonical Huffman code.
- The code lengths are lens[0..codes-1]. The result starts at *table,
- whose indices are 0..2^bits-1. work is a writable array of at least
- lens shorts, which is used as a work area. type is the type of code
- to be generated, build::codes, build::lens, or build::dists. On
- return, zero is success, -1 is an invalid code, and +1 means that
- kEnough isn't enough. table on return points to the next available
- entry's address. bits is the requested root table index bits, and
- on return it is the actual root table index bits. It will differ if
- the request is greater than the longest code or if it is less than
- the shortest code.
-*/
-template<class>
-void
-inflate_stream::
-inflate_table(
- build type,
- std::uint16_t* lens,
- std::size_t codes,
- code** table,
- unsigned *bits,
- std::uint16_t* work,
- error_code& ec)
-{
- unsigned len; // a code's length in bits
- unsigned sym; // index of code symbols
- unsigned min, max; // minimum and maximum code lengths
- unsigned root; // number of index bits for root table
- unsigned curr; // number of index bits for current table
- unsigned drop; // code bits to drop for sub-table
- int left; // number of prefix codes available
- unsigned used; // code entries in table used
- unsigned huff; // Huffman code
- unsigned incr; // for incrementing code, index
- unsigned fill; // index for replicating entries
- unsigned low; // low bits for current root entry
- unsigned mask; // mask for low root bits
- code here; // table entry for duplication
- code *next; // next available space in table
- std::uint16_t const* base; // base value table to use
- std::uint16_t const* extra; // extra bits table to use
- int end; // use base and extra for symbol > end
- std::uint16_t count[15+1]; // number of codes of each length
- std::uint16_t offs[15+1]; // offsets in table for each length
-
- // Length codes 257..285 base
- static std::uint16_t constexpr lbase[31] = {
- 3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31,
- 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0};
-
- // Length codes 257..285 extra
- static std::uint16_t constexpr lext[31] = {
- 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18,
- 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72, 78};
-
- // Distance codes 0..29 base
- static std::uint16_t constexpr dbase[32] = {
- 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193,
- 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145,
- 8193, 12289, 16385, 24577, 0, 0};
-
- // Distance codes 0..29 extra
- static std::uint16_t constexpr dext[32] = {
- 16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22,
- 23, 23, 24, 24, 25, 25, 26, 26, 27, 27,
- 28, 28, 29, 29, 64, 64};
-
- /*
- Process a set of code lengths to create a canonical Huffman code. The
- code lengths are lens[0..codes-1]. Each length corresponds to the
- symbols 0..codes-1. The Huffman code is generated by first sorting the
- symbols by length from short to long, and retaining the symbol order
- for codes with equal lengths. Then the code starts with all zero bits
- for the first code of the shortest length, and the codes are integer
- increments for the same length, and zeros are appended as the length
- increases. For the deflate format, these bits are stored backwards
- from their more natural integer increment ordering, and so when the
- decoding tables are built in the large loop below, the integer codes
- are incremented backwards.
-
- This routine assumes, but does not check, that all of the entries in
- lens[] are in the range 0..15. The caller must assure this.
- 1..15 is interpreted as that code length. zero means that that
- symbol does not occur in this code.
-
- The codes are sorted by computing a count of codes for each length,
- creating from that a table of starting indices for each length in the
- sorted table, and then entering the symbols in order in the sorted
- table. The sorted table is work[], with that space being provided by
- the caller.
-
- The length counts are used for other purposes as well, i.e. finding
- the minimum and maximum length codes, determining if there are any
- codes at all, checking for a valid set of lengths, and looking ahead
- at length counts to determine sub-table sizes when building the
- decoding tables.
- */
-
- /* accumulate lengths for codes (assumes lens[] all in 0..15) */
- for (len = 0; len <= 15; len++)
- count[len] = 0;
- for (sym = 0; sym < codes; sym++)
- count[lens[sym]]++;
-
- /* bound code lengths, force root to be within code lengths */
- root = *bits;
- for (max = 15; max >= 1; max--)
- if (count[max] != 0)
- break;
- if (root > max)
- root = max;
- if (max == 0)
- { /* no symbols to code at all */
- here.op = (std::uint8_t)64; /* invalid code marker */
- here.bits = (std::uint8_t)1;
- here.val = (std::uint16_t)0;
- *(*table)++ = here; /* make a table to force an error */
- *(*table)++ = here;
- *bits = 1;
- return; /* no symbols, but wait for decoding to report error */
- }
- for (min = 1; min < max; min++)
- if (count[min] != 0)
- break;
- if (root < min)
- root = min;
-
- /* check for an over-subscribed or incomplete set of lengths */
- left = 1;
- for (len = 1; len <= 15; len++)
- {
- left <<= 1;
- left -= count[len];
- if (left < 0)
- {
- ec = error::over_subscribed_length;
- return;
- }
- }
- if (left > 0 && (type == build::codes || max != 1))
- {
- ec = error::incomplete_length_set;
- return;
- }
-
- /* generate offsets into symbol table for each length for sorting */
- offs[1] = 0;
- for (len = 1; len < 15; len++)
- offs[len + 1] = offs[len] + count[len];
-
- /* sort symbols by length, by symbol order within each length */
- for (sym = 0; sym < codes; sym++)
- if (lens[sym] != 0)
- work[offs[lens[sym]]++] = (std::uint16_t)sym;
-
- /*
- Create and fill in decoding tables. In this loop, the table being
- filled is at next and has curr index bits. The code being used is huff
- with length len. That code is converted to an index by dropping drop
- bits off of the bottom. For codes where len is less than drop + curr,
- those top drop + curr - len bits are incremented through all values to
- fill the table with replicated entries.
-
- root is the number of index bits for the root table. When len exceeds
- root, sub-tables are created pointed to by the root entry with an index
- of the low root bits of huff. This is saved in low to check for when a
- new sub-table should be started. drop is zero when the root table is
- being filled, and drop is root when sub-tables are being filled.
-
- When a new sub-table is needed, it is necessary to look ahead in the
- code lengths to determine what size sub-table is needed. The length
- counts are used for this, and so count[] is decremented as codes are
- entered in the tables.
-
- used keeps track of how many table entries have been allocated from the
- provided *table space. It is checked for build::lens and DIST tables against
- the constants kEnoughLens and kEnoughDists to guard against changes in
- the initial root table size constants. See the comments in inftrees.hpp
- for more information.
-
- sym increments through all symbols, and the loop terminates when
- all codes of length max, i.e. all codes, have been processed. This
- routine permits incomplete codes, so another loop after this one fills
- in the rest of the decoding tables with invalid code markers.
- */
-
- /* set up for code type */
- switch (type)
- {
- case build::codes:
- base = extra = work; /* dummy value--not used */
- end = 19;
- break;
- case build::lens:
- base = lbase;
- base -= 257;
- extra = lext;
- extra -= 257;
- end = 256;
- break;
- default: /* build::dists */
- base = dbase;
- extra = dext;
- end = -1;
- }
-
- /* initialize state for loop */
- huff = 0; /* starting code */
- sym = 0; /* starting code symbol */
- len = min; /* starting code length */
- next = *table; /* current table to fill in */
- curr = root; /* current table index bits */
- drop = 0; /* current bits to drop from code for index */
- low = (unsigned)(-1); /* trigger new sub-table when len > root */
- used = 1U << root; /* use root table entries */
- mask = used - 1; /* mask for comparing low */
-
- auto const not_enough = []
- {
- BOOST_THROW_EXCEPTION(std::logic_error{
- "insufficient output size when inflating tables"});
- };
-
- // check available table space
- if ((type == build::lens && used > kEnoughLens) ||
- (type == build::dists && used > kEnoughDists))
- return not_enough();
-
- /* process all codes and make table entries */
- for (;;)
- {
- /* create table entry */
- here.bits = (std::uint8_t)(len - drop);
- if ((int)(work[sym]) < end)
- {
- here.op = (std::uint8_t)0;
- here.val = work[sym];
- }
- else if ((int)(work[sym]) > end)
- {
- here.op = (std::uint8_t)(extra[work[sym]]);
- here.val = base[work[sym]];
- }
- else
- {
- here.op = (std::uint8_t)(32 + 64); /* end of block */
- here.val = 0;
- }
-
- /* replicate for those indices with low len bits equal to huff */
- incr = 1U << (len - drop);
- fill = 1U << curr;
- min = fill; /* save offset to next table */
- do
- {
- fill -= incr;
- next[(huff >> drop) + fill] = here;
- } while (fill != 0);
-
- /* backwards increment the len-bit code huff */
- incr = 1U << (len - 1);
- while (huff & incr)
- incr >>= 1;
- if (incr != 0)
- {
- huff &= incr - 1;
- huff += incr;
- }
- else
- huff = 0;
-
- /* go to next symbol, update count, len */
- sym++;
- if (--(count[len]) == 0)
- {
- if (len == max) break;
- len = lens[work[sym]];
- }
-
- /* create new sub-table if needed */
- if (len > root && (huff & mask) != low)
- {
- /* if first time, transition to sub-tables */
- if (drop == 0)
- drop = root;
-
- /* increment past last table */
- next += min; /* here min is 1 << curr */
-
- /* determine length of next table */
- curr = len - drop;
- left = (int)(1 << curr);
- while (curr + drop < max)
- {
- left -= count[curr + drop];
- if (left <= 0) break;
- curr++;
- left <<= 1;
- }
-
- /* check for enough space */
- used += 1U << curr;
- if ((type == build::lens && used > kEnoughLens) ||
- (type == build::dists && used > kEnoughDists))
- return not_enough();
-
- /* point entry in root table to sub-table */
- low = huff & mask;
- (*table)[low].op = (std::uint8_t)curr;
- (*table)[low].bits = (std::uint8_t)root;
- (*table)[low].val = (std::uint16_t)(next - *table);
- }
- }
-
- /* fill in remaining table entry if code is incomplete (guaranteed to have
- at most one remaining entry, since if the code is incomplete, the
- maximum code length that was allowed to get this far is one bit) */
- if (huff != 0)
- {
- here.op = 64; // invalid code marker
- here.bits = (std::uint8_t)(len - drop);
- here.val = 0;
- next[huff] = here;
- }
-
- *table += used;
- *bits = root;
-}
-
-template<class>
-auto
-inflate_stream::
-get_fixed_tables() ->
- codes const&
-{
- struct fixed_codes : codes
- {
- code len_[512];
- code dist_[32];
-
- fixed_codes()
- {
- lencode = len_;
- lenbits = 9;
- distcode = dist_;
- distbits = 5;
-
- std::uint16_t lens[320];
- std::uint16_t work[288];
-
- std::fill(&lens[ 0], &lens[144], std::uint16_t{8});
- std::fill(&lens[144], &lens[256], std::uint16_t{9});
- std::fill(&lens[256], &lens[280], std::uint16_t{7});
- std::fill(&lens[280], &lens[288], std::uint16_t{8});
-
- {
- error_code ec;
- auto next = &len_[0];
- inflate_table(build::lens,
- lens, 288, &next, &lenbits, work, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(std::logic_error{ec.message()});
- }
-
- // VFALCO These fixups are from ZLib
- len_[ 99].op = 64;
- len_[227].op = 64;
- len_[355].op = 64;
- len_[483].op = 64;
-
- {
- error_code ec;
- auto next = &dist_[0];
- std::fill(&lens[0], &lens[32], std::uint16_t{5});
- inflate_table(build::dists,
- lens, 32, &next, &distbits, work, ec);
- if(ec)
- BOOST_THROW_EXCEPTION(std::logic_error{ec.message()});
- }
- }
- };
-
- static fixed_codes const fc;
- return fc;
-}
-
-template<class>
-void
-inflate_stream::
-fixedTables()
-{
- auto const fc = get_fixed_tables();
- lencode_ = fc.lencode;
- lenbits_ = fc.lenbits;
- distcode_ = fc.distcode;
- distbits_ = fc.distbits;
-}
-
-/*
- Decode literal, length, and distance codes and write out the resulting
- literal and match bytes until either not enough input or output is
- available, an end-of-block is encountered, or a data error is encountered.
- When large enough input and output buffers are supplied to inflate(), for
- example, a 16K input buffer and a 64K output buffer, more than 95% of the
- inflate execution time is spent in this routine.
-
- Entry assumptions:
-
- state->mode_ == LEN
- zs.avail_in >= 6
- zs.avail_out >= 258
- start >= zs.avail_out
- state->bits_ < 8
-
- On return, state->mode_ is one of:
-
- LEN -- ran out of enough output space or enough available input
- TYPE -- reached end of block code, inflate() to interpret next block
- BAD -- error in block data
-
- Notes:
-
- - The maximum input bits used by a length/distance pair is 15 bits for the
- length code, 5 bits for the length extra, 15 bits for the distance code,
- and 13 bits for the distance extra. This totals 48 bits, or six bytes.
- Therefore if zs.avail_in >= 6, then there is enough input to avoid
- checking for available input while decoding.
-
- - The maximum bytes that a single length/distance pair can output is 258
- bytes, which is the maximum length that can be coded. inflate_fast()
- requires zs.avail_out >= 258 for each loop to avoid checking for
- output space.
-
- inflate_fast() speedups that turned out slower (on a PowerPC G3 750CXe):
- - Using bit fields for code structure
- - Different op definition to avoid & for extra bits (do & for table bits)
- - Three separate decoding do-loops for direct, window, and wnext == 0
- - Special case for distance > 1 copies to do overlapped load and store copy
- - Explicit branch predictions (based on measured branch probabilities)
- - Deferring match copy and interspersed it with decoding subsequent codes
- - Swapping literal/length else
- - Swapping window/direct else
- - Larger unrolled copy loops (three is about right)
- - Moving len -= 3 statement into middle of loop
- */
-template<class>
-void
-inflate_stream::
-inflate_fast(ranges& r, error_code& ec)
-{
- unsigned char const* last; // have enough input while in < last
- unsigned char *end; // while out < end, enough space available
- std::size_t op; // code bits, operation, extra bits, or window position, window bytes to copy
- unsigned len; // match length, unused bytes
- unsigned dist; // match distance
- unsigned const lmask =
- (1U << lenbits_) - 1; // mask for first level of length codes
- unsigned const dmask =
- (1U << distbits_) - 1; // mask for first level of distance codes
-
- last = r.in.next + (r.in.avail() - 5);
- end = r.out.next + (r.out.avail() - 257);
-
- /* decode literals and length/distances until end-of-block or not enough
- input data or output space */
- do
- {
- if(bi_.size() < 15)
- bi_.fill_16(r.in.next);
- auto cp = &lencode_[bi_.peek_fast() & lmask];
- dolen:
- bi_.drop(cp->bits);
- op = (unsigned)(cp->op);
- if(op == 0)
- {
- // literal
- *r.out.next++ = (unsigned char)(cp->val);
- }
- else if(op & 16)
- {
- // length base
- len = (unsigned)(cp->val);
- op &= 15; // number of extra bits
- if(op)
- {
- if(bi_.size() < op)
- bi_.fill_8(r.in.next);
- len += (unsigned)bi_.peek_fast() & ((1U << op) - 1);
- bi_.drop(op);
- }
- if(bi_.size() < 15)
- bi_.fill_16(r.in.next);
- cp = &distcode_[bi_.peek_fast() & dmask];
- dodist:
- bi_.drop(cp->bits);
- op = (unsigned)(cp->op);
- if(op & 16)
- {
- // distance base
- dist = (unsigned)(cp->val);
- op &= 15; // number of extra bits
- if(bi_.size() < op)
- {
- bi_.fill_8(r.in.next);
- if(bi_.size() < op)
- bi_.fill_8(r.in.next);
- }
- dist += (unsigned)bi_.peek_fast() & ((1U << op) - 1);
-#ifdef INFLATE_STRICT
- if(dist > dmax_)
- {
- ec = error::invalid_distance;
- mode_ = BAD;
- break;
- }
-#endif
- bi_.drop(op);
-
- op = r.out.used();
- if(dist > op)
- {
- // copy from window
- op = dist - op; // distance back in window
- if(op > w_.size())
- {
- ec = error::invalid_distance;
- mode_ = BAD;
- break;
- }
- auto const n = clamp(len, op);
- w_.read(r.out.next, op, n);
- r.out.next += n;
- len -= n;
- }
- if(len > 0)
- {
- // copy from output
- auto in = r.out.next - dist;
- auto n = clamp(len, r.out.avail());
- len -= n;
- while(n--)
- *r.out.next++ = *in++;
- }
- }
- else if((op & 64) == 0)
- {
- // 2nd level distance code
- cp = &distcode_[cp->val + (bi_.peek_fast() & ((1U << op) - 1))];
- goto dodist;
- }
- else
- {
- ec = error::invalid_distance_code;
- mode_ = BAD;
- break;
- }
- }
- else if((op & 64) == 0)
- {
- // 2nd level length code
- cp = &lencode_[cp->val + (bi_.peek_fast() & ((1U << op) - 1))];
- goto dolen;
- }
- else if(op & 32)
- {
- // end-of-block
- mode_ = TYPE;
- break;
- }
- else
- {
- ec = error::invalid_literal_length;
- mode_ = BAD;
- break;
- }
- }
- while(r.in.next < last && r.out.next < end);
-
- // return unused bytes (on entry, bits < 8, so in won't go too far back)
- bi_.rewind(r.in.next);
-}
-
-} // detail
-} // zlib
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/zlib/detail/ranges.hpp b/contrib/restricted/boost/boost/beast/zlib/detail/ranges.hpp
deleted file mode 100644
index aee141f357..0000000000
--- a/contrib/restricted/boost/boost/beast/zlib/detail/ranges.hpp
+++ /dev/null
@@ -1,104 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-// This is a derivative work based on Zlib, copyright below:
-/*
- Copyright (C) 1995-2013 Jean-loup Gailly and Mark Adler
-
- This software is provided 'as-is', without any express or implied
- warranty. In no event will the authors be held liable for any damages
- arising from the use of this software.
-
- Permission is granted to anyone to use this software for any purpose,
- including commercial applications, and to alter it and redistribute it
- freely, subject to the following restrictions:
-
- 1. The origin of this software must not be misrepresented; you must not
- claim that you wrote the original software. If you use this software
- in a product, an acknowledgment in the product documentation would be
- appreciated but is not required.
- 2. Altered source versions must be plainly marked as such, and must not be
- misrepresented as being the original software.
- 3. This notice may not be removed or altered from any source distribution.
-
- Jean-loup Gailly Mark Adler
- jloup@gzip.org madler@alumni.caltech.edu
-
- The data format used by the zlib library is described by RFCs (Request for
- Comments) 1950 to 1952 in the files http://tools.ietf.org/html/rfc1950
- (zlib format), rfc1951 (deflate format) and rfc1952 (gzip format).
-*/
-
-#ifndef BOOST_BEAST_ZLIB_DETAIL_RANGES_HPP
-#define BOOST_BEAST_ZLIB_DETAIL_RANGES_HPP
-
-#include <cstdint>
-#include <type_traits>
-
-namespace boost {
-namespace beast {
-namespace zlib {
-namespace detail {
-
-struct ranges
-{
- template<bool isConst>
- struct range
- {
- using iter_t =
- typename std::conditional<isConst,
- std::uint8_t const*,
- std::uint8_t*>::type;
-
- iter_t first;
- iter_t last;
- iter_t next;
-
- // total bytes in range
- std::size_t
- size() const
- {
- return last - first;
- }
-
- // bytes consumed
- std::size_t
- used() const
- {
- return next - first;
- }
-
- // bytes remaining
- std::size_t
- avail() const
- {
- return last - next;
- }
- };
-
- range<true> in;
- range<false> out;
-};
-
-// Clamp u to v where u and v are different types
-template<class U, class V>
-inline
-U
-clamp(U u, V v)
-{
- if(u > v)
- u = static_cast<U>(v);
- return u;
-}
-
-} // detail
-} // zlib
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/zlib/detail/window.hpp b/contrib/restricted/boost/boost/beast/zlib/detail/window.hpp
deleted file mode 100644
index f089649183..0000000000
--- a/contrib/restricted/boost/boost/beast/zlib/detail/window.hpp
+++ /dev/null
@@ -1,167 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-// This is a derivative work based on Zlib, copyright below:
-/*
- Copyright (C) 1995-2013 Jean-loup Gailly and Mark Adler
-
- This software is provided 'as-is', without any express or implied
- warranty. In no event will the authors be held liable for any damages
- arising from the use of this software.
-
- Permission is granted to anyone to use this software for any purpose,
- including commercial applications, and to alter it and redistribute it
- freely, subject to the following restrictions:
-
- 1. The origin of this software must not be misrepresented; you must not
- claim that you wrote the original software. If you use this software
- in a product, an acknowledgment in the product documentation would be
- appreciated but is not required.
- 2. Altered source versions must be plainly marked as such, and must not be
- misrepresented as being the original software.
- 3. This notice may not be removed or altered from any source distribution.
-
- Jean-loup Gailly Mark Adler
- jloup@gzip.org madler@alumni.caltech.edu
-
- The data format used by the zlib library is described by RFCs (Request for
- Comments) 1950 to 1952 in the files http://tools.ietf.org/html/rfc1950
- (zlib format), rfc1951 (deflate format) and rfc1952 (gzip format).
-*/
-
-#ifndef BOOST_BEAST_ZLIB_DETAIL_WINDOW_HPP
-#define BOOST_BEAST_ZLIB_DETAIL_WINDOW_HPP
-
-#include <boost/assert.hpp>
-#include <boost/make_unique.hpp>
-#include <cstdint>
-#include <cstring>
-#include <memory>
-
-namespace boost {
-namespace beast {
-namespace zlib {
-namespace detail {
-
-class window
-{
- std::unique_ptr<std::uint8_t[]> p_;
- std::uint16_t i_ = 0;
- std::uint16_t size_ = 0;
- std::uint16_t capacity_ = 0;
- std::uint8_t bits_ = 0;
-
-public:
- int
- bits() const
- {
- return bits_;
- }
-
- unsigned
- capacity() const
- {
- return capacity_;
- }
-
- unsigned
- size() const
- {
- return size_;
- }
-
- void
- reset(int bits);
-
- void
- read(std::uint8_t* out, std::size_t pos, std::size_t n);
-
- template<class = void>
- void
- write(std::uint8_t const* in, std::size_t n);
-};
-
-inline
-void
-window::
-reset(int bits)
-{
- if(bits_ != bits)
- {
- p_.reset();
- bits_ = static_cast<std::uint8_t>(bits);
- capacity_ = 1U << bits_;
- }
- i_ = 0;
- size_ = 0;
-}
-
-inline
-void
-window::
-read(std::uint8_t* out, std::size_t pos, std::size_t n)
-{
- if(i_ >= size_)
- {
- // window is contiguous
- std::memcpy(out, &p_[i_ - pos], n);
- return;
- }
- auto i = ((i_ - pos) + capacity_) % capacity_;
- auto m = capacity_ - i;
- if(n <= m)
- {
- std::memcpy(out, &p_[i], n);
- return;
- }
- std::memcpy(out, &p_[i], m);
- out += m;
- std::memcpy(out, &p_[0], n - m);
-}
-
-template<class>
-void
-window::
-write(std::uint8_t const* in, std::size_t n)
-{
- if(! p_)
- p_ = boost::make_unique<
- std::uint8_t[]>(capacity_);
- if(n >= capacity_)
- {
- i_ = 0;
- size_ = capacity_;
- std::memcpy(&p_[0], in + (n - size_), size_);
- return;
- }
- if(i_ + n <= capacity_)
- {
- std::memcpy(&p_[i_], in, n);
- if(size_ >= capacity_ - n)
- size_ = capacity_;
- else
- size_ = static_cast<std::uint16_t>(size_ + n);
-
- i_ = static_cast<std::uint16_t>(
- (i_ + n) % capacity_);
- return;
- }
- auto m = capacity_ - i_;
- std::memcpy(&p_[i_], in, m);
- in += m;
- i_ = static_cast<std::uint16_t>(n - m);
- std::memcpy(&p_[0], in, i_);
- size_ = capacity_;
-}
-
-} // detail
-} // zlib
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/zlib/error.hpp b/contrib/restricted/boost/boost/beast/zlib/error.hpp
deleted file mode 100644
index 797c511ba1..0000000000
--- a/contrib/restricted/boost/boost/beast/zlib/error.hpp
+++ /dev/null
@@ -1,139 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_ZLIB_ERROR_HPP
-#define BOOST_BEAST_ZLIB_ERROR_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/core/error.hpp>
-
-namespace boost {
-namespace beast {
-namespace zlib {
-
-// This is a derivative work based on Zlib, copyright below:
-/*
- Copyright (C) 1995-2013 Jean-loup Gailly and Mark Adler
-
- This software is provided 'as-is', without any express or implied
- warranty. In no event will the authors be held liable for any damages
- arising from the use of this software.
-
- Permission is granted to anyone to use this software for any purpose,
- including commercial applications, and to alter it and redistribute it
- freely, subject to the following restrictions:
-
- 1. The origin of this software must not be misrepresented; you must not
- claim that you wrote the original software. If you use this software
- in a product, an acknowledgment in the product documentation would be
- appreciated but is not required.
- 2. Altered source versions must be plainly marked as such, and must not be
- misrepresented as being the original software.
- 3. This notice may not be removed or altered from any source distribution.
-
- Jean-loup Gailly Mark Adler
- jloup@gzip.org madler@alumni.caltech.edu
-
- The data format used by the zlib library is described by RFCs (Request for
- Comments) 1950 to 1952 in the files http://tools.ietf.org/html/rfc1950
- (zlib format), rfc1951 (deflate format) and rfc1952 (gzip format).
-*/
-
-/** Error codes returned by the codec.
-*/
-enum class error
-{
- /** Additional buffers are required.
-
- This error indicates that one or both of the buffers
- provided buffers do not have sufficient available bytes
- to make forward progress.
-
- This does not always indicate a failure condition.
-
- @note This is the same as `Z_BUF_ERROR` returned by ZLib.
- */
- need_buffers = 1,
-
- /** End of stream reached.
-
- @note This is the same as `Z_STREAM_END` returned by ZLib.
- */
- end_of_stream,
-
- /** Invalid stream or parameters.
-
- This error is returned when invalid parameters are passed,
- or the operation being performed is not consistent with the
- state of the stream. For example, attempting to write data
- when the end of stream is already reached.
-
- @note This is the same as `Z_STREAM_ERROR` returned by ZLib.
- */
- stream_error,
-
- //
- // Errors generated by basic_deflate_stream
- //
-
- //
- // Errors generated by basic_inflate_stream
- //
-
- /// Invalid block type
- invalid_block_type,
-
- /// Invalid stored block length
- invalid_stored_length,
-
- /// Too many length or distance symbols
- too_many_symbols,
-
- /// Invalid code lengths
- invalid_code_lenths,
-
- /// Invalid bit length repeat
- invalid_bit_length_repeat,
-
- /// Missing end of block code
- missing_eob,
-
- /// Invalid literal/length code
- invalid_literal_length,
-
- /// Invalid distance code
- invalid_distance_code,
-
- /// Invalid distance too far back
- invalid_distance,
-
- //
- // Errors generated by inflate_table
- //
-
- /// Over-subscribed length code
- over_subscribed_length,
-
- /// Incomplete length set
- incomplete_length_set,
-
-
-
- /// general error
- general
-};
-
-} // zlib
-} // beast
-} // boost
-
-#include <boost/beast/zlib/impl/error.ipp>
-
-#endif
-
diff --git a/contrib/restricted/boost/boost/beast/zlib/impl/error.ipp b/contrib/restricted/boost/boost/beast/zlib/impl/error.ipp
deleted file mode 100644
index 6aa3d22d47..0000000000
--- a/contrib/restricted/boost/boost/beast/zlib/impl/error.ipp
+++ /dev/null
@@ -1,140 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-// This is a derivative work based on Zlib, copyright below:
-/*
- Copyright (C) 1995-2013 Jean-loup Gailly and Mark Adler
-
- This software is provided 'as-is', without any express or implied
- warranty. In no event will the authors be held liable for any damages
- arising from the use of this software.
-
- Permission is granted to anyone to use this software for any purpose,
- including commercial applications, and to alter it and redistribute it
- freely, subject to the following restrictions:
-
- 1. The origin of this software must not be misrepresented; you must not
- claim that you wrote the original software. If you use this software
- in a product, an acknowledgment in the product documentation would be
- appreciated but is not required.
- 2. Altered source versions must be plainly marked as such, and must not be
- misrepresented as being the original software.
- 3. This notice may not be removed or altered from any source distribution.
-
- Jean-loup Gailly Mark Adler
- jloup@gzip.org madler@alumni.caltech.edu
-
- The data format used by the zlib library is described by RFCs (Request for
- Comments) 1950 to 1952 in the files http://tools.ietf.org/html/rfc1950
- (zlib format), rfc1951 (deflate format) and rfc1952 (gzip format).
-*/
-
-#ifndef BOOST_BEAST_ZLIB_IMPL_ERROR_IPP
-#define BOOST_BEAST_ZLIB_IMPL_ERROR_IPP
-
-#include <boost/beast/core/error.hpp>
-#include <type_traits>
-
-namespace boost {
-
-namespace system {
-template<>
-struct is_error_code_enum<beast::zlib::error>
-{
- static bool const value = true;
-};
-} // system
-
-namespace beast {
-namespace zlib {
-namespace detail {
-
-class zlib_error_category : public error_category
-{
-public:
- const char*
- name() const noexcept override
- {
- return "beast.zlib";
- }
-
- std::string
- message(int ev) const override
- {
- switch(static_cast<error>(ev))
- {
- case error::need_buffers: return "need buffers";
- case error::end_of_stream: return "unexpected end of deflate stream";
- case error::stream_error: return "stream error";
-
- case error::invalid_block_type: return "invalid block type";
- case error::invalid_stored_length: return "invalid stored block length";
- case error::too_many_symbols: return "too many symbols";
- case error::invalid_code_lenths: return "invalid code lengths";
- case error::invalid_bit_length_repeat: return "invalid bit length repeat";
- case error::missing_eob: return "missing end of block code";
- case error::invalid_literal_length: return "invalid literal/length code";
- case error::invalid_distance_code: return "invalid distance code";
- case error::invalid_distance: return "invalid distance";
-
- case error::over_subscribed_length: return "over-subscribed length";
- case error::incomplete_length_set: return "incomplete length set";
-
- case error::general:
- default:
- return "beast.zlib error";
- }
- }
-
- error_condition
- default_error_condition(int ev) const noexcept override
- {
- return error_condition{ev, *this};
- }
-
- bool
- equivalent(int ev,
- error_condition const& condition
- ) const noexcept override
- {
- return condition.value() == ev &&
- &condition.category() == this;
- }
-
- bool
- equivalent(error_code const& error, int ev) const noexcept override
- {
- return error.value() == ev &&
- &error.category() == this;
- }
-};
-
-inline
-error_category const&
-get_error_category()
-{
- static zlib_error_category const cat{};
- return cat;
-}
-
-} // detail
-
-inline
-error_code
-make_error_code(error ev)
-{
- return error_code{
- static_cast<std::underlying_type<error>::type>(ev),
- detail::get_error_category()};
-}
-
-} // zlib
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/zlib/inflate_stream.hpp b/contrib/restricted/boost/boost/beast/zlib/inflate_stream.hpp
deleted file mode 100644
index 8410cb8bc2..0000000000
--- a/contrib/restricted/boost/boost/beast/zlib/inflate_stream.hpp
+++ /dev/null
@@ -1,220 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_ZLIB_INFLATE_STREAM_HPP
-#define BOOST_BEAST_ZLIB_INFLATE_STREAM_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <boost/beast/zlib/detail/inflate_stream.hpp>
-
-// This is a derivative work based on Zlib, copyright below:
-/*
- Copyright (C) 1995-2013 Jean-loup Gailly and Mark Adler
-
- This software is provided 'as-is', without any express or implied
- warranty. In no event will the authors be held liable for any damages
- arising from the use of this software.
-
- Permission is granted to anyone to use this software for any purpose,
- including commercial applications, and to alter it and redistribute it
- freely, subject to the following restrictions:
-
- 1. The origin of this software must not be misrepresented; you must not
- claim that you wrote the original software. If you use this software
- in a product, an acknowledgment in the product documentation would be
- appreciated but is not required.
- 2. Altered source versions must be plainly marked as such, and must not be
- misrepresented as being the original software.
- 3. This notice may not be removed or altered from any source distribution.
-
- Jean-loup Gailly Mark Adler
- jloup@gzip.org madler@alumni.caltech.edu
-
- The data format used by the zlib library is described by RFCs (Request for
- Comments) 1950 to 1952 in the files http://tools.ietf.org/html/rfc1950
- (zlib format), rfc1951 (deflate format) and rfc1952 (gzip format).
-*/
-
-namespace boost {
-namespace beast {
-namespace zlib {
-
-/** Raw deflate stream decompressor.
-
- This implements a raw deflate stream decompressor. The deflate
- protocol is a compression protocol described in
- "DEFLATE Compressed Data Format Specification version 1.3"
- located here: https://tools.ietf.org/html/rfc1951
-
- The implementation is a refactored port to C++ of ZLib's "inflate".
- A more detailed description of ZLib is at http://zlib.net/.
-
- Compression can be done in a single step if the buffers are large
- enough (for example if an input file is memory mapped), or can be done
- by repeated calls of the compression function. In the latter case, the
- application must provide more input and/or consume the output (providing
- more output space) before each call.
-*/
-class inflate_stream
- : private detail::inflate_stream
-{
-public:
- /** Construct a raw deflate decompression stream.
-
- The window size is set to the default of 15 bits.
- */
- inflate_stream() = default;
-
- /** Reset the stream.
-
- This puts the stream in a newly constructed state with
- the previously specified window size, but without de-allocating
- any dynamically created structures.
- */
- void
- reset()
- {
- doReset();
- }
-
- /** Reset the stream.
-
- This puts the stream in a newly constructed state with the
- specified window size, but without de-allocating any dynamically
- created structures.
- */
- void
- reset(int windowBits)
- {
- doReset(windowBits);
- }
-
- /** Put the stream in a newly constructed state.
-
- All dynamically allocated memory is de-allocated.
- */
- void
- clear()
- {
- doClear();
- }
-
- /** Decompress input and produce output.
-
- This function decompresses as much data as possible, and stops when
- the input buffer becomes empty or the output buffer becomes full. It
- may introduce some output latency (reading input without producing any
- output) except when forced to flush.
-
- One or both of the following actions are performed:
-
- @li Decompress more input starting at `zs.next_in` and update `zs.next_in`
- and `zs.avail_in` accordingly. If not all input can be processed (because
- there is not enough room in the output buffer), `zs.next_in` is updated
- and processing will resume at this point for the next call.
-
- @li Provide more output starting at `zs.next_out` and update `zs.next_out`
- and `zs.avail_out` accordingly. `write` provides as much output as
- possible, until there is no more input data or no more space in the output
- buffer (see below about the flush parameter).
-
- Before the call, the application should ensure that at least one of the
- actions is possible, by providing more input and/or consuming more output,
- and updating the values in `zs` accordingly. The application can consume
- the uncompressed output when it wants, for example when the output buffer
- is full (`zs.avail_out == 0`), or after each call. If `write` returns no
- error and with zero `zs.avail_out`, it must be called again after making
- room in the output buffer because there might be more output pending.
-
- The flush parameter may be `Flush::none`, `Flush::sync`, `Flush::finish`,
- `Flush::block`, or `Flush::trees`. `Flush::sync` requests to flush as much
- output as possible to the output buffer. `Flush::block` requests to stop if
- and when it gets to the next deflate block boundary. When decoding the
- zlib or gzip format, this will cause `write` to return immediately after
- the header and before the first block. When doing a raw inflate, `write` will
- go ahead and process the first block, and will return when it gets to the
- end of that block, or when it runs out of data.
-
- The `Flush::block` option assists in appending to or combining deflate
- streams. Also to assist in this, on return `write` will set `zs.data_type`
- to the number of unused bits in the last byte taken from `zs.next_in`, plus
- 64 if `write` is currently decoding the last block in the deflate stream,
- plus 128 if `write` returned immediately after decoding an end-of-block code
- or decoding the complete header up to just before the first byte of the
- deflate stream. The end-of-block will not be indicated until all of the
- uncompressed data from that block has been written to `zs.next_out`. The
- number of unused bits may in general be greater than seven, except when
- bit 7 of `zs.data_type` is set, in which case the number of unused bits
- will be less than eight. `zs.data_type` is set as noted here every time
- `write` returns for all flush options, and so can be used to determine the
- amount of currently consumed input in bits.
-
- The `Flush::trees` option behaves as `Flush::block` does, but it also returns
- when the end of each deflate block header is reached, before any actual data
- in that block is decoded. This allows the caller to determine the length of
- the deflate block header for later use in random access within a deflate block.
- 256 is added to the value of `zs.data_type` when `write` returns immediately
- after reaching the end of the deflate block header.
-
- `write` should normally be called until it returns `error::end_of_stream` or
- another error. However if all decompression is to be performed in a single
- step (a single call of `write`), the parameter flush should be set to
- `Flush::finish`. In this case all pending input is processed and all pending
- output is flushed; `zs.avail_out` must be large enough to hold all of the
- uncompressed data for the operation to complete. (The size of the uncompressed
- data may have been saved by the compressor for this purpose.) The use of
- `Flush::finish` is not required to perform an inflation in one step. However
- it may be used to inform inflate that a faster approach can be used for the
- single call. `Flush::finish` also informs inflate to not maintain a sliding
- window if the stream completes, which reduces inflate's memory footprint.
- If the stream does not complete, either because not all of the stream is
- provided or not enough output space is provided, then a sliding window will be
- allocated and `write` can be called again to continue the operation as if
- `Flush::none` had been used.
-
- In this implementation, `write` always flushes as much output as possible to
- the output buffer, and always uses the faster approach on the first call. So
- the effects of the flush parameter in this implementation are on the return value
- of `write` as noted below, when `write` returns early when `Flush::block` or
- `Flush::trees` is used, and when `write` avoids the allocation of memory for a
- sliding window when `Flush::finsih` is used.
-
- If a preset dictionary is needed after this call,
- `write` sets `zs.adler` to the Adler-32 checksum of the dictionary chosen by
- the compressor and returns `error::need_dictionary`; otherwise it sets
- `zs.adler` to the Adler-32 checksum of all output produced so far (that is,
- `zs.total_out bytes`) and returns no error, `error::end_of_stream`, or an
- error code as described below. At the end of the stream, `write` checks that
- its computed adler32 checksum is equal to that saved by the compressor and
- returns `error::end_of_stream` only if the checksum is correct.
-
- This function returns no error if some progress has been made (more input
- processed or more output produced), `error::end_of_stream` if the end of the
- compressed data has been reached and all uncompressed output has been produced,
- `error::need_dictionary` if a preset dictionary is needed at this point,
- `error::invalid_data` if the input data was corrupted (input stream not
- conforming to the zlib format or incorrect check value), `error::stream_error`
- if the stream structure was inconsistent (for example if `zs.next_in` or
- `zs.next_out` was null), `error::need_buffers` if no progress is possible or
- if there was not enough room in the output buffer when `Flush::finish` is
- used. Note that `error::need_buffers` is not fatal, and `write` can be called
- again with more input and more output space to continue decompressing.
- */
- void
- write(z_params& zs, Flush flush, error_code& ec)
- {
- doWrite(zs, flush, ec);
- }
-};
-
-} // zlib
-} // beast
-} // boost
-
-#endif
diff --git a/contrib/restricted/boost/boost/beast/zlib/zlib.hpp b/contrib/restricted/boost/boost/beast/zlib/zlib.hpp
deleted file mode 100644
index b8dddcbfe8..0000000000
--- a/contrib/restricted/boost/boost/beast/zlib/zlib.hpp
+++ /dev/null
@@ -1,184 +0,0 @@
-//
-// Copyright (c) 2016-2017 Vinnie Falco (vinnie dot falco at gmail dot com)
-//
-// Distributed under the Boost Software License, Version 1.0. (See accompanying
-// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
-//
-// Official repository: https://github.com/boostorg/beast
-//
-
-#ifndef BOOST_BEAST_ZLIB_ZLIB_HPP
-#define BOOST_BEAST_ZLIB_ZLIB_HPP
-
-#include <boost/beast/core/detail/config.hpp>
-#include <cstdint>
-#include <cstdlib>
-
-// This is a derivative work based on Zlib, copyright below:
-/*
- Copyright (C) 1995-2013 Jean-loup Gailly and Mark Adler
-
- This software is provided 'as-is', without any express or implied
- warranty. In no event will the authors be held liable for any damages
- arising from the use of this software.
-
- Permission is granted to anyone to use this software for any purpose,
- including commercial applications, and to alter it and redistribute it
- freely, subject to the following restrictions:
-
- 1. The origin of this software must not be misrepresented; you must not
- claim that you wrote the original software. If you use this software
- in a product, an acknowledgment in the product documentation would be
- appreciated but is not required.
- 2. Altered source versions must be plainly marked as such, and must not be
- misrepresented as being the original software.
- 3. This notice may not be removed or altered from any source distribution.
-
- Jean-loup Gailly Mark Adler
- jloup@gzip.org madler@alumni.caltech.edu
-
- The data format used by the zlib library is described by RFCs (Request for
- Comments) 1950 to 1952 in the files http://tools.ietf.org/html/rfc1950
- (zlib format), rfc1951 (deflate format) and rfc1952 (gzip format).
-*/
-
-namespace boost {
-namespace beast {
-namespace zlib {
-
-#if !defined(__MACTYPES__)
-using Byte = unsigned char; // 8 bits
-#endif
-using uInt = unsigned int; // 16 bits or more
-
-/* Possible values of the data_type field (though see inflate()) */
-enum kind
-{
- binary = 0,
- text = 1,
- unknown = 2
-};
-
-/** Deflate codec parameters.
-
- Objects of this type are filled in by callers and provided to the
- deflate codec to define the input and output areas for the next
- compress or decompress operation.
-
- The application must update next_in and avail_in when avail_in has dropped
- to zero. It must update next_out and avail_out when avail_out has dropped
- to zero. The application must initialize zalloc, zfree and opaque before
- calling the init function. All other fields are set by the compression
- library and must not be updated by the application.
-
- The fields total_in and total_out can be used for statistics or progress
- reports. After compression, total_in holds the total size of the
- uncompressed data and may be saved for use in the decompressor (particularly
- if the decompressor wants to decompress everything in a single step).
-*/
-struct z_params
-{
- /** A pointer to the next input byte.
-
- If there is no more input, this may be set to `nullptr`.
- */
- void const* next_in;
-
- /** The number of bytes of input available at `next_in`.
-
- If there is no more input, this should be set to zero.
- */
- std::size_t avail_in;
-
- /** The total number of input bytes read so far.
- */
- std::size_t total_in = 0;
-
- /** A pointer to the next output byte.
- */
- void* next_out;
-
- /** The remaining bytes of space at `next_out`.
- */
- std::size_t avail_out;
-
- /** The total number of bytes output so far.
- */
- std::size_t total_out = 0;
-
- int data_type = unknown; // best guess about the data type: binary or text
-};
-
-/** Flush option.
-*/
-enum class Flush
-{
- // order matters
-
- none,
- block,
- partial,
- sync,
- full,
- finish,
- trees
-};
-
-/* compression levels */
-enum compression
-{
- none = 0,
- best_speed = 1,
- best_size = 9,
- default_size = -1
-};
-
-/** Compression strategy.
-
- These are used when compressing streams.
-*/
-enum class Strategy
-{
- /** Default strategy.
-
- This is suitable for general purpose compression, and works
- well in the majority of cases.
- */
- normal,
-
- /** Filtered strategy.
-
- This strategy should be used when the data be compressed
- is produced by a filter or predictor.
- */
- filtered,
-
- /** Huffman-only strategy.
-
- This strategy only performs Huffman encoding, without doing
- any string matching.
- */
- huffman,
-
- /** Run Length Encoding strategy.
-
- This strategy limits match distances to one, making it
- equivalent to run length encoding. This can give better
- performance for things like PNG image data.
- */
- rle,
-
- /** Fixed table strategy.
-
- This strategy prevents the use of dynamic Huffman codes,
- allowing for a simpler decoder for special applications.
- */
- fixed
-};
-
-} // zlib
-} // beast
-} // boost
-
-#endif
-