2014-09-06 20:44:53 -07:00
#![ feature(phase, macro_rules) ]
2014-09-07 01:19:36 -07:00
#![ allow(non_camel_case_types) ]
#[ phase(plugin) ]
extern crate serde2_macros ;
2014-09-06 20:44:53 -07:00
extern crate serde2 ;
extern crate serialize ;
extern crate test ;
2014-09-07 01:19:36 -07:00
use std ::io ;
use std ::io ::MemWriter ;
2014-09-06 20:44:53 -07:00
use test ::Bencher ;
//use serde2::de;
2014-09-07 01:19:36 -07:00
use serde2 ::json ;
2014-09-06 20:44:53 -07:00
use serde2 ::Serialize ;
use serde2 ::ser ;
#[ deriving(Encodable, Decodable) ]
#[ deriving_serializable ]
//#[deriving_deserializable]
struct Http {
protocol : HttpProtocol ,
status : u32 ,
host_status : u32 ,
up_status : u32 ,
method : HttpMethod ,
content_type : String ,
user_agent : String ,
referer : String ,
request_uri : String ,
}
#[ deriving(Show, Encodable, Decodable, FromPrimitive) ]
enum HttpProtocol {
HTTP_PROTOCOL_UNKNOWN ,
HTTP10 ,
HTTP11 ,
}
impl < S : ser ::VisitorState < R > , R > ser ::Serialize < S , R > for HttpProtocol {
#[ inline ]
fn serialize ( & self , s : & mut S ) -> R {
s . visit_uint ( * self as uint )
}
}
/*
impl < D : de ::Deserializer < E > , E > de ::Deserializable < D , E > for HttpProtocol {
#[ inline ]
fn deserialize_token ( d : & mut D , token : de ::Token ) -> Result < HttpProtocol , E > {
d . expect_from_primitive ( token )
}
}
* /
#[ deriving(Show, Encodable, Decodable, FromPrimitive) ]
enum HttpMethod {
METHOD_UNKNOWN ,
GET ,
POST ,
DELETE ,
PUT ,
HEAD ,
PURGE ,
OPTIONS ,
PROPFIND ,
MKCOL ,
PATCH ,
}
impl < S : ser ::VisitorState < R > , R > ser ::Serialize < S , R > for HttpMethod {
#[ inline ]
fn serialize ( & self , s : & mut S ) -> R {
s . visit_uint ( * self as uint )
}
}
/*
impl < D : de ::Deserializer < E > , E > de ::Deserializable < D , E > for HttpMethod {
#[ inline ]
fn deserialize_token ( d : & mut D , token : de ::Token ) -> Result < HttpMethod , E > {
d . expect_from_primitive ( token )
}
}
* /
#[ deriving(Show, Encodable, Decodable, FromPrimitive) ]
enum CacheStatus {
CACHESTATUS_UNKNOWN ,
Miss ,
Expired ,
Hit ,
}
impl < S : ser ::VisitorState < R > , R > ser ::Serialize < S , R > for CacheStatus {
#[ inline ]
fn serialize ( & self , s : & mut S ) -> R {
s . visit_uint ( * self as uint )
}
}
/*
impl < D : de ::Deserializer < E > , E > de ::Deserializable < D , E > for CacheStatus {
#[ inline ]
fn deserialize_token ( d : & mut D , token : de ::Token ) -> Result < CacheStatus , E > {
d . expect_from_primitive ( token )
}
}
* /
#[ deriving(Encodable, Decodable) ]
#[ deriving_serializable ]
//#[deriving_deserializable]
struct Origin {
ip : String ,
port : u32 ,
hostname : String ,
protocol : OriginProtocol ,
}
#[ deriving(Show, Encodable, Decodable, FromPrimitive) ]
enum OriginProtocol {
ORIGIN_PROTOCOL_UNKNOWN ,
HTTP ,
HTTPS ,
}
impl < S : ser ::VisitorState < R > , R > ser ::Serialize < S , R > for OriginProtocol {
#[ inline ]
fn serialize ( & self , s : & mut S ) -> R {
s . visit_uint ( * self as uint )
}
}
/*
impl < D : de ::Deserializer < E > , E > de ::Deserializable < D , E > for OriginProtocol {
#[ inline ]
fn deserialize_token ( d : & mut D , token : de ::Token ) -> Result < OriginProtocol , E > {
d . expect_from_primitive ( token )
}
}
* /
#[ deriving(Show, Encodable, Decodable, FromPrimitive) ]
enum ZonePlan {
ZONEPLAN_UNKNOWN ,
FREE ,
PRO ,
BIZ ,
ENT ,
}
impl < S : ser ::VisitorState < R > , R > ser ::Serialize < S , R > for ZonePlan {
#[ inline ]
fn serialize ( & self , s : & mut S ) -> R {
s . visit_uint ( * self as uint )
}
}
/*
impl < D : de ::Deserializer < E > , E > de ::Deserializable < D , E > for ZonePlan {
#[ inline ]
fn deserialize_token ( d : & mut D , token : de ::Token ) -> Result < ZonePlan , E > {
d . expect_from_primitive ( token )
}
}
* /
#[ deriving(Show, Encodable, Decodable, FromPrimitive) ]
enum Country {
UNKNOWN ,
A1 ,
A2 ,
O1 ,
AD ,
AE ,
AF ,
AG ,
AI ,
AL ,
AM ,
AO ,
AP ,
AQ ,
AR ,
AS ,
AT ,
AU ,
AW ,
AX ,
AZ ,
BA ,
BB ,
BD ,
BE ,
BF ,
BG ,
BH ,
BI ,
BJ ,
BL ,
BM ,
BN ,
BO ,
BQ ,
BR ,
BS ,
BT ,
BV ,
BW ,
BY ,
BZ ,
CA ,
CC ,
CD ,
CF ,
CG ,
CH ,
CI ,
CK ,
CL ,
CM ,
CN ,
CO ,
CR ,
CU ,
CV ,
CW ,
CX ,
CY ,
CZ ,
DE ,
DJ ,
DK ,
DM ,
DO ,
DZ ,
EC ,
EE ,
EG ,
EH ,
ER ,
ES ,
ET ,
EU ,
FI ,
FJ ,
FK ,
FM ,
FO ,
FR ,
GA ,
GB ,
GD ,
GE ,
GF ,
GG ,
GH ,
GI ,
GL ,
GM ,
GN ,
GP ,
GQ ,
GR ,
GS ,
GT ,
GU ,
GW ,
GY ,
HK ,
HM ,
HN ,
HR ,
HT ,
HU ,
ID ,
IE ,
IL ,
IM ,
IN ,
IO ,
IQ ,
IR ,
IS ,
IT ,
JE ,
JM ,
JO ,
JP ,
KE ,
KG ,
KH ,
KI ,
KM ,
KN ,
KP ,
KR ,
KW ,
KY ,
KZ ,
LA ,
LB ,
LC ,
LI ,
LK ,
LR ,
LS ,
LT ,
LU ,
LV ,
LY ,
MA ,
MC ,
MD ,
ME ,
MF ,
MG ,
MH ,
MK ,
ML ,
MM ,
MN ,
MO ,
MP ,
MQ ,
MR ,
MS ,
MT ,
MU ,
MV ,
MW ,
MX ,
MY ,
MZ ,
NA ,
NC ,
NE ,
NF ,
NG ,
NI ,
NL ,
NO ,
NP ,
NR ,
NU ,
NZ ,
OM ,
PA ,
PE ,
PF ,
PG ,
PH ,
PK ,
PL ,
PM ,
PN ,
PR ,
PS ,
PT ,
PW ,
PY ,
QA ,
RE ,
RO ,
RS ,
RU ,
RW ,
SA ,
SB ,
SC ,
SD ,
SE ,
SG ,
SH ,
SI ,
SJ ,
SK ,
SL ,
SM ,
SN ,
SO ,
SR ,
SS ,
ST ,
SV ,
SX ,
SY ,
SZ ,
TC ,
TD ,
TF ,
TG ,
TH ,
TJ ,
TK ,
TL ,
TM ,
TN ,
TO ,
TR ,
TT ,
TV ,
TW ,
TZ ,
UA ,
UG ,
UM ,
US ,
UY ,
UZ ,
VA ,
VC ,
VE ,
VG ,
VI ,
VN ,
VU ,
WF ,
WS ,
XX ,
YE ,
YT ,
ZA ,
ZM ,
ZW ,
}
impl < S : ser ::VisitorState < R > , R > ser ::Serialize < S , R > for Country {
#[ inline ]
fn serialize ( & self , s : & mut S ) -> R {
s . visit_uint ( * self as uint )
}
}
/*
impl < D : de ::Deserializer < E > , E > de ::Deserializable < D , E > for Country {
#[ inline ]
fn deserialize_token ( d : & mut D , token : de ::Token ) -> Result < Country , E > {
d . expect_from_primitive ( token )
}
}
* /
#[ deriving(Encodable, Decodable) ]
2014-09-07 01:19:36 -07:00
#[ deriving_serializable ]
2014-09-06 20:44:53 -07:00
//#[deriving_deserializable]
struct Log {
timestamp : i64 ,
zone_id : u32 ,
zone_plan : ZonePlan ,
http : Http ,
origin : Origin ,
country : Country ,
cache_status : CacheStatus ,
server_ip : String ,
server_name : String ,
remote_ip : String ,
bytes_dlv : u64 ,
ray_id : String ,
}
impl Log {
fn new ( ) -> Log {
Log {
2014-09-07 01:02:19 -07:00
timestamp : 2837513946597 ,
2014-09-06 20:44:53 -07:00
zone_id : 123456 ,
zone_plan : FREE ,
http : Http {
protocol : HTTP11 ,
status : 200 ,
host_status : 503 ,
up_status : 520 ,
method : GET ,
content_type : " text/html " . to_string ( ) ,
user_agent : " Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36 " . to_string ( ) ,
referer : " https://www.cloudflare.com/ " . to_string ( ) ,
request_uri : " /cdn-cgi/trace " . to_string ( ) ,
} ,
origin : Origin {
ip : " 1.2.3.4 " . to_string ( ) ,
port : 8000 ,
hostname : " www.example.com " . to_string ( ) ,
protocol : HTTPS ,
} ,
country : US ,
cache_status : Hit ,
server_ip : " 192.168.1.1 " . to_string ( ) ,
server_name : " metal.cloudflare.com " . to_string ( ) ,
remote_ip : " 10.1.2.3 " . to_string ( ) ,
bytes_dlv : 123456 ,
ray_id : " 10c73629cce30078-LAX " . to_string ( ) ,
}
}
}
2014-09-07 01:19:36 -07:00
macro_rules ! likely (
( $val :expr ) = > {
{
extern {
#[ link_name = " llvm.expect.i8 " ]
fn expect ( val : u8 , expected_val : u8 ) -> u8 ;
}
let x : bool = $val ;
unsafe { expect ( x as u8 , 1 ) ! = 0 }
}
}
)
macro_rules ! unlikely (
( $val :expr ) = > {
{
extern {
#[ link_name = " llvm.expect.i8 " ]
fn expect ( val : u8 , expected_val : u8 ) -> u8 ;
}
let x : bool = $val ;
unsafe { expect ( x as u8 , 0 ) ! = 0 }
}
}
)
struct MyMemWriter0 {
buf : Vec < u8 > ,
}
impl MyMemWriter0 {
/*
pub fn new ( ) -> MyMemWriter0 {
MyMemWriter0 ::with_capacity ( 128 )
}
* /
pub fn with_capacity ( cap : uint ) -> MyMemWriter0 {
MyMemWriter0 {
buf : Vec ::with_capacity ( cap )
}
}
2014-09-06 20:44:53 -07:00
#[ inline ]
2014-09-07 01:19:36 -07:00
pub fn unwrap ( self ) -> Vec < u8 > { self . buf }
}
impl Writer for MyMemWriter0 {
#[ inline ]
fn write ( & mut self , buf : & [ u8 ] ) -> io ::IoResult < ( ) > {
self . buf . push_all ( buf ) ;
Ok ( ( ) )
}
}
struct MyMemWriter1 {
buf : Vec < u8 > ,
}
impl MyMemWriter1 {
/*
pub fn new ( ) -> MyMemWriter1 {
MyMemWriter1 ::with_capacity ( 128 )
}
* /
pub fn with_capacity ( cap : uint ) -> MyMemWriter1 {
MyMemWriter1 {
buf : Vec ::with_capacity ( cap )
2014-09-06 20:44:53 -07:00
}
2014-09-07 01:19:36 -07:00
}
#[ inline ]
pub fn unwrap ( self ) -> Vec < u8 > { self . buf }
}
// LLVM isn't yet able to lower `Vec::push_all` into a memcpy, so this helps
// MemWriter eke out that last bit of performance.
//#[inline(always)]
fn push_all_bytes ( dst : & mut Vec < u8 > , src : & [ u8 ] ) {
let dst_len = dst . len ( ) ;
let src_len = src . len ( ) ;
dst . reserve_additional ( src_len ) ;
unsafe {
// we would have failed if `reserve_additional` overflowed.
dst . set_len ( dst_len + src_len ) ;
::std ::ptr ::copy_nonoverlapping_memory (
dst . as_mut_ptr ( ) . offset ( dst_len as int ) ,
src . as_ptr ( ) ,
src_len ) ;
}
}
impl Writer for MyMemWriter1 {
#[ inline ]
fn write ( & mut self , buf : & [ u8 ] ) -> io ::IoResult < ( ) > {
push_all_bytes ( & mut self . buf , buf ) ;
Ok ( ( ) )
}
}
pub struct MyMemWriter2 {
buf : Vec < u8 > ,
pos : uint ,
}
impl MyMemWriter2 {
/// Create a new `MemWriter`.
#[ inline ]
pub fn new ( ) -> MyMemWriter2 {
MyMemWriter2 ::with_capacity ( 128 )
}
/// Create a new `MemWriter`, allocating at least `n` bytes for
/// the internal buffer.
#[ inline ]
pub fn with_capacity ( n : uint ) -> MyMemWriter2 {
MyMemWriter2 { buf : Vec ::with_capacity ( n ) , pos : 0 }
}
/// Acquires an immutable reference to the underlying buffer of this
/// `MemWriter`.
///
/// No method is exposed for acquiring a mutable reference to the buffer
/// because it could corrupt the state of this `MemWriter`.
#[ inline ]
pub fn get_ref < ' a > ( & ' a self ) -> & ' a [ u8 ] { self . buf . as_slice ( ) }
/// Unwraps this `MemWriter`, returning the underlying buffer
#[ inline ]
pub fn unwrap ( self ) -> Vec < u8 > { self . buf }
}
2014-09-06 20:44:53 -07:00
2014-09-07 01:19:36 -07:00
impl Writer for MyMemWriter2 {
#[ inline ]
fn write ( & mut self , buf : & [ u8 ] ) -> io ::IoResult < ( ) > {
if self . pos ! = self . buf . len ( ) {
push_all_bytes ( & mut self . buf , buf ) ;
} else {
// Make sure the internal buffer is as least as big as where we
// currently are
let difference = self . pos as i64 - self . buf . len ( ) as i64 ;
if difference > 0 {
self . buf . grow ( difference as uint , & 0 ) ;
}
// Figure out what bytes will be used to overwrite what's currently
// there (left), and what will be appended on the end (right)
let cap = self . buf . len ( ) - self . pos ;
let ( left , right ) = if cap < = buf . len ( ) {
( buf . slice_to ( cap ) , buf . slice_from ( cap ) )
} else {
( buf , & [ ] )
} ;
// Do the necessary writes
if left . len ( ) > 0 {
::std ::slice ::bytes ::copy_memory ( self . buf . mut_slice_from ( self . pos ) , left ) ;
}
if right . len ( ) > 0 {
push_all_bytes ( & mut self . buf , right ) ;
2014-09-06 20:44:53 -07:00
}
}
2014-09-07 01:19:36 -07:00
// Bump us forward
self . pos + = buf . len ( ) ;
Ok ( ( ) )
2014-09-06 20:44:53 -07:00
}
}
2014-09-07 01:19:36 -07:00
fn combine ( seek : io ::SeekStyle , cur : uint , end : uint , offset : i64 ) -> io ::IoResult < u64 > {
// compute offset as signed and clamp to prevent overflow
let pos = match seek {
io ::SeekSet = > 0 ,
io ::SeekEnd = > end ,
io ::SeekCur = > cur ,
} as i64 ;
if offset + pos < 0 {
Err ( io ::IoError {
kind : io ::InvalidInput ,
desc : " invalid seek to a negative offset " ,
detail : None
} )
} else {
Ok ( ( offset + pos ) as u64 )
}
}
impl Seek for MyMemWriter2 {
#[ inline ]
fn tell ( & self ) -> io ::IoResult < u64 > { Ok ( self . pos as u64 ) }
#[ inline ]
fn seek ( & mut self , pos : i64 , style : io ::SeekStyle ) -> io ::IoResult < ( ) > {
let new = try ! ( combine ( style , self . pos , self . buf . len ( ) , pos ) ) ;
self . pos = new as uint ;
Ok ( ( ) )
}
}
pub struct MyMemWriter3 {
buf : Vec < u8 > ,
pos : uint ,
}
impl MyMemWriter3 {
/// Create a new `MemWriter`.
#[ inline ]
pub fn new ( ) -> MyMemWriter3 {
MyMemWriter3 ::with_capacity ( 128 )
}
/// Create a new `MemWriter`, allocating at least `n` bytes for
/// the internal buffer.
#[ inline ]
pub fn with_capacity ( n : uint ) -> MyMemWriter3 {
MyMemWriter3 { buf : Vec ::with_capacity ( n ) , pos : 0 }
}
/// Acquires an immutable reference to the underlying buffer of this
/// `MemWriter`.
///
/// No method is exposed for acquiring a mutable reference to the buffer
/// because it could corrupt the state of this `MemWriter`.
#[ inline ]
pub fn get_ref < ' a > ( & ' a self ) -> & ' a [ u8 ] { self . buf . as_slice ( ) }
/// Unwraps this `MemWriter`, returning the underlying buffer
#[ inline ]
pub fn unwrap ( self ) -> Vec < u8 > { self . buf }
}
impl Writer for MyMemWriter3 {
#[ inline ]
fn write ( & mut self , buf : & [ u8 ] ) -> io ::IoResult < ( ) > {
// Make sure the internal buffer is as least as big as where we
// currently are
let difference = self . pos as i64 - self . buf . len ( ) as i64 ;
if difference > 0 {
self . buf . grow ( difference as uint , & 0 ) ;
}
// Figure out what bytes will be used to overwrite what's currently
// there (left), and what will be appended on the end (right)
let cap = self . buf . len ( ) - self . pos ;
let ( left , right ) = if cap < = buf . len ( ) {
( buf . slice_to ( cap ) , buf . slice_from ( cap ) )
} else {
( buf , & [ ] )
} ;
// Do the necessary writes
if left . len ( ) > 0 {
::std ::slice ::bytes ::copy_memory ( self . buf . mut_slice_from ( self . pos ) , left ) ;
}
if right . len ( ) > 0 {
push_all_bytes ( & mut self . buf , right ) ;
}
// Bump us forward
self . pos + = buf . len ( ) ;
Ok ( ( ) )
}
}
2014-09-06 20:44:53 -07:00
#[ bench ]
fn bench_encoder ( b : & mut Bencher ) {
let log = Log ::new ( ) ;
let json = serialize ::json ::encode ( & log ) ;
b . bytes = json . len ( ) as u64 ;
b . iter ( | | {
//for _ in range(0u, 1000) {
let _json = serialize ::json ::encode ( & log ) ;
//}
} ) ;
}
#[ bench ]
fn bench_serializer ( b : & mut Bencher ) {
let log = Log ::new ( ) ;
let json = json ::to_vec ( & log ) . unwrap ( ) ;
b . bytes = json . len ( ) as u64 ;
b . iter ( | | {
//for _ in range(0u, 1000) {
let _json = json ::to_vec ( & log ) . unwrap ( ) ;
//}
} ) ;
}
#[ bench ]
fn bench_copy ( b : & mut Bencher ) {
let s = r # "{"timestamp":2837513946597,"zone_id":123456,"zone_plan":"FREE","http":{"protocol":"HTTP11","status":200,"host_status":503,"up_status":520,"method":"GET","content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":"HTTPS"},"country":"US","cache_status":"Hit","server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
let json = Vec ::from_slice ( s . as_bytes ( ) ) ;
b . bytes = json . len ( ) as u64 ;
b . iter ( | | {
let _json = Vec ::from_slice ( s . as_bytes ( ) ) ;
} ) ;
}
fn manual_no_escape < W : Writer > ( mut wr : W , log : & Log ) {
wr . write_str ( " { \" timestamp \" : " ) . unwrap ( ) ;
( write! ( wr , " {} " , log . timestamp ) ) . unwrap ( ) ;
wr . write_str ( " , \" zone_id \" : " ) . unwrap ( ) ;
( write! ( wr , " {} " , log . zone_id ) ) . unwrap ( ) ;
wr . write_str ( " , \" zone_plan \" : " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
( write! ( wr , " {} " , log . zone_plan as uint ) ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
wr . write_str ( " , \" http \" :{ \" protocol \" : " ) . unwrap ( ) ;
( write! ( wr , " {} " , log . http . protocol as uint ) ) . unwrap ( ) ;
wr . write_str ( " , \" status \" : " ) . unwrap ( ) ;
( write! ( wr , " {} " , log . http . status ) ) . unwrap ( ) ;
wr . write_str ( " , \" host_status \" : " ) . unwrap ( ) ;
( write! ( wr , " {} " , log . http . host_status ) ) . unwrap ( ) ;
wr . write_str ( " , \" up_status \" : " ) . unwrap ( ) ;
( write! ( wr , " {} " , log . http . up_status ) ) . unwrap ( ) ;
wr . write_str ( " , \" method \" : " ) . unwrap ( ) ;
( write! ( wr , " {} " , log . http . method as uint ) ) . unwrap ( ) ;
wr . write_str ( " , \" content_type \" : " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
( write! ( wr , " \" {} \" " , log . http . content_type ) ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
wr . write_str ( " , \" user_agent \" : " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
( write! ( wr , " \" {} \" " , log . http . user_agent ) ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
wr . write_str ( " , \" referer \" : " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
( write! ( wr , " \" {} \" " , log . http . referer ) ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
wr . write_str ( " , \" request_uri \" : " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
( write! ( wr , " \" {} \" " , log . http . request_uri ) ) . unwrap ( ) ;
wr . write_str ( " }, \" origin \" :{ " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
2014-09-07 01:04:39 -07:00
wr . write_str ( " \" ip \" : " ) . unwrap ( ) ;
( write! ( wr , " \" {} \" " , log . origin . ip ) ) . unwrap ( ) ;
wr . write_str ( " , \" port \" : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
( write! ( wr , " {} " , log . origin . port ) ) . unwrap ( ) ;
wr . write_str ( " , \" hostname \" : " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
( write! ( wr , " \" {} \" " , log . origin . hostname ) ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
wr . write_str ( " , \" protocol \" : " ) . unwrap ( ) ;
( write! ( wr , " {} " , log . origin . protocol as uint ) ) . unwrap ( ) ;
wr . write_str ( " }, \" country \" : " ) . unwrap ( ) ;
( write! ( wr , " {} " , log . country as uint ) ) . unwrap ( ) ;
wr . write_str ( " , \" cache_status \" : " ) . unwrap ( ) ;
( write! ( wr , " {} " , log . cache_status as uint ) ) . unwrap ( ) ;
wr . write_str ( " , \" server_ip \" : " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
( write! ( wr , " \" {} \" " , log . server_ip ) ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
wr . write_str ( " , \" server_name \" : " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
( write! ( wr , " \" {} \" " , log . server_name ) ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
wr . write_str ( " , \" remote_ip \" : " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
( write! ( wr , " \" {} \" " , log . remote_ip ) ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
wr . write_str ( " , \" bytes_dlv \" : " ) . unwrap ( ) ;
( write! ( wr , " {} " , log . bytes_dlv ) ) . unwrap ( ) ;
wr . write_str ( " , \" ray_id \" : " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
( write! ( wr , " \" {} \" " , log . ray_id ) ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
wr . write_str ( " } " ) . unwrap ( ) ;
}
fn manual_escape < W : Writer > ( mut wr : W , log : & Log ) {
2014-09-07 01:04:39 -07:00
wr . write_str ( " { " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " timestamp " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
( write! ( wr , " {} " , log . timestamp ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " zone_id " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
( write! ( wr , " {} " , log . zone_id ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " zone_plan " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
( write! ( wr , " {} " , log . zone_plan as int ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " http " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " :{ " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " protocol " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
( write! ( wr , " {} " , log . http . protocol as uint ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " status " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
( write! ( wr , " {} " , log . http . status ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " host_status " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
( write! ( wr , " {} " , log . http . host_status ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " up_status " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
( write! ( wr , " {} " , log . http . up_status ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " method " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
( write! ( wr , " {} " , log . http . method as uint ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " content_type " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , log . http . content_type . as_slice ( ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " user_agent " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , log . http . user_agent . as_slice ( ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " referer " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , log . http . referer . as_slice ( ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " request_uri " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , log . http . request_uri . as_slice ( ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " }, " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " origin " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " :{ " ) . unwrap ( ) ;
json ::escape_str ( & mut wr , " ip " ) . unwrap ( ) ;
wr . write_str ( " : " ) . unwrap ( ) ;
json ::escape_str ( & mut wr , log . origin . ip . as_slice ( ) ) . unwrap ( ) ;
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " port " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
( write! ( wr , " {} " , log . origin . port ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " hostname " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , log . origin . hostname . as_slice ( ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " protocol " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
( write! ( wr , " {} " , log . origin . protocol as uint ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " }, " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " country " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
( write! ( wr , " {} " , log . country as uint ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " cache_status " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
( write! ( wr , " {} " , log . cache_status as uint ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " server_ip " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , log . server_ip . as_slice ( ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " server_name " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , log . server_name . as_slice ( ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " remote_ip " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , log . remote_ip . as_slice ( ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " bytes_dlv " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
( write! ( wr , " {} " , log . bytes_dlv ) ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " , " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , " ray_id " ) . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
wr . write_str ( " : " ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
json ::escape_str ( & mut wr , log . ray_id . as_slice ( ) ) . unwrap ( ) ;
wr . write_str ( " } " ) . unwrap ( ) ;
}
#[ bench ]
fn bench_manual_mem_writer_no_escape ( b : & mut Bencher ) {
let log = Log ::new ( ) ;
2014-09-07 01:04:39 -07:00
let _s = r # "{"timestamp":2837513946597,"zone_id":123456,"zone_plan":1,"http":{"protocol":2,"status":200,"host_status":503,"up_status":520,"method":1,"content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":2},"country":238,"cache_status":3,"server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
2014-09-06 20:44:53 -07:00
let mut wr = MemWriter ::with_capacity ( 1024 ) ;
manual_no_escape ( wr . by_ref ( ) , & log ) ;
b . bytes = wr . unwrap ( ) . len ( ) as u64 ;
b . iter ( | | {
let mut wr = MemWriter ::with_capacity ( 1024 ) ;
manual_no_escape ( wr . by_ref ( ) , & log ) ;
let _json = wr . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
//let _json = String::from_utf8(_json).unwrap();
//assert_eq!(_s, _json.as_slice());
2014-09-06 20:44:53 -07:00
} ) ;
}
#[ bench ]
fn bench_manual_mem_writer_escape ( b : & mut Bencher ) {
let log = Log ::new ( ) ;
2014-09-07 01:04:39 -07:00
let _s = r # "{"timestamp":2837513946597,"zone_id":123456,"zone_plan":1,"http":{"protocol":2,"status":200,"host_status":503,"up_status":520,"method":1,"content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":2},"country":238,"cache_status":3,"server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
2014-09-06 20:44:53 -07:00
let mut wr = MemWriter ::with_capacity ( 1024 ) ;
manual_escape ( wr . by_ref ( ) , & log ) ;
b . bytes = wr . unwrap ( ) . len ( ) as u64 ;
b . iter ( | | {
let mut wr = MemWriter ::with_capacity ( 1024 ) ;
manual_escape ( wr . by_ref ( ) , & log ) ;
let _json = wr . unwrap ( ) ;
2014-09-07 01:04:39 -07:00
//let _json = String::from_utf8(_json).unwrap();
//assert_eq!(_s, _json.as_slice());
2014-09-06 20:44:53 -07:00
} ) ;
}
#[ bench ]
fn bench_manual_my_mem_writer0_no_escape ( b : & mut Bencher ) {
let log = Log ::new ( ) ;
let _s = r # "{"timestamp":2837513946597,"zone_id":123456,"zone_plan":"FREE","http":{"protocol":"HTTP11","status":200,"host_status":503,"up_status":520,"method":"GET","content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":"HTTPS"},"country":"US","cache_status":"Hit","server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
let mut wr = MyMemWriter0 ::with_capacity ( 1000 ) ;
manual_no_escape ( wr . by_ref ( ) , & log ) ;
b . bytes = wr . unwrap ( ) . len ( ) as u64 ;
b . iter ( | | {
let mut wr = MyMemWriter0 ::with_capacity ( 1024 ) ;
manual_no_escape ( wr . by_ref ( ) , & log ) ;
let _json = wr . unwrap ( ) ;
//let _json = String::from_utf8(wr.unwrap()).unwrap();
/*
assert_eq! ( _s , _json . as_slice ( ) ) ;
* /
} ) ;
}
#[ bench ]
fn bench_manual_my_mem_writer0_escape ( b : & mut Bencher ) {
let log = Log ::new ( ) ;
let _s = r # "{"timestamp":2837513946597,"zone_id":123456,"zone_plan":"FREE","http":{"protocol":"HTTP11","status":200,"host_status":503,"up_status":520,"method":"GET","content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":"HTTPS"},"country":"US","cache_status":"Hit","server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
let mut wr = MemWriter ::with_capacity ( 1024 ) ;
manual_escape ( wr . by_ref ( ) , & log ) ;
b . bytes = wr . unwrap ( ) . len ( ) as u64 ;
b . iter ( | | {
let mut wr = MyMemWriter0 ::with_capacity ( 1024 ) ;
manual_escape ( wr . by_ref ( ) , & log ) ;
let _json = wr . unwrap ( ) ;
//let _json = String::from_utf8(wr.unwrap()).unwrap();
/*
assert_eq! ( _s , _json . as_slice ( ) ) ;
* /
} ) ;
}
#[ bench ]
fn bench_manual_my_mem_writer1_no_escape ( b : & mut Bencher ) {
let log = Log ::new ( ) ;
let _s = r # "{"timestamp":2837513946597,"zone_id":123456,"zone_plan":"FREE","http":{"protocol":"HTTP11","status":200,"host_status":503,"up_status":520,"method":"GET","content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":"HTTPS"},"country":"US","cache_status":"Hit","server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
let mut wr = MyMemWriter1 ::with_capacity ( 1000 ) ;
manual_no_escape ( wr . by_ref ( ) , & log ) ;
b . bytes = wr . unwrap ( ) . len ( ) as u64 ;
b . iter ( | | {
let mut wr = MyMemWriter1 ::with_capacity ( 1024 ) ;
manual_no_escape ( wr . by_ref ( ) , & log ) ;
let _json = wr . unwrap ( ) ;
//let _json = String::from_utf8(wr.unwrap()).unwrap();
/*
assert_eq! ( _s , _json . as_slice ( ) ) ;
* /
} ) ;
}
#[ bench ]
fn bench_manual_my_mem_writer1_escape ( b : & mut Bencher ) {
let log = Log ::new ( ) ;
let _s = r # "{"timestamp":2837513946597,"zone_id":123456,"zone_plan":"FREE","http":{"protocol":"HTTP11","status":200,"host_status":503,"up_status":520,"method":"GET","content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":"HTTPS"},"country":"US","cache_status":"Hit","server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
let mut wr = MyMemWriter1 ::with_capacity ( 1024 ) ;
manual_escape ( wr . by_ref ( ) , & log ) ;
b . bytes = wr . unwrap ( ) . len ( ) as u64 ;
b . iter ( | | {
let mut wr = MyMemWriter1 ::with_capacity ( 1024 ) ;
manual_escape ( wr . by_ref ( ) , & log ) ;
let _json = wr . unwrap ( ) ;
//let _json = String::from_utf8(wr.unwrap()).unwrap();
/*
assert_eq! ( _s , _json . as_slice ( ) ) ;
* /
} ) ;
}
#[ bench ]
fn bench_manual_my_mem_writer2_no_escape ( b : & mut Bencher ) {
let log = Log ::new ( ) ;
let _s = r # "{"timestamp":2837513946597,"zone_id":123456,"zone_plan":"FREE","http":{"protocol":"HTTP11","status":200,"host_status":503,"up_status":520,"method":"GET","content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":"HTTPS"},"country":"US","cache_status":"Hit","server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
let mut wr = MyMemWriter2 ::with_capacity ( 1000 ) ;
manual_no_escape ( wr . by_ref ( ) , & log ) ;
b . bytes = wr . unwrap ( ) . len ( ) as u64 ;
b . iter ( | | {
let mut wr = MyMemWriter2 ::with_capacity ( 1024 ) ;
manual_no_escape ( wr . by_ref ( ) , & log ) ;
let _json = wr . unwrap ( ) ;
//let _json = String::from_utf8(wr.unwrap()).unwrap();
/*
assert_eq! ( _s , _json . as_slice ( ) ) ;
* /
} ) ;
}
#[ bench ]
fn bench_manual_my_mem_writer2_escape ( b : & mut Bencher ) {
let log = Log ::new ( ) ;
let _s = r # "{"timestamp":2837513946597,"zone_id":123456,"zone_plan":"FREE","http":{"protocol":"HTTP11","status":200,"host_status":503,"up_status":520,"method":"GET","content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":"HTTPS"},"country":"US","cache_status":"Hit","server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
let mut wr = MyMemWriter2 ::with_capacity ( 1024 ) ;
manual_escape ( wr . by_ref ( ) , & log ) ;
b . bytes = wr . unwrap ( ) . len ( ) as u64 ;
b . iter ( | | {
let mut wr = MyMemWriter2 ::with_capacity ( 1024 ) ;
manual_escape ( wr . by_ref ( ) , & log ) ;
let _json = wr . unwrap ( ) ;
//let _json = String::from_utf8(wr.unwrap()).unwrap();
/*
assert_eq! ( _s , _json . as_slice ( ) ) ;
* /
} ) ;
}
#[ bench ]
fn bench_manual_my_mem_writer3_no_escape ( b : & mut Bencher ) {
let log = Log ::new ( ) ;
let _s = r # "{"timestamp":2837513946597,"zone_id":123456,"zone_plan":"FREE","http":{"protocol":"HTTP11","status":200,"host_status":503,"up_status":520,"method":"GET","content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":"HTTPS"},"country":"US","cache_status":"Hit","server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
let mut wr = MyMemWriter3 ::with_capacity ( 1000 ) ;
manual_no_escape ( wr . by_ref ( ) , & log ) ;
b . bytes = wr . unwrap ( ) . len ( ) as u64 ;
b . iter ( | | {
let mut wr = MyMemWriter3 ::with_capacity ( 1024 ) ;
manual_no_escape ( wr . by_ref ( ) , & log ) ;
let _json = wr . unwrap ( ) ;
//let _json = String::from_utf8(wr.unwrap()).unwrap();
/*
assert_eq! ( _s , _json . as_slice ( ) ) ;
* /
} ) ;
}
#[ bench ]
fn bench_manual_my_mem_writer3_escape ( b : & mut Bencher ) {
let log = Log ::new ( ) ;
let _s = r # "{"timestamp":2837513946597,"zone_id":123456,"zone_plan":"FREE","http":{"protocol":"HTTP11","status":200,"host_status":503,"up_status":520,"method":"GET","content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":"HTTPS"},"country":"US","cache_status":"Hit","server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
let mut wr = MyMemWriter3 ::with_capacity ( 1024 ) ;
manual_escape ( wr . by_ref ( ) , & log ) ;
b . bytes = wr . unwrap ( ) . len ( ) as u64 ;
b . iter ( | | {
let mut wr = MyMemWriter3 ::with_capacity ( 1024 ) ;
manual_escape ( wr . by_ref ( ) , & log ) ;
let _json = wr . unwrap ( ) ;
//let _json = String::from_utf8(wr.unwrap()).unwrap();
/*
assert_eq! ( _s , _json . as_slice ( ) ) ;
* /
} ) ;
}
2014-09-07 01:19:36 -07:00
/*
2014-09-06 20:44:53 -07:00
fn direct < W : Writer > ( wr : W , log : & Log ) {
2014-09-07 01:19:36 -07:00
use serde2 ::ser ::VisitorState ;
2014-09-06 20:44:53 -07:00
let mut serializer = json ::Serializer ::new ( wr ) ;
2014-09-07 01:19:36 -07:00
serializer . serialize_struct_start ( " Log " , 12 ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
2014-09-07 01:19:36 -07:00
serializer . serialize_struct_elt ( " timestamp " , & log . timestamp ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " zone_id " , & log . zone_id ) . unwrap ( ) ;
2014-09-06 20:44:53 -07:00
serializer . serialize_struct_elt ( " zone_plan " , & ( log . zone_plan as uint ) ) . unwrap ( ) ;
serializer . serialize_struct_start ( " Http " , 9 ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " protocol " , & ( log . http . protocol as uint ) ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " status " , & log . http . status ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " host_status " , & log . http . host_status ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " up_status " , & log . http . up_status ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " method " , & ( log . http . method as uint ) ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " content_type " , & log . http . content_type ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " user_agent " , & log . http . user_agent ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " referer " , & log . http . referer . as_slice ( ) ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " request_uri " , & log . http . request_uri . as_slice ( ) ) . unwrap ( ) ;
serializer . serialize_struct_end ( ) . unwrap ( ) ;
serializer . serialize_struct_start ( " Origin " , 3 ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " port " , & log . origin . port ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " hostname " , & log . origin . hostname . as_slice ( ) ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " protocol " , & ( log . origin . protocol as uint ) ) . unwrap ( ) ;
serializer . serialize_struct_end ( ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " country " , & ( log . country as uint ) ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " cache_status " , & ( log . cache_status as uint ) ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " server_ip " , & log . server_ip . as_slice ( ) ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " server_name " , & log . server_name . as_slice ( ) ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " remote_ip " , & log . remote_ip . as_slice ( ) ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " bytes_dlv " , & log . bytes_dlv ) . unwrap ( ) ;
serializer . serialize_struct_elt ( " ray_id " , & log . ray_id . as_slice ( ) ) . unwrap ( ) ;
serializer . serialize_struct_end ( ) . unwrap ( ) ;
}
#[ bench ]
fn bench_direct_mem_writer ( b : & mut Bencher ) {
let log = Log ::new ( ) ;
let _s = r # "{"timestamp":2837513946597,"zone_id":123456,"zone_plan":"FREE","http":{"protocol":"HTTP11","status":200,"host_status":503,"up_status":520,"method":"GET","content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":"HTTPS"},"country":"US","cache_status":"Hit","server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
let mut wr = MemWriter ::with_capacity ( 1024 ) ;
direct ( wr . by_ref ( ) , & log ) ;
b . bytes = wr . unwrap ( ) . len ( ) as u64 ;
b . iter ( | | {
let mut wr = MemWriter ::with_capacity ( 1024 ) ;
direct ( wr . by_ref ( ) , & log ) ;
let _json = wr . unwrap ( ) ;
2014-09-07 01:19:36 -07:00
//let _json = String::from_utf8(_json).unwrap();
//assert_eq!(_s, _json.as_slice());
2014-09-06 20:44:53 -07:00
} ) ;
}
#[ bench ]
fn bench_direct_my_mem_writer0 ( b : & mut Bencher ) {
let log = Log ::new ( ) ;
let _s = r # "{"timestamp":2837513946597,"zone_id":123456,"zone_plan":"FREE","http":{"protocol":"HTTP11","status":200,"host_status":503,"up_status":520,"method":"GET","content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":"HTTPS"},"country":"US","cache_status":"Hit","server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
let mut wr = MyMemWriter0 ::with_capacity ( 1024 ) ;
direct ( wr . by_ref ( ) , & log ) ;
b . bytes = wr . unwrap ( ) . len ( ) as u64 ;
b . iter ( | | {
let mut wr = MyMemWriter0 ::with_capacity ( 1024 ) ;
direct ( wr . by_ref ( ) , & log ) ;
let _json = wr . unwrap ( ) ;
2014-09-07 01:19:36 -07:00
//let _json = String::from_utf8(_json).unwrap();
//assert_eq!(_s, _json.as_slice());
2014-09-06 20:44:53 -07:00
} ) ;
}
2014-09-07 01:19:36 -07:00
* /
2014-09-06 20:44:53 -07:00
2014-09-07 01:19:36 -07:00
/*
2014-09-06 20:44:53 -07:00
#[ bench ]
fn bench_decoder ( b : & mut Bencher ) {
let s = r # "{"timestamp":2837513946597,"zone_id":123456,"zone_plan":"FREE","http":{"protocol":"HTTP11","status":200,"host_status":503,"up_status":520,"method":"GET","content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":"HTTPS"},"country":"US","cache_status":"Hit","server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
b . bytes = s . len ( ) as u64 ;
b . iter ( | | {
let json = serialize ::json ::from_str ( s ) . unwrap ( ) ;
let mut decoder = serialize ::json ::Decoder ::new ( json ) ;
let _log : Log = serialize ::Decodable ::decode ( & mut decoder ) . unwrap ( ) ;
} ) ;
}
#[ bench ]
fn bench_deserializer ( b : & mut Bencher ) {
let s = r # "{"timestamp":25469139677502,"zone_id":123456,"zone_plan":1,"http":{"protocol":2,"status":200,"host_status":503,"up_status":520,"method":1,"content_type":"text/html","user_agent":"Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.146 Safari/537.36","referer":"https://www.cloudflare.com/","request_uri":"/cdn-cgi/trace"},"origin":{"ip":"1.2.3.4","port":8000,"hostname":"www.example.com","protocol":2},"country":238,"cache_status":3,"server_ip":"192.168.1.1","server_name":"metal.cloudflare.com","remote_ip":"10.1.2.3","bytes_dlv":123456,"ray_id":"10c73629cce30078-LAX"}"# ;
b . bytes = s . len ( ) as u64 ;
b . iter ( | | {
let _log : Log = json ::from_str ( s ) . unwrap ( ) ;
} ) ;
}
* /