Comparison

net/server_select.lua @ 2997:6ccaefea80ec

Merge with tip.
author Tobias Markmann <tm@ayena.de>
date Fri, 12 Mar 2010 18:41:05 +0100
parent 2996:b0515ed4d9d7
parent 2740:2442c54cf9ec
child 2998:36c169ed1576
comparison
equal deleted inserted replaced
2996:b0515ed4d9d7 2997:6ccaefea80ec
428 end 428 end
429 return noread, nosend 429 return noread, nosend
430 end 430 end
431 local _readbuffer = function( ) -- this function reads data 431 local _readbuffer = function( ) -- this function reads data
432 local buffer, err, part = receive( socket, pattern ) -- receive buffer with "pattern" 432 local buffer, err, part = receive( socket, pattern ) -- receive buffer with "pattern"
433 if not err or (err == "wantread" or err == "timeout") or string_len(part) > 0 then -- received something 433 if not err or (err == "wantread" or err == "timeout") or (part and string_len(part) > 0) then -- received something
434 local buffer = buffer or part or "" 434 local buffer = buffer or part or ""
435 local len = string_len( buffer ) 435 local len = string_len( buffer )
436 if len > maxreadlen then 436 if len > maxreadlen then
437 disconnect( handler, "receive buffer exceeded" ) 437 disconnect( handler, "receive buffer exceeded" )
438 handler.close( true ) 438 handler:close( true )
439 return false 439 return false
440 end 440 end
441 local count = len * STAT_UNIT 441 local count = len * STAT_UNIT
442 readtraffic = readtraffic + count 442 readtraffic = readtraffic + count
443 _readtraffic = _readtraffic + count 443 _readtraffic = _readtraffic + count
446 return dispatch( handler, buffer, err ) 446 return dispatch( handler, buffer, err )
447 else -- connections was closed or fatal error 447 else -- connections was closed or fatal error
448 out_put( "server.lua: client ", tostring(ip), ":", tostring(clientport), " read error: ", tostring(err) ) 448 out_put( "server.lua: client ", tostring(ip), ":", tostring(clientport), " read error: ", tostring(err) )
449 fatalerror = true 449 fatalerror = true
450 disconnect( handler, err ) 450 disconnect( handler, err )
451 _ = handler and handler.close( ) 451 _ = handler and handler:close( )
452 return false 452 return false
453 end 453 end
454 end 454 end
455 local _sendbuffer = function( ) -- this function sends data 455 local _sendbuffer = function( ) -- this function sends data
456 local succ, err, byte, buffer, count; 456 local succ, err, byte, buffer, count;
470 bufferqueuelen = 0 470 bufferqueuelen = 0
471 bufferlen = 0 471 bufferlen = 0
472 _sendlistlen = removesocket( _sendlist, socket, _sendlistlen ) -- delete socket from writelist 472 _sendlistlen = removesocket( _sendlist, socket, _sendlistlen ) -- delete socket from writelist
473 _ = needtls and handler:starttls(nil, true) 473 _ = needtls and handler:starttls(nil, true)
474 _writetimes[ handler ] = nil 474 _writetimes[ handler ] = nil
475 _ = toclose and handler.close( ) 475 _ = toclose and handler:close( )
476 return true 476 return true
477 elseif byte and ( err == "timeout" or err == "wantwrite" ) then -- want write 477 elseif byte and ( err == "timeout" or err == "wantwrite" ) then -- want write
478 buffer = string_sub( buffer, byte + 1, bufferlen ) -- new buffer 478 buffer = string_sub( buffer, byte + 1, bufferlen ) -- new buffer
479 bufferqueue[ 1 ] = buffer -- insert new buffer in queue 479 bufferqueue[ 1 ] = buffer -- insert new buffer in queue
480 bufferqueuelen = 1 480 bufferqueuelen = 1
483 return true 483 return true
484 else -- connection was closed during sending or fatal error 484 else -- connection was closed during sending or fatal error
485 out_put( "server.lua: client ", tostring(ip), ":", tostring(clientport), " write error: ", tostring(err) ) 485 out_put( "server.lua: client ", tostring(ip), ":", tostring(clientport), " write error: ", tostring(err) )
486 fatalerror = true 486 fatalerror = true
487 disconnect( handler, err ) 487 disconnect( handler, err )
488 _ = handler and handler.close( ) 488 _ = handler and handler:close( )
489 return false 489 return false
490 end 490 end
491 end 491 end
492 492
493 -- Set the sslctx 493 -- Set the sslctx