diff options
| author | cuiweixie <cuiweixie@gmail.com> | 2022-08-16 17:52:13 +0800 |
|---|---|---|
| committer | Matthew Dempsky <mdempsky@google.com> | 2022-08-31 17:15:15 +0000 |
| commit | c7085329367e14f0aa828a3793cf66d9f82f05c2 (patch) | |
| tree | 94f2e9ae0cfc74e1b3cd477480f718a2bd4b6814 /src/cmd/compile/internal/noder | |
| parent | 301ca7513f427f6511fb67cc0385151403cd1729 (diff) | |
| download | go-c7085329367e14f0aa828a3793cf66d9f82f05c2.tar.xz | |
cmd/compile: add support for unsafe.{String,StringData,SliceData}
For #53003
Change-Id: I13a761daca8b433b271a1feb711c103d9820772d
Reviewed-on: https://go-review.googlesource.com/c/go/+/423774
Reviewed-by: Heschi Kreinick <heschi@google.com>
Reviewed-by: Matthew Dempsky <mdempsky@google.com>
Reviewed-by: hopehook <hopehook@golangcn.org>
Reviewed-by: Cuong Manh Le <cuong.manhle.vn@gmail.com>
Reviewed-by: Keith Randall <khr@golang.org>
Run-TryBot: Matthew Dempsky <mdempsky@google.com>
TryBot-Result: Gopher Robot <gobot@golang.org>
Diffstat (limited to 'src/cmd/compile/internal/noder')
| -rw-r--r-- | src/cmd/compile/internal/noder/transform.go | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/src/cmd/compile/internal/noder/transform.go b/src/cmd/compile/internal/noder/transform.go index 87068a9412..15adb89e5f 100644 --- a/src/cmd/compile/internal/noder/transform.go +++ b/src/cmd/compile/internal/noder/transform.go @@ -900,7 +900,7 @@ func transformBuiltin(n *ir.CallExpr) ir.Node { transformArgs(n) fallthrough - case ir.ONEW, ir.OALIGNOF, ir.OOFFSETOF, ir.OSIZEOF: + case ir.ONEW, ir.OALIGNOF, ir.OOFFSETOF, ir.OSIZEOF, ir.OUNSAFESLICEDATA, ir.OUNSAFESTRINGDATA: u := ir.NewUnaryExpr(n.Pos(), op, n.Args[0]) u1 := typed(n.Type(), ir.InitExpr(n.Init(), u)) // typecheckargs can add to old.Init switch op { @@ -913,12 +913,12 @@ func transformBuiltin(n *ir.CallExpr) ir.Node { case ir.OALIGNOF, ir.OOFFSETOF, ir.OSIZEOF: // This corresponds to the EvalConst() call near end of typecheck(). return typecheck.EvalConst(u1) - case ir.OCLOSE, ir.ONEW: + case ir.OCLOSE, ir.ONEW, ir.OUNSAFESTRINGDATA, ir.OUNSAFESLICEDATA: // nothing more to do return u1 } - case ir.OCOMPLEX, ir.OCOPY, ir.OUNSAFEADD, ir.OUNSAFESLICE: + case ir.OCOMPLEX, ir.OCOPY, ir.OUNSAFEADD, ir.OUNSAFESLICE, ir.OUNSAFESTRING: transformArgs(n) b := ir.NewBinaryExpr(n.Pos(), op, n.Args[0], n.Args[1]) n1 := typed(n.Type(), ir.InitExpr(n.Init(), b)) |
