mirror of
https://github.com/transmission/transmission
synced 2025-02-02 20:43:51 +00:00
random code optimization: when escaping http, use an if with a lot less comparisons rather than a switch
This commit is contained in:
parent
8f6e1dedf5
commit
5af45426d4
1 changed files with 6 additions and 24 deletions
|
@ -514,32 +514,14 @@ tr_http_escape( struct evbuffer * out,
|
|||
len = strlen( str );
|
||||
|
||||
for( i = 0; i < len; i++ ) {
|
||||
switch( str[i] ) {
|
||||
case ',': case '-': case '.':
|
||||
case '0': case '1': case '2': case '3': case '4':
|
||||
case '5': case '6': case '7': case '8': case '9':
|
||||
case 'a': case 'b': case 'c': case 'd': case 'e':
|
||||
case 'f': case 'g': case 'h': case 'i': case 'j':
|
||||
case 'k': case 'l': case 'm': case 'n': case 'o':
|
||||
case 'p': case 'q': case 'r': case 's': case 't':
|
||||
case 'u': case 'v': case 'w': case 'x': case 'y': case 'z':
|
||||
case 'A': case 'B': case 'C': case 'D': case 'E':
|
||||
case 'F': case 'G': case 'H': case 'I': case 'J':
|
||||
case 'K': case 'L': case 'M': case 'N': case 'O':
|
||||
case 'P': case 'Q': case 'R': case 'S': case 'T':
|
||||
case 'U': case 'V': case 'W': case 'X': case 'Y': case 'Z':
|
||||
if( str[i] == ',' || str[i] == '-' || str[i] == '.'
|
||||
|| ( '0' <= str[i] && str[i] <= '9' )
|
||||
|| ( 'a' <= str[i] && str[i] <= 'z' )
|
||||
|| ( 'A' <= str[i] && str[i] <= 'Z' )
|
||||
|| ( str[i] == '/' && !escape_slashes ) )
|
||||
evbuffer_add( out, &str[i], 1 );
|
||||
break;
|
||||
case '/':
|
||||
if(!escape_slashes) {
|
||||
evbuffer_add( out, &str[i], 1 );
|
||||
break;
|
||||
}
|
||||
/* Fall through. */
|
||||
default:
|
||||
else
|
||||
evbuffer_add_printf( out, "%%%02X", (unsigned)(str[i]&0xFF) );
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue