Compare commits
197 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
6346d11286 | ||
|
|
1edb6a1424 | ||
|
|
a2f56431ea | ||
|
|
42abedb25d | ||
|
|
151699ef9f | ||
|
|
f1f3ca7e06 | ||
|
|
9ddecfa121 | ||
|
|
04770a4b81 | ||
|
|
341c69d922 | ||
|
|
f4cc059e3e | ||
|
|
535e7e1c42 | ||
|
|
cb0f3a77bb | ||
|
|
b1279d0a21 | ||
|
|
f3f9ffaea7 | ||
|
|
e332a6b3be | ||
|
|
358a57b4b9 | ||
|
|
3640f2f820 | ||
|
|
3faa47c61e | ||
|
|
896bfeb5a1 | ||
|
|
1029d102e5 | ||
|
|
065d4fa4d7 | ||
|
|
332becf95d | ||
|
|
da9e6a0d6c | ||
|
|
913680d1ed | ||
|
|
a004809fc2 | ||
|
|
b0cd93a936 | ||
|
|
611a8c37fa | ||
|
|
e71ddc7edd | ||
|
|
1fe75f149d | ||
|
|
cdc352cee2 | ||
|
|
88569f5df7 | ||
|
|
2ac0c6f70b | ||
|
|
bd4ce37baa | ||
|
|
9c4d3d1e5a | ||
|
|
25c681c1e6 | ||
|
|
9c51f6bb69 | ||
|
|
589b2a0cd2 | ||
|
|
68911f8b4e | ||
|
|
e5a7b0de11 | ||
|
|
563270ca02 | ||
|
|
5eecbe515b | ||
|
|
0a79069dfc | ||
|
|
0c8f538cd9 | ||
|
|
ca80ada849 | ||
|
|
3c6df504df | ||
|
|
98eacf3610 | ||
|
|
16ff52a949 | ||
|
|
640d1429e5 | ||
|
|
659913eebe | ||
|
|
b3766509cc | ||
|
|
bc2b224bae | ||
|
|
9d4685deea | ||
|
|
2a70a71dc2 | ||
|
|
851444453c | ||
|
|
a8b1c2a017 | ||
|
|
d229c2a2c7 | ||
|
|
2f2df7a0f8 | ||
|
|
4058fd8c44 | ||
|
|
097a745e72 | ||
|
|
1f514e63a8 | ||
|
|
a15ecb7176 | ||
|
|
d4aa84f729 | ||
|
|
9977ef6fc6 | ||
|
|
39430c34bb | ||
|
|
4f3481b55c | ||
|
|
55f2fe396a | ||
|
|
108b6fd722 | ||
|
|
a3b2737b5c | ||
|
|
d2c4a36c25 | ||
|
|
f5f44f7ddd | ||
|
|
4d013e4686 | ||
|
|
c11d361953 | ||
|
|
c2ad279643 | ||
|
|
9627782394 | ||
|
|
e00b853971 | ||
|
|
7cfa264dbc | ||
|
|
a6c24a0d13 | ||
|
|
f19b7563ea | ||
|
|
0643762852 | ||
|
|
7323d97023 | ||
|
|
6486909921 | ||
|
|
d252821df3 | ||
|
|
2bef03e253 | ||
|
|
1fe91be882 | ||
|
|
5cbbf9339c | ||
|
|
8365f687e7 | ||
|
|
36836cd4f2 | ||
|
|
82b499a1c8 | ||
|
|
0ef7f8fb80 | ||
|
|
c1f5005b2a | ||
|
|
def57d57c2 | ||
|
|
74479d70e6 | ||
|
|
f1cff308e6 | ||
|
|
6f878052f8 | ||
|
|
eb25c84797 | ||
|
|
2de0c80d38 | ||
|
|
151a856bf2 | ||
|
|
d5217f7db4 | ||
|
|
01e4cdea70 | ||
|
|
3c88542180 | ||
|
|
56d88ef89d | ||
|
|
5d78c8ae27 | ||
|
|
184623d81f | ||
|
|
5d56bac8d0 | ||
|
|
4a068ea452 | ||
|
|
8605c238ef | ||
|
|
4f39eaf893 | ||
|
|
4f8e1de267 | ||
|
|
6f4643ff19 | ||
|
|
bb1be9e6e1 | ||
|
|
cdf4622421 | ||
|
|
b9720d15e1 | ||
|
|
7fab75fbe4 | ||
|
|
7eac6955b3 | ||
|
|
7070367d21 | ||
|
|
22dfc8b10a | ||
|
|
7fba3fe580 | ||
|
|
ff36ec58b1 | ||
|
|
f6c8b8b14f | ||
|
|
e12c8b72c4 | ||
|
|
e4acba031d | ||
|
|
7d56fb067e | ||
|
|
1feece61ce | ||
|
|
01e2e4600e | ||
|
|
92eebbade2 | ||
|
|
a6389aca5e | ||
|
|
de8cb7dc3b | ||
|
|
18b843646c | ||
|
|
71f730b3d7 | ||
|
|
7b2d91bcb5 | ||
|
|
3ed4ec3f6f | ||
|
|
5e142fdedd | ||
|
|
94d44e7265 | ||
|
|
56925e6fea | ||
|
|
c580dfdbc8 | ||
|
|
29e1777d82 | ||
|
|
50a34fd2a7 | ||
|
|
465cb578e7 | ||
|
|
12942b59a0 | ||
|
|
3e76267f8e | ||
|
|
988f0c9672 | ||
|
|
b0053c874f | ||
|
|
b20ad3a01d | ||
|
|
e78650d359 | ||
|
|
7327ff2811 | ||
|
|
ebde09b47d | ||
|
|
4995654e04 | ||
|
|
0a99eb48c3 | ||
|
|
4a22635585 | ||
|
|
b52dd8cc08 | ||
|
|
daaeac6e2c | ||
|
|
ca68c6cd95 | ||
|
|
953b122e67 | ||
|
|
9b07e73b5e | ||
|
|
78bbcda1f8 | ||
|
|
6e33f89146 | ||
|
|
d29b0a48ff | ||
|
|
c7c1bea7ef | ||
|
|
1ae2649655 | ||
|
|
0ace9244c4 | ||
|
|
2edd18a0c0 | ||
|
|
cfb73445a2 | ||
|
|
94e0b582ea | ||
|
|
3548c8744e | ||
|
|
d8bdc6670b | ||
|
|
27520f6dae | ||
|
|
7037424edf | ||
|
|
1b971b539c | ||
|
|
681f2f9c40 | ||
|
|
05960316f8 | ||
|
|
902af477b8 | ||
|
|
812e55b95e | ||
|
|
6c339ce562 | ||
|
|
23dfef0ac8 | ||
|
|
4fd6a2dc56 | ||
|
|
92a63dbe09 | ||
|
|
e434892b9a | ||
|
|
712891dd77 | ||
|
|
137b16580c | ||
|
|
b057ada531 | ||
|
|
6d90c5a641 | ||
|
|
5381ee65d1 | ||
|
|
f1cde2be0f | ||
|
|
bb04af2d4d | ||
|
|
9a8a88dcb9 | ||
|
|
f3f54a5302 | ||
|
|
878fcc835c | ||
|
|
a1f2d3bf1d | ||
|
|
3cd37645eb | ||
|
|
e1ac83f7d8 | ||
|
|
4f93be7f19 | ||
|
|
7a0c09f5eb | ||
|
|
275391c1e8 | ||
|
|
273df8af9f | ||
|
|
0d2c39d155 | ||
|
|
1ff1a50753 | ||
|
|
488e491bf8 |
@@ -37,6 +37,12 @@
|
|||||||
"funlen",
|
"funlen",
|
||||||
"gocognit",
|
"gocognit",
|
||||||
"stylecheck",
|
"stylecheck",
|
||||||
|
"gomnd",
|
||||||
|
"testpackage",
|
||||||
|
"goerr113",
|
||||||
|
"nestif",
|
||||||
|
"exhaustive",
|
||||||
|
"nlreturn",
|
||||||
]
|
]
|
||||||
|
|
||||||
[issues]
|
[issues]
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ project_name: yaegi
|
|||||||
builds:
|
builds:
|
||||||
- id: yaegi
|
- id: yaegi
|
||||||
binary: yaegi
|
binary: yaegi
|
||||||
main: ./cmd/yaegi/yaegi.go
|
main: ./cmd/yaegi/
|
||||||
|
|
||||||
goos:
|
goos:
|
||||||
- darwin
|
- darwin
|
||||||
@@ -28,7 +28,7 @@ builds:
|
|||||||
|
|
||||||
- id: goexports
|
- id: goexports
|
||||||
binary: goexports
|
binary: goexports
|
||||||
main: ./cmd/goexports/goexports.go
|
main: ./cmd/goexports/
|
||||||
|
|
||||||
goos:
|
goos:
|
||||||
- darwin
|
- darwin
|
||||||
|
|||||||
@@ -19,15 +19,15 @@ cache:
|
|||||||
matrix:
|
matrix:
|
||||||
fast_finish: true
|
fast_finish: true
|
||||||
include:
|
include:
|
||||||
- go: 1.12.x
|
- go: 1.14.x
|
||||||
- go: 1.13.x
|
- go: 1.15.x
|
||||||
env: STABLE=true
|
env: STABLE=true
|
||||||
|
|
||||||
env:
|
env:
|
||||||
global:
|
global:
|
||||||
- GO111MODULE=on
|
- GO111MODULE=on
|
||||||
|
|
||||||
go_import_path: github.com/containous/yaegi
|
go_import_path: github.com/traefik/yaegi
|
||||||
|
|
||||||
before_install:
|
before_install:
|
||||||
# Install linters and misspell
|
# Install linters and misspell
|
||||||
@@ -39,7 +39,7 @@ install:
|
|||||||
- go mod download
|
- go mod download
|
||||||
|
|
||||||
before_script:
|
before_script:
|
||||||
- rm -f interp/op.go interp/interp_test.go
|
- rm -f interp/op.go
|
||||||
- make generate
|
- make generate
|
||||||
- git update-index -q --refresh
|
- git update-index -q --refresh
|
||||||
- CHANGED=$(git diff-index --name-only HEAD --)
|
- CHANGED=$(git diff-index --name-only HEAD --)
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
Yaegi is an open source project, and your feedback and contributions
|
Yaegi is an open source project, and your feedback and contributions
|
||||||
are needed and always welcome.
|
are needed and always welcome.
|
||||||
|
|
||||||
[Issues] and [Pull Requests] are opened at https://github.com/containous/yaegi.
|
[Issues] and [Pull Requests] are opened at https://github.com/traefik/yaegi.
|
||||||
|
|
||||||
Non trivial changes should be discussed with the project maintainers by
|
Non trivial changes should be discussed with the project maintainers by
|
||||||
opening a [Feature Request] clearly explaining rationale, background
|
opening a [Feature Request] clearly explaining rationale, background
|
||||||
@@ -13,7 +13,12 @@ discussions.
|
|||||||
Once the proposal is approved, a Pull Request can be opened. If you want
|
Once the proposal is approved, a Pull Request can be opened. If you want
|
||||||
to provide early visibility to reviewers, create a [Draft Pull Request].
|
to provide early visibility to reviewers, create a [Draft Pull Request].
|
||||||
|
|
||||||
[Issues]: https://github.com/containous/yaegi/issues
|
We will also require you to sign the [Traefik Contributor License Agreement]
|
||||||
[Pull Requests]: https://github.com/containous/yaegi/issues
|
after you submit your first pull request to this project. The link to sign the
|
||||||
[Feature Request]: https://github.com/containous/yaegi/issues/new?template=feature_request.md
|
agreement will be presented to you in the web interface of the pull request.
|
||||||
|
|
||||||
|
[Issues]: https://github.com/traefik/yaegi/issues
|
||||||
|
[Pull Requests]: https://github.com/traefik/yaegi/issues
|
||||||
|
[Feature Request]: https://github.com/traefik/yaegi/issues/new?template=feature_request.md
|
||||||
[Draft Pull Request]: https://github.blog/2019-02-14-introducing-draft-pull-requests/
|
[Draft Pull Request]: https://github.blog/2019-02-14-introducing-draft-pull-requests/
|
||||||
|
[Traefik Labs Contributor License Agreement]: https://cla-assistant.io/traefik/yaegi
|
||||||
|
|||||||
1
LICENSE
1
LICENSE
@@ -187,6 +187,7 @@
|
|||||||
identification within third-party archives.
|
identification within third-party archives.
|
||||||
|
|
||||||
Copyright 2019 Containous SAS
|
Copyright 2019 Containous SAS
|
||||||
|
Copyright 2020 Traefik Labs SAS
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
you may not use this file except in compliance with the License.
|
you may not use this file except in compliance with the License.
|
||||||
|
|||||||
54
README.md
54
README.md
@@ -2,9 +2,9 @@
|
|||||||
<img width="400" src="doc/images/yaegi.png" alt="Yaegi" title="Yaegi" />
|
<img width="400" src="doc/images/yaegi.png" alt="Yaegi" title="Yaegi" />
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
[](https://github.com/containous/yaegi/releases)
|
[](https://github.com/traefik/yaegi/releases)
|
||||||
[](https://travis-ci.com/containous/yaegi)
|
[](https://travis-ci.com/traefik/yaegi)
|
||||||
[](https://godoc.org/github.com/containous/yaegi)
|
[](https://godoc.org/github.com/traefik/yaegi)
|
||||||
[](https://community.containo.us/c/yaegi)
|
[](https://community.containo.us/c/yaegi)
|
||||||
|
|
||||||
Yaegi is Another Elegant Go Interpreter.
|
Yaegi is Another Elegant Go Interpreter.
|
||||||
@@ -18,20 +18,20 @@ 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.12 and Go 1.13 (the latest 2 major releases)
|
* Support Go 1.13 and Go 1.14 (the latest 2 major releases)
|
||||||
|
|
||||||
## Install
|
## Install
|
||||||
|
|
||||||
### Go package
|
### Go package
|
||||||
|
|
||||||
```go
|
```go
|
||||||
import "github.com/containous/yaegi/interp"
|
import "github.com/traefik/yaegi/interp"
|
||||||
```
|
```
|
||||||
|
|
||||||
### Command-line executable
|
### Command-line executable
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
go get -u github.com/containous/yaegi/cmd/yaegi
|
go get -u github.com/traefik/yaegi/cmd/yaegi
|
||||||
```
|
```
|
||||||
|
|
||||||
Note that you can use [rlwrap](https://github.com/hanslub42/rlwrap) (install with your favorite package manager),
|
Note that you can use [rlwrap](https://github.com/hanslub42/rlwrap) (install with your favorite package manager),
|
||||||
@@ -47,8 +47,8 @@ Create an interpreter with `New()`, run Go code with `Eval()`:
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/containous/yaegi/interp"
|
"github.com/traefik/yaegi/interp"
|
||||||
"github.com/containous/yaegi/stdlib"
|
"github.com/traefik/yaegi/stdlib"
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
@@ -81,7 +81,7 @@ The following program is compiled ahead of time, except `bar()` which is interpr
|
|||||||
```go
|
```go
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import "github.com/containous/yaegi/interp"
|
import "github.com/traefik/yaegi/interp"
|
||||||
|
|
||||||
const src = `package foo
|
const src = `package foo
|
||||||
func Bar(s string) string { return s + "-Foo" }`
|
func Bar(s string) string { return s + "-Foo" }`
|
||||||
@@ -129,6 +129,24 @@ $ yaegi cmd/yaegi/yaegi.go
|
|||||||
>
|
>
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Or for Go scripting in the shebang line:
|
||||||
|
|
||||||
|
```console
|
||||||
|
$ cat /tmp/test
|
||||||
|
#!/usr/bin/env yaegi
|
||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println("test")
|
||||||
|
}
|
||||||
|
$ ls -la /tmp/test
|
||||||
|
-rwxr-xr-x 1 dow184 dow184 93 Jan 6 13:38 /tmp/test
|
||||||
|
$ /tmp/test
|
||||||
|
test
|
||||||
|
```
|
||||||
|
|
||||||
## Documentation
|
## Documentation
|
||||||
|
|
||||||
Documentation about Yaegi commands and libraries can be found at usual [godoc.org][docs].
|
Documentation about Yaegi commands and libraries can be found at usual [godoc.org][docs].
|
||||||
@@ -137,11 +155,11 @@ Documentation about Yaegi commands and libraries can be found at usual [godoc.or
|
|||||||
|
|
||||||
Beside the known [bugs] which are supposed to be fixed in the short term, there are some limitations not planned to be addressed soon:
|
Beside the known [bugs] which are supposed to be fixed in the short term, there are some limitations not planned to be addressed soon:
|
||||||
|
|
||||||
- assembly files (`.s`) are not supported
|
- Assembly files (`.s`) are not supported.
|
||||||
- calling C code is not supported (no virtual "C" package)
|
- Calling C code is not supported (no virtual "C" package).
|
||||||
- interfaces to be used from the pre-compiled code can not be added dynamically, as it is required to pre-compile interface wrappers
|
- Interfaces to be used from the pre-compiled code can not be added dynamically, as it is required to pre-compile interface wrappers.
|
||||||
- representation of types by `reflect` and printing values using %T may give different results between compiled mode and interpreted mode
|
- Representation of types by `reflect` and printing values using %T may give different results between compiled mode and interpreted mode.
|
||||||
- interpreting computation intensive code is likely to remain significantly slower than in compiled mode
|
- Interpreting computation intensive code is likely to remain significantly slower than in compiled mode.
|
||||||
|
|
||||||
## Contributing
|
## Contributing
|
||||||
|
|
||||||
@@ -152,7 +170,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/containous/yaegi
|
[docs]: https://godoc.org/github.com/traefik/yaegi
|
||||||
[license]: https://github.com/containous/yaegi/blob/master/LICENSE
|
[license]: https://github.com/traefik/yaegi/blob/master/LICENSE
|
||||||
[github]: https://github.com/containous/yaegi
|
[github]: https://github.com/traefik/yaegi
|
||||||
[bugs]: https://github.com/containous/yaegi/issues?q=is%3Aissue+is%3Aopen+label%3Abug
|
[bugs]: https://github.com/traefik/yaegi/issues?q=is%3Aissue+is%3Aopen+label%3Abug
|
||||||
|
|||||||
23
_test/a40.go
Normal file
23
_test/a40.go
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type rule uint8
|
||||||
|
|
||||||
|
const (
|
||||||
|
r0 rule = iota
|
||||||
|
r1
|
||||||
|
r2
|
||||||
|
)
|
||||||
|
|
||||||
|
var a = [...]int{
|
||||||
|
r0: 1,
|
||||||
|
r1: 12,
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println(a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [1 12]
|
||||||
10
_test/a41.go
Normal file
10
_test/a41.go
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
var a = [...]bool{true, true}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(a[0] && true)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true
|
||||||
16
_test/a42.go
Normal file
16
_test/a42.go
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/binary"
|
||||||
|
"fmt"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var b [8]byte
|
||||||
|
binary.LittleEndian.PutUint64(b[:], uint64(1))
|
||||||
|
|
||||||
|
fmt.Println(b)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [1 0 0 0 0 0 0 0]
|
||||||
9
_test/add0.go
Normal file
9
_test/add0.go
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var a interface{} = 2 + 5
|
||||||
|
println(a.(int))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 7
|
||||||
10
_test/add1.go
Normal file
10
_test/add1.go
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
b := 2
|
||||||
|
var a interface{} = 5 + b
|
||||||
|
println(a.(int))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 7
|
||||||
12
_test/add2.go
Normal file
12
_test/add2.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type iface interface{}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
b := 2
|
||||||
|
var a iface = 5 + b
|
||||||
|
println(a.(int))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 7
|
||||||
25
_test/addr0.go
Normal file
25
_test/addr0.go
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
|
type extendedRequest struct {
|
||||||
|
http.Request
|
||||||
|
|
||||||
|
Data string
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
r := extendedRequest{}
|
||||||
|
req := &r.Request
|
||||||
|
|
||||||
|
|
||||||
|
fmt.Println(r)
|
||||||
|
fmt.Println(req)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// {{ <nil> 0 0 map[] <nil> <nil> 0 [] false map[] map[] <nil> map[] <nil> <nil> <nil> <nil>} }
|
||||||
|
// &{ <nil> 0 0 map[] <nil> <nil> 0 [] false map[] map[] <nil> map[] <nil> <nil> <nil> <nil>}
|
||||||
10
_test/and3.go
Normal file
10
_test/and3.go
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
var a = true && true
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true
|
||||||
14
_test/append0.go
Normal file
14
_test/append0.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func f(a []int, b int) interface{} { return append(a, b) }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := []int{1, 2}
|
||||||
|
r := f(a, 3)
|
||||||
|
fmt.Println(r.([]int))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [1 2 3]
|
||||||
@@ -9,5 +9,5 @@ func main() {
|
|||||||
fmt.Println(buf)
|
fmt.Println(buf)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Output
|
// Output:
|
||||||
// []
|
// []
|
||||||
|
|||||||
10
_test/assign11.go
Normal file
10
_test/assign11.go
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
_, _, _ = fmt.Println("test")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Error:
|
||||||
|
// 6:2: assignment mismatch: 3 variables but fmt.Println returns 2 values
|
||||||
11
_test/assign12.go
Normal file
11
_test/assign12.go
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a, b, c := fmt.Println("test")
|
||||||
|
println(a, b, c)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Error:
|
||||||
|
// 6:2: assignment mismatch: 3 variables but fmt.Println returns 2 values
|
||||||
19
_test/assign13.go
Normal file
19
_test/assign13.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func getStr() string {
|
||||||
|
return "test"
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
m := make(map[string]string, 0)
|
||||||
|
m["a"] = fmt.Sprintf("%v", 0.1)
|
||||||
|
m["b"] = string(fmt.Sprintf("%v", 0.1))
|
||||||
|
m["c"] = getStr()
|
||||||
|
|
||||||
|
fmt.Println(m)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// map[a:0.1 b:0.1 c:test]
|
||||||
16
_test/assign14.go
Normal file
16
_test/assign14.go
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
var optionsG map[string]string = nil
|
||||||
|
|
||||||
|
var roundG = 30
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
dummy := roundG
|
||||||
|
roundG = dummy + 1
|
||||||
|
println(roundG)
|
||||||
|
println(optionsG == nil)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 31
|
||||||
|
// true
|
||||||
11
_test/assign15.go
Normal file
11
_test/assign15.go
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var c chan<- struct{} = make(chan struct{})
|
||||||
|
var d <-chan struct{} = c
|
||||||
|
|
||||||
|
_ = d
|
||||||
|
}
|
||||||
|
|
||||||
|
// Error:
|
||||||
|
// _test/assign15.go:5:26: cannot use type chan<- struct{} as type <-chan struct{} in assignment
|
||||||
7
_test/b1/foo/foo.go
Normal file
7
_test/b1/foo/foo.go
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
package foo
|
||||||
|
|
||||||
|
import bar "github.com/traefik/yaegi/_test/b2/foo"
|
||||||
|
|
||||||
|
var Desc = "in b1/foo"
|
||||||
|
|
||||||
|
var Desc2 = Desc + bar.Desc
|
||||||
3
_test/b2/foo/foo.go
Normal file
3
_test/b2/foo/foo.go
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
package foo
|
||||||
|
|
||||||
|
var Desc = "in b2/foo"
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
println("Hello")
|
println("Hello")
|
||||||
|
|
||||||
// Error:
|
// Error:
|
||||||
// _test/bad0.go:1:1: expected 'package', found println
|
// 1:1: expected 'package', found println
|
||||||
|
|||||||
3
_test/baz-bat/baz-bat.go
Normal file
3
_test/baz-bat/baz-bat.go
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
package baz
|
||||||
|
|
||||||
|
var Name = "baz-bat"
|
||||||
13
_test/bin2.go
Normal file
13
_test/bin2.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"math"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println(math.Abs(-5))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 5
|
||||||
12
_test/bin3.go
Normal file
12
_test/bin3.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
str := "part1"
|
||||||
|
str += fmt.Sprintf("%s", "part2")
|
||||||
|
fmt.Println(str)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// part1part2
|
||||||
18
_test/bin4.go
Normal file
18
_test/bin4.go
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
func Bar(s string) bool {
|
||||||
|
a := strings.HasPrefix("fas", "f")
|
||||||
|
b := strings.HasPrefix("aaaaa", "a")
|
||||||
|
a_and_b := strings.HasPrefix("fas", "f") && strings.HasPrefix("aaaaa", "a")
|
||||||
|
fmt.Println(a, b, a && b, a_and_b)
|
||||||
|
return a && b
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(Bar("kung"))
|
||||||
|
}
|
||||||
15
_test/bin5.go
Normal file
15
_test/bin5.go
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"net"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
addr := net.TCPAddr{IP: net.IPv4(1, 1, 1, 1), Port: 80}
|
||||||
|
var s fmt.Stringer = &addr
|
||||||
|
fmt.Println(s.String())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 1.1.1.1:80
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
package c1
|
package c1
|
||||||
|
|
||||||
import "github.com/containous/yaegi/_test/c2"
|
import "github.com/traefik/yaegi/_test/c2"
|
||||||
|
|
||||||
var C1 = c2.C2 + "x"
|
var C1 = c2.C2 + "x"
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
package c2
|
package c2
|
||||||
|
|
||||||
import "github.com/containous/yaegi/_test/c1"
|
import "github.com/traefik/yaegi/_test/c1"
|
||||||
|
|
||||||
var C2 = c1.C1 + "Y"
|
var C2 = c1.C1 + "Y"
|
||||||
|
|||||||
13
_test/cap0.go
Normal file
13
_test/cap0.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func f(a []int) interface{} {
|
||||||
|
return cap(a)
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := []int{1, 2}
|
||||||
|
println(f(a).(int))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 2
|
||||||
12
_test/chan10.go
Normal file
12
_test/chan10.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "time"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var tick <-chan time.Time = time.Tick(time.Millisecond)
|
||||||
|
_ = tick
|
||||||
|
println("success")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// success
|
||||||
12
_test/chan8.go
Normal file
12
_test/chan8.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
messages := make(chan bool)
|
||||||
|
|
||||||
|
go func() { messages <- true }()
|
||||||
|
|
||||||
|
println(<-messages && true)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true
|
||||||
20
_test/chan9.go
Normal file
20
_test/chan9.go
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type Channel chan string
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
Channel
|
||||||
|
}
|
||||||
|
|
||||||
|
func send(c Channel) { c <- "ping" }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
t := &T{}
|
||||||
|
t.Channel = make(Channel)
|
||||||
|
go send(t.Channel)
|
||||||
|
msg := <-t.Channel
|
||||||
|
println(msg)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// ping
|
||||||
59
_test/cli2.go
Normal file
59
_test/cli2.go
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"log"
|
||||||
|
"net"
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
ln net.Listener
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *T) Close() {
|
||||||
|
t.ln.Close()
|
||||||
|
}
|
||||||
|
|
||||||
|
func client(uri string) {
|
||||||
|
resp, err := http.Get(uri)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
body, err := ioutil.ReadAll(resp.Body)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
fmt.Println(string(body))
|
||||||
|
}
|
||||||
|
|
||||||
|
func server(ln net.Listener, ready chan bool) {
|
||||||
|
http.HandleFunc("/hello", func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
var r1 *http.Request = r
|
||||||
|
fmt.Fprintln(w, "Welcome to my website!", r1.RequestURI)
|
||||||
|
})
|
||||||
|
|
||||||
|
go http.Serve(ln, nil)
|
||||||
|
ready <- true
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
ln, err := net.Listen("tcp", "localhost:0")
|
||||||
|
t := &T{ln}
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
defer t.Close()
|
||||||
|
// defer ln.Close()
|
||||||
|
|
||||||
|
ready := make(chan bool)
|
||||||
|
go server(ln, ready)
|
||||||
|
<-ready
|
||||||
|
|
||||||
|
client(fmt.Sprintf("http://%s/hello", ln.Addr().String()))
|
||||||
|
http.DefaultServeMux = &http.ServeMux{}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// Welcome to my website! /hello
|
||||||
51
_test/cli4.go
Normal file
51
_test/cli4.go
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"log"
|
||||||
|
"net/http"
|
||||||
|
"net/http/httptest"
|
||||||
|
)
|
||||||
|
|
||||||
|
type mw1 struct {
|
||||||
|
next http.Handler
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *mw1) ServeHTTP(rw http.ResponseWriter, rq *http.Request) {
|
||||||
|
m.next.ServeHTTP(rw, rq)
|
||||||
|
}
|
||||||
|
|
||||||
|
type mw0 struct{}
|
||||||
|
|
||||||
|
func (m *mw0) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||||
|
fmt.Fprint(w, "Welcome to my website!")
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
m0 := &mw0{}
|
||||||
|
m1 := &mw1{m0}
|
||||||
|
|
||||||
|
mux := http.NewServeMux()
|
||||||
|
mux.HandleFunc("/", m1.ServeHTTP)
|
||||||
|
|
||||||
|
server := httptest.NewServer(mux)
|
||||||
|
defer server.Close()
|
||||||
|
|
||||||
|
client(server.URL)
|
||||||
|
}
|
||||||
|
|
||||||
|
func client(uri string) {
|
||||||
|
resp, err := http.Get(uri)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
body, err := ioutil.ReadAll(resp.Body)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
fmt.Println(string(body))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// Welcome to my website!
|
||||||
51
_test/cli5.go
Normal file
51
_test/cli5.go
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"log"
|
||||||
|
"net/http"
|
||||||
|
"net/http/httptest"
|
||||||
|
)
|
||||||
|
|
||||||
|
type mw1 struct {
|
||||||
|
next http.Handler
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *mw1) ServeHTTP(rw http.ResponseWriter, rq *http.Request) {
|
||||||
|
m.next.ServeHTTP(rw, rq)
|
||||||
|
}
|
||||||
|
|
||||||
|
type mw0 struct{}
|
||||||
|
|
||||||
|
func (m *mw0) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||||
|
fmt.Fprint(w, "Welcome to my website!")
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
m0 := &mw0{}
|
||||||
|
m1 := &mw1{next: m0}
|
||||||
|
|
||||||
|
mux := http.NewServeMux()
|
||||||
|
mux.HandleFunc("/", m1.ServeHTTP)
|
||||||
|
|
||||||
|
server := httptest.NewServer(mux)
|
||||||
|
defer server.Close()
|
||||||
|
|
||||||
|
client(server.URL)
|
||||||
|
}
|
||||||
|
|
||||||
|
func client(uri string) {
|
||||||
|
resp, err := http.Get(uri)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
body, err := ioutil.ReadAll(resp.Body)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
fmt.Println(string(body))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// Welcome to my website!
|
||||||
52
_test/cli6.go
Normal file
52
_test/cli6.go
Normal file
@@ -0,0 +1,52 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"log"
|
||||||
|
"net/http"
|
||||||
|
"net/http/httptest"
|
||||||
|
)
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
http.ResponseWriter
|
||||||
|
}
|
||||||
|
|
||||||
|
type mw1 struct {
|
||||||
|
next http.Handler
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *mw1) ServeHTTP(rw http.ResponseWriter, rq *http.Request) {
|
||||||
|
t := &T{
|
||||||
|
ResponseWriter: rw,
|
||||||
|
}
|
||||||
|
x := t.Header()
|
||||||
|
fmt.Fprint(rw, "Welcome to my website!", x)
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
m1 := &mw1{}
|
||||||
|
|
||||||
|
mux := http.NewServeMux()
|
||||||
|
mux.HandleFunc("/", m1.ServeHTTP)
|
||||||
|
|
||||||
|
server := httptest.NewServer(mux)
|
||||||
|
defer server.Close()
|
||||||
|
|
||||||
|
client(server.URL)
|
||||||
|
}
|
||||||
|
|
||||||
|
func client(uri string) {
|
||||||
|
resp, err := http.Get(uri)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
body, err := ioutil.ReadAll(resp.Body)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
fmt.Println(string(body))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// Welcome to my website!map[]
|
||||||
9
_test/comp1.go
Normal file
9
_test/comp1.go
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var a interface{} = 1 < 2
|
||||||
|
println(a.(bool))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true
|
||||||
14
_test/comp2.go
Normal file
14
_test/comp2.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type delta int32
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := delta(-1)
|
||||||
|
|
||||||
|
println(a != -1)
|
||||||
|
println(a == -1)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// false
|
||||||
|
// true
|
||||||
@@ -7,5 +7,5 @@ func main() {
|
|||||||
fmt.Printf("%T %v\n", s, s)
|
fmt.Printf("%T %v\n", s, s)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Output
|
// Output:
|
||||||
// int 2
|
// int 2
|
||||||
|
|||||||
13
_test/complex4.go
Normal file
13
_test/complex4.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func f(a, b float64) interface{} { return complex(a, b) }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := f(3, 2)
|
||||||
|
fmt.Println(a.(complex128))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// (3+2i)
|
||||||
14
_test/composite10.go
Normal file
14
_test/composite10.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := []map[int]int{make(map[int]int)}
|
||||||
|
|
||||||
|
for _, b := range a {
|
||||||
|
fmt.Println(b)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// map[]
|
||||||
15
_test/composite11.go
Normal file
15
_test/composite11.go
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"image/color"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
c := color.NRGBA64{1, 1, 1, 1}
|
||||||
|
|
||||||
|
fmt.Println(c)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// {1 1 1 1}
|
||||||
16
_test/composite5.go
Normal file
16
_test/composite5.go
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
m uint16
|
||||||
|
}
|
||||||
|
|
||||||
|
var t = T{1<<2 | 1<<3}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println(t)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// {12}
|
||||||
20
_test/composite6.go
Normal file
20
_test/composite6.go
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"github.com/traefik/yaegi/_test/ct1"
|
||||||
|
)
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
m uint16
|
||||||
|
}
|
||||||
|
|
||||||
|
var t = T{1 << ct1.R}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println(t)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// {2}
|
||||||
20
_test/composite7.go
Normal file
20
_test/composite7.go
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
name string
|
||||||
|
}
|
||||||
|
|
||||||
|
var tab = []*T{{
|
||||||
|
name: "foo",
|
||||||
|
}, {
|
||||||
|
name: "bar",
|
||||||
|
}}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(len(tab))
|
||||||
|
println(tab[0].name)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 2
|
||||||
|
// foo
|
||||||
16
_test/composite8.go
Normal file
16
_test/composite8.go
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type T struct{ I int }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
t := []*T{}
|
||||||
|
s := []int{1, 2}
|
||||||
|
for _, e := range s {
|
||||||
|
x := &T{e}
|
||||||
|
t = append(t, x)
|
||||||
|
}
|
||||||
|
println(t[0].I, t[1].I)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 1 2
|
||||||
14
_test/composite9.go
Normal file
14
_test/composite9.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := [][]int{make([]int,0)}
|
||||||
|
|
||||||
|
for _, b := range a {
|
||||||
|
fmt.Println(b)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// []
|
||||||
17
_test/const10.go
Normal file
17
_test/const10.go
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
const (
|
||||||
|
a = 2
|
||||||
|
b = c + d
|
||||||
|
c = a + d
|
||||||
|
d = e + f
|
||||||
|
e = 3
|
||||||
|
f = 4
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(b)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 16
|
||||||
13
_test/const11.go
Normal file
13
_test/const11.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
const (
|
||||||
|
x = 2 * iota
|
||||||
|
dim
|
||||||
|
)
|
||||||
|
var t [dim * 2]int
|
||||||
|
println(t[0], len(t))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 0 4
|
||||||
17
_test/const12.go
Normal file
17
_test/const12.go
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type Kind int
|
||||||
|
|
||||||
|
const (
|
||||||
|
None Kind = 0
|
||||||
|
Left Kind = 1 << iota
|
||||||
|
Right
|
||||||
|
Both Kind = Left | Right
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(None, Left, Right, Both)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 0 2 4 6
|
||||||
16
_test/const13.go
Normal file
16
_test/const13.go
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
const tooBig = 1267650600228229401496703205376
|
||||||
|
const huge = 1 << 100
|
||||||
|
const large = huge >> 38
|
||||||
|
|
||||||
|
fmt.Println(large)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 4611686018427387904
|
||||||
13
_test/const14.go
Normal file
13
_test/const14.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "compress/flate"
|
||||||
|
|
||||||
|
func f1(i int) { println("i:", i) }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
i := flate.BestSpeed
|
||||||
|
f1(i)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// i: 1
|
||||||
17
_test/const15.go
Normal file
17
_test/const15.go
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type T1 t1
|
||||||
|
|
||||||
|
type t1 int8
|
||||||
|
|
||||||
|
const (
|
||||||
|
P2 T1 = 2
|
||||||
|
P3 T1 = 3
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(P3)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 3
|
||||||
22
_test/const6.go
Normal file
22
_test/const6.go
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
const (
|
||||||
|
maxNonStarters = 30
|
||||||
|
maxBufferSize = maxNonStarters + 2
|
||||||
|
)
|
||||||
|
|
||||||
|
type reorderBuffer struct {
|
||||||
|
rune [maxBufferSize]Properties
|
||||||
|
}
|
||||||
|
|
||||||
|
type Properties struct {
|
||||||
|
pos uint8
|
||||||
|
size uint8
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(len(reorderBuffer{}.rune))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 32
|
||||||
19
_test/const7.go
Normal file
19
_test/const7.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
const (
|
||||||
|
a = iota
|
||||||
|
b
|
||||||
|
c
|
||||||
|
d
|
||||||
|
)
|
||||||
|
|
||||||
|
type T [c]int
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println(T{})
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [0 0]
|
||||||
15
_test/const8.go
Normal file
15
_test/const8.go
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
const (
|
||||||
|
a = 2
|
||||||
|
b = c + d
|
||||||
|
c = 4
|
||||||
|
d = 5
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(a, b, c, d)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 2 9 4 5
|
||||||
17
_test/const9.go
Normal file
17
_test/const9.go
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
const (
|
||||||
|
a = 2
|
||||||
|
b = c + d
|
||||||
|
c = a + d
|
||||||
|
d = e + f
|
||||||
|
e = b + 2
|
||||||
|
f = 4
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(b)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Error:
|
||||||
|
// 5:2: constant definition loop
|
||||||
16
_test/copy2.go
Normal file
16
_test/copy2.go
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func f(a, b []int) interface{} { return copy(a, b) }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := []int{10, 20, 30}
|
||||||
|
b := [4]int{}
|
||||||
|
c := b[:]
|
||||||
|
r := f(c, a)
|
||||||
|
fmt.Println(r.(int))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 3
|
||||||
9
_test/ct1/ct1.go
Normal file
9
_test/ct1/ct1.go
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
package ct1
|
||||||
|
|
||||||
|
type Class uint
|
||||||
|
|
||||||
|
const (
|
||||||
|
L Class = iota
|
||||||
|
R
|
||||||
|
AL
|
||||||
|
)
|
||||||
23
_test/defer4.go
Normal file
23
_test/defer4.go
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "sync"
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
mu sync.RWMutex
|
||||||
|
name string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *T) get() string {
|
||||||
|
t.mu.RLock()
|
||||||
|
defer t.mu.RUnlock()
|
||||||
|
return t.name
|
||||||
|
}
|
||||||
|
|
||||||
|
var d = T{name: "test"}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(d.get())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// test
|
||||||
32
_test/defer5.go
Normal file
32
_test/defer5.go
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func f1() {
|
||||||
|
defer println("f1-begin")
|
||||||
|
f2()
|
||||||
|
defer println("f1-end")
|
||||||
|
}
|
||||||
|
|
||||||
|
func f2() {
|
||||||
|
defer println("f2-begin")
|
||||||
|
f3()
|
||||||
|
defer println("f2-end")
|
||||||
|
}
|
||||||
|
|
||||||
|
func f3() {
|
||||||
|
defer println("f3-begin")
|
||||||
|
println("hello")
|
||||||
|
defer println("f3-end")
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
f1()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// hello
|
||||||
|
// f3-end
|
||||||
|
// f3-begin
|
||||||
|
// f2-end
|
||||||
|
// f2-begin
|
||||||
|
// f1-end
|
||||||
|
// f1-begin
|
||||||
27
_test/defer6.go
Normal file
27
_test/defer6.go
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func f1() {
|
||||||
|
defer print("f1-begin ")
|
||||||
|
f2()
|
||||||
|
defer print("f1-end ")
|
||||||
|
}
|
||||||
|
|
||||||
|
func f2() {
|
||||||
|
defer print("f2-begin ")
|
||||||
|
f3()
|
||||||
|
defer print("f2-end ")
|
||||||
|
}
|
||||||
|
|
||||||
|
func f3() {
|
||||||
|
defer print("f3-begin ")
|
||||||
|
print("hello ")
|
||||||
|
defer print("f3-end ")
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
f1()
|
||||||
|
println()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// hello f3-end f3-begin f2-end f2-begin f1-end f1-begin
|
||||||
18
_test/defer7.go
Normal file
18
_test/defer7.go
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func f1(in, out []string) {
|
||||||
|
defer copy(out, in)
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
in := []string{"foo", "bar"}
|
||||||
|
out := make([]string, 2)
|
||||||
|
f1(in, out)
|
||||||
|
|
||||||
|
fmt.Println(out)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [foo bar]
|
||||||
24
_test/defer8.go
Normal file
24
_test/defer8.go
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func f1(m map[string]string) {
|
||||||
|
defer delete(m, "foo")
|
||||||
|
defer delete(m, "test")
|
||||||
|
|
||||||
|
fmt.Println(m)
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
m := map[string]string{
|
||||||
|
"foo": "bar",
|
||||||
|
"baz": "bat",
|
||||||
|
}
|
||||||
|
f1(m)
|
||||||
|
|
||||||
|
fmt.Println(m)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// map[baz:bat foo:bar]
|
||||||
|
// map[baz:bat]
|
||||||
21
_test/defer9.go
Normal file
21
_test/defer9.go
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func f1(ch chan string) {
|
||||||
|
defer close(ch)
|
||||||
|
|
||||||
|
ch <- "foo"
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
ch := make(chan string, 1)
|
||||||
|
f1(ch)
|
||||||
|
|
||||||
|
for s := range ch {
|
||||||
|
fmt.Println(s)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// foo
|
||||||
@@ -2,13 +2,14 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"log"
|
"log"
|
||||||
|
"os"
|
||||||
|
|
||||||
"github.com/containous/yaegi/interp"
|
"github.com/traefik/yaegi/interp"
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
log.SetFlags(log.Lshortfile)
|
log.SetFlags(log.Lshortfile)
|
||||||
i := interp.New(interp.Options{})
|
i := interp.New(interp.Options{Stdout: os.Stdout})
|
||||||
if _, err := i.Eval(`func f() (int, int) { return 1, 2 }`); err != nil {
|
if _, err := i.Eval(`func f() (int, int) { return 1, 2 }`); err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|||||||
3
_test/foo-bar/foo-bar.go
Normal file
3
_test/foo-bar/foo-bar.go
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
package bar
|
||||||
|
|
||||||
|
var Name = "foo-bar"
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
package foo
|
package foo
|
||||||
|
|
||||||
import "github.com/containous/yaegi/_test/foo/boo"
|
import "github.com/traefik/yaegi/_test/foo/boo"
|
||||||
|
|
||||||
var Bar = "BARR"
|
var Bar = "BARR"
|
||||||
var Boo = boo.Boo
|
var Boo = boo.Boo
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
package foo
|
package foo
|
||||||
|
|
||||||
import "github.com/containous/yaegi/_test/foo/boo"
|
import "github.com/traefik/yaegi/_test/foo/boo"
|
||||||
|
|
||||||
var Bir = boo.Boo + "22"
|
var Bir = boo.Boo + "22"
|
||||||
|
|||||||
13
_test/for10.go
Normal file
13
_test/for10.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
for a := 0; false; {
|
||||||
|
println("nok", a)
|
||||||
|
a++
|
||||||
|
break
|
||||||
|
}
|
||||||
|
println("bye")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// bye
|
||||||
14
_test/for11.go
Normal file
14
_test/for11.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := 0
|
||||||
|
for ; true; a++ {
|
||||||
|
println("nok", a)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
println("bye", a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// nok 0
|
||||||
|
// bye 0
|
||||||
12
_test/for12.go
Normal file
12
_test/for12.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
for a := 0; false; a++ {
|
||||||
|
println("nok", a)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
println("bye")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// bye
|
||||||
13
_test/for13.go
Normal file
13
_test/for13.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := 0
|
||||||
|
for ; false; a++ {
|
||||||
|
println("nok", a)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
println("bye", a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// bye 0
|
||||||
16
_test/for14.go
Normal file
16
_test/for14.go
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
for a := 0; true; a++ {
|
||||||
|
println(a)
|
||||||
|
if a > 0 {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
println("bye")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 0
|
||||||
|
// 1
|
||||||
|
// bye
|
||||||
18
_test/for8.go
Normal file
18
_test/for8.go
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
for i := 0; i < 4; i++ {
|
||||||
|
for {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
if i == 1 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
println(i)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 0
|
||||||
|
// 2
|
||||||
|
// 3
|
||||||
12
_test/for9.go
Normal file
12
_test/for9.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
for false {
|
||||||
|
println("nok")
|
||||||
|
break
|
||||||
|
}
|
||||||
|
println("bye")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// bye
|
||||||
12
_test/fun11.go
Normal file
12
_test/fun11.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
var f F
|
||||||
|
|
||||||
|
type F func(int)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println("ok")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// ok
|
||||||
12
_test/fun12.go
Normal file
12
_test/fun12.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func use(interface{}) {}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
z := map[string]interface{}{"a": 5}
|
||||||
|
use(z)
|
||||||
|
println("bye")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// bye
|
||||||
19
_test/fun13.go
Normal file
19
_test/fun13.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type T struct{}
|
||||||
|
|
||||||
|
func newT() (T, error) { return T{}, nil }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var (
|
||||||
|
i interface{}
|
||||||
|
err error
|
||||||
|
)
|
||||||
|
i, err = newT()
|
||||||
|
fmt.Println(i, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// {} <nil>
|
||||||
13
_test/fun14.go
Normal file
13
_test/fun14.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func f() (bool, int) { return true, 2 }
|
||||||
|
|
||||||
|
func g() (bool, int) { return f() }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
b, i := g()
|
||||||
|
println(b, i)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true 2
|
||||||
11
_test/fun15.go
Normal file
11
_test/fun15.go
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func f1(a int) interface{} { return a + 1 }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
c := f1(3)
|
||||||
|
println(c.(int))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 4
|
||||||
13
_test/fun16.go
Normal file
13
_test/fun16.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func f1(a int) int { return a + 1 }
|
||||||
|
|
||||||
|
func f2(a int) interface{} { return f1(a) }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
c := f2(3)
|
||||||
|
println(c.(int))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 4
|
||||||
13
_test/fun17.go
Normal file
13
_test/fun17.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func f1(a int) interface{} { return a + 1 }
|
||||||
|
|
||||||
|
func f2(a int) interface{} { return f1(a) }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
c := f2(3)
|
||||||
|
println(c.(int))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 4
|
||||||
12
_test/fun18.go
Normal file
12
_test/fun18.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
var m = map[string]int{"foo": 1, "bar": 2}
|
||||||
|
|
||||||
|
func f(s string) interface{} { return m[s] }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(f("foo").(int))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 1
|
||||||
17
_test/fun19.go
Normal file
17
_test/fun19.go
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
)
|
||||||
|
|
||||||
|
func foo() ([]string, error) {
|
||||||
|
return nil, fmt.Errorf("bar")
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a, b := foo()
|
||||||
|
fmt.Println(a, b)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [] bar
|
||||||
19
_test/fun20.go
Normal file
19
_test/fun20.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
var myerr error = fmt.Errorf("bar")
|
||||||
|
|
||||||
|
func ferr() error { return myerr }
|
||||||
|
|
||||||
|
func foo() ([]string, error) {
|
||||||
|
return nil, ferr()
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a, b := foo()
|
||||||
|
fmt.Println(a, b)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [] bar
|
||||||
12
_test/fun21.go
Normal file
12
_test/fun21.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func Bar() string {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(Bar())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Error:
|
||||||
|
// 4:2: not enough arguments to return
|
||||||
10
_test/fun22.go
Normal file
10
_test/fun22.go
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "time"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
time.Date()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Error:
|
||||||
|
// 6:2: not enough arguments in call to time.Date
|
||||||
17
_test/if3.go
Normal file
17
_test/if3.go
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := 0
|
||||||
|
if false {
|
||||||
|
println("false")
|
||||||
|
a = 1
|
||||||
|
} else {
|
||||||
|
println("true")
|
||||||
|
a = -1
|
||||||
|
}
|
||||||
|
println(a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true
|
||||||
|
// -1
|
||||||
19
_test/if4.go
Normal file
19
_test/if4.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
const bad = false
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := 0
|
||||||
|
if bad {
|
||||||
|
println("false")
|
||||||
|
a = 1
|
||||||
|
} else {
|
||||||
|
println("true")
|
||||||
|
a = -1
|
||||||
|
}
|
||||||
|
println(a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true
|
||||||
|
// -1
|
||||||
12
_test/if5.go
Normal file
12
_test/if5.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
if true {
|
||||||
|
println("ok")
|
||||||
|
}
|
||||||
|
println("bye")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// ok
|
||||||
|
// bye
|
||||||
11
_test/if6.go
Normal file
11
_test/if6.go
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
if false {
|
||||||
|
println("nok")
|
||||||
|
}
|
||||||
|
println("bye")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// bye
|
||||||
15
_test/if7.go
Normal file
15
_test/if7.go
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := 0
|
||||||
|
b := false
|
||||||
|
if (b) {
|
||||||
|
a = 1
|
||||||
|
} else {
|
||||||
|
a = -1
|
||||||
|
}
|
||||||
|
println(a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// -1
|
||||||
14
_test/imag0.go
Normal file
14
_test/imag0.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func f(c complex128) interface{} { return imag(c) }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
c := complex(3, 2)
|
||||||
|
a := f(c)
|
||||||
|
fmt.Println(a.(float64))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 2
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import "github.com/containous/yaegi/_test/foo"
|
import "github.com/traefik/yaegi/_test/foo"
|
||||||
|
|
||||||
func main() { println(foo.Bar, foo.Boo) }
|
func main() { println(foo.Bar, foo.Boo) }
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import "github.com/containous/yaegi/_test/p1"
|
import "github.com/traefik/yaegi/_test/p1"
|
||||||
|
|
||||||
func main() { println("num:", p1.Uint32()) }
|
func main() { println("num:", p1.Uint32()) }
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import boo "github.com/containous/yaegi/_test/foo"
|
import boo "github.com/traefik/yaegi/_test/foo"
|
||||||
|
|
||||||
func main() { println(boo.Bar, boo.Boo, boo.Bir) }
|
func main() { println(boo.Bar, boo.Boo, boo.Bir) }
|
||||||
|
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user