Expand description
ยงhttparse
A push library for parsing HTTP/1.x requests and responses.
The focus is on speed and safety. Unsafe code is used to keep parsing fast,
but unsafety is contained in a submodule, with invariants enforced. The
parsing internals use an Iterator
instead of direct indexing, while
skipping bounds checks.
With Rust 1.27.0 or later, support for SIMD is enabled automatically.
If building an executable to be run on multiple platforms, and thus
not passing target_feature
or target_cpu
flags to the compiler,
runtime detection can still detect SSE4.2 or AVX2 support to provide
massive wins.
If compiling for a specific target, remembering to include
-C target_cpu=native
allows the detection to become compile time checks,
making it even faster.
Modulesยง
Structsยง
- Represents a parsed header.
- HeaderParserConfig ๐
- An error in parsing a chunk size.
- Parser configuration.
- A parsed Request.
- A parsed Response.
Enumsยง
- An error in parsing.
- The result of a successful parse pass.
Constantsยง
- An empty header, useful for constructing a
Header
array to pass in for parsing.
Staticsยง
- HEADER_NAME_MAP ๐
- HEADER_VALUE_MAP ๐
- URI_MAP ๐
Functionsยง
- assume_init_slice ๐ โ
- deinit_slice_mut ๐ โ
- is_header_name_token ๐
- is_token ๐Determines if byte is a token char.
- is_uri_token ๐
- Parse a buffer of bytes as a chunk size.
- parse_code ๐
- Parse a buffer of bytes as headers.
- parse_headers_iter ๐
- parse_reason ๐From RFC 7230:
- parse_token ๐
- skip_empty_lines ๐
- skip_spaces ๐
Type Aliasesยง
- A Result of any parsing action.