There you’ll find the instructions to test the feature before it’s released. It will allow you to add gleam path dependencies in your mix.exs file without the need for the mix_gleam archive.
Please try it out and report back with your findings, if any.
Thanks for working on this PR Rodrigo! It’s coming in at a perfect timing
Today I was trying to set up a new umbrella repo and import an external Gleam project. I had started with gleam_mix but was clearly having issues given my umbrella + external Gleam project setup. Then I found this post and I’m super grateful for the help to get this working.
I just compiled your branch (I’m using Nix with src overlay) and rewound the gleam_mix config. At first I got this error:
12:19:03.397 [error] beam/beam_load.c(583): Error loading function ‘Elixir.Hex.Netrc.Cache’:fetch/1: op make_fun2 u: please re-compile this module with an Erlang/OTP 27 compiler or update your Erlang/OTP version
That was easy to fix by wiping out project and home folder caches (e.g. rm -rf ~/.mix).
Now when I run mix deps.get, I’m getting this:
zsh ❯ mix deps.get
error: unrecognized subcommand 'package-information'
tip: a similar subcommand exists: 'package-interface'
Usage: gleam export <COMMAND>
For more information, try '--help'.
** (Mix) Command "gleam export package-information --out /dev/stdout" failed with reason:
I believe that is because I’m running on Gleam 1.9.1. Should it be using the ‘package-interface’ given this is the newest version?
I believe that is because I’m running on Gleam 1.9.1. Should it be using the ‘package-interface’ given this is the newest version?
No, export package-information is a new command I had to implement in the gleam compiler precisely for Mix integration: it exports the gleam.toml file as JSON so Mix can use it.
As described on the PR comment you need to install gleam nightly to have this new command, which will be released in gleam 1.10.0. That should fix the issue you are having.
Let me know if you hit any other hurdle after that or if it works as expected. Thanks!
Amazing! Just using the latest main branch from Gleam and mix deps.get and mix compile are working fine. I can see Gleam logs during the compilation and the artifacts under _build. Now I’m struggling to find how to import anything from the Gleam package into Elixir. I couldn’t find any module or atom referencing it.
Yes, that’s expected because gleam_stdlib does not have an .app file, so you need to add app: false to the dependency in mix.exs. In fact this is true for any hex dependency as well.
It makes sense. And it is all working now. Thank you so much @Papipo!
One observation is that adding app: false leads to a conflict:
Dependencies have diverged:
* gleam_stdlib (Hex package)
the dependency gleam_stdlib in apps/buzz_agent/mix.exs is overriding a child dependency:
> In apps/buzz_agent/mix.exs:
{:gleam_stdlib, "~> 0.34 or ~> 1.0", [env: :prod, hex: "gleam_stdlib", app: false, repo: "hexpm"]}
> In /code/claude/corev2/gleam.toml:
{:gleam_stdlib, ">= 0.34.0 and < 2.0.0", [env: :prod, hex: "gleam_stdlib", repo: "hexpm"]}
Ensure they match or specify one of the above in your deps and set "override: true"
** (Mix) Can't continue due to errors on dependencies
Adding override: true did fix it (though felt a bit weird having to override it). Also realized I could have used it as a transitive dependency from the gleam package which would have avoided the conflict but led to having direct code usage on transitive packages.
Another improvement, though possibly unrelated to this, is making the gleam dependency atoms (.e.g. :gleam@list or :gleam@json) visible or searchable in iex. It seems there is some lazy loading because they don’t show up for tab completion in iex, but after you use them once, then they show up.