Commit Graph

176 Commits

Author SHA1 Message Date
Robert van Gent
b869afc095 wire/tests: Add a test that defines a ProviderSet with a binding but no (#121)
corresponding concrete type. The current error message is poor and
should be improved.
2019-02-07 14:36:06 -08:00
Robert van Gent
ab2332aa8a all: re-enable travis windows build (#123) 2019-02-06 14:12:16 -08:00
Robert van Gent
dbfad100dd all: update version of golang.org/x/tools (#122) 2019-02-06 08:08:23 -08:00
Robert van Gent
b1113bfdf1 travis: disable windows, update import path config, and only run goveralls on linux (#115) 2019-02-05 16:08:41 -08:00
Ross Light
bee5b6c7c7 internal/wire: remove support for go-cloud import path (#111) 2019-01-28 13:57:58 -08:00
Ross Light
3b0186f7df internal/wire: move field name into ProviderInput (#104)
Avoids having parallel arrays for conceptually related data.
2019-01-23 11:34:39 -08:00
Ross Light
9a7ae3ba6b internal/wire/testdata/PkgImport: really add the duplicated import (#105) 2019-01-07 14:57:50 -08:00
Ross Light
5b99fcb30b internal/wire/testdata/PkgImport: add back duplicate import (#103)
This got removed as part of my gofmt run on #101.
2019-01-07 14:15:33 -08:00
Kumbirai Tanekha
f285c073b5 internal/wire: copy over anonymous imports (#101)
Adds Kumbirai Tanekha to A+C.

Fixes #94
2019-01-07 09:04:35 -08:00
shantuo
4243b011bd internal/wire: factor out common code in solve (#98)
- Fixed a bug when a interface is bind to a value wire would fail to record it is used.
- Also rename ProvidedType.ConcreteType to Type since it doesn't necessarily returns a concrete type.

Fixes #72
2018-12-14 12:56:01 -08:00
Ross Light
f9328a1d90 .contributebot: disable issue title check (#97)
All issues are assumed to be about Wire, so there's no need to include
the package name.

Updates #82
2018-12-12 13:26:22 -08:00
Ross Light
983dc94257 internal/proxy: port script from Go Cloud to create module proxy (#95)
I have created gs://wire-modules to store the Wire dependencies. I ran
the script in this commit to populate the contents of the GCS bucket and
am updating Travis to point to the new proxy.

Fixes #81
2018-12-10 15:12:36 -08:00
Ben Hoyt
28f5930663 docs: fix typo (missing "forgot") in comment (#92) 2018-12-03 09:19:00 -08:00
shantuo
ef9bb67152 Support variadic provider and injector functions (#91)
Fixes #61
2018-12-03 08:30:42 -08:00
Robert van Gent
65d810f60a wire: output diffs to stdout, and return 1 for diffs and 2 for trouble from diff subcommand (#90) 2018-11-30 15:14:40 -08:00
Ross Light
90ac48ab7d Remove more references to Go Cloud (#88) 2018-11-30 10:08:58 -08:00
Ross Light
31bae0df4e Copy over Wire tutorial from Go Cloud (#86)
Originally authored by @enocom. Added to CONTRIBUTORS.

Fixes #80
2018-11-30 09:46:48 -08:00
Ross Light
cacf1bc4ed Split out documentation into multiple files (#85)
Fixes #84
2018-11-29 12:31:59 -08:00
Robert van Gent
8c0a284dec docs: update CONTRIBUTING.md (#78) 2018-11-28 16:14:36 -08:00
Robert van Gent
ec9fb34688 doc: add embeds for Travis, godoc, coveralls to README (#79) 2018-11-28 15:14:59 -08:00
Ross Light
ba990f92ac Add GitHub PR and issue templates (#76) 2018-11-28 13:06:48 -08:00
Ross Light
1a5e046395 Remove more references to Go Cloud (#75) 2018-11-28 12:51:41 -08:00
Ross Light
507d4f1d03 Copy over Travis setup from Go Cloud (#74) 2018-11-28 12:48:01 -08:00
Robert van Gent
58d6a2c2c8 wire: add a diff command (google/go-cloud#745) 2018-11-28 11:12:42 -08:00
Robert van Gent
65eb134857 wire: support multiple packages in Generate (google/go-cloud#729) 2018-11-28 11:06:19 -08:00
Robert van Gent
925a11ad0d wire: add a test for using a function argument as a provider (google/go-cloud#724) 2018-11-28 11:02:13 -08:00
Robert van Gent
6ea381b3fe wire: give wire.Bind access to the arguments to the injector function (google/go-cloud#715) 2018-11-28 11:02:13 -08:00
Robert van Gent
67170e739d wire/tests: add a test for wire.Bind on an injector arg (google/go-cloud#708) 2018-11-28 11:02:13 -08:00
Robert van Gent
ebb381989a wire/tests: add a test for multiple args of the same type to an injector function (google/go-cloud#706) 2018-11-28 11:02:13 -08:00
Ross Light
3488a41780 wire: serialize test execution (google/go-cloud#704) 2018-11-28 11:00:42 -08:00
Ross Light
6ca3ea0efe wire: add FAQ for duplicate providers (google/go-cloud#660)
Fixes google/go-cloud#492
2018-11-28 10:32:36 -08:00
Ross Light
30574010a0 Update import path and mirror project docs 2018-11-13 13:16:46 -08:00
Robert van Gent
ded9eb899b wire: remove trailing CR at end of error about cycles (google/go-cloud#662) 2018-11-13 13:16:46 -08:00
Ross Light
282105c273 wire: use go/packages for analysis (google/go-cloud#623)
Unfortunately, this does come with a ~4x slowdown to Wire, as it is
now pulling source for all transitively depended packages, but not
trimming comments or function bodies. This is due to limitations with
the ParseFile callback in go/packages.

This comes with a single semantic change: when performing analysis, Wire
will now evaluate everything with the wireinject build tag. I updated
the build tags tests accordingly. Prior to this PR, only the packages
directly named by the package patterns would be evaluated with the
wireinject build tag. Dependencies would not have the wireinject build
tag applied. There isn't a way to selectively apply build tags in go/packages,
and there isn't a clear benefit to applying it selectively. Being consistent with
other Go tooling provides greater benefit.

I deleted the vendoring test, as non-top-level vendoring
becomes obsolete with modules.

go/packages now parses comments by default, so now the generated code
includes comments for non-injector declarations.

Fixes google/go-cloud#78
2018-11-13 13:16:46 -08:00
Christina Austin
ce30a430c6 wire: update README installation instructions (google/go-cloud#647)
* wire: update README installation instructions

* Made verb tense agree
2018-11-13 13:16:46 -08:00
Ross Light
c3ea2961cb wire: in tests, don't copy want/wire_gen.go into the temporary GOPATH (google/go-cloud#646)
This does not change the results of the test, but should not be
happening.
2018-11-13 13:16:46 -08:00
Ross Light
64470a2452 wire/internal/wire: use on-disk GOPATH in generate tests (google/go-cloud#616)
The primary motivation is to permit a move to using go/packages instead
of go/loader. go/packages runs exclusively by shelling out to the go
tool, which precludes use of the in-memory "magic" GOPATH being used
up to this point.

This has a secondary effect of removing a lot of code to support "magic"
GOPATH from the test infrastructure. This is on the whole good, but
necessitated a change in the error scrubbing: since the filenames are
no longer fixed, error scrubbing also must remove the leading
$GOPATH/src lines.

Another related change: since all callers of Generate needed to know the
package path in order to write out wire_gen.go (necessitating a
find-only import search) and Generate already has this information,
Generate now returns this information to the caller. This should further
reduce callers' coupling to Wire's load internals. It also eliminates
code duplication.

This should hopefully shake out any difference in path separators for
running on Windows, but I have not tested that yet.

Updates google/go-cloud#78
Updates google/go-cloud#323
2018-11-13 13:16:46 -08:00
Robert van Gent
ab113bf8d1 wire: allow wire.Value to use values with no parent (i.e., struct fields) (google/go-cloud#596) 2018-11-13 13:16:46 -08:00
Ross Light
b4218146b9 wire: expand on package documentation (google/go-cloud#587) 2018-11-13 13:16:46 -08:00
Ross Light
c4f6234106 wire: add FAQ section (google/go-cloud#573)
Fixes google/go-cloud#555
Updates google/go-cloud#513
2018-11-13 13:16:46 -08:00
Robert van Gent
b7c4e8db66 wire: use multiline errors instead of one single line for errors with traces (google/go-cloud#571) 2018-11-13 13:16:46 -08:00
ktr
cf9080e300 wire: remove duplicated "a" (google/go-cloud#561) 2018-11-13 13:16:46 -08:00
ktr
0a4cc23d20 wire: fix typo in example code (google/go-cloud#560) 2018-11-13 13:16:46 -08:00
Robert van Gent
97e5c83e18 wire/test: support multi-line errors and -record mode in tests (google/go-cloud#550) 2018-11-13 13:16:46 -08:00
Robert van Gent
a8825fef58 wire: add info from the dependency graph when a type is not provided 2018-11-13 13:16:46 -08:00
Yoichiro Shimizu
b84ad6154f wire/readme: wire.InterfaceValue should not return Foo{} (google/go-cloud#504) 2018-11-13 13:16:46 -08:00
Robert van Gent
b1fd26c92a wire: improve error message for provider set conflicts (google/go-cloud#500) 2018-11-13 13:16:46 -08:00
Robert van Gent
be8ecba636 wire: fix error messages for Bind and InterfaceValue when the arg doesn't implement the interface (google/go-cloud#491)
Fixes google/go-cloud#490
2018-11-13 13:16:46 -08:00
Robert van Gent
2c50843322 wire: add an example and document how to use wire with mocks (google/go-cloud#488) 2018-11-13 13:16:46 -08:00
Robert van Gent
32c3dc8578 wire/doc: reformat README.md (google/go-cloud#495) 2018-11-13 13:16:46 -08:00