I second Richard's suggestion. I used the same trick for
https://github.com/periph/d2xx. This git repository contains a minimalist
shim for the .a libraries and nothing else. It's designed to compile on any
platform. It falls back to a scaffolding if the corresponding .a library is
not present for the OS-arch combination or if CGO is disabled. It makes
testing easier.

Then a proper package under https://github.com/periph/host/tree/main/ftdi
exposes a higher level abstraction for the user.

M-A

Le lun. 16 oct. 2023, à 14 h 48, Mike Schinkel <m...@newclarity.net> a
écrit :

> Hi Jan,
>
> I'm going to go out on a limb here and suggest looking at using Go's
> `embed` feature?
>
> https://blog.jetbrains.com/go/2021/06/09/how-to-use-go-embed-in-go-1-16/
>
> I have not tried it with C libraries so there may be numerous reasons why
> it may not work for your needs. For example, I do not know what is required
> to *"install"* the libraries so that might be your sticking point that
> embed would not address. But if building on the user's machine is the real
> problem and you can distribute pre-build binaries then this might work for
> you.
>
> Basically Go reads a `//go:embed` comment, converts your files into Go
> source code, compiles that code, and then provides a package that allows
> you to write those files to disk from an your Go app before you need to
> load the libraries.
>
> Maybe this will work for you?  If yes, would love to hear back how it
> worked out.
>
> -Mike
> On Monday, October 16, 2023 at 8:40:54 AM UTC-4 Bruno Albuquerque wrote:
>
>> I guess you switched things here. Shared libraries (.so) need to be
>> available at engine. Static libraries (.a) are bagged into the binary.
>>
>> -Bruno
>>
>>
>> On Sun, Oct 15, 2023, 3:55 PM Jan <pfe...@gmail.com> wrote:
>>
>>> Thanks Tamas, this is useful information.
>>>
>>> One of my libraries is using a `.a` library -- as opposed to `.so`,
>>> which is another level of complexity, since the library has to be available
>>> in runtime, not only in compile time -- and I'm going to follow your
>>> "incantation" suggestion.
>>>
>>>
>>> On Sunday, October 15, 2023 at 7:55:55 AM UTC+2 Tamás Gulácsi wrote:
>>>
>>>> Neither I see a convenient way.
>>>> BUT if you add a .go file into the directories where your precompiled
>>>> libraries live,
>>>> then "go get" will download them too (and only those dirs that have .go
>>>> files in it).
>>>>
>>>> So your next mission is to prepare the right #cgo CFLAGS LDFLAGS
>>>> incantations to use those libraries.
>>>>
>>>> Jan a következőt írta (2023. október 14., szombat, 8:37:48 UTC+2):
>>>>
>>>>> Thanks Tamás, I may not be understanding correctly, but after taking a
>>>>> look at github.com/godror/godror, and the odpi subdirectory,
>>>>> I see it is including all the `.c` files on the fly
>>>>> <https://github.com/godror/godror/blob/main/odpi/embed/dpi.c>.
>>>>>
>>>>> A couple of reasons immediately come to mind, that make this not a
>>>>> generically valid option:
>>>>>
>>>>> * ODPI library is all C code (see src
>>>>> <https://github.com/godror/godror/tree/main/odpi/src>) so it works
>>>>> including in Go: my dependencies are C++/Rust code, for which I write a
>>>>> small C wrapper (or for Rust just `extern "C"`). Also architecture
>>>>> dependent compilation is different in C++/C/Rust code ...
>>>>> * The C++ libraries I'm including have sub-dependencies of themselves
>>>>> (one of which is llvm). It uses Bazel to organize it, and to manually move
>>>>> all the required C++ files to a directory would be years of work :) Plus
>>>>> would require me to slave to maintain things in sync.
>>>>> * The C++ libraries take hours to compile ... I don't want to impose
>>>>> this to users of my libraries.
>>>>>
>>>>> I think the only way to work this out is distributing the pre-compiled
>>>>> C++/Rust libraries, so the Go simply refer to them (and we get the fast
>>>>> compilation times from Go). But then, how to best distribute them in an
>>>>> automatic fashion, so that users don't need to one by one figure out how 
>>>>> to
>>>>> install them (and clean up them later if they are no longer using...) ?
>>>>>
>>>>> Or maybe there is another convenient way I'm not seeing ?
>>>>>
>>>>>
>>>>> On Thursday, October 12, 2023 at 6:39:34 PM UTC+2 Tamás Gulácsi wrote:
>>>>>
>>>>>> Can't you build (make go build for you) those libraries?
>>>>>> For example, see github.com/godror/godror just includes the sources
>>>>>> of that third party library in an "odpi" subdir, and with
>>>>>> ```
>>>>>> /*
>>>>>> #cgo CFLAGS: -I./odpi/include -I./odpi/src -I./odpi/embed
>>>>>>
>>>>>> #include "dpi.c"
>>>>>>
>>>>>> */
>>>>>> import "C"
>>>>>> ```
>>>>>> it is compiled automatically.
>>>>>>
>>>>>>
>>>>>> Caveat: for "go get" to download a directory, it must include a
>>>>>> sth.go file ("require.go" in the odpi/* subdirs).
>>>>>> But it may work that your precompiled libs in a subdir, with a mock
>>>>>> .go file gets downloaded.
>>>>>> But how will it found by your lib/app ?
>>>>>>
>>>>>> Tamás
>>>>>>
>>>>>>
>>>>>> Jan a következőt írta (2023. október 12., csütörtök, 8:14:41 UTC+2):
>>>>>>
>>>>>>> Thanks Richard. Indeed, as you pointed out the downside is the
>>>>>>> bloating of the git repo, but it makes sense.
>>>>>>>
>>>>>>> But does the user have to manually clone the repository and move the
>>>>>>> `.a` file to, let's say, /usr/local/lib, or does a simple `go get`
>>>>>>> magically does everything ?
>>>>>>>
>>>>>>>
>>>>>>> On Thursday, October 12, 2023 at 2:29:21 AM UTC+2 Richard Wilkes
>>>>>>> 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...@googlegroups.com.
>>>
>> To view this discussion on the web visit
>>> https://groups.google.com/d/msgid/golang-nuts/a00b3a7b-200d-44ce-8060-913d9ac3c6cen%40googlegroups.com
>>> <https://groups.google.com/d/msgid/golang-nuts/a00b3a7b-200d-44ce-8060-913d9ac3c6cen%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/ca2d8979-f741-4b81-9099-8672bc5e2312n%40googlegroups.com
> <https://groups.google.com/d/msgid/golang-nuts/ca2d8979-f741-4b81-9099-8672bc5e2312n%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/CAFqRfrDEPcszOF8Hx9Zm9Et570wzyWjnsXut4kVRwTnkmW-XCw%40mail.gmail.com.

Reply via email to