I would put down Makefile includes for the supported targets and build each
target at a time, as cross compiled shared libraries.  This is easier for
linux, harder for windows.
But, you can build/export from docker containers as part of the overall
build process to allow simulated build environments.   At some point, you
may come to a dependency in which you have to build the included C code for
it to run in platform dependent libraries.  At this point, you probably
will want to build on the environment as you go.  You can cross target *.o,
but build the *.so on the specific target.

You could have separate repos and distribute the C code from a dependency
point of view.  This would be a tgz of 'shared/$ARCH/$COMPILED_LIB", or
some such.

On Wed, Oct 11, 2023 at 5:29 PM Richard Wilkes <raw.softw...@gmail.com>
wrote:

> It isn't a great solution, but I currently include the built library files
> and necessary headers in the git repo alongside the Go code. You can see an
> example here
> https://github.com/richardwilkes/unison/tree/main/internal/skia where I
> include the skia library I built for use in my UI framework, unison.
>
> The main downside of this is bloating the git repo with the binary .a and
> .dll files... but I've not found a better way to handle it. glfw, which
> unison also depends upon, does something very similar.
>
> - Rich
>
> On Wednesday, October 11, 2023 at 2:58:23 AM UTC-7 Jan wrote:
>
>> hi,
>>
>> I'm developing a couple of ML framework/libraries for Go that depend on
>> C/C++ code. Once C-libraries dependencies are installed, the CGO
>> integration work great.
>>
>> Now, for end-users that just want to use these Go libraries, having to
>> figure out how to manually build and install those C/C++/Rust dependencies
>> is a hassle -- sadly each one with a different type of build system.
>>
>> I offer pre-built `.tgz` files (for a limited set of architectures) with
>> the required `.h` and `.a/.so` files along the releases, which facilitates.
>> But it's still a hassle to install -- and no auto-uninstall if someone is
>> no longer using the Go module.
>>
>> I was wondering if others have figured out how to handle this in a nicer
>> way.  Is there a recommended way to distribute prebuilt CGO dependencies ?
>>
>> I like how Python wheels (`.whl` files) solve the issue, by including the
>> pre-built libraries in a sub-directory of the python library installation.
>> I was hoping there would be a similar way (maybe with a separate tool) to
>> integrate with `go.mod`.
>>
>> Any pointers, thoughts or suggestions are very appreciated.
>>
>> Thanks!
>> Jan
>>
>> ps: While searching I saw similar questions, but none that exactly
>> answered this aspect of distribution. Just in case, apologies if it's a
>> duplicate question.
>>
> --
> You received this message because you are subscribed to the Google Groups
> "golang-nuts" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to golang-nuts+unsubscr...@googlegroups.com.
> To view this discussion on the web visit
> https://groups.google.com/d/msgid/golang-nuts/3b03b9e1-655e-452a-9b97-e9471b9b9dc1n%40googlegroups.com
> <https://groups.google.com/d/msgid/golang-nuts/3b03b9e1-655e-452a-9b97-e9471b9b9dc1n%40googlegroups.com?utm_medium=email&utm_source=footer>
> .
>

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/golang-nuts/CAMyFqkRai48nKKFvqPN1ALU0LipzTgJe0YEPFmqx1Dv0T9RkTA%40mail.gmail.com.

Reply via email to