1
0
mirror of https://github.com/golang/go synced 2024-11-26 21:51:44 -07:00
go/test/fixedbugs/issue59709.dir/cmem.go
Than McIntosh ea69de9b92 cmd/compile: rework marking of dead hidden closure functions
[This is a roll-forward of CL 484859, this time including a fix for
issue #59709. The call to do dead function marking was taking place in
the wrong spot, causing it to run more than once if generics were
instantiated.]

This patch generalizes the code in the inliner that marks unreferenced
hidden closure functions as dead. Rather than doing the marking on the
fly (previous approach), this new approach does a single pass at the
end of inlining, which catches more dead functions.

Change-Id: I0e079ad755c21295477201acbd7e1a732a98fffd
Reviewed-on: https://go-review.googlesource.com/c/go/+/492016
Reviewed-by: Matthew Dempsky <mdempsky@google.com>
TryBot-Result: Gopher Robot <gobot@golang.org>
Reviewed-by: Cuong Manh Le <cuong.manhle.vn@gmail.com>
Run-TryBot: Than McIntosh <thanm@google.com>
Reviewed-by: Cherry Mui <cherryyz@google.com>
2023-05-05 21:04:28 +00:00

38 lines
714 B
Go

// 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 cmem
import (
"./aconfig"
"./bresource"
)
type MemT *int
var G int
type memResource struct {
x *int
}
func (m *memResource) initialize(*int) (res *int, err error) {
return nil, nil
}
func (m *memResource) teardown() {
}
func NewResource(cfg *aconfig.Config) *bresource.Resource[*int] {
res := &memResource{
x: &G,
}
return bresource.New("Mem", res.initialize, bresource.ResConfig{
// We always would want to retry the Memcache initialization.
ShouldRetry: func(error) bool { return true },
TearDown: res.teardown,
})
}