|  | @@ -9,6 +9,7 @@ const (
 | 
											
												
													
														|  |  	defaultOffset = 16
 |  |  	defaultOffset = 16
 | 
											
												
													
														|  |  )
 |  |  )
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +// BytesWriter is a writer that writes contents into the given buffer.
 | 
											
												
													
														|  |  type BytesWriter func([]byte) int
 |  |  type BytesWriter func([]byte) int
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // Buffer is a recyclable allocation of a byte array. Buffer.Release() recycles
 |  |  // Buffer is a recyclable allocation of a byte array. Buffer.Release() recycles
 | 
											
										
											
												
													
														|  | @@ -22,6 +23,7 @@ type Buffer struct {
 | 
											
												
													
														|  |  	end   int
 |  |  	end   int
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +// CreateBuffer creates a new Buffer object based on given container and parent pool.
 | 
											
												
													
														|  |  func CreateBuffer(container []byte, parent Pool) *Buffer {
 |  |  func CreateBuffer(container []byte, parent Pool) *Buffer {
 | 
											
												
													
														|  |  	b := new(Buffer)
 |  |  	b := new(Buffer)
 | 
											
												
													
														|  |  	b.v = container
 |  |  	b.v = container
 | 
											
										
											
												
													
														|  | @@ -67,6 +69,7 @@ func (b *Buffer) Append(data []byte) {
 | 
											
												
													
														|  |  	b.end += nBytes
 |  |  	b.end += nBytes
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +// AppendFunc appends the content of a BytesWriter to the buffer.
 | 
											
												
													
														|  |  func (b *Buffer) AppendFunc(writer BytesWriter) {
 |  |  func (b *Buffer) AppendFunc(writer BytesWriter) {
 | 
											
												
													
														|  |  	nBytes := writer(b.v[b.end:])
 |  |  	nBytes := writer(b.v[b.end:])
 | 
											
												
													
														|  |  	b.end += nBytes
 |  |  	b.end += nBytes
 | 
											
										
											
												
													
														|  | @@ -79,6 +82,7 @@ func (b *Buffer) Prepend(data []byte) {
 | 
											
												
													
														|  |  	copy(b.v[b.start:], data)
 |  |  	copy(b.v[b.start:], data)
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +// PrependBytes prepends all data in front of the buffer.
 | 
											
												
													
														|  |  func (b *Buffer) PrependBytes(data ...byte) {
 |  |  func (b *Buffer) PrependBytes(data ...byte) {
 | 
											
												
													
														|  |  	b.Prepend(data)
 |  |  	b.Prepend(data)
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
										
											
												
													
														|  | @@ -88,10 +92,12 @@ func (b *Buffer) PrependFunc(offset int, writer BytesWriter) {
 | 
											
												
													
														|  |  	writer(b.v[b.start:])
 |  |  	writer(b.v[b.start:])
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +// Byte returns the bytes at index.
 | 
											
												
													
														|  |  func (b *Buffer) Byte(index int) byte {
 |  |  func (b *Buffer) Byte(index int) byte {
 | 
											
												
													
														|  |  	return b.v[b.start+index]
 |  |  	return b.v[b.start+index]
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +// SetByte sets the byte value at index.
 | 
											
												
													
														|  |  func (b *Buffer) SetByte(index int, value byte) {
 |  |  func (b *Buffer) SetByte(index int, value byte) {
 | 
											
												
													
														|  |  	b.v[b.start+index] = value
 |  |  	b.v[b.start+index] = value
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
										
											
												
													
														|  | @@ -105,6 +111,7 @@ func (b *Buffer) SetBytesFunc(writer BytesWriter) {
 | 
											
												
													
														|  |  	b.end = b.start + writer(b.v[b.start:])
 |  |  	b.end = b.start + writer(b.v[b.start:])
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +// BytesRange returns a slice of this buffer with given from and to bounary.
 | 
											
												
													
														|  |  func (b *Buffer) BytesRange(from, to int) []byte {
 |  |  func (b *Buffer) BytesRange(from, to int) []byte {
 | 
											
												
													
														|  |  	if from < 0 {
 |  |  	if from < 0 {
 | 
											
												
													
														|  |  		from += b.Len()
 |  |  		from += b.Len()
 | 
											
										
											
												
													
														|  | @@ -169,6 +176,7 @@ func (b *Buffer) Len() int {
 | 
											
												
													
														|  |  	return b.end - b.start
 |  |  	return b.end - b.start
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +// IsEmpty returns true if the buffer is empty.
 | 
											
												
													
														|  |  func (b *Buffer) IsEmpty() bool {
 |  |  func (b *Buffer) IsEmpty() bool {
 | 
											
												
													
														|  |  	return b.Len() == 0
 |  |  	return b.Len() == 0
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
										
											
												
													
														|  | @@ -220,10 +228,12 @@ func NewBuffer() *Buffer {
 | 
											
												
													
														|  |  	return mediumPool.Allocate()
 |  |  	return mediumPool.Allocate()
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +// NewSmallBuffer returns a buffer with 2K bytes capacity.
 | 
											
												
													
														|  |  func NewSmallBuffer() *Buffer {
 |  |  func NewSmallBuffer() *Buffer {
 | 
											
												
													
														|  |  	return smallPool.Allocate()
 |  |  	return smallPool.Allocate()
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +// NewLocalBuffer creates and returns a buffer on current thread.
 | 
											
												
													
														|  |  func NewLocalBuffer(size int) *Buffer {
 |  |  func NewLocalBuffer(size int) *Buffer {
 | 
											
												
													
														|  |  	return CreateBuffer(make([]byte, size), nil)
 |  |  	return CreateBuffer(make([]byte, size), nil)
 | 
											
												
													
														|  |  }
 |  |  }
 |