mirror of
https://github.com/golang/go.git
synced 2025-12-08 06:10:04 +00:00
cmd/link, plugin: always encode path
Both the linker and the plugin package were inconsistent about when they applied the path encoding defined in objabi.PathToPrefix. As a result, only some symbols from a package path that required encoding were being found. So always encoding the path. Fixes #22295 Change-Id: Ife86c79ca20b2e9307008ed83885e193d32b7dc4 Reviewed-on: https://go-review.googlesource.com/72390 Run-TryBot: David Crawshaw <crawshaw@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Ian Lance Taylor <iant@golang.org>
This commit is contained in:
parent
78ea9a7129
commit
6355d6c7e2
7 changed files with 54 additions and 35 deletions
|
|
@ -49,37 +49,6 @@ func lastIndexByte(s string, c byte) int {
|
|||
return -1
|
||||
}
|
||||
|
||||
// pathToPrefix converts raw string to the prefix that will be used in the symbol
|
||||
// table. If modifying, modify the version in internal/obj/sym.go as well.
|
||||
func pathToPrefix(s string) string {
|
||||
slash := lastIndexByte(s, '/')
|
||||
// check for chars that need escaping
|
||||
n := 0
|
||||
for r := 0; r < len(s); r++ {
|
||||
if c := s[r]; c <= ' ' || (c == '.' && r > slash) || c == '%' || c == '"' || c >= 0x7F {
|
||||
n++
|
||||
}
|
||||
}
|
||||
|
||||
// quick exit
|
||||
if n == 0 {
|
||||
return s
|
||||
}
|
||||
|
||||
// escape
|
||||
const hex = "0123456789abcdef"
|
||||
p := make([]byte, 0, len(s)+2*n)
|
||||
for r := 0; r < len(s); r++ {
|
||||
if c := s[r]; c <= ' ' || (c == '.' && r > slash) || c == '%' || c == '"' || c >= 0x7F {
|
||||
p = append(p, '%', hex[c>>4], hex[c&0xF])
|
||||
} else {
|
||||
p = append(p, c)
|
||||
}
|
||||
}
|
||||
|
||||
return string(p)
|
||||
}
|
||||
|
||||
func open(name string) (*Plugin, error) {
|
||||
cPath := make([]byte, C.PATH_MAX+1)
|
||||
cRelName := make([]byte, len(name)+1)
|
||||
|
|
@ -153,7 +122,7 @@ func open(name string) (*Plugin, error) {
|
|||
symName = symName[1:]
|
||||
}
|
||||
|
||||
fullName := pathToPrefix(pluginpath) + "." + symName
|
||||
fullName := pluginpath + "." + symName
|
||||
cname := make([]byte, len(fullName)+1)
|
||||
copy(cname, fullName)
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue