0
1
mirror of https://github.com/golang/go synced 2024-11-11 12:49:30 +00:00
go/test/typeparam/issue47740.go
Matthew Dempsky e24977d231 all: avoid use of cmd/compile -G flag in tests
The next CL will remove the -G flag, effectively hard-coding it to its
current default (-G=3).

Change-Id: Ib4743b529206928f9f1cca9fdb19989728327831
Reviewed-on: https://go-review.googlesource.com/c/go/+/388534
Reviewed-by: Keith Randall <khr@golang.org>
Trust: Matthew Dempsky <mdempsky@google.com>
Run-TryBot: Matthew Dempsky <mdempsky@google.com>
TryBot-Result: Gopher Robot <gobot@golang.org>
2022-03-01 19:45:34 +00:00

41 lines
1008 B
Go

// run
// Copyright 2021 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
import "fmt"
type Exp[Ty any] interface {
Eval() Ty
}
// For now, a lone type parameter is not permitted as RHS in a type declaration (issue #45639).
// type Lit[Ty any] Ty
//
// func (lit Lit[Ty]) Eval() Ty { return Ty(lit) }
// func (lit Lit[Ty]) String() string { return fmt.Sprintf("(lit %v)", Ty(lit)) }
type Eq[Ty any] struct {
a Exp[Ty]
b Exp[Ty]
}
func (e Eq[Ty]) String() string {
return fmt.Sprintf("(eq %v %v)", e.a, e.b)
}
// For now, a lone type parameter is not permitted as RHS in a type declaration (issue #45639).
// var (
// e0 = Eq[int]{Lit[int](128), Lit[int](64)}
// e1 = Eq[bool]{Lit[bool](true), Lit[bool](true)}
// )
func main() {
// For now, a lone type parameter is not permitted as RHS in a type declaration (issue #45639).
// fmt.Printf("%v\n", e0)
// fmt.Printf("%v\n", e1)
}