golang dev

#120 android build using docker 2 months ago

Comment by ~joe-getcouragenow on ~whereswaldon/arbor-dev


Its pretty easy to copy the output from the guest to the host. But there is an excellent golang tool that does all of this in local and CI for you. Cant find it right now. Will come to me...

#120 android build using docker 2 months ago

Ticket created by ~joe-getcouragenow on ~whereswaldon/arbor-dev

Can we use docker for the android build. Just such a PITA to get android and its tooling going.

tailscale do it this way and its a joy for teams and also CI.


#150 Mobile Web: Input events not bringing up a keyboard 2 months ago

Comment by ~joe-getcouragenow on ~eliasnaur/gio

Its cool. I will have a look and post back here on progress, questions etc.

#150 Mobile Web: Input events not bringing up a keyboard 2 months ago

Comment by ~joe-getcouragenow on ~eliasnaur/gio

:) well thanks for letting me know.

Any feelings about where the problem could be, before i start hunting for the source of the bug ?

#146 Rendering and caret positioning for complex scripts 2 months ago

Comment by ~joe-getcouragenow on ~eliasnaur/gio

The sqlite tool that translates c to go has now reached beta and actually works. This transpiler is a likely candidate for doing the same with hafbuzz


Here is the generator: https://gitlab.com/cznic/sqlite/-/blob/master/generator.go

#151 tinygo compilation 2 months ago

Ticket created by ~joe-getcouragenow on ~eliasnaur/gio

This is the only working example that i could find to show tinygo being used to compile golang to WASM for browsers

Its all here:


Which uses: https://github.com/vugu/docker-vugu-tinygo-dev

  • this does nothing special and is just a convenience.

This is the example that shows it:


I plan to have a go at this approach, but wanted to let others know also as they may have their own thoughts on this.

It would be cool to get this working as the WASM code will go from 8 MB to 400 KB in general for basic projects.

#150 Mobile Web: Input events not bringing up a keyboard 2 months ago

Ticket created by ~joe-getcouragenow on ~eliasnaur/gio

In the kitchen example on IOS Safari the touch events now work.

The input events dont work. For example when the user types in the "Hint" area, no virtual keyboard comes up on the mobile.

#149 Mobile Web touch events not working ? Or something else amiss on mobile web.. 2 months ago

Comment by ~joe-getcouragenow on ~eliasnaur/gio

Thanks so much. I just tested the kitchen example on IOS Safari and the touch events work.

Everything seems to work pretty well. The input events dont work. For example when the user types in the "Hint" area, no virtual keyboard comes up on the mobile. I will raise an issue for this for now.

I agree that the runtime performance is not great. Getting the obvious bugs fixed will allow me and others to experiment with getting it working with Tinygo. Being able to write a GUi app in golang for web is still a huge win for gophers in many ways still.

Download size can be reduced using compression. This compresses the WASM file using brotli https://github.com/ctessum/cityaq/blob/master/gendoc.go#L34 Kitchen.wasm goes from 7 MB to about 1 MB. Not a bad win.

About tinygo. Here is the only example i could find where tinygo works for golang wasm: https://www.vugu.org/ Code: https://github.com/vugu-examples/tinygo Docker: I suspect that this is the dockerised version of Tiny go that is being used by this example.

Again thank you for the fix.

#101 Assess Flutter as a possible platform for Arbor Mobile/Desktop development 2 months ago

Comment by ~joe-getcouragenow on ~whereswaldon/arbor-dev

Go-Flutter and Flutter in general is very impressive. Things really work.

  • Video does not work... Which is sad.
  • When google changes stuff the go-flutter teams fixes things.

GIO is literally the exact same architecture and way way closer to the metal. Hence why my interest in GIO :) Not as many plugins, but way easier to develop.

Its a game of tradeoffs as always, so here goes:

The way i use them. You can code up all your plugins in go and use them for desktop, mobile and Web ( as wasm). So then the community can use them with gio and flutter. Thats my intent. Some projects need flutter some need gio and give people choice. The plugins can have a DB, Event source changes to the GUI layer to update for real time apps.

Hope this helps.

I am much more into GIO because i find using it much faster. But GIO web on mobile does not work properly, hence why i am trying to get that fixed with the Team.

#113 Notification storm on first connection from a machine 2 months ago

Comment by ~joe-getcouragenow on ~whereswaldon/arbor-dev

thanks for the comments.

Cross device. Sometimes you need a Device ID, as well as the UserID. You basically you to know all the devices the user is logged in on.

Also you need to push over a few channels normally due to the many devices world we live in. See: https://github.com/appleboy/gorush

  • Where you need to send notifications via the Apple and Google Gateway.
  • Used in order to "wake up" you app if you know what i mean.

So as always we have to support native and PWA Service workers perhaps.

With the PWA situation, and the Service Worker allows Web Push Notifications. The OS "should" then allow the notifications to create OS level notifications because the Service Worker is "always on" based on the contract that PWA and Service workers guarantee. See the Gorush Features list where is says "Support Web API to send push notification." - so should work.

IOS Safari is however is a little behind the times here i think. See: https://caniuse.com/#feat=notifications.

  • Lets se if Apple play ball going forward. Good chance they will i think. But you never know...

Then you need something on the Server that acts as a store and forward relay. Why ? Because User X writes a chat message to a group and then goes offline, and so the message needs to be delivery to all the others in the group. Whatever way arbor models this as data is nether here nor there - you got to sent something to the other users to tell them about the new data...

One candidate is LiftBridge. See: https://github.com/liftbridge-io/liftbridge The code is very clean and has a simple GRPC API. Its golang all the way down too and designed for HA world. Its basically Kafka but in golang. Also you need to store and forward images data too. Use case woudl be when a user adds a Picture to the chat, and then goes offline. I am currently quite impressed with SeaweedFS. See: https://github.com/chrislusf/seaweedfs/issues/1394

Hope that this is useful for Arbor...