vendor: cilium/ebbf 4032b1d8aae306b7bb94a2a11002932caf88c644
full diff: 60c3aa43f4...4032b1d8aa
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
			
			
This commit is contained in:
		
							
								
								
									
										60
									
								
								vendor/github.com/cilium/ebpf/internal/btf/strings.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								vendor/github.com/cilium/ebpf/internal/btf/strings.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,60 @@
 | 
			
		||||
package btf
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"bytes"
 | 
			
		||||
	"io"
 | 
			
		||||
	"io/ioutil"
 | 
			
		||||
 | 
			
		||||
	"github.com/pkg/errors"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type stringTable []byte
 | 
			
		||||
 | 
			
		||||
func readStringTable(r io.Reader) (stringTable, error) {
 | 
			
		||||
	contents, err := ioutil.ReadAll(r)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, errors.Wrap(err, "can't read string table")
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if len(contents) < 1 {
 | 
			
		||||
		return nil, errors.New("string table is empty")
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if contents[0] != '\x00' {
 | 
			
		||||
		return nil, errors.New("first item in string table is non-empty")
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if contents[len(contents)-1] != '\x00' {
 | 
			
		||||
		return nil, errors.New("string table isn't null terminated")
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return stringTable(contents), nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (st stringTable) Lookup(offset uint32) (string, error) {
 | 
			
		||||
	if int64(offset) > int64(^uint(0)>>1) {
 | 
			
		||||
		return "", errors.Errorf("offset %d overflows int", offset)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	pos := int(offset)
 | 
			
		||||
	if pos >= len(st) {
 | 
			
		||||
		return "", errors.Errorf("offset %d is out of bounds", offset)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if pos > 0 && st[pos-1] != '\x00' {
 | 
			
		||||
		return "", errors.Errorf("offset %d isn't start of a string", offset)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	str := st[pos:]
 | 
			
		||||
	end := bytes.IndexByte(str, '\x00')
 | 
			
		||||
	if end == -1 {
 | 
			
		||||
		return "", errors.Errorf("offset %d isn't null terminated", offset)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return string(str[:end]), nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func (st stringTable) LookupName(offset uint32) (Name, error) {
 | 
			
		||||
	str, err := st.Lookup(offset)
 | 
			
		||||
	return Name(str), err
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user