From 3f396078ab1d81254d08164b657d8cd1f9b5afe4 Mon Sep 17 00:00:00 2001 From: v2ray Date: Sat, 16 Jul 2016 13:22:34 +0200 Subject: [PATCH] remove unnecessary buffer --- proxy/http/server.go | 14 +++----------- 1 file changed, 3 insertions(+), 11 deletions(-) diff --git a/proxy/http/server.go b/proxy/http/server.go index 41fb7a100..453b04c9d 100644 --- a/proxy/http/server.go +++ b/proxy/http/server.go @@ -11,7 +11,6 @@ import ( "github.com/v2ray/v2ray-core/app" "github.com/v2ray/v2ray-core/app/dispatcher" - "github.com/v2ray/v2ray-core/common/alloc" v2io "github.com/v2ray/v2ray-core/common/io" "github.com/v2ray/v2ray-core/common/log" v2net "github.com/v2ray/v2ray-core/common/net" @@ -96,7 +95,7 @@ func parseHost(rawHost string, defaultPort v2net.Port) (v2net.Destination, error func (this *Server) handleConnection(conn internet.Connection) { defer conn.Close() timedReader := v2net.NewTimeOutReader(this.config.Timeout, conn) - reader := bufio.NewReader(timedReader) + reader := bufio.NewReaderSize(timedReader, 2048) request, err := http.ReadRequest(reader) if err != nil { @@ -139,11 +138,7 @@ func (this *Server) handleConnect(request *http.Request, destination v2net.Desti ContentLength: 0, Close: false, } - - buffer := alloc.NewSmallBuffer().Clear() - response.Write(buffer) - writer.Write(buffer.Value) - buffer.Release() + response.Write(writer) ray := this.packetDispatcher.DispatchToOutbound(destination) this.transport(reader, writer, ray) @@ -217,11 +212,8 @@ func (this *Server) GenerateResponse(statusCode int, status string) *http.Respon func (this *Server) handlePlainHTTP(request *http.Request, dest v2net.Destination, reader *bufio.Reader, writer io.Writer) { if len(request.URL.Host) <= 0 { response := this.GenerateResponse(400, "Bad Request") + response.Write(writer) - buffer := alloc.NewSmallBuffer().Clear() - response.Write(buffer) - writer.Write(buffer.Value) - buffer.Release() return }