2022-05-05 02:47:06 +00:00
|
|
|
// This file will only be included to the build if neither
|
|
|
|
// easyjson_nounsafe nor appengine build tag is set. See README notes
|
|
|
|
// for more details.
|
|
|
|
|
|
|
|
//+build !easyjson_nounsafe
|
|
|
|
//+build !appengine
|
|
|
|
|
|
|
|
package jlexer
|
|
|
|
|
|
|
|
import (
|
|
|
|
"unsafe"
|
|
|
|
)
|
|
|
|
|
|
|
|
// bytesToStr creates a string pointing at the slice to avoid copying.
|
|
|
|
//
|
|
|
|
// Warning: the string returned by the function should be used with care, as the whole input data
|
|
|
|
// chunk may be either blocked from being freed by GC because of a single string or the buffer.Data
|
|
|
|
// may be garbage-collected even when the string exists.
|
|
|
|
func bytesToStr(data []byte) string {
|
2025-01-15 08:18:34 +00:00
|
|
|
return *(*string)(unsafe.Pointer(&data))
|
2022-05-05 02:47:06 +00:00
|
|
|
}
|