Hang on - I missed your original statement that you are building 
*libraries* yourself. I am building executables. Sorry for the confusion 
and my too-fast scan reading!

On Wednesday, 11 October 2023 at 12:08:53 UTC+1 Peter Galbavy wrote:

> If you link statically, e.g. from my Dockerfile:
>
>   go build -tags netgo,osusergo --ldflags '-s -w -linkmode external 
> -extldflags=-static'
>
> then the libraries are in the single binary. I also then use "upx" to 
> compress the resulting binaries to save a little space. The build tags are 
> there to not require GLIBC for user and dns lookups.
>
>
>
> On Wednesday, 11 October 2023 at 11:43:20 UTC+1 Jan wrote:
>
>> Edit: ...so folks using your library don't need to install them manually 
>> ? What about uninstalling ?
>> On Wednesday, October 11, 2023 at 12:41:40 PM UTC+2 Jan wrote:
>>
>>> Thanks Peter, but I don't follow ... I also use docker to build the 
>>> pre-built binaries.
>>>
>>> But how do you distribute them, so folks using your library don't think 
>>> to install them ?
>>>
>>> On Wednesday, October 11, 2023 at 12:32:57 PM UTC+2 Peter Galbavy wrote:
>>>
>>>> I use a docker container (golang:bullseye seems the most compatible) 
>>>> and build static binaries. This is feasible as long as your dependencies 
>>>> do 
>>>> not require dynamic loading of dependencies.
>>>>
>>>> Poor (my Dockerfile skills) example here: 
>>>> https://github.com/ITRS-Group/cordial/blob/main/Dockerfile
>>>>
>>>> Peter
>>>>
>>>> On Wednesday, 11 October 2023 at 10:58:23 UTC+1 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/c31db183-c69a-43e4-bee3-8f113d5e37c4n%40googlegroups.com.

Reply via email to