@Jan You haven't thought of a good way to do it?

суббота, 4 ноября 2023 г. в 05:23:51 UTC+3, Luke Crook: 

> For Windows, could you package and distribute the prebuilt binaries using 
> an MSI file? (https://nsis.sourceforge.io/Main_Page)
>
>
>
> On Fri, Nov 3, 2023 at 12:10 PM Robert Engels <ren...@ix.netcom.com> 
> wrote:
>
>> Better to rewrite the native portions in Go. 
>>
>> If you’re not going to do that, just give instructions on how to build 
>> and let the app builder figure out how to package it. 
>>
>> On Nov 3, 2023, at 1:47 PM, Jason E. Aten <j.e....@gmail.com> wrote:
>>
>> 
>> It is still rough around lots of edges, but you are wanting to write your 
>> own deployment system, you might find in https://nixos.org/ some 
>> inspiration.
>>
>> It generalizes the idea of cryptographic hashed based dependency 
>> management to, well, everything.
>>
>> Sadly not that easy to use; it may be harsh to inflict on end users.  But 
>> it tackles the reproducibility issue (it works on my machine! but not 
>> yours?) head on.
>> You might profitably write some glue between Go and Nix that provides a 
>> nice end user experience.
>>
>> On Friday, November 3, 2023 at 5:23:21 PM UTC Jan wrote:
>>
>>> That works if what I'm doing is a end product (a server or something). 
>>> But what I'm doing is in itself a library. Imagine if every library offers 
>>> a docker/VM image, how is the end-user supposed to merge those docker 
>>> images ? The docker is also not a viable/ergonomic solution in my case. I 
>>> mean ... actually I do offer a docker for one of my projects 
>>> <https://hub.docker.com/r/janpfeifer/gomlx_jupyterlab>, along with 
>>> Jupyter, a Tutorial and demo. But generically, it is a library, and I would 
>>> like it to be easily `go get`able. Or at most with one simple/standard step.
>>>
>>> Yes, I hear you with respect to unnecessary extra dependencies (X11) -- 
>>> at least make them optional, right ? But In my case the dependencies are 
>>> essential, and the docker doesn't really solve the problem...  But also I'm 
>>> running out of hope that there would be anything to solve it, I'm almost 
>>> thinking I should write something myself.
>>>
>>>
>>> On Thursday, November 2, 2023 at 11:54:01 PM UTC+1 Jason E. Aten wrote:
>>>
>>>> What I would do for that case would be to deliver the users a either a 
>>>> VM image (heavy), or a docker container (lighter) with batteries included 
>>>> inside. 
>>>>
>>>> There is often little need to write a docker file unless you really 
>>>> want. Just get everything working inside docker and "docker commit" it to 
>>>> an image. I do this often for projects that need python/R + 100s of 
>>>> libraries.  Its really the only sane way to deliver sprawling dependencies 
>>>> that assume they can write all over the filesystem.  
>>>>
>>>> One hint: I recently did this for code that wanted to output graphics, 
>>>> and that needed X11 (or Xvfb), and that wanted systemd, which is available 
>>>> in docker but used to be discouraged so is not available in many base 
>>>> images. So I would recommend starting an docker image that already 
>>>> supports 
>>>> systemd and X11, if graphics (or x11vnc, say) is ever going to be desired. 
>>>> Its a pain to add after the fact. Podman claims to be useful for this, but 
>>>> I found in immature and not really production ready when trying to run it 
>>>> on blah standard Ubuntu 22.
>>>>
>>>> On Wednesday, November 1, 2023 at 9:08:51 PM UTC Jan wrote:
>>>>
>>>>> Thanks @Jason, but the point was exactly not need to do anything 
>>>>> extra: no manual unzipping of a file, or manual Makefile/Magefile.
>>>>>
>>>>> Let's say project in Go links some 30 external modules, 5 of them have 
>>>>> their own specific steps that need to be read, understood and and run to 
>>>>> install them ... very quickly the user just gives up from 
>>>>> installing/compiling the thing, with good reason ... 
>>>>>
>>>>> The Go toolset solves that beautifully for Go only projects. But at 
>>>>> least in my line of work, that's not feasible, I need to interface with 
>>>>> libraries that in turn require other libraries in C++ (OpenXLA/llvm for 
>>>>> JIT), Rust (HuggingFace Tokenizer), C (Gtk), etc.
>>>>>
>>>>> cheers
>>>>>
>>>>>
>>>>>
>>>>>
>>>>> On Monday, October 30, 2023 at 7:42:19 PM UTC+1 Jason E. Aten wrote:
>>>>>
>>>>>> > including the `.a` (static libraries) in the Github just got to its 
>>>>>> limit (100Mb)
>>>>>>
>>>>>> I have used bzip2 to compress libraries that are too big for Github. 
>>>>>> If that gets them under the limit, then great. 
>>>>>> Just provide installation instructions or a Makefile target that 
>>>>>> decompresses them once checked out.
>>>>>>
>>>>>> (Or xz? Apparently it can compress more than bzip2; but I have no 
>>>>>> experience with it. https://en.wikipedia.org/wiki/XZ_Utils )
>>>>>>
>>>>> -- 
>> 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/149f28a5-417e-4642-9c04-13f0254e2dcbn%40googlegroups.com
>>  
>> <https://groups.google.com/d/msgid/golang-nuts/149f28a5-417e-4642-9c04-13f0254e2dcbn%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...@googlegroups.com.
>>
> To view this discussion on the web visit 
>> https://groups.google.com/d/msgid/golang-nuts/5E033742-EDBD-4D44-BD09-60927C27448E%40ix.netcom.com
>>  
>> <https://groups.google.com/d/msgid/golang-nuts/5E033742-EDBD-4D44-BD09-60927C27448E%40ix.netcom.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/a2738453-838e-4778-8068-c6a3fbfdce8dn%40googlegroups.com.

Reply via email to