From 6d792d9948a9cab387fe26c6057f64c8dca490c5 Mon Sep 17 00:00:00 2001 From: Nikolay Kim Date: Fri, 16 Mar 2018 20:56:23 -0700 Subject: [PATCH] simplify h1 parse --- src/client/parser.rs | 4 +++- src/server/h1.rs | 42 ++++++++++++++++++++++++------------------ 2 files changed, 27 insertions(+), 19 deletions(-) diff --git a/src/client/parser.rs b/src/client/parser.rs index 8fe399009..6ffcd76e4 100644 --- a/src/client/parser.rs +++ b/src/client/parser.rs @@ -145,7 +145,9 @@ impl HttpResponseParser { // convert headers let mut hdrs = HeaderMap::new(); for header in headers[..headers_len].iter() { - if let Ok(name) = HeaderName::try_from(header.name) { + let n_start = header.name.as_ptr() as usize - bytes_ptr; + let n_end = n_start + header.name.len(); + if let Ok(name) = HeaderName::try_from(slice.slice(n_start, n_end)) { let v_start = header.value.as_ptr() as usize - bytes_ptr; let v_end = v_start + header.value.len(); let value = unsafe { diff --git a/src/server/h1.rs b/src/server/h1.rs index f9a5c4c07..b7055ea05 100644 --- a/src/server/h1.rs +++ b/src/server/h1.rs @@ -522,28 +522,34 @@ impl Reader { // convert headers let msg = settings.get_http_message(); - for header in headers[..headers_len].iter() { - if let Ok(name) = HeaderName::try_from(header.name) { - let v_start = header.value.as_ptr() as usize - bytes_ptr; - let v_end = v_start + header.value.len(); - let value = unsafe { - HeaderValue::from_shared_unchecked(slice.slice(v_start, v_end)) }; - msg.get_mut().headers.append(name, value); - } else { - return Err(ParseError::Header) + { + let msg_mut = msg.get_mut(); + for header in headers[..headers_len].iter() { + let n_start = header.name.as_ptr() as usize - bytes_ptr; + let n_end = n_start + header.name.len(); + if let Ok(name) = HeaderName::try_from(slice.slice(n_start, n_end)) { + let v_start = header.value.as_ptr() as usize - bytes_ptr; + let v_end = v_start + header.value.len(); + let value = unsafe { + HeaderValue::from_shared_unchecked( + slice.slice(v_start, v_end)) }; + msg_mut.headers.append(name, value); + } else { + return Err(ParseError::Header) + } } + + msg_mut.uri = Uri::from_shared( + slice.slice(path.0, path.1)).map_err(ParseError::Uri)?; + msg_mut.method = method; + msg_mut.version = version; } - - let path = slice.slice(path.0, path.1); - let uri = Uri::from_shared(path).map_err(ParseError::Uri)?; - - msg.get_mut().uri = uri; - msg.get_mut().method = method; - msg.get_mut().version = version; msg }; - let decoder = if let Some(len) = msg.get_ref().headers.get(header::CONTENT_LENGTH) { + let decoder = if let Some(len) = + msg.get_ref().headers.get(header::CONTENT_LENGTH) + { // Content-Length if let Ok(s) = len.to_str() { if let Ok(len) = s.parse::() { @@ -570,7 +576,7 @@ impl Reader { if let Some(decoder) = decoder { let (psender, payload) = Payload::new(false); let info = PayloadInfo { - tx: PayloadType::new(&msg.get_mut().headers, psender), + tx: PayloadType::new(&msg.get_ref().headers, psender), decoder, }; msg.get_mut().payload = Some(payload);