Compare commits
134 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
f07f25f1ba | ||
|
|
c93b836c77 | ||
|
|
371103f0d1 | ||
|
|
8bd7afbe62 | ||
|
|
8ea3a493f4 | ||
|
|
f2abd346c0 | ||
|
|
c784713aca | ||
|
|
14acf618af | ||
|
|
fbee2baf9d | ||
|
|
2819b4167b | ||
|
|
2af660cb1f | ||
|
|
8323068414 | ||
|
|
5b62f9fdb6 | ||
|
|
4f66e3fe6c | ||
|
|
1335b4c64f | ||
|
|
da03c922ca | ||
|
|
9620116c30 | ||
|
|
dd7197f2a2 | ||
|
|
9214806342 | ||
|
|
348e713a8e | ||
|
|
cb81fe41ab | ||
|
|
a876bb3673 | ||
|
|
afa46daccd | ||
|
|
3c00da291e | ||
|
|
c847481184 | ||
|
|
f46ef67180 | ||
|
|
229ddfdae1 | ||
|
|
aa7f0849e3 | ||
|
|
7617b8a090 | ||
|
|
4e06abe002 | ||
|
|
b1a758dd5a | ||
|
|
5bf4daef2d | ||
|
|
e56db3b82e | ||
|
|
d3bbe01d5c | ||
|
|
286d6c6359 | ||
|
|
84424b52bc | ||
|
|
98c2dcd3e5 | ||
|
|
808f0bde9d | ||
|
|
c5c6012947 | ||
|
|
836060c8ad | ||
|
|
7a54353c7b | ||
|
|
b591ba0e78 | ||
|
|
5af51aefe6 | ||
|
|
e7c0f68bab | ||
|
|
bd9a6a4f8a | ||
|
|
3eb2c79fd8 | ||
|
|
4653d87298 | ||
|
|
45d569c215 | ||
|
|
c33caeb573 | ||
|
|
91a55cc4c5 | ||
|
|
05f08d776a | ||
|
|
d2569a85a6 | ||
|
|
772cd68fea | ||
|
|
4af992bccb | ||
|
|
da922ce90b | ||
|
|
7b77b0fa22 | ||
|
|
b7f9a39eff | ||
|
|
d2b25a7426 | ||
|
|
b5bf4ef31a | ||
|
|
a69b9bc2dc | ||
|
|
b84278dcc6 | ||
|
|
32cbcfb412 | ||
|
|
5c73f30f36 | ||
|
|
5cc6fa42e4 | ||
|
|
37fe3422d8 | ||
|
|
d4e25f0259 | ||
|
|
32ff3fb9b0 | ||
|
|
b41fa6eb9d | ||
|
|
c80c605ab9 | ||
|
|
bf843fc09e | ||
|
|
a913a4ea8b | ||
|
|
2f8493c405 | ||
|
|
c7fcfa8534 | ||
|
|
aa012b992e | ||
|
|
538182e12c | ||
|
|
13d554acbe | ||
|
|
4fcf90edae | ||
|
|
fc970799a1 | ||
|
|
78d7e85352 | ||
|
|
c503855262 | ||
|
|
77acfb4593 | ||
|
|
f6d0cf95fd | ||
|
|
25b570d7e9 | ||
|
|
297b40d526 | ||
|
|
bd2cb06789 | ||
|
|
3c5682150d | ||
|
|
e32b2ab6bd | ||
|
|
1df5dc2e93 | ||
|
|
36594014c9 | ||
|
|
8f9eccdd61 | ||
|
|
dd03989709 | ||
|
|
b2a11eaf2a | ||
|
|
25c2a435f5 | ||
|
|
3d1a21094a | ||
|
|
2a0d29a390 | ||
|
|
db955e671f | ||
|
|
ab44c38298 | ||
|
|
93e2db7085 | ||
|
|
b1ef9251d4 | ||
|
|
b19afbfe93 | ||
|
|
a6762d500c | ||
|
|
c4174a7167 | ||
|
|
2f9fe7003a | ||
|
|
c86436afa6 | ||
|
|
29e912e90b | ||
|
|
e29de04513 | ||
|
|
c6945514cb | ||
|
|
847cd7ed2b | ||
|
|
fbf897b047 | ||
|
|
45c7b8008a | ||
|
|
4788775f8c | ||
|
|
bcb8546e91 | ||
|
|
befa5a2b54 | ||
|
|
0ba64fc318 | ||
|
|
d16bd4bcdb | ||
|
|
33a532ee01 | ||
|
|
cdc6b773c2 | ||
|
|
17d5f1814a | ||
|
|
5f8be70066 | ||
|
|
5530eca17d | ||
|
|
c8d9e25085 | ||
|
|
a241119bf7 | ||
|
|
3e3f8d5c2f | ||
|
|
9aeb78fc36 | ||
|
|
7863456d52 | ||
|
|
428b658160 | ||
|
|
350cf80bbf | ||
|
|
d92051d40f | ||
|
|
aa2621f6c6 | ||
|
|
2b1d6f0e7a | ||
|
|
992676722d | ||
|
|
451c754068 | ||
|
|
84ad46751a | ||
|
|
ec5392d566 |
27
.github/ISSUE_TEMPLATE/bug_report.md
vendored
27
.github/ISSUE_TEMPLATE/bug_report.md
vendored
@@ -1,27 +0,0 @@
|
|||||||
---
|
|
||||||
name: Bug report
|
|
||||||
about: Create a report to help us improve
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
The following program `sample.go` triggers a panic:
|
|
||||||
|
|
||||||
```go
|
|
||||||
package main
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
// add a sample
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
Expected result:
|
|
||||||
```console
|
|
||||||
$ go run ./sample.go
|
|
||||||
// output
|
|
||||||
```
|
|
||||||
|
|
||||||
Got:
|
|
||||||
```console
|
|
||||||
$ yaegi ./sample.go
|
|
||||||
// output
|
|
||||||
```
|
|
||||||
66
.github/ISSUE_TEMPLATE/bug_report.yml
vendored
Normal file
66
.github/ISSUE_TEMPLATE/bug_report.yml
vendored
Normal file
@@ -0,0 +1,66 @@
|
|||||||
|
name: Bug Report
|
||||||
|
description: Create a report to help us improve
|
||||||
|
|
||||||
|
body:
|
||||||
|
- type: markdown
|
||||||
|
attributes:
|
||||||
|
value: |
|
||||||
|
⚠️ Make sure to browse the opened and closed issues before submit your issue.
|
||||||
|
|
||||||
|
- type: textarea
|
||||||
|
id: sample
|
||||||
|
attributes:
|
||||||
|
label: "The following program `sample.go` triggers an unexpected result"
|
||||||
|
value: |
|
||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
// add a sample
|
||||||
|
}
|
||||||
|
render: go
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
|
||||||
|
- type: textarea
|
||||||
|
id: expected
|
||||||
|
attributes:
|
||||||
|
label: Expected result
|
||||||
|
description: |-
|
||||||
|
```console
|
||||||
|
$ go run ./sample.go
|
||||||
|
// output
|
||||||
|
```
|
||||||
|
placeholder: $ go run ./sample.go
|
||||||
|
render: console
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
|
||||||
|
- type: textarea
|
||||||
|
id: got
|
||||||
|
attributes:
|
||||||
|
label: Got
|
||||||
|
description: |-
|
||||||
|
```console
|
||||||
|
$ yaegi ./sample.go
|
||||||
|
// output
|
||||||
|
```
|
||||||
|
placeholder: $ yaegi ./sample.go
|
||||||
|
render: console
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
|
||||||
|
- type: input
|
||||||
|
id: version
|
||||||
|
attributes:
|
||||||
|
label: Yaegi Version
|
||||||
|
description: Can be a tag or a hash.
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
|
||||||
|
- type: textarea
|
||||||
|
id: additional
|
||||||
|
attributes:
|
||||||
|
label: Additional Notes
|
||||||
|
description: Use [Markdown syntax](https://help.github.com/articles/github-flavored-markdown) if needed.
|
||||||
|
validations:
|
||||||
|
required: false
|
||||||
8
.github/ISSUE_TEMPLATE/config.yml
vendored
Normal file
8
.github/ISSUE_TEMPLATE/config.yml
vendored
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
blank_issues_enabled: false
|
||||||
|
contact_links:
|
||||||
|
- name: Questions
|
||||||
|
url: https://community.traefik.io/c/yaegi
|
||||||
|
about: If you have a question, or are looking for advice, please post on our discussions forum!
|
||||||
|
- name: Documentation
|
||||||
|
url: https://pkg.go.dev/github.com/traefik/yaegi
|
||||||
|
about: Please take a look to our documenation.
|
||||||
19
.github/ISSUE_TEMPLATE/feature_request.md
vendored
19
.github/ISSUE_TEMPLATE/feature_request.md
vendored
@@ -1,19 +0,0 @@
|
|||||||
---
|
|
||||||
name: Feature request
|
|
||||||
about: Propose a change to Yaegi!
|
|
||||||
---
|
|
||||||
|
|
||||||
<!-- ⚠️ If you do not respect this template your issue will be closed. -->
|
|
||||||
<!-- ⚠️ Make sure to browse the opened and closed issues before submit your issue. -->
|
|
||||||
|
|
||||||
#### Proposal
|
|
||||||
|
|
||||||
<!-- Write your feature request in the form of a proposal to be considered for implementation -->
|
|
||||||
|
|
||||||
#### Background
|
|
||||||
|
|
||||||
<!-- Describe the background problem or need that led to this feature request -->
|
|
||||||
|
|
||||||
#### Workarounds
|
|
||||||
|
|
||||||
<!-- Are there any current workarounds that you're using that others in similar positions should know about? -->
|
|
||||||
32
.github/ISSUE_TEMPLATE/feature_request.yml
vendored
Normal file
32
.github/ISSUE_TEMPLATE/feature_request.yml
vendored
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
name: Feature request
|
||||||
|
description: Propose a change to Yaegi
|
||||||
|
|
||||||
|
body:
|
||||||
|
- type: markdown
|
||||||
|
attributes:
|
||||||
|
value: |
|
||||||
|
⚠️ Make sure to browse the opened and closed issues before submit your issue.
|
||||||
|
|
||||||
|
- type: textarea
|
||||||
|
id: proposal
|
||||||
|
attributes:
|
||||||
|
label: Proposal
|
||||||
|
description: Write your feature request in the form of a proposal to be considered for implementation.
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
|
||||||
|
- type: textarea
|
||||||
|
id: background
|
||||||
|
attributes:
|
||||||
|
label: Background
|
||||||
|
description: Describe the background problem or need that led to this feature request.
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
|
||||||
|
- type: textarea
|
||||||
|
id: workarounds
|
||||||
|
attributes:
|
||||||
|
label: Workarounds
|
||||||
|
description: Are there any current workarounds that you're using that others in similar positions should know about?
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
15
.github/workflows/go-cross.yml
vendored
15
.github/workflows/go-cross.yml
vendored
@@ -17,7 +17,7 @@ jobs:
|
|||||||
|
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version: [ 1.15, 1.16 ]
|
go-version: [ 1.16, 1.17 ]
|
||||||
os: [ubuntu-latest, macos-latest, windows-latest]
|
os: [ubuntu-latest, macos-latest, windows-latest]
|
||||||
|
|
||||||
include:
|
include:
|
||||||
@@ -45,11 +45,16 @@ jobs:
|
|||||||
- name: Cache Go modules
|
- name: Cache Go modules
|
||||||
uses: actions/cache@v2
|
uses: actions/cache@v2
|
||||||
with:
|
with:
|
||||||
|
# In order:
|
||||||
|
# * Module download cache
|
||||||
|
# * Build cache (Linux)
|
||||||
|
# * Build cache (Mac)
|
||||||
|
# * Build cache (Windows)
|
||||||
path: |
|
path: |
|
||||||
~/go/pkg/mod # Module download cache
|
~/go/pkg/mod
|
||||||
~/.cache/go-build # Build cache (Linux)
|
~/.cache/go-build
|
||||||
~/Library/Caches/go-build # Build cache (Mac)
|
~/Library/Caches/go-build
|
||||||
'%LocalAppData%\go-build' # Build cache (Windows)
|
%LocalAppData%\go-build
|
||||||
key: ${{ runner.os }}-${{ matrix.go-version }}-go-${{ hashFiles('**/go.sum') }}
|
key: ${{ runner.os }}-${{ matrix.go-version }}-go-${{ hashFiles('**/go.sum') }}
|
||||||
restore-keys: |
|
restore-keys: |
|
||||||
${{ runner.os }}-${{ matrix.go-version }}-go-
|
${{ runner.os }}-${{ matrix.go-version }}-go-
|
||||||
|
|||||||
8
.github/workflows/main.yml
vendored
8
.github/workflows/main.yml
vendored
@@ -7,8 +7,8 @@ on:
|
|||||||
pull_request:
|
pull_request:
|
||||||
|
|
||||||
env:
|
env:
|
||||||
GO_VERSION: 1.16
|
GO_VERSION: 1.17
|
||||||
GOLANGCI_LINT_VERSION: v1.36.0
|
GOLANGCI_LINT_VERSION: v1.42.1
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
|
|
||||||
@@ -45,7 +45,7 @@ jobs:
|
|||||||
needs: linting
|
needs: linting
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version: [ 1.15, 1.16 ]
|
go-version: [ 1.16, 1.17 ]
|
||||||
steps:
|
steps:
|
||||||
- name: Set up Go ${{ matrix.go-version }}
|
- name: Set up Go ${{ matrix.go-version }}
|
||||||
uses: actions/setup-go@v2
|
uses: actions/setup-go@v2
|
||||||
@@ -75,7 +75,7 @@ jobs:
|
|||||||
working-directory: ${{ github.workspace }}/go/src/github.com/traefik/yaegi
|
working-directory: ${{ github.workspace }}/go/src/github.com/traefik/yaegi
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
go-version: [ 1.15, 1.16 ]
|
go-version: [ 1.16, 1.17 ]
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Set up Go ${{ matrix.go-version }}
|
- name: Set up Go ${{ matrix.go-version }}
|
||||||
|
|||||||
2
.github/workflows/release.yml
vendored
2
.github/workflows/release.yml
vendored
@@ -6,7 +6,7 @@ on:
|
|||||||
- v[0-9]+.[0-9]+*
|
- v[0-9]+.[0-9]+*
|
||||||
|
|
||||||
env:
|
env:
|
||||||
GO_VERSION: 1.16
|
GO_VERSION: 1.17
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
|
|
||||||
|
|||||||
@@ -23,13 +23,16 @@
|
|||||||
[linters]
|
[linters]
|
||||||
enable-all = true
|
enable-all = true
|
||||||
disable = [
|
disable = [
|
||||||
"maligned",
|
"golint", # deprecated
|
||||||
|
"scopelint", # deprecated
|
||||||
|
"interfacer", # deprecated
|
||||||
|
"maligned", # deprecated
|
||||||
"lll",
|
"lll",
|
||||||
"gas",
|
"gas",
|
||||||
"dupl",
|
"dupl",
|
||||||
"prealloc",
|
"prealloc",
|
||||||
"scopelint",
|
|
||||||
"gocyclo",
|
"gocyclo",
|
||||||
|
"cyclop",
|
||||||
"gochecknoinits",
|
"gochecknoinits",
|
||||||
"gochecknoglobals",
|
"gochecknoglobals",
|
||||||
"wsl",
|
"wsl",
|
||||||
@@ -49,6 +52,7 @@
|
|||||||
"exhaustivestruct",
|
"exhaustivestruct",
|
||||||
"forbidigo",
|
"forbidigo",
|
||||||
"ifshort",
|
"ifshort",
|
||||||
|
"forcetypeassert",
|
||||||
"errorlint", # TODO: must be reactivate before fixes
|
"errorlint", # TODO: must be reactivate before fixes
|
||||||
]
|
]
|
||||||
|
|
||||||
@@ -59,8 +63,11 @@
|
|||||||
exclude = []
|
exclude = []
|
||||||
|
|
||||||
[[issues.exclude-rules]]
|
[[issues.exclude-rules]]
|
||||||
path = "interp/.+_test\\.go"
|
path = ".+_test\\.go"
|
||||||
linters = ["goconst"]
|
linters = ["goconst"]
|
||||||
|
[[issues.exclude-rules]]
|
||||||
|
path = ".+_test\\.go"
|
||||||
|
text = "var-declaration:"
|
||||||
|
|
||||||
[[issues.exclude-rules]]
|
[[issues.exclude-rules]]
|
||||||
path = "interp/interp.go"
|
path = "interp/interp.go"
|
||||||
@@ -68,6 +75,9 @@
|
|||||||
[[issues.exclude-rules]]
|
[[issues.exclude-rules]]
|
||||||
path = "interp/interp.go"
|
path = "interp/interp.go"
|
||||||
text = "`out` can be `io.Writer`"
|
text = "`out` can be `io.Writer`"
|
||||||
|
[[issues.exclude-rules]]
|
||||||
|
path = "interp/interp.go"
|
||||||
|
text = "`Panic` should conform to the `XxxError` format"
|
||||||
[[issues.exclude-rules]]
|
[[issues.exclude-rules]]
|
||||||
path = "interp/interp_eval_test.go"
|
path = "interp/interp_eval_test.go"
|
||||||
linters = ["thelper"]
|
linters = ["thelper"]
|
||||||
|
|||||||
10
README.md
10
README.md
@@ -3,9 +3,9 @@
|
|||||||
</p>
|
</p>
|
||||||
|
|
||||||
[](https://github.com/traefik/yaegi/releases)
|
[](https://github.com/traefik/yaegi/releases)
|
||||||
[](https://travis-ci.com/traefik/yaegi)
|
[](https://github.com/traefik/yaegi/actions/workflows/main.yml)
|
||||||
[](https://godoc.org/github.com/traefik/yaegi)
|
[](https://pkg.go.dev/mod/github.com/traefik/yaegi)
|
||||||
[](https://community.containo.us/c/yaegi)
|
[](https://community.traefik.io/c/yaegi)
|
||||||
|
|
||||||
Yaegi is Another Elegant Go Interpreter.
|
Yaegi is Another Elegant Go Interpreter.
|
||||||
It powers executable Go scripts and plugins, in embedded interpreters or interactive shells, on top of the Go runtime.
|
It powers executable Go scripts and plugins, in embedded interpreters or interactive shells, on top of the Go runtime.
|
||||||
@@ -18,7 +18,7 @@ It powers executable Go scripts and plugins, in embedded interpreters or interac
|
|||||||
* Works everywhere Go works
|
* Works everywhere Go works
|
||||||
* All Go & runtime resources accessible from script (with control)
|
* All Go & runtime resources accessible from script (with control)
|
||||||
* Security: `unsafe` and `syscall` packages neither used nor exported by default
|
* Security: `unsafe` and `syscall` packages neither used nor exported by default
|
||||||
* Support Go 1.13 and Go 1.14 (the latest 2 major releases)
|
* Support Go 1.16 and Go 1.17 (the latest 2 major releases)
|
||||||
|
|
||||||
## Install
|
## Install
|
||||||
|
|
||||||
@@ -186,7 +186,7 @@ Beside the known [bugs] which are supposed to be fixed in the short term, there
|
|||||||
[Apache 2.0][License].
|
[Apache 2.0][License].
|
||||||
|
|
||||||
[specs]: https://golang.org/ref/spec
|
[specs]: https://golang.org/ref/spec
|
||||||
[docs]: https://godoc.org/github.com/traefik/yaegi
|
[docs]: https://pkg.go.dev/github.com/traefik/yaegi
|
||||||
[license]: https://github.com/traefik/yaegi/blob/master/LICENSE
|
[license]: https://github.com/traefik/yaegi/blob/master/LICENSE
|
||||||
[github]: https://github.com/traefik/yaegi
|
[github]: https://github.com/traefik/yaegi
|
||||||
[bugs]: https://github.com/traefik/yaegi/issues?q=is%3Aissue+is%3Aopen+label%3Abug
|
[bugs]: https://github.com/traefik/yaegi/issues?q=is%3Aissue+is%3Aopen+label%3Abug
|
||||||
|
|||||||
@@ -6,16 +6,18 @@ const (
|
|||||||
zero = iota
|
zero = iota
|
||||||
one
|
one
|
||||||
two
|
two
|
||||||
|
three
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
a := [...]string{
|
a := [...]string{
|
||||||
zero: "zero",
|
zero: "zero",
|
||||||
one: "one",
|
one: "one",
|
||||||
two: "two",
|
three: "three",
|
||||||
|
three + 2: "five",
|
||||||
}
|
}
|
||||||
fmt.Printf("%v %T\n", a, a)
|
fmt.Printf("%v %T\n", a, a)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Output:
|
// Output:
|
||||||
// [zero one two] [3]string
|
// [zero one three five] [6]string
|
||||||
|
|||||||
@@ -22,6 +22,12 @@ func main() {
|
|||||||
var g int = 2
|
var g int = 2
|
||||||
a = 10 + g
|
a = 10 + g
|
||||||
println(a.(int))
|
println(a.(int))
|
||||||
|
|
||||||
|
// multiple assignment
|
||||||
|
var foo interface{}
|
||||||
|
foo, a = "hello", 11 + g
|
||||||
|
println(a.(int))
|
||||||
|
println(foo.(string))
|
||||||
}
|
}
|
||||||
|
|
||||||
// Output:
|
// Output:
|
||||||
@@ -31,3 +37,5 @@ func main() {
|
|||||||
// 10
|
// 10
|
||||||
// 11
|
// 11
|
||||||
// 12
|
// 12
|
||||||
|
// 13
|
||||||
|
// hello
|
||||||
|
|||||||
@@ -57,7 +57,7 @@ func main() {
|
|||||||
fmt.Println(err, vvv)
|
fmt.Println(err, vvv)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Ouput:
|
// Output:
|
||||||
// <nil> {work bob@work.com}
|
// <nil> {work bob@work.com}
|
||||||
// <nil> {work bob@work.com}
|
// <nil> {work bob@work.com}
|
||||||
// <nil> {work bob@work.com}
|
// <nil> {work bob@work.com}
|
||||||
|
|||||||
@@ -103,7 +103,7 @@ func main() {
|
|||||||
intoMap()
|
intoMap()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Ouput:
|
// Output:
|
||||||
// 0 : foo
|
// 0 : foo
|
||||||
// 1 : bar
|
// 1 : bar
|
||||||
// 0 : foo
|
// 0 : foo
|
||||||
|
|||||||
18
_test/alias2.go
Normal file
18
_test/alias2.go
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func (t MyT) Test() string {
|
||||||
|
return "hello"
|
||||||
|
}
|
||||||
|
|
||||||
|
type MyT int
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
t := MyT(1)
|
||||||
|
|
||||||
|
fmt.Println(t.Test())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// hello
|
||||||
22
_test/alias3.go
Normal file
22
_test/alias3.go
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "github.com/traefik/yaegi/_test/alias3"
|
||||||
|
|
||||||
|
var globalT *T
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
globalT = &T{A: "test"}
|
||||||
|
}
|
||||||
|
|
||||||
|
type T alias3.T
|
||||||
|
|
||||||
|
func (t *T) PrintT() {
|
||||||
|
(*alias3.T)(t).Print()
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
globalT.PrintT()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// test
|
||||||
9
_test/alias3/alias3.go
Normal file
9
_test/alias3/alias3.go
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
package alias3
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
A string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *T) Print() {
|
||||||
|
println(t.A)
|
||||||
|
}
|
||||||
27
_test/alias4.go
Normal file
27
_test/alias4.go
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
|
type A http.Header
|
||||||
|
|
||||||
|
func (a A) Test1() {
|
||||||
|
fmt.Println("test1")
|
||||||
|
}
|
||||||
|
|
||||||
|
type B A
|
||||||
|
|
||||||
|
func (b B) Test2() {
|
||||||
|
fmt.Println("test2")
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
b := B{}
|
||||||
|
|
||||||
|
b.Test2()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// test2
|
||||||
14
_test/append3.go
Normal file
14
_test/append3.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := []int{1, 2}
|
||||||
|
b := [2]int{3, 4}
|
||||||
|
fmt.Println(append(a, b[:]...))
|
||||||
|
fmt.Println(append(a, []int{5, 6}...))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [1 2 3 4]
|
||||||
|
// [1 2 5 6]
|
||||||
12
_test/append4.go
Normal file
12
_test/append4.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := []*int{}
|
||||||
|
a = append(a, nil)
|
||||||
|
fmt.Println(a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [<nil>]
|
||||||
37
_test/assert2.go
Normal file
37
_test/assert2.go
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strings"
|
||||||
|
"sync"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Defined an interface of stringBuilder that compatible with
|
||||||
|
// strings.Builder(go 1.10) and bytes.Buffer(< go 1.10)
|
||||||
|
type stringBuilder interface {
|
||||||
|
WriteRune(r rune) (n int, err error)
|
||||||
|
WriteString(s string) (int, error)
|
||||||
|
Reset()
|
||||||
|
Grow(n int)
|
||||||
|
String() string
|
||||||
|
}
|
||||||
|
|
||||||
|
var builderPool = sync.Pool{New: func() interface{} {
|
||||||
|
return newStringBuilder()
|
||||||
|
}}
|
||||||
|
|
||||||
|
func newStringBuilder() stringBuilder {
|
||||||
|
return &strings.Builder{}
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
i := builderPool.Get()
|
||||||
|
sb := i.(stringBuilder)
|
||||||
|
_, _ = sb.WriteString("hello")
|
||||||
|
|
||||||
|
println(sb.String())
|
||||||
|
|
||||||
|
builderPool.Put(i)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// hello
|
||||||
@@ -1,13 +0,0 @@
|
|||||||
// A test program
|
|
||||||
|
|
||||||
// +build darwin,linux !arm
|
|
||||||
// +build go1.12 !go1.13
|
|
||||||
|
|
||||||
package main
|
|
||||||
|
|
||||||
func main() {
|
|
||||||
println("hello world")
|
|
||||||
}
|
|
||||||
|
|
||||||
// Output:
|
|
||||||
// hello world
|
|
||||||
@@ -2,7 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
"net"
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
@@ -13,7 +13,7 @@ func client(uri string) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
body, err := ioutil.ReadAll(resp.Body)
|
body, err := io.ReadAll(resp.Body)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
"net"
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
@@ -21,7 +21,7 @@ func client(uri string) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
body, err := ioutil.ReadAll(resp.Body)
|
body, err := io.ReadAll(resp.Body)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
@@ -13,7 +13,7 @@ func client(uri string) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
body, err := ioutil.ReadAll(resp.Body)
|
body, err := io.ReadAll(resp.Body)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
@@ -40,7 +40,7 @@ func client(uri string) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
body, err := ioutil.ReadAll(resp.Body)
|
body, err := io.ReadAll(resp.Body)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
@@ -40,7 +40,7 @@ func client(uri string) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
body, err := ioutil.ReadAll(resp.Body)
|
body, err := io.ReadAll(resp.Body)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
@@ -41,7 +41,7 @@ func client(uri string) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
body, err := ioutil.ReadAll(resp.Body)
|
body, err := io.ReadAll(resp.Body)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|||||||
32
_test/composite18.go
Normal file
32
_test/composite18.go
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type fn func(string, string) bool
|
||||||
|
|
||||||
|
var funcs = []fn{
|
||||||
|
cmpLessFn,
|
||||||
|
cmpGreaterFn,
|
||||||
|
nil,
|
||||||
|
}
|
||||||
|
|
||||||
|
func cmpLessFn(a string, b string) bool {
|
||||||
|
return a < b
|
||||||
|
}
|
||||||
|
|
||||||
|
func cmpGreaterFn(a string, b string) bool {
|
||||||
|
return a > b
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
for _, f := range funcs {
|
||||||
|
if f == nil {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
fmt.Println(f("a", "b"))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true
|
||||||
|
// false
|
||||||
33
_test/composite19.go
Normal file
33
_test/composite19.go
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type fn func(string, string) bool
|
||||||
|
|
||||||
|
var funcs = map[string]fn{
|
||||||
|
"less": cmpLessFn,
|
||||||
|
"greater": cmpGreaterFn,
|
||||||
|
"none": nil,
|
||||||
|
}
|
||||||
|
|
||||||
|
func cmpLessFn(a string, b string) bool {
|
||||||
|
return a < b
|
||||||
|
}
|
||||||
|
|
||||||
|
func cmpGreaterFn(a string, b string) bool {
|
||||||
|
return a > b
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
for _, n := range []string{"less", "greater", "none"} {
|
||||||
|
f := funcs[n]
|
||||||
|
if f == nil {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
fmt.Println(f("a", "b"))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true
|
||||||
|
// false
|
||||||
@@ -9,7 +9,7 @@ func main() {
|
|||||||
const huge = 1 << 100
|
const huge = 1 << 100
|
||||||
const large = huge >> 38
|
const large = huge >> 38
|
||||||
|
|
||||||
fmt.Println(large)
|
fmt.Println(int64(large))
|
||||||
}
|
}
|
||||||
|
|
||||||
// Output:
|
// Output:
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ package main
|
|||||||
|
|
||||||
import "fmt"
|
import "fmt"
|
||||||
|
|
||||||
const maxLen = int64(int(^uint(0) >> 1))
|
const maxLen = int64(int64(^uint64(0) >> 1))
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
fmt.Println(maxLen)
|
fmt.Println(maxLen)
|
||||||
|
|||||||
28
_test/const26.go
Normal file
28
_test/const26.go
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
fmt.Println(constString)
|
||||||
|
fmt.Println(const2)
|
||||||
|
fmt.Println(varString)
|
||||||
|
}
|
||||||
|
|
||||||
|
const constString string = "hello"
|
||||||
|
|
||||||
|
const (
|
||||||
|
const1 = iota + 10
|
||||||
|
const2
|
||||||
|
const3
|
||||||
|
)
|
||||||
|
|
||||||
|
var varString string = "test"
|
||||||
|
|
||||||
|
func main() {}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// hello
|
||||||
|
// 11
|
||||||
|
// test
|
||||||
9
_test/d1/d1.go
Normal file
9
_test/d1/d1.go
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
package d1
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
Name string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *T) F() { println(t.Name) }
|
||||||
|
|
||||||
|
func NewT(s string) *T { return &T{s} }
|
||||||
8
_test/d2/d2.go
Normal file
8
_test/d2/d2.go
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
package d2
|
||||||
|
|
||||||
|
import "github.com/traefik/yaegi/_test/d1"
|
||||||
|
|
||||||
|
var (
|
||||||
|
X = d1.NewT("test")
|
||||||
|
F = X.F
|
||||||
|
)
|
||||||
11
_test/d3.go
Normal file
11
_test/d3.go
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "github.com/traefik/yaegi/_test/d2"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
f := d2.F
|
||||||
|
f()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// test
|
||||||
@@ -2,12 +2,11 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
|
||||||
"os"
|
"os"
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
file, err := ioutil.TempFile("", "yeagibench")
|
file, err := os.CreateTemp("", "yeagibench")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
@@ -23,7 +22,7 @@ func main() {
|
|||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
b, err := ioutil.ReadFile(file.Name())
|
b, err := os.ReadFile(file.Name())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
|||||||
25
_test/fun27.go
Normal file
25
_test/fun27.go
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"sync"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var wg sync.WaitGroup
|
||||||
|
wg.Add(1)
|
||||||
|
go func() {
|
||||||
|
defer wg.Done()
|
||||||
|
|
||||||
|
print("test")
|
||||||
|
}()
|
||||||
|
|
||||||
|
wg.Wait()
|
||||||
|
}
|
||||||
|
|
||||||
|
func print(state string) {
|
||||||
|
fmt.Println(state)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// test
|
||||||
23
_test/interface51.go
Normal file
23
_test/interface51.go
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type Error interface {
|
||||||
|
error
|
||||||
|
Message() string
|
||||||
|
}
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
Msg string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *T) Error() string { return t.Msg }
|
||||||
|
func (t *T) Message() string { return "message:" + t.Msg }
|
||||||
|
|
||||||
|
func newError() Error { return &T{"test"} }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
e := newError()
|
||||||
|
println(e.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// test
|
||||||
17
_test/interface52.go
Normal file
17
_test/interface52.go
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "testing"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
t := testing.T{}
|
||||||
|
var tb testing.TB
|
||||||
|
tb = &t
|
||||||
|
if tb.TempDir() == "" {
|
||||||
|
println("FAIL")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
println("PASS")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// PASS
|
||||||
@@ -2,7 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
@@ -10,7 +10,7 @@ import (
|
|||||||
func main() {
|
func main() {
|
||||||
r := strings.NewReader("Go is a general-purpose language designed with systems programming in mind.")
|
r := strings.NewReader("Go is a general-purpose language designed with systems programming in mind.")
|
||||||
|
|
||||||
b, err := ioutil.ReadAll(r)
|
b, err := io.ReadAll(r)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
23
_test/issue-1052.go
Normal file
23
_test/issue-1052.go
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a, b := 1, 1
|
||||||
|
for i := 0; i < 10; i++ {
|
||||||
|
fmt.Println(a)
|
||||||
|
a, b = b, a+b
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 1
|
||||||
|
// 1
|
||||||
|
// 2
|
||||||
|
// 3
|
||||||
|
// 5
|
||||||
|
// 8
|
||||||
|
// 13
|
||||||
|
// 21
|
||||||
|
// 34
|
||||||
|
// 55
|
||||||
20
_test/issue-1065.go
Normal file
20
_test/issue-1065.go
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type AST struct {
|
||||||
|
Num int
|
||||||
|
Children []AST
|
||||||
|
}
|
||||||
|
|
||||||
|
func newAST(num int, root AST, children ...AST) AST {
|
||||||
|
return AST{num, append([]AST{root}, children...)}
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
ast := newAST(1, AST{}, AST{})
|
||||||
|
fmt.Println(ast)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// {1 [{0 []} {0 []}]}
|
||||||
19
_test/issue-1068.go
Normal file
19
_test/issue-1068.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type I interface {
|
||||||
|
Hello()
|
||||||
|
}
|
||||||
|
|
||||||
|
type T struct{}
|
||||||
|
|
||||||
|
func (t T) Hello() { println("hello") }
|
||||||
|
|
||||||
|
type I2 I
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var i I2 = T{}
|
||||||
|
i.Hello()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// hello
|
||||||
14
_test/issue-1088.go
Normal file
14
_test/issue-1088.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
for i, ch := range "日本語" {
|
||||||
|
fmt.Printf("%#U starts at byte position %d\n", ch, i)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// U+65E5 '日' starts at byte position 0
|
||||||
|
// U+672C '本' starts at byte position 3
|
||||||
|
// U+8A9E '語' starts at byte position 6
|
||||||
13
_test/issue-1089.go
Normal file
13
_test/issue-1089.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println(`"` + time.RFC3339Nano + `"`)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// "2006-01-02T15:04:05.999999999Z07:00"
|
||||||
13
_test/issue-1093.go
Normal file
13
_test/issue-1093.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func b() string {
|
||||||
|
return "b"
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var x int
|
||||||
|
x = "a" + b()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Error:
|
||||||
|
// 9:6: cannot use type untyped string as type int in assignment
|
||||||
12
_test/issue-1094.go
Normal file
12
_test/issue-1094.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var x interface{}
|
||||||
|
x = "a" + fmt.Sprintf("b")
|
||||||
|
fmt.Printf("%v %T\n", x, x)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// ab string
|
||||||
17
_test/issue-1101.go
Normal file
17
_test/issue-1101.go
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
method := "POST"
|
||||||
|
switch method {
|
||||||
|
case http.MethodPost:
|
||||||
|
fmt.Println("It's a post!")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// It's a post!
|
||||||
24
_test/issue-1115.go
Normal file
24
_test/issue-1115.go
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
outer:
|
||||||
|
for y := 0; y < 10; y++ {
|
||||||
|
for x := 0; x < 10; x++ {
|
||||||
|
if x == 5 && y == 5 {
|
||||||
|
break outer
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fmt.Println(y)
|
||||||
|
}
|
||||||
|
fmt.Println("Yay! I finished!")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 0
|
||||||
|
// 1
|
||||||
|
// 2
|
||||||
|
// 3
|
||||||
|
// 4
|
||||||
|
// Yay! I finished!
|
||||||
23
_test/issue-1126.go
Normal file
23
_test/issue-1126.go
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"fmt"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
err := errors.New("hello there")
|
||||||
|
|
||||||
|
switch true {
|
||||||
|
case err == nil:
|
||||||
|
break
|
||||||
|
case strings.Contains(err.Error(), "hello"):
|
||||||
|
fmt.Println("True!")
|
||||||
|
default:
|
||||||
|
fmt.Println("False!")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// True!
|
||||||
11
_test/issue-1128.go
Normal file
11
_test/issue-1128.go
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "net"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
c := append(net.Buffers{}, []byte{})
|
||||||
|
println(len(c))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 1
|
||||||
20
_test/issue-1134.go
Normal file
20
_test/issue-1134.go
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type I interface {
|
||||||
|
Hello()
|
||||||
|
}
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
Name string
|
||||||
|
Child []*T
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *T) Hello() { println("Hello", t.Name) }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var i I = new(T)
|
||||||
|
i.Hello()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// Hello
|
||||||
22
_test/issue-1136.go
Normal file
22
_test/issue-1136.go
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
)
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
r io.Reader
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *T) Read(p []byte) (n int, err error) { n, err = t.r.Read(p); return }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
x := io.LimitedReader{}
|
||||||
|
y := io.Reader(&x)
|
||||||
|
y = &T{y}
|
||||||
|
fmt.Println(y.Read([]byte("")))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 0 EOF
|
||||||
14
_test/issue-1145.go
Normal file
14
_test/issue-1145.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "sync"
|
||||||
|
|
||||||
|
type F func()
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var wg sync.WaitGroup
|
||||||
|
var f F = wg.Done
|
||||||
|
println(f != nil)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true
|
||||||
25
_test/issue-1156.go
Normal file
25
_test/issue-1156.go
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type myInterface interface {
|
||||||
|
myFunc() string
|
||||||
|
}
|
||||||
|
|
||||||
|
type V struct{}
|
||||||
|
|
||||||
|
func (v *V) myFunc() string { return "hello" }
|
||||||
|
|
||||||
|
type U struct {
|
||||||
|
v myInterface
|
||||||
|
}
|
||||||
|
|
||||||
|
func (u *U) myFunc() string { return u.v.myFunc() }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
x := V{}
|
||||||
|
y := myInterface(&x)
|
||||||
|
y = &U{y}
|
||||||
|
println(y.myFunc())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// hello
|
||||||
41
_test/issue-1163.go
Normal file
41
_test/issue-1163.go
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type WidgetEvent struct {
|
||||||
|
Nothing string
|
||||||
|
}
|
||||||
|
|
||||||
|
type WidgetControl interface {
|
||||||
|
HandleEvent(e *WidgetEvent)
|
||||||
|
}
|
||||||
|
|
||||||
|
type Button struct{}
|
||||||
|
|
||||||
|
func (b *Button) HandleEvent(e *WidgetEvent) {
|
||||||
|
}
|
||||||
|
|
||||||
|
type WindowEvent struct {
|
||||||
|
Something int
|
||||||
|
}
|
||||||
|
|
||||||
|
type Window struct {
|
||||||
|
Widget WidgetControl
|
||||||
|
}
|
||||||
|
|
||||||
|
func (w *Window) HandleEvent(e *WindowEvent) {
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
window := &Window{
|
||||||
|
Widget: &Button{},
|
||||||
|
}
|
||||||
|
windowevent := &WindowEvent{}
|
||||||
|
// The next line uses the signature from the wrong method, resulting in an error.
|
||||||
|
// Renaming one of the clashing method names fixes the problem.
|
||||||
|
window.HandleEvent(windowevent)
|
||||||
|
fmt.Println("OK!")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// OK!
|
||||||
24
_test/issue-1166.go
Normal file
24
_test/issue-1166.go
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
)
|
||||||
|
|
||||||
|
type T []byte
|
||||||
|
|
||||||
|
func (t *T) Write(p []byte) (n int, err error) { *t = append(*t, p...); return len(p), nil }
|
||||||
|
|
||||||
|
func foo(w io.Writer) {
|
||||||
|
a := w.(*T)
|
||||||
|
fmt.Fprint(a, "test")
|
||||||
|
fmt.Printf("%s\n", *a)
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
x := T{}
|
||||||
|
foo(&x)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// test
|
||||||
19
_test/issue-1167.go
Normal file
19
_test/issue-1167.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"crypto/ecdsa"
|
||||||
|
"crypto/elliptic"
|
||||||
|
"crypto/rand"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
key, err := ecdsa.GenerateKey(elliptic.P256(), rand.Reader)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
pub := key.Public().(*ecdsa.PublicKey)
|
||||||
|
println(pub.Params().Name)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// P-256
|
||||||
10
_test/issue-1173.go
Normal file
10
_test/issue-1173.go
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
var real = func() { println("Hello") }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
real()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// Hello
|
||||||
18
_test/issue-1175.go
Normal file
18
_test/issue-1175.go
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type Level int8
|
||||||
|
|
||||||
|
const (
|
||||||
|
a Level = -1
|
||||||
|
b Level = 5
|
||||||
|
d = b - a + 1
|
||||||
|
)
|
||||||
|
|
||||||
|
type counters [d]int
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(len(counters{}))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 7
|
||||||
13
_test/issue-1177.go
Normal file
13
_test/issue-1177.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type counters [3][16]int
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
cs := &counters{}
|
||||||
|
p := &cs[0][1]
|
||||||
|
*p = 2
|
||||||
|
println(cs[0][1])
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 2
|
||||||
23
_test/issue-1179.go
Normal file
23
_test/issue-1179.go
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type I interface {
|
||||||
|
F()
|
||||||
|
}
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
Name string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *T) F() { println("in F", t.Name) }
|
||||||
|
|
||||||
|
func NewI(s string) I { return newT(s) }
|
||||||
|
|
||||||
|
func newT(s string) *T { return &T{s} }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
i := NewI("test")
|
||||||
|
i.F()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// in F test
|
||||||
10
_test/issue-1181.go
Normal file
10
_test/issue-1181.go
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a, b := 1, 2
|
||||||
|
a, b = b, -a
|
||||||
|
println(a, b)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 2 -1
|
||||||
20
_test/issue-1185.go
Normal file
20
_test/issue-1185.go
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "io"
|
||||||
|
|
||||||
|
type B []byte
|
||||||
|
|
||||||
|
func (b B) Write(p []byte) (n int, err error) {
|
||||||
|
b = p
|
||||||
|
return len(p), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
b := B{}
|
||||||
|
a := make([]io.Writer, 0)
|
||||||
|
a = append(a, b)
|
||||||
|
println(len(a))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 1
|
||||||
46
_test/issue-1187.go
Normal file
46
_test/issue-1187.go
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io"
|
||||||
|
"os"
|
||||||
|
)
|
||||||
|
|
||||||
|
type sink interface {
|
||||||
|
io.Writer
|
||||||
|
io.Closer
|
||||||
|
}
|
||||||
|
|
||||||
|
func newSink() sink {
|
||||||
|
// return os.Stdout // Stdout is special in yaegi tests
|
||||||
|
file, err := os.CreateTemp("", "yaegi-test.*")
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
return file
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
s := newSink()
|
||||||
|
n, err := s.Write([]byte("Hello\n"))
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
var writer io.Writer = s
|
||||||
|
m, err := writer.Write([]byte("Hello\n"))
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
var closer io.Closer = s
|
||||||
|
err = closer.Close()
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
err = os.Remove(s.(*os.File).Name())
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
println(m, n)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 6 6
|
||||||
31
_test/issue-1189.go
Normal file
31
_test/issue-1189.go
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type I interface {
|
||||||
|
Foo() int
|
||||||
|
}
|
||||||
|
|
||||||
|
type S1 struct {
|
||||||
|
i int
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s S1) Foo() int { return s.i }
|
||||||
|
|
||||||
|
type S2 struct{}
|
||||||
|
|
||||||
|
func (s *S2) Foo() int { return 42 }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
Is := map[string]I{
|
||||||
|
"foo": S1{21},
|
||||||
|
"bar": &S2{},
|
||||||
|
}
|
||||||
|
n := 0
|
||||||
|
for _, s := range Is {
|
||||||
|
n += s.Foo()
|
||||||
|
}
|
||||||
|
bar := "bar"
|
||||||
|
println(n, Is["foo"].Foo(), Is[bar].Foo())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 63 21 42
|
||||||
34
_test/issue-1202.go
Normal file
34
_test/issue-1202.go
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type foobar struct {
|
||||||
|
callback func(string) func()
|
||||||
|
}
|
||||||
|
|
||||||
|
func cb(text string) func() {
|
||||||
|
return func() {
|
||||||
|
fmt.Println(text)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
// These ways of invoking it all work...
|
||||||
|
cb("Hi from inline callback!")()
|
||||||
|
|
||||||
|
asVarTest1 := cb("Hi from asVarTest1 callback!")
|
||||||
|
asVarTest1()
|
||||||
|
|
||||||
|
asVarTest2 := cb
|
||||||
|
asVarTest2("Hi from asVarTest2 callback!")()
|
||||||
|
|
||||||
|
// But inside a struct panics in yaegi...
|
||||||
|
asStructField := &foobar{callback: cb}
|
||||||
|
asStructField.callback("Hi from struct field callback!")() // <--- panics here
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// Hi from inline callback!
|
||||||
|
// Hi from asVarTest1 callback!
|
||||||
|
// Hi from asVarTest2 callback!
|
||||||
|
// Hi from struct field callback!
|
||||||
25
_test/issue-1205.go
Normal file
25
_test/issue-1205.go
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type Option interface {
|
||||||
|
apply()
|
||||||
|
}
|
||||||
|
|
||||||
|
func f(opts ...Option) {
|
||||||
|
for _, opt := range opts {
|
||||||
|
opt.apply()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
type T struct{}
|
||||||
|
|
||||||
|
func (t *T) apply() { println("in apply") }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
opt := []Option{&T{}}
|
||||||
|
f(opt[0]) // works
|
||||||
|
f(opt...) // fails
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// in apply
|
||||||
|
// in apply
|
||||||
23
_test/issue-1208.go
Normal file
23
_test/issue-1208.go
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type Enabler interface {
|
||||||
|
Enabled() bool
|
||||||
|
}
|
||||||
|
|
||||||
|
type Logger struct {
|
||||||
|
core Enabler
|
||||||
|
}
|
||||||
|
|
||||||
|
func (log *Logger) GetCore() Enabler { return log.core }
|
||||||
|
|
||||||
|
type T struct{}
|
||||||
|
|
||||||
|
func (t *T) Enabled() bool { return true }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
base := &Logger{&T{}}
|
||||||
|
println(base.GetCore().Enabled())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true
|
||||||
67
_test/issue-1260.go
Normal file
67
_test/issue-1260.go
Normal file
@@ -0,0 +1,67 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"os"
|
||||||
|
)
|
||||||
|
|
||||||
|
type WriteSyncer interface {
|
||||||
|
io.Writer
|
||||||
|
Sync() error
|
||||||
|
}
|
||||||
|
|
||||||
|
type Sink interface {
|
||||||
|
WriteSyncer
|
||||||
|
io.Closer
|
||||||
|
}
|
||||||
|
|
||||||
|
func newFileSink(path string) (Sink, error) {
|
||||||
|
return os.OpenFile(path, os.O_WRONLY|os.O_APPEND|os.O_CREATE, 0666)
|
||||||
|
}
|
||||||
|
|
||||||
|
type Sink1 struct{ name string }
|
||||||
|
|
||||||
|
func (s Sink1) Write(b []byte) (int, error) { println("in Write"); return 0, nil }
|
||||||
|
func (s Sink1) Sync() error { println("in Sync"); return nil }
|
||||||
|
func (s Sink1) Close() error { println("in Close", s.name); return nil }
|
||||||
|
func newS1(name string) Sink { return Sink1{name} }
|
||||||
|
func newS1p(name string) Sink { return &Sink1{name} }
|
||||||
|
|
||||||
|
type Sink2 struct{ name string }
|
||||||
|
|
||||||
|
func (s *Sink2) Write(b []byte) (int, error) { println("in Write"); return 0, nil }
|
||||||
|
func (s *Sink2) Sync() error { println("in Sync"); return nil }
|
||||||
|
func (s *Sink2) Close() error { println("in Close", s.name); return nil }
|
||||||
|
func newS2(name string) Sink { return Sink1{name} }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
tmpfile, err := os.CreateTemp("", "xxx")
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
defer os.Remove(tmpfile.Name())
|
||||||
|
closers := []io.Closer{}
|
||||||
|
sink, err := newFileSink(tmpfile.Name())
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
closers = append(closers, sink)
|
||||||
|
|
||||||
|
s1p := newS1p("ptr")
|
||||||
|
s1 := newS1("struct")
|
||||||
|
s2 := newS2("ptr2")
|
||||||
|
closers = append(closers, s1p, s1, s2)
|
||||||
|
for _, closer := range closers {
|
||||||
|
fmt.Println(closer.Close())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// <nil>
|
||||||
|
// in Close ptr
|
||||||
|
// <nil>
|
||||||
|
// in Close struct
|
||||||
|
// <nil>
|
||||||
|
// in Close ptr2
|
||||||
|
// <nil>
|
||||||
24
_test/issue-1276.go
Normal file
24
_test/issue-1276.go
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"flag"
|
||||||
|
)
|
||||||
|
|
||||||
|
type customFlag struct{}
|
||||||
|
|
||||||
|
func (cf customFlag) String() string {
|
||||||
|
return "custom flag"
|
||||||
|
}
|
||||||
|
|
||||||
|
func (cf customFlag) Set(string) error {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
flag.Var(customFlag{}, "cf", "custom flag")
|
||||||
|
flag.Parse()
|
||||||
|
println("Hello, playground")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// Hello, playground
|
||||||
30
_test/issue-1280.go
Normal file
30
_test/issue-1280.go
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io"
|
||||||
|
"log"
|
||||||
|
"os"
|
||||||
|
)
|
||||||
|
|
||||||
|
type DBReader interface {
|
||||||
|
io.ReadCloser
|
||||||
|
io.ReaderAt
|
||||||
|
}
|
||||||
|
|
||||||
|
type DB struct {
|
||||||
|
f DBReader
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
f, err := os.Open("/dev/null")
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
d := &DB{f}
|
||||||
|
data := make([]byte, 1)
|
||||||
|
_, _ = d.f.ReadAt(data, 0)
|
||||||
|
println("bye")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// bye
|
||||||
25
_test/issue-1285.go
Normal file
25
_test/issue-1285.go
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type (
|
||||||
|
T1 struct{ Path [12]int8 }
|
||||||
|
T2 struct{ Path *[12]int8 }
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
t11 = &T1{}
|
||||||
|
t21 = &T2{}
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
b := [12]byte{}
|
||||||
|
t12 := &T1{}
|
||||||
|
t22 := &T2{}
|
||||||
|
b11 := (*[len(t11.Path)]byte)(&b)
|
||||||
|
b12 := (*[len(t12.Path)]byte)(&b)
|
||||||
|
b21 := (*[len(t21.Path)]byte)(&b)
|
||||||
|
b22 := (*[len(t22.Path)]byte)(&b)
|
||||||
|
println(len(b11), len(b12), len(b21), len(b22))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 12 12 12 12
|
||||||
10
_test/issue-1288.go
Normal file
10
_test/issue-1288.go
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println("Hi")
|
||||||
|
goto done
|
||||||
|
done:
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// Hi
|
||||||
20
_test/issue-1300.go
Normal file
20
_test/issue-1300.go
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
const buflen = 512
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
buf []byte
|
||||||
|
}
|
||||||
|
|
||||||
|
func f(t *T) { *t = T{buf: make([]byte, 0, buflen)} }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
s := T{}
|
||||||
|
println(cap(s.buf))
|
||||||
|
f(&s)
|
||||||
|
println(cap(s.buf))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 0
|
||||||
|
// 512
|
||||||
16
_test/issue-1304.go
Normal file
16
_test/issue-1304.go
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type Node struct {
|
||||||
|
Name string
|
||||||
|
Alias *Node
|
||||||
|
Child []*Node
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
n := &Node{Name: "parent"}
|
||||||
|
n.Child = append(n.Child, &Node{Name: "child"})
|
||||||
|
println(n.Name, n.Child[0].Name)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// parent child
|
||||||
15
_test/issue-1306.go
Normal file
15
_test/issue-1306.go
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func check() (result bool, err error) {
|
||||||
|
return true, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
result, error := check()
|
||||||
|
fmt.Println(result, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true <nil>
|
||||||
27
_test/issue-1308.go
Normal file
27
_test/issue-1308.go
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type test struct {
|
||||||
|
v interface{}
|
||||||
|
s string
|
||||||
|
}
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
name string
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
t := []test{
|
||||||
|
{
|
||||||
|
v: []interface{}{
|
||||||
|
T{"hello"},
|
||||||
|
},
|
||||||
|
s: "world",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
fmt.Println(t)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [{[{hello}] world}]
|
||||||
19
_test/issue-1311.go
Normal file
19
_test/issue-1311.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
v interface{}
|
||||||
|
}
|
||||||
|
|
||||||
|
func f() (ret int64, err error) {
|
||||||
|
ret += 2
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
t := &T{}
|
||||||
|
t.v, _ = f()
|
||||||
|
println(t.v.(int64))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 2
|
||||||
32
_test/issue-1315.go
Normal file
32
_test/issue-1315.go
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type Intf interface {
|
||||||
|
M()
|
||||||
|
}
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
s string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *T) M() { println("in M") }
|
||||||
|
|
||||||
|
func f(i interface{}) {
|
||||||
|
switch j := i.(type) {
|
||||||
|
case Intf:
|
||||||
|
j.M()
|
||||||
|
default:
|
||||||
|
println("default")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var i Intf
|
||||||
|
var k interface{} = 1
|
||||||
|
i = &T{"hello"}
|
||||||
|
f(i)
|
||||||
|
f(k)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// in M
|
||||||
|
// default
|
||||||
29
_test/issue-1320.go
Normal file
29
_test/issue-1320.go
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type Pooler interface {
|
||||||
|
Get() string
|
||||||
|
}
|
||||||
|
|
||||||
|
type baseClient struct {
|
||||||
|
connPool Pooler
|
||||||
|
}
|
||||||
|
|
||||||
|
type connPool struct {
|
||||||
|
name string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *connPool) Get() string { return c.name }
|
||||||
|
|
||||||
|
func newBaseClient(i int, p Pooler) *baseClient {
|
||||||
|
return &baseClient{connPool: p}
|
||||||
|
}
|
||||||
|
|
||||||
|
func newConnPool() *connPool { return &connPool{name: "connPool"} }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
b := newBaseClient(0, newConnPool())
|
||||||
|
println(b.connPool.(*connPool).name)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// connPool
|
||||||
42
_test/issue-1326.go
Normal file
42
_test/issue-1326.go
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type Option interface {
|
||||||
|
apply(*T)
|
||||||
|
}
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
s string
|
||||||
|
}
|
||||||
|
|
||||||
|
type opt struct {
|
||||||
|
name string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *opt) apply(t *T) {
|
||||||
|
println(o.name)
|
||||||
|
}
|
||||||
|
|
||||||
|
func BuildOptions() []Option {
|
||||||
|
return []Option{
|
||||||
|
&opt{"opt1"},
|
||||||
|
&opt{"opt2"},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewT(name string, options ...Option) *T {
|
||||||
|
t := &T{name}
|
||||||
|
for _, opt := range options {
|
||||||
|
opt.apply(t)
|
||||||
|
}
|
||||||
|
return t
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
t := NewT("hello", BuildOptions()...)
|
||||||
|
println(t.s)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// opt1
|
||||||
|
// opt2
|
||||||
|
// hello
|
||||||
16
_test/issue-1328.go
Normal file
16
_test/issue-1328.go
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"crypto/sha1"
|
||||||
|
"encoding/hex"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
script := "hello"
|
||||||
|
sumRaw := sha1.Sum([]byte(script))
|
||||||
|
sum := hex.EncodeToString(sumRaw[:])
|
||||||
|
println(sum)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// aaf4c61ddcc5e8a2dabede0f3b482cd9aea9434d
|
||||||
42
_test/issue-1330.go
Normal file
42
_test/issue-1330.go
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"net"
|
||||||
|
)
|
||||||
|
|
||||||
|
type wrappedConn struct {
|
||||||
|
net.Conn
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
_, err := net.Listen("tcp", "127.0.0.1:49153")
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
dialer := &net.Dialer{
|
||||||
|
LocalAddr: &net.TCPAddr{
|
||||||
|
IP: net.ParseIP("127.0.0.1"),
|
||||||
|
Port: 0,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
conn, err := dialer.Dial("tcp", "127.0.0.1:49153")
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
defer conn.Close()
|
||||||
|
|
||||||
|
t := &wrappedConn{conn}
|
||||||
|
var w io.Writer = t
|
||||||
|
if n, err := w.Write([]byte("hello")); err != nil {
|
||||||
|
fmt.Println(err)
|
||||||
|
} else {
|
||||||
|
fmt.Println(n)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 5
|
||||||
17
_test/issue-1332.go
Normal file
17
_test/issue-1332.go
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func run(fn func(name string)) { fn("test") }
|
||||||
|
|
||||||
|
type T2 struct {
|
||||||
|
name string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *T2) f(s string) { println(s, t.name) }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
t2 := &T2{"foo"}
|
||||||
|
run(t2.f)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// test foo
|
||||||
37
_test/issue-1333.go
Normal file
37
_test/issue-1333.go
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"net/http"
|
||||||
|
"net/http/httptest"
|
||||||
|
)
|
||||||
|
|
||||||
|
func mock(name string) http.HandlerFunc {
|
||||||
|
return func(rw http.ResponseWriter, req *http.Request) {
|
||||||
|
fmt.Fprint(rw, "Hello ", name)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func client(uri string) {
|
||||||
|
resp, err := http.Get(uri)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
body, err := io.ReadAll(resp.Body)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
fmt.Println(string(body))
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
mux := http.NewServeMux()
|
||||||
|
server := httptest.NewServer(mux)
|
||||||
|
defer server.Close()
|
||||||
|
mux.Handle("/", mock("foo"))
|
||||||
|
client(server.URL)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// Hello foo
|
||||||
26
_test/issue-1337.go
Normal file
26
_test/issue-1337.go
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io"
|
||||||
|
"os"
|
||||||
|
)
|
||||||
|
|
||||||
|
func f(i interface{}) {
|
||||||
|
switch at := i.(type) {
|
||||||
|
case int, int8:
|
||||||
|
println("integer", at)
|
||||||
|
case io.Reader:
|
||||||
|
println("reader")
|
||||||
|
}
|
||||||
|
println("bye")
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var fd *os.File
|
||||||
|
var r io.Reader = fd
|
||||||
|
f(r)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// reader
|
||||||
|
// bye
|
||||||
27
_test/issue-1361.go
Normal file
27
_test/issue-1361.go
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"math"
|
||||||
|
)
|
||||||
|
|
||||||
|
type obj struct {
|
||||||
|
num float64
|
||||||
|
}
|
||||||
|
|
||||||
|
type Fun func(o *obj) (r *obj, err error)
|
||||||
|
|
||||||
|
func numFun(fn func(f float64) float64) Fun {
|
||||||
|
return func(o *obj) (*obj, error) {
|
||||||
|
return &obj{fn(o.num)}, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
f := numFun(math.Cos)
|
||||||
|
r, err := f(&obj{})
|
||||||
|
fmt.Println(r, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// &{1} <nil>
|
||||||
16
_test/issue-1364.go
Normal file
16
_test/issue-1364.go
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"strconv"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var value interface{}
|
||||||
|
var err error
|
||||||
|
value, err = strconv.ParseFloat("123", 64)
|
||||||
|
fmt.Println(value, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 123 <nil>
|
||||||
18
_test/issue-1365.go
Normal file
18
_test/issue-1365.go
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func genInt() (int, error) { return 3, nil }
|
||||||
|
|
||||||
|
func getInt() (value int) {
|
||||||
|
value, err := genInt()
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(getInt())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 3
|
||||||
16
_test/issue-1368.go
Normal file
16
_test/issue-1368.go
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
const dollar byte = 36
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var c byte = 36
|
||||||
|
switch true {
|
||||||
|
case c == dollar:
|
||||||
|
println("ok")
|
||||||
|
default:
|
||||||
|
println("not ok")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// ok
|
||||||
18
_test/issue-1371.go
Normal file
18
_test/issue-1371.go
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type node struct {
|
||||||
|
parent *node
|
||||||
|
child []*node
|
||||||
|
key string
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
root := &node{key: "root"}
|
||||||
|
root.child = nil
|
||||||
|
fmt.Println("root:", root)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// root: &{<nil> [] root}
|
||||||
38
_test/issue-1375.go
Normal file
38
_test/issue-1375.go
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type Option func(*Struct)
|
||||||
|
|
||||||
|
func WithOption(opt string) Option {
|
||||||
|
return func(s *Struct) {
|
||||||
|
s.opt = opt
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
type Struct struct {
|
||||||
|
opt string
|
||||||
|
}
|
||||||
|
|
||||||
|
func New(opts ...Option) *Struct {
|
||||||
|
s := new(Struct)
|
||||||
|
for _, opt := range opts {
|
||||||
|
opt(s)
|
||||||
|
}
|
||||||
|
return s
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *Struct) ShowOption() {
|
||||||
|
fmt.Println(s.opt)
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
opts := []Option{
|
||||||
|
WithOption("test"),
|
||||||
|
}
|
||||||
|
s := New(opts...)
|
||||||
|
s.ShowOption()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// test
|
||||||
@@ -3,7 +3,6 @@ package main
|
|||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
|
||||||
"log"
|
"log"
|
||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
@@ -36,7 +35,7 @@ type pipe struct {
|
|||||||
|
|
||||||
func newReadAutoCloser(r io.Reader) readAutoCloser {
|
func newReadAutoCloser(r io.Reader) readAutoCloser {
|
||||||
if _, ok := r.(io.Closer); !ok {
|
if _, ok := r.(io.Closer); !ok {
|
||||||
return readAutoCloser{ioutil.NopCloser(r)}
|
return readAutoCloser{io.NopCloser(r)}
|
||||||
}
|
}
|
||||||
return readAutoCloser{r.(io.ReadCloser)}
|
return readAutoCloser{r.(io.ReadCloser)}
|
||||||
}
|
}
|
||||||
@@ -44,7 +43,7 @@ func newReadAutoCloser(r io.Reader) readAutoCloser {
|
|||||||
func main() {
|
func main() {
|
||||||
p := &pipe{}
|
p := &pipe{}
|
||||||
p.Reader = newReadAutoCloser(strings.NewReader("test"))
|
p.Reader = newReadAutoCloser(strings.NewReader("test"))
|
||||||
b, err := ioutil.ReadAll(p.Reader)
|
b, err := io.ReadAll(p.Reader)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|||||||
27
_test/map30.go
Normal file
27
_test/map30.go
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "strings"
|
||||||
|
|
||||||
|
func f(s string) string { return "hello " + s }
|
||||||
|
|
||||||
|
func g(s string) string { return "hi " + s }
|
||||||
|
|
||||||
|
var methods = map[string]func(string) string{
|
||||||
|
"f": f,
|
||||||
|
"h": strings.ToLower,
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
methods["i"] = strings.ToUpper
|
||||||
|
methods["g"] = g
|
||||||
|
println(methods["f"]("test"))
|
||||||
|
println(methods["g"]("test"))
|
||||||
|
println(methods["i"]("test"))
|
||||||
|
println(methods["h"]("TEST"))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// hello test
|
||||||
|
// hi test
|
||||||
|
// TEST
|
||||||
|
// test
|
||||||
19
_test/method37.go
Normal file
19
_test/method37.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"net"
|
||||||
|
"os"
|
||||||
|
)
|
||||||
|
|
||||||
|
func writeBufs(bufs ...[]byte) error {
|
||||||
|
b := net.Buffers(bufs)
|
||||||
|
_, err := b.WriteTo(os.Stdout)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
writeBufs([]byte("hello"))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// hello
|
||||||
14
_test/method38.go
Normal file
14
_test/method38.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"github.com/traefik/yaegi/_test/method38"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println(method38.Get())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// &{[] {<nil>}}
|
||||||
19
_test/method38/a.go
Normal file
19
_test/method38/a.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package method38
|
||||||
|
|
||||||
|
import "sync"
|
||||||
|
|
||||||
|
func NewPool() Pool { return Pool{} }
|
||||||
|
|
||||||
|
type Buffer struct {
|
||||||
|
bs []byte
|
||||||
|
pool Pool
|
||||||
|
}
|
||||||
|
|
||||||
|
type Pool struct {
|
||||||
|
p *sync.Pool
|
||||||
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
_pool = NewPool()
|
||||||
|
Get = _pool.Get
|
||||||
|
)
|
||||||
3
_test/method38/b.go
Normal file
3
_test/method38/b.go
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
package method38
|
||||||
|
|
||||||
|
func (p Pool) Get() *Buffer { return &Buffer{} }
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user