mirror of
https://github.com/servo/servo.git
synced 2025-08-03 12:40:06 +01:00
Move trim_http_whitespace to net_traits.
This commit is contained in:
parent
6a1722e18d
commit
80fc666734
5 changed files with 47 additions and 52 deletions
|
@ -573,3 +573,27 @@ pub enum NetworkError {
|
||||||
/// SSL validation error that has to be handled in the HTML parser
|
/// SSL validation error that has to be handled in the HTML parser
|
||||||
SslValidation(Url),
|
SslValidation(Url),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Normalize `slice`, as defined by
|
||||||
|
/// [the Fetch Spec](https://fetch.spec.whatwg.org/#concept-header-value-normalize).
|
||||||
|
pub fn trim_http_whitespace(mut slice: &[u8]) -> &[u8] {
|
||||||
|
const HTTP_WS_BYTES: &'static [u8] = b"\x09\x0A\x0D\x20";
|
||||||
|
|
||||||
|
loop {
|
||||||
|
match slice.split_first() {
|
||||||
|
Some((first, remainder)) if HTTP_WS_BYTES.contains(first) =>
|
||||||
|
slice = remainder,
|
||||||
|
_ => break,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
loop {
|
||||||
|
match slice.split_last() {
|
||||||
|
Some((last, remainder)) if HTTP_WS_BYTES.contains(last) =>
|
||||||
|
slice = remainder,
|
||||||
|
_ => break,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
slice
|
||||||
|
}
|
||||||
|
|
|
@ -46,6 +46,7 @@ use js::jsapi::{JSContext, JS_ParseJSON, RootedValue};
|
||||||
use js::jsval::{JSVal, NullValue, UndefinedValue};
|
use js::jsval::{JSVal, NullValue, UndefinedValue};
|
||||||
use msg::constellation_msg::{PipelineId, ReferrerPolicy};
|
use msg::constellation_msg::{PipelineId, ReferrerPolicy};
|
||||||
use net_traits::CoreResourceMsg::Load;
|
use net_traits::CoreResourceMsg::Load;
|
||||||
|
use net_traits::trim_http_whitespace;
|
||||||
use net_traits::{AsyncResponseListener, AsyncResponseTarget, Metadata, NetworkError, RequestSource};
|
use net_traits::{AsyncResponseListener, AsyncResponseTarget, Metadata, NetworkError, RequestSource};
|
||||||
use net_traits::{LoadConsumer, LoadContext, LoadData, ResourceCORSData, CoreResourceThread, LoadOrigin};
|
use net_traits::{LoadConsumer, LoadContext, LoadData, ResourceCORSData, CoreResourceThread, LoadOrigin};
|
||||||
use network_listener::{NetworkListener, PreInvoke};
|
use network_listener::{NetworkListener, PreInvoke};
|
||||||
|
@ -1506,27 +1507,3 @@ pub fn is_field_value(slice: &[u8]) -> bool {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Normalize `self`, as defined by
|
|
||||||
/// [the Fetch Spec](https://fetch.spec.whatwg.org/#concept-header-value-normalize).
|
|
||||||
pub fn trim_http_whitespace(mut slice: &[u8]) -> &[u8] {
|
|
||||||
const HTTP_WS_BYTES: &'static [u8] = b"\x09\x0A\x0D\x20";
|
|
||||||
|
|
||||||
loop {
|
|
||||||
match slice.split_first() {
|
|
||||||
Some((first, remainder)) if HTTP_WS_BYTES.contains(first) =>
|
|
||||||
slice = remainder,
|
|
||||||
_ => break,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
loop {
|
|
||||||
match slice.split_last() {
|
|
||||||
Some((last, remainder)) if HTTP_WS_BYTES.contains(last) =>
|
|
||||||
slice = remainder,
|
|
||||||
_ => break,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
slice
|
|
||||||
}
|
|
||||||
|
|
|
@ -5,3 +5,25 @@
|
||||||
extern crate net_traits;
|
extern crate net_traits;
|
||||||
|
|
||||||
#[cfg(test)] mod image;
|
#[cfg(test)] mod image;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_trim_http_whitespace() {
|
||||||
|
fn test_trim(in_: &[u8], out: &[u8]) {
|
||||||
|
let b = net_traits::trim_http_whitespace(in_);
|
||||||
|
assert_eq!(b, out);
|
||||||
|
}
|
||||||
|
|
||||||
|
test_trim(b"", b"");
|
||||||
|
|
||||||
|
test_trim(b" ", b"");
|
||||||
|
test_trim(b"a", b"a");
|
||||||
|
test_trim(b" a", b"a");
|
||||||
|
test_trim(b"a ", b"a");
|
||||||
|
test_trim(b" a ", b"a");
|
||||||
|
|
||||||
|
test_trim(b"\t", b"");
|
||||||
|
test_trim(b"a", b"a");
|
||||||
|
test_trim(b"\ta", b"a");
|
||||||
|
test_trim(b"a\t", b"a");
|
||||||
|
test_trim(b"\ta\t", b"a");
|
||||||
|
}
|
||||||
|
|
|
@ -1,27 +0,0 @@
|
||||||
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
||||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
||||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
||||||
|
|
||||||
use script::dom::xmlhttprequest::trim_http_whitespace;
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn test_trim_http_whitespace() {
|
|
||||||
fn test_trim(in_: &[u8], out: &[u8]) {
|
|
||||||
let b = trim_http_whitespace(in_);
|
|
||||||
assert_eq!(b, out);
|
|
||||||
}
|
|
||||||
|
|
||||||
test_trim(b"", b"");
|
|
||||||
|
|
||||||
test_trim(b" ", b"");
|
|
||||||
test_trim(b"a", b"a");
|
|
||||||
test_trim(b" a", b"a");
|
|
||||||
test_trim(b"a ", b"a");
|
|
||||||
test_trim(b" a ", b"a");
|
|
||||||
|
|
||||||
test_trim(b"\t", b"");
|
|
||||||
test_trim(b"a", b"a");
|
|
||||||
test_trim(b"\ta", b"a");
|
|
||||||
test_trim(b"a\t", b"a");
|
|
||||||
test_trim(b"\ta\t", b"a");
|
|
||||||
}
|
|
|
@ -15,5 +15,4 @@ extern crate url;
|
||||||
#[cfg(test)] mod dom {
|
#[cfg(test)] mod dom {
|
||||||
mod bindings;
|
mod bindings;
|
||||||
mod blob;
|
mod blob;
|
||||||
mod xmlhttprequest;
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue