// More annoying case: (ArraySelect[0] (StructSelect[0] isAPtr))
// There, result of the StructSelect is an Array (not a pointer) and
// the pre-rewrite input to the ArraySelect is a struct, not a pointer.
-(StructSelect [0] x) && x.Type.IsPtr() => x
-(ArraySelect [0] x) && x.Type.IsPtr() => x
+(StructSelect [0] x) && x.Type.IsPtrShaped() => x
+(ArraySelect [0] x) && x.Type.IsPtrShaped() => x
// These, too. Bits is bits.
-(ArrayMake1 x) && x.Type.IsPtr() => x
-(StructMake1 x) && x.Type.IsPtr() => x
+(ArrayMake1 x) && x.Type.IsPtrShaped() => x
+(StructMake1 x) && x.Type.IsPtrShaped() => x
(Store dst (StructMake1 <t> f0) mem) =>
(Store {t.FieldType(0)} (OffPtr <t.FieldType(0).PtrTo()> [0] dst) f0 mem)
func rewriteValuedec_OpArrayMake1(v *Value) bool {
v_0 := v.Args[0]
// match: (ArrayMake1 x)
- // cond: x.Type.IsPtr()
+ // cond: x.Type.IsPtrShaped()
// result: x
for {
x := v_0
- if !(x.Type.IsPtr()) {
+ if !(x.Type.IsPtrShaped()) {
break
}
v.copyOf(x)
v_0 := v.Args[0]
b := v.Block
// match: (ArraySelect [0] x)
- // cond: x.Type.IsPtr()
+ // cond: x.Type.IsPtrShaped()
// result: x
for {
if auxIntToInt64(v.AuxInt) != 0 {
break
}
x := v_0
- if !(x.Type.IsPtr()) {
+ if !(x.Type.IsPtrShaped()) {
break
}
v.copyOf(x)
func rewriteValuedec_OpStructMake1(v *Value) bool {
v_0 := v.Args[0]
// match: (StructMake1 x)
- // cond: x.Type.IsPtr()
+ // cond: x.Type.IsPtrShaped()
// result: x
for {
x := v_0
- if !(x.Type.IsPtr()) {
+ if !(x.Type.IsPtrShaped()) {
break
}
v.copyOf(x)
return true
}
// match: (StructSelect [0] x)
- // cond: x.Type.IsPtr()
+ // cond: x.Type.IsPtrShaped()
// result: x
for {
if auxIntToInt64(v.AuxInt) != 0 {
break
}
x := v_0
- if !(x.Type.IsPtr()) {
+ if !(x.Type.IsPtrShaped()) {
break
}
v.copyOf(x)
--- /dev/null
+// compile
+
+// Copyright 2023 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+package main
+
+type explainer struct {
+ m map[string]string
+}
+
+func init() {
+ RegisterExplainer(newExplainer())
+}
+
+type Explainer interface {
+ Name() string
+ Map() map[string]string
+}
+
+func (e explainer) Name() string {
+ return "HelloWorldExplainer"
+}
+
+func (e explainer) Map() map[string]string {
+ return e.m
+}
+
+//go:noinline
+func newExplainer() explainer {
+ m := make(map[string]string)
+ m["Hello"] = "World!"
+ return explainer{m}
+}
+
+var explainers = make(map[string]Explainer)
+
+func RegisterExplainer(e Explainer) {
+ explainers[e.Name()] = e
+}
+
+func main() {
+
+}