DarthSim 2e6296c4d9 Go go mod 6 years ago
..
oleutil b66b27bef9 Errors reporting 7 years ago
.travis.yml 2e6296c4d9 Go go mod 6 years ago
ChangeLog.md 2e6296c4d9 Go go mod 6 years ago
LICENSE b66b27bef9 Errors reporting 7 years ago
README.md 2e6296c4d9 Go go mod 6 years ago
appveyor.yml 2e6296c4d9 Go go mod 6 years ago
com.go 384a2909c3 Update vendored dependencies 6 years ago
com_func.go 384a2909c3 Update vendored dependencies 6 years ago
connect.go b66b27bef9 Errors reporting 7 years ago
constants.go b66b27bef9 Errors reporting 7 years ago
error.go b66b27bef9 Errors reporting 7 years ago
error_func.go b66b27bef9 Errors reporting 7 years ago
error_windows.go b66b27bef9 Errors reporting 7 years ago
go.mod 2e6296c4d9 Go go mod 6 years ago
go.sum 2e6296c4d9 Go go mod 6 years ago
guid.go b66b27bef9 Errors reporting 7 years ago
iconnectionpoint.go b66b27bef9 Errors reporting 7 years ago
iconnectionpoint_func.go b66b27bef9 Errors reporting 7 years ago
iconnectionpoint_windows.go b66b27bef9 Errors reporting 7 years ago
iconnectionpointcontainer.go b66b27bef9 Errors reporting 7 years ago
iconnectionpointcontainer_func.go b66b27bef9 Errors reporting 7 years ago
iconnectionpointcontainer_windows.go b66b27bef9 Errors reporting 7 years ago
idispatch.go b66b27bef9 Errors reporting 7 years ago
idispatch_func.go b66b27bef9 Errors reporting 7 years ago
idispatch_windows.go 384a2909c3 Update vendored dependencies 6 years ago
ienumvariant.go b66b27bef9 Errors reporting 7 years ago
ienumvariant_func.go b66b27bef9 Errors reporting 7 years ago
ienumvariant_windows.go b66b27bef9 Errors reporting 7 years ago
iinspectable.go b66b27bef9 Errors reporting 7 years ago
iinspectable_func.go b66b27bef9 Errors reporting 7 years ago
iinspectable_windows.go b66b27bef9 Errors reporting 7 years ago
iprovideclassinfo.go b66b27bef9 Errors reporting 7 years ago
iprovideclassinfo_func.go b66b27bef9 Errors reporting 7 years ago
iprovideclassinfo_windows.go b66b27bef9 Errors reporting 7 years ago
itypeinfo.go b66b27bef9 Errors reporting 7 years ago
itypeinfo_func.go b66b27bef9 Errors reporting 7 years ago
itypeinfo_windows.go b66b27bef9 Errors reporting 7 years ago
iunknown.go b66b27bef9 Errors reporting 7 years ago
iunknown_func.go b66b27bef9 Errors reporting 7 years ago
iunknown_windows.go b66b27bef9 Errors reporting 7 years ago
ole.go b66b27bef9 Errors reporting 7 years ago
safearray.go b66b27bef9 Errors reporting 7 years ago
safearray_func.go 384a2909c3 Update vendored dependencies 6 years ago
safearray_windows.go 384a2909c3 Update vendored dependencies 6 years ago
safearrayconversion.go 384a2909c3 Update vendored dependencies 6 years ago
safearrayslices.go b66b27bef9 Errors reporting 7 years ago
utility.go b66b27bef9 Errors reporting 7 years ago
variables.go b66b27bef9 Errors reporting 7 years ago
variant.go 384a2909c3 Update vendored dependencies 6 years ago
variant_386.go b66b27bef9 Errors reporting 7 years ago
variant_amd64.go b66b27bef9 Errors reporting 7 years ago
variant_date_386.go 384a2909c3 Update vendored dependencies 6 years ago
variant_date_amd64.go 384a2909c3 Update vendored dependencies 6 years ago
variant_ppc64le.go 384a2909c3 Update vendored dependencies 6 years ago
variant_s390x.go b66b27bef9 Errors reporting 7 years ago
vt_string.go b66b27bef9 Errors reporting 7 years ago
winrt.go b66b27bef9 Errors reporting 7 years ago
winrt_doc.go b66b27bef9 Errors reporting 7 years ago

README.md

Go OLE

Build status Build Status GoDoc

Go bindings for Windows COM using shared libraries instead of cgo.

By Yasuhiro Matsumoto.

Install

To experiment with go-ole, you can just compile and run the example program:

go get github.com/go-ole/go-ole
cd /path/to/go-ole/
go test

cd /path/to/go-ole/example/excel
go run excel.go

Continuous Integration

Continuous integration configuration has been added for both Travis-CI and AppVeyor. You will have to add these to your own account for your fork in order for it to run.

Travis-CI

Travis-CI was added to check builds on Linux to ensure that go get works when cross building. Currently, Travis-CI is not used to test cross-building, but this may be changed in the future. It is also not currently possible to test the library on Linux, since COM API is specific to Windows and it is not currently possible to run a COM server on Linux or even connect to a remote COM server.

AppVeyor

AppVeyor is used to build on Windows using the (in-development) test COM server. It is currently only used to test the build and ensure that the code works on Windows. It will be used to register a COM server and then run the test cases based on the test COM server.

The tests currently do run and do pass and this should be maintained with commits.

Versioning

Go OLE uses semantic versioning for version numbers, which is similar to the version contract of the Go language. Which means that the major version will always maintain backwards compatibility with minor versions. Minor versions will only add new additions and changes. Fixes will always be in patch.

This contract should allow you to upgrade to new minor and patch versions without breakage or modifications to your existing code. Leave a ticket, if there is breakage, so that it could be fixed.

LICENSE

Under the MIT License: http://mattn.mit-license.org/2013