Compare commits
133 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
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 | ||
|
|
eef59153d8 | ||
|
|
d44e4af527 | ||
|
|
786ea366ab | ||
|
|
e506969172 | ||
|
|
9f1f31210a | ||
|
|
56bec974e1 | ||
|
|
08a37fc4bf | ||
|
|
c5ec5e492f | ||
|
|
773147ef71 | ||
|
|
a6ecebab92 | ||
|
|
d893a7427e | ||
|
|
3969ab16c4 | ||
|
|
714253c1e6 | ||
|
|
75a696a5c8 | ||
|
|
15686873e0 | ||
|
|
ac504a2e8a | ||
|
|
e193d95dc2 | ||
|
|
7164a23664 | ||
|
|
0b4dcbf7bb | ||
|
|
2765478137 | ||
|
|
de5a6e1038 | ||
|
|
398b0e0255 | ||
|
|
4f95c27634 | ||
|
|
7d19108f01 | ||
|
|
1cf327bd7d | ||
|
|
4bf4aeecbb | ||
|
|
47923866ff | ||
|
|
bb2921b42f | ||
|
|
2c2b471cb9 | ||
|
|
0f46cd5efb | ||
|
|
35e645c690 | ||
|
|
03596dac45 | ||
|
|
8db7a815e3 | ||
|
|
424e7ac90d | ||
|
|
effd64c980 | ||
|
|
8a88a1ab8a | ||
|
|
030dd3cbc2 | ||
|
|
bee21968c7 | ||
|
|
9abaeeb729 | ||
|
|
c8ae73ae8c | ||
|
|
5e49f83519 | ||
|
|
ec1ee5f5b6 | ||
|
|
e03016b6d7 | ||
|
|
400b625153 | ||
|
|
f7810d9761 | ||
|
|
7d4e5fb224 | ||
|
|
b08a51cb16 | ||
|
|
9e664ee8dd | ||
|
|
cda23836f0 | ||
|
|
058c121273 | ||
|
|
3645904a15 | ||
|
|
82dd3f2953 | ||
|
|
2f0279f0f5 | ||
|
|
bfa9a267be | ||
|
|
978bbe0301 | ||
|
|
63a537c8d9 | ||
|
|
b0937618b0 | ||
|
|
d23a7e1d8b | ||
|
|
71fd938040 | ||
|
|
869b6d2850 | ||
|
|
a4e15d7788 | ||
|
|
c88297459d | ||
|
|
8aa22b9ebb | ||
|
|
75ad29c6b4 | ||
|
|
a89a8b9ce4 | ||
|
|
458e8e911a | ||
|
|
ee81ee7fea | ||
|
|
aaddc39981 | ||
|
|
5bf6618a53 | ||
|
|
aad4c5a99b |
@@ -17,11 +17,11 @@ func main() {
|
|||||||
Expected result:
|
Expected result:
|
||||||
```console
|
```console
|
||||||
$ go run ./sample.go
|
$ go run ./sample.go
|
||||||
// ouput
|
// output
|
||||||
```
|
```
|
||||||
|
|
||||||
Got:
|
Got:
|
||||||
```console
|
```console
|
||||||
$ yaegi ./sample.go
|
$ yaegi ./sample.go
|
||||||
// ouput
|
// output
|
||||||
```
|
```
|
||||||
19
.github/ISSUE_TEMPLATE/feature_request.md
vendored
Normal file
19
.github/ISSUE_TEMPLATE/feature_request.md
vendored
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
---
|
||||||
|
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? -->
|
||||||
1
.gitignore
vendored
1
.gitignore
vendored
@@ -6,3 +6,4 @@
|
|||||||
cmd/goexports/goexports
|
cmd/goexports/goexports
|
||||||
example/inception/inception
|
example/inception/inception
|
||||||
_test/tmp/
|
_test/tmp/
|
||||||
|
/dist
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
[linters-settings]
|
[linters-settings]
|
||||||
|
|
||||||
[linters-settings.govet]
|
[linters-settings.govet]
|
||||||
check-shadowing = true
|
check-shadowing = false
|
||||||
|
|
||||||
[linters-settings.gocyclo]
|
[linters-settings.gocyclo]
|
||||||
min-complexity = 12.0
|
min-complexity = 12.0
|
||||||
@@ -32,6 +32,12 @@
|
|||||||
"gocyclo",
|
"gocyclo",
|
||||||
"gochecknoinits",
|
"gochecknoinits",
|
||||||
"gochecknoglobals",
|
"gochecknoglobals",
|
||||||
|
"wsl",
|
||||||
|
"godox",
|
||||||
|
"funlen",
|
||||||
|
"gocognit",
|
||||||
|
"stylecheck",
|
||||||
|
"gomnd",
|
||||||
]
|
]
|
||||||
|
|
||||||
[issues]
|
[issues]
|
||||||
@@ -41,10 +47,12 @@
|
|||||||
exclude = []
|
exclude = []
|
||||||
|
|
||||||
[[issues.exclude-rules]]
|
[[issues.exclude-rules]]
|
||||||
path = "cmd/goexports/goexports.go"
|
path = "interp/.+_test\\.go"
|
||||||
text = "SA1019: importer.For is deprecated: use ForCompiler, which populates a FileSet with the positions of objects created by the importer."
|
linters = ["goconst"]
|
||||||
|
|
||||||
# structcheck false-positive
|
|
||||||
[[issues.exclude-rules]]
|
[[issues.exclude-rules]]
|
||||||
path = "interp/interp.go"
|
path = "interp/interp.go"
|
||||||
text = "`(astDot|cfgDot|noRun)` is unused"
|
text = "`in` can be `io.Reader`"
|
||||||
|
[[issues.exclude-rules]]
|
||||||
|
path = "interp/interp.go"
|
||||||
|
text = "`out` can be `io.Writer`"
|
||||||
|
|||||||
@@ -1,7 +1,8 @@
|
|||||||
project_name: yaegi
|
project_name: yaegi
|
||||||
|
|
||||||
builds:
|
builds:
|
||||||
- binary: yaegi
|
- id: yaegi
|
||||||
|
binary: yaegi
|
||||||
main: ./cmd/yaegi/yaegi.go
|
main: ./cmd/yaegi/yaegi.go
|
||||||
|
|
||||||
goos:
|
goos:
|
||||||
@@ -25,6 +26,31 @@ builds:
|
|||||||
- goos: darwin
|
- goos: darwin
|
||||||
goarch: 386
|
goarch: 386
|
||||||
|
|
||||||
|
- id: goexports
|
||||||
|
binary: goexports
|
||||||
|
main: ./cmd/goexports/goexports.go
|
||||||
|
|
||||||
|
goos:
|
||||||
|
- darwin
|
||||||
|
- linux
|
||||||
|
# - windows
|
||||||
|
- freebsd
|
||||||
|
- openbsd
|
||||||
|
- solaris
|
||||||
|
goarch:
|
||||||
|
- amd64
|
||||||
|
- 386
|
||||||
|
- arm
|
||||||
|
- arm64
|
||||||
|
goarm:
|
||||||
|
- 7
|
||||||
|
- 6
|
||||||
|
- 5
|
||||||
|
|
||||||
|
ignore:
|
||||||
|
- goos: darwin
|
||||||
|
goarch: 386
|
||||||
|
|
||||||
changelog:
|
changelog:
|
||||||
sort: asc
|
sort: asc
|
||||||
filters:
|
filters:
|
||||||
@@ -35,11 +61,12 @@ changelog:
|
|||||||
- '^test:'
|
- '^test:'
|
||||||
- '^tests:'
|
- '^tests:'
|
||||||
|
|
||||||
archive:
|
archives:
|
||||||
name_template: '{{ .ProjectName }}_v{{ .Version }}_{{ .Os }}_{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}'
|
- id: archive
|
||||||
format: tar.gz
|
name_template: '{{ .ProjectName }}_v{{ .Version }}_{{ .Os }}_{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}'
|
||||||
format_overrides:
|
format: tar.gz
|
||||||
- goos: windows
|
format_overrides:
|
||||||
format: zip
|
- goos: windows
|
||||||
files:
|
format: zip
|
||||||
- LICENSE
|
files:
|
||||||
|
- LICENSE
|
||||||
|
|||||||
27
.travis.yml
27
.travis.yml
@@ -2,23 +2,36 @@ language: go
|
|||||||
|
|
||||||
dist: xenial
|
dist: xenial
|
||||||
|
|
||||||
env:
|
branches:
|
||||||
- GO111MODULE=on
|
only:
|
||||||
|
- master
|
||||||
|
- /^v\d+\.\d+(\.\d+)?(-\S*)?$/
|
||||||
|
|
||||||
notifications:
|
notifications:
|
||||||
email:
|
email:
|
||||||
on_success: never
|
on_success: never
|
||||||
on_failure: change
|
on_failure: change
|
||||||
|
|
||||||
go:
|
cache:
|
||||||
- 1.11.x
|
directories:
|
||||||
- 1.12.x
|
- $GOPATH/pkg/mod
|
||||||
|
|
||||||
|
matrix:
|
||||||
|
fast_finish: true
|
||||||
|
include:
|
||||||
|
- go: 1.13.x
|
||||||
|
- go: 1.14.x
|
||||||
|
env: STABLE=true
|
||||||
|
|
||||||
|
env:
|
||||||
|
global:
|
||||||
|
- GO111MODULE=on
|
||||||
|
|
||||||
go_import_path: github.com/containous/yaegi
|
go_import_path: github.com/containous/yaegi
|
||||||
|
|
||||||
before_install:
|
before_install:
|
||||||
# Install linters and misspell
|
# Install linters and misspell
|
||||||
- curl -sfL https://install.goreleaser.com/github.com/golangci/golangci-lint.sh | bash -s -- -b $GOPATH/bin v1.16.0
|
- curl -sfL https://install.goreleaser.com/github.com/golangci/golangci-lint.sh | bash -s -- -b $GOPATH/bin ${GOLANGCI_LINT_VERSION}
|
||||||
- golangci-lint --version
|
- golangci-lint --version
|
||||||
|
|
||||||
install:
|
install:
|
||||||
@@ -44,4 +57,4 @@ deploy:
|
|||||||
script: curl -sL https://git.io/goreleaser | bash
|
script: curl -sL https://git.io/goreleaser | bash
|
||||||
on:
|
on:
|
||||||
tags: true
|
tags: true
|
||||||
condition: $TRAVIS_GO_VERSION =~ ^1\.12\.x$
|
condition: $STABLE = true
|
||||||
|
|||||||
24
CONTRIBUTING.md
Normal file
24
CONTRIBUTING.md
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
# Contributing
|
||||||
|
|
||||||
|
Yaegi is an open source project, and your feedback and contributions
|
||||||
|
are needed and always welcome.
|
||||||
|
|
||||||
|
[Issues] and [Pull Requests] are opened at https://github.com/containous/yaegi.
|
||||||
|
|
||||||
|
Non trivial changes should be discussed with the project maintainers by
|
||||||
|
opening a [Feature Request] clearly explaining rationale, background
|
||||||
|
and possible implementation ideas. Feel free to provide code in such
|
||||||
|
discussions.
|
||||||
|
|
||||||
|
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].
|
||||||
|
|
||||||
|
We will also require you to sign the [Containous Contributor License Agreement]
|
||||||
|
after you submit your first pull request to this project. The link to sign the
|
||||||
|
agreement will be presented to you in the web interface of the pull request.
|
||||||
|
|
||||||
|
[Issues]: https://github.com/containous/yaegi/issues
|
||||||
|
[Pull Requests]: https://github.com/containous/yaegi/issues
|
||||||
|
[Feature Request]: https://github.com/containous/yaegi/issues/new?template=feature_request.md
|
||||||
|
[Draft Pull Request]: https://github.blog/2019-02-14-introducing-draft-pull-requests/
|
||||||
|
[Containous Contributor License Agreement]: https://cla-assistant.io/containous/yaegi
|
||||||
1
Makefile
1
Makefile
@@ -18,5 +18,6 @@ generate: gen_all_syscall
|
|||||||
|
|
||||||
tests:
|
tests:
|
||||||
GO111MODULE=off go test -v ./...
|
GO111MODULE=off go test -v ./...
|
||||||
|
GO111MODULE=off go test -race ./interp
|
||||||
|
|
||||||
.PHONY: check gen_all_syscall gen_tests
|
.PHONY: check gen_all_syscall gen_tests
|
||||||
|
|||||||
27
README.md
27
README.md
@@ -5,6 +5,7 @@
|
|||||||
[](https://github.com/containous/yaegi/releases)
|
[](https://github.com/containous/yaegi/releases)
|
||||||
[](https://travis-ci.com/containous/yaegi)
|
[](https://travis-ci.com/containous/yaegi)
|
||||||
[](https://godoc.org/github.com/containous/yaegi)
|
[](https://godoc.org/github.com/containous/yaegi)
|
||||||
|
[](https://community.containo.us/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.
|
||||||
@@ -17,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.11 and Go 1.12 (the latest 2 major releases)
|
* Support Go 1.13 and Go 1.14 (the latest 2 major releases)
|
||||||
|
|
||||||
## Install
|
## Install
|
||||||
|
|
||||||
@@ -128,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].
|
||||||
@@ -144,9 +163,7 @@ Beside the known [bugs] which are supposed to be fixed in the short term, there
|
|||||||
|
|
||||||
## Contributing
|
## Contributing
|
||||||
|
|
||||||
Yaegi is an open source project, and your feedback and contributions are needed and always welcome.
|
[Contributing guide](CONTRIBUTING.md).
|
||||||
|
|
||||||
[Issues] and [pull requests] are opened at https://github.com/containous/yaegi
|
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
@@ -156,6 +173,4 @@ Yaegi is an open source project, and your feedback and contributions are needed
|
|||||||
[docs]: https://godoc.org/github.com/containous/yaegi
|
[docs]: https://godoc.org/github.com/containous/yaegi
|
||||||
[license]: https://github.com/containous/yaegi/blob/master/LICENSE
|
[license]: https://github.com/containous/yaegi/blob/master/LICENSE
|
||||||
[github]: https://github.com/containous/yaegi
|
[github]: https://github.com/containous/yaegi
|
||||||
[Issues]: https://github.com/containous/yaegi/issues
|
|
||||||
[pull requests]: https://github.com/containous/yaegi/issues
|
|
||||||
[bugs]: https://github.com/containous/yaegi/issues?q=is%3Aissue+is%3Aopen+label%3Abug
|
[bugs]: https://github.com/containous/yaegi/issues?q=is%3Aissue+is%3Aopen+label%3Abug
|
||||||
|
|||||||
10
_test/a30.go
Normal file
10
_test/a30.go
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
for range []struct{}{} {
|
||||||
|
}
|
||||||
|
println("ok")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// ok
|
||||||
11
_test/a31.go
Normal file
11
_test/a31.go
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
for range []int{0, 1, 2} {
|
||||||
|
print("hello ")
|
||||||
|
}
|
||||||
|
println("")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// hello hello hello
|
||||||
14
_test/a32.go
Normal file
14
_test/a32.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type T struct{}
|
||||||
|
|
||||||
|
var a = []T{{}}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println(a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [{}]
|
||||||
12
_test/a33.go
Normal file
12
_test/a33.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := [...]int{1, 2, 3}
|
||||||
|
b := a
|
||||||
|
fmt.Println(b)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [1 2 3]
|
||||||
12
_test/a34.go
Normal file
12
_test/a34.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := [...]int{1, 2, 3}
|
||||||
|
var b [3]int = a
|
||||||
|
fmt.Println(b)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [1 2 3]
|
||||||
13
_test/a35.go
Normal file
13
_test/a35.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := [...]int{1, 2, 3}
|
||||||
|
b := a
|
||||||
|
b[0] = -1
|
||||||
|
fmt.Println(a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [1 2 3]
|
||||||
13
_test/a36.go
Normal file
13
_test/a36.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := [...]int{1, 2, 3}
|
||||||
|
var b [3]int = a
|
||||||
|
b[0] = -1
|
||||||
|
fmt.Println(a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [1 2 3]
|
||||||
11
_test/a37.go
Normal file
11
_test/a37.go
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := [...]int{1, 2, 3}
|
||||||
|
fmt.Println(a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [1 2 3]
|
||||||
11
_test/a38.go
Normal file
11
_test/a38.go
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := [...]byte{}
|
||||||
|
fmt.Printf("%T\n", a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [0]uint8
|
||||||
12
_test/a39.go
Normal file
12
_test/a39.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := [...]byte{}
|
||||||
|
b := a
|
||||||
|
fmt.Printf("%T %T\n", a, b)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [0]uint8 [0]uint8
|
||||||
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/alias1.go
Normal file
16
_test/alias1.go
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type MyT T
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
Name string
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println(MyT{})
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// {}
|
||||||
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
|
||||||
@@ -9,5 +9,5 @@ func main() {
|
|||||||
fmt.Println(buf)
|
fmt.Println(buf)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Output
|
// Output:
|
||||||
// []
|
// []
|
||||||
|
|||||||
10
_test/assign10.go
Normal file
10
_test/assign10.go
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var a uint
|
||||||
|
a = 1 + 2
|
||||||
|
println(a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 3
|
||||||
15
_test/assign9.go
Normal file
15
_test/assign9.go
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type foo func(b int)
|
||||||
|
|
||||||
|
func boo(b int) { println("boo", b) }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var f foo
|
||||||
|
|
||||||
|
f = boo
|
||||||
|
f(4)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// boo 4
|
||||||
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/containous/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"
|
||||||
4
_test/bad0.go
Normal file
4
_test/bad0.go
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
println("Hello")
|
||||||
|
|
||||||
|
// Error:
|
||||||
|
// 1:1: expected 'package', found println
|
||||||
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
|
||||||
5
_test/c1/c1.go
Normal file
5
_test/c1/c1.go
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
package c1
|
||||||
|
|
||||||
|
import "github.com/containous/yaegi/_test/c2"
|
||||||
|
|
||||||
|
var C1 = c2.C2 + "x"
|
||||||
5
_test/c2/c2.go
Normal file
5
_test/c2/c2.go
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
package c2
|
||||||
|
|
||||||
|
import "github.com/containous/yaegi/_test/c1"
|
||||||
|
|
||||||
|
var C2 = c1.C1 + "Y"
|
||||||
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
|
||||||
10
_test/closure8.go
Normal file
10
_test/closure8.go
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
var f = func(a int) int { return 2 + a }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(f(3))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 5
|
||||||
12
_test/complex1.go
Normal file
12
_test/complex1.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var c complex128
|
||||||
|
c = 1
|
||||||
|
fmt.Printf("%T %v\n", c, c)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// complex128 (1+0i)
|
||||||
12
_test/complex2.go
Normal file
12
_test/complex2.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
c := complex(1, 0)
|
||||||
|
c += 1
|
||||||
|
fmt.Printf("%T %v\n", c, c)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// complex128 (2+0i)
|
||||||
11
_test/complex3.go
Normal file
11
_test/complex3.go
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var s int = 1 + complex(1, 0)
|
||||||
|
fmt.Printf("%T %v\n", s, s)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// int 2
|
||||||
14
_test/composite0.go
Normal file
14
_test/composite0.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
var a = &[]*T{}
|
||||||
|
|
||||||
|
type T struct{ name string }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println(a)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// &[]
|
||||||
14
_test/composite1.go
Normal file
14
_test/composite1.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
var a = &[]*T{{}}
|
||||||
|
|
||||||
|
type T struct{ name string }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println((*a)[0])
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// &{}
|
||||||
14
_test/composite2.go
Normal file
14
_test/composite2.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
var a = &[]*T{{"hello"}}
|
||||||
|
|
||||||
|
type T struct{ name string }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println((*a)[0])
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// &{hello}
|
||||||
12
_test/composite3.go
Normal file
12
_test/composite3.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var err error
|
||||||
|
var ok bool
|
||||||
|
|
||||||
|
_, ok = err.(interface{ IsSet() bool })
|
||||||
|
println(ok)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// false
|
||||||
11
_test/composite4.go
Normal file
11
_test/composite4.go
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var err error
|
||||||
|
|
||||||
|
_, ok := err.(interface{ IsSet() bool })
|
||||||
|
println(ok)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// false
|
||||||
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/containous/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
|
||||||
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
|
||||||
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
|
||||||
14
_test/copy1.go
Normal file
14
_test/copy1.go
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
a := []int{10, 20, 30}
|
||||||
|
b := &[4]int{}
|
||||||
|
c := b[:]
|
||||||
|
copy(c, a)
|
||||||
|
fmt.Println(c)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// [10 20 30 0]
|
||||||
3
_test/ct/ct1.go
Normal file
3
_test/ct/ct1.go
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
package ct
|
||||||
|
|
||||||
|
func init() { println("hello from ct1") }
|
||||||
5
_test/ct/ct2.go
Normal file
5
_test/ct/ct2.go
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
// +build !dummy
|
||||||
|
|
||||||
|
package ct
|
||||||
|
|
||||||
|
func init() { println("hello from ct2") }
|
||||||
5
_test/ct/ct3.go
Normal file
5
_test/ct/ct3.go
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
// +build dummy
|
||||||
|
|
||||||
|
package ct
|
||||||
|
|
||||||
|
func init() { println("hello from ct3") }
|
||||||
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
|
||||||
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,8 @@
|
|||||||
package foo
|
package foo
|
||||||
|
|
||||||
import "./boo"
|
import "github.com/containous/yaegi/_test/foo/boo"
|
||||||
|
|
||||||
var Bar = "BARR"
|
var Bar = "BARR"
|
||||||
var Boo = boo.Boo
|
var Boo = boo.Boo
|
||||||
|
|
||||||
|
func init() { println("init foo") }
|
||||||
|
|||||||
5
_test/foo/bir.go
Normal file
5
_test/foo/bir.go
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
package foo
|
||||||
|
|
||||||
|
import "github.com/containous/yaegi/_test/foo/boo"
|
||||||
|
|
||||||
|
var Bir = boo.Boo + "22"
|
||||||
@@ -1,3 +1,5 @@
|
|||||||
package boo
|
package boo
|
||||||
|
|
||||||
var Boo = "Boo"
|
var Boo = "Boo"
|
||||||
|
|
||||||
|
func init() { println("init boo") }
|
||||||
|
|||||||
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
|
||||||
19
_test/for6.go
Normal file
19
_test/for6.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
s := "三"
|
||||||
|
for i := 0; i < len(s); i++ {
|
||||||
|
fmt.Printf("byte %d: %d\n", i, s[i])
|
||||||
|
}
|
||||||
|
for i, r := range s {
|
||||||
|
fmt.Printf("rune %d: %d\n", i, r)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// byte 0: 228
|
||||||
|
// byte 1: 184
|
||||||
|
// byte 2: 137
|
||||||
|
// rune 0: 19977
|
||||||
9
_test/for7.go
Normal file
9
_test/for7.go
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
for i := 0; i; {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Error:
|
||||||
|
// 4:14: non-bool used as for condition
|
||||||
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
|
||||||
19
_test/fun10.go
Normal file
19
_test/fun10.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func f() func() {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
g := f()
|
||||||
|
fmt.Printf("%T %v\n", g, g)
|
||||||
|
if g == nil {
|
||||||
|
fmt.Println("nil func")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// func() <nil>
|
||||||
|
// nil func
|
||||||
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
|
||||||
21
_test/fun6.go
Normal file
21
_test/fun6.go
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"sync"
|
||||||
|
)
|
||||||
|
|
||||||
|
func NewPool() Pool { return Pool{} }
|
||||||
|
|
||||||
|
type Pool struct {
|
||||||
|
p *sync.Pool
|
||||||
|
}
|
||||||
|
|
||||||
|
var _pool = NewPool()
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
fmt.Println(_pool)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// {<nil>}
|
||||||
18
_test/fun7.go
Normal file
18
_test/fun7.go
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
goflag "flag"
|
||||||
|
"fmt"
|
||||||
|
)
|
||||||
|
|
||||||
|
func Foo(goflag *goflag.Flag) {
|
||||||
|
fmt.Println(goflag)
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
g := &goflag.Flag{}
|
||||||
|
Foo(g)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// &{ <nil> }
|
||||||
8
_test/fun8.go
Normal file
8
_test/fun8.go
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
func main() { println(f == nil) }
|
||||||
|
|
||||||
|
var f func()
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// true
|
||||||
12
_test/fun9.go
Normal file
12
_test/fun9.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type T uint
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
type myint int
|
||||||
|
var i = myint(1)
|
||||||
|
println(i)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 1
|
||||||
13
_test/if2.go
Normal file
13
_test/if2.go
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var i int
|
||||||
|
if i % 1000000 {
|
||||||
|
fmt.Println("oops")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Error:
|
||||||
|
// 7:5: non-bool used as if condition
|
||||||
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
|
||||||
@@ -1,8 +1,10 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import "./foo"
|
import "github.com/containous/yaegi/_test/foo"
|
||||||
|
|
||||||
func main() { println(foo.Bar, foo.Boo) }
|
func main() { println(foo.Bar, foo.Boo) }
|
||||||
|
|
||||||
// Output:
|
// Output:
|
||||||
|
// init boo
|
||||||
|
// init foo
|
||||||
// BARR Boo
|
// BARR Boo
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import "./p1"
|
import "github.com/containous/yaegi/_test/p1"
|
||||||
|
|
||||||
func main() { println("num:", p1.Uint32()) }
|
func main() { println("num:", p1.Uint32()) }
|
||||||
|
|
||||||
|
|||||||
10
_test/import5.go
Normal file
10
_test/import5.go
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import boo "github.com/containous/yaegi/_test/foo"
|
||||||
|
|
||||||
|
func main() { println(boo.Bar, boo.Boo, boo.Bir) }
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// init boo
|
||||||
|
// init foo
|
||||||
|
// BARR Boo Boo22
|
||||||
11
_test/import6.go
Normal file
11
_test/import6.go
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "github.com/containous/yaegi/_test/c1"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(c1.C1)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Error:
|
||||||
|
// import cycle not allowed
|
||||||
|
// imports github.com/containous/yaegi/_test/c1
|
||||||
10
_test/import7.go
Normal file
10
_test/import7.go
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "github.com/containous/yaegi/_test/foo-bar"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(bar.Name)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// foo-bar
|
||||||
10
_test/import8.go
Normal file
10
_test/import8.go
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "github.com/containous/yaegi/_test/b1/foo"
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println(foo.Desc)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// in b1/foo
|
||||||
12
_test/interface10.go
Normal file
12
_test/interface10.go
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type Edge interface {
|
||||||
|
ReverseEdge() Edge
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
println("hello")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// hello
|
||||||
27
_test/interface11.go
Normal file
27
_test/interface11.go
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type Error interface {
|
||||||
|
error
|
||||||
|
Code() string
|
||||||
|
}
|
||||||
|
|
||||||
|
type MyError Error
|
||||||
|
|
||||||
|
type T struct {
|
||||||
|
Name string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *T) Error() string { return "err: " + t.Name }
|
||||||
|
func (t *T) Code() string { return "code: " + t.Name }
|
||||||
|
|
||||||
|
func newT(s string) MyError { return &T{s} }
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
t := newT("foo")
|
||||||
|
fmt.Println(t.Code())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// code: foo
|
||||||
18
_test/interface12.go
Normal file
18
_test/interface12.go
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type I1 interface {
|
||||||
|
Truc()
|
||||||
|
}
|
||||||
|
|
||||||
|
type T1 struct{}
|
||||||
|
|
||||||
|
func (T1) Truc() { println("in T1 truc") }
|
||||||
|
|
||||||
|
var x I1 = T1{}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
x.Truc()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// in T1 truc
|
||||||
32
_test/interface13.go
Normal file
32
_test/interface13.go
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
)
|
||||||
|
|
||||||
|
type X struct{}
|
||||||
|
|
||||||
|
func (X) Foo() int {
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
func (X) Bar() int {
|
||||||
|
return 2
|
||||||
|
}
|
||||||
|
|
||||||
|
type Foo interface {
|
||||||
|
Foo() int
|
||||||
|
}
|
||||||
|
type Bar interface {
|
||||||
|
Bar() int
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var x X
|
||||||
|
var i Foo = x
|
||||||
|
j := i.(Bar)
|
||||||
|
|
||||||
|
fmt.Println(j.Bar())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// 2
|
||||||
17
_test/interface14.go
Normal file
17
_test/interface14.go
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type T struct{}
|
||||||
|
|
||||||
|
func (t *T) Error() string { return "T: error" }
|
||||||
|
|
||||||
|
var invalidT = &T{}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var err error
|
||||||
|
if err != invalidT {
|
||||||
|
println("ok")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// ok
|
||||||
28
_test/interface15.go
Normal file
28
_test/interface15.go
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type Fooer interface {
|
||||||
|
Foo() string
|
||||||
|
}
|
||||||
|
|
||||||
|
type Barer interface {
|
||||||
|
//fmt.Stringer
|
||||||
|
Fooer
|
||||||
|
Bar()
|
||||||
|
}
|
||||||
|
|
||||||
|
type T struct{}
|
||||||
|
|
||||||
|
func (t *T) Foo() string { return "T: foo" }
|
||||||
|
func (*T) Bar() { println("in bar") }
|
||||||
|
|
||||||
|
var t = &T{}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var f Barer
|
||||||
|
if f != t {
|
||||||
|
println("ok")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// ok
|
||||||
25
_test/interface16.go
Normal file
25
_test/interface16.go
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
type Barer interface {
|
||||||
|
fmt.Stringer
|
||||||
|
Bar()
|
||||||
|
}
|
||||||
|
|
||||||
|
type T struct{}
|
||||||
|
|
||||||
|
func (*T) String() string { return "T: nothing" }
|
||||||
|
func (*T) Bar() { println("in bar") }
|
||||||
|
|
||||||
|
var t = &T{}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var f Barer
|
||||||
|
if f != t {
|
||||||
|
println("ok")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// ok
|
||||||
17
_test/interface17.go
Normal file
17
_test/interface17.go
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type T struct{}
|
||||||
|
|
||||||
|
func (t T) Error() string { return "T: error" }
|
||||||
|
|
||||||
|
var invalidT = T{}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var err error
|
||||||
|
if err != invalidT {
|
||||||
|
println("ok")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// ok
|
||||||
18
_test/interface18.go
Normal file
18
_test/interface18.go
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
type T struct{}
|
||||||
|
|
||||||
|
func (t *T) Error() string { return "T: error" }
|
||||||
|
func (*T) Foo() { println("foo") }
|
||||||
|
|
||||||
|
var invalidT = &T{}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var err error
|
||||||
|
if err != invalidT {
|
||||||
|
println("ok")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Output:
|
||||||
|
// ok
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user