- 
                Notifications
    You must be signed in to change notification settings 
- Fork 3.5k
Add gleam support to Mix #14262
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: main
Are you sure you want to change the base?
Add gleam support to Mix #14262
Conversation
421dc7c    to
    0afa895      
    Compare
  
    | @josevalim when working on this I was always thinking of  | 
| It should be possible because we use heroicons, a regular JS package, as a dependency on Phoenix applications. So we could probably support a  | 
| Hello! You shouldn't need to do anything special target-wise as Gleam performs dead code elimination for code that is for other targets. 
 I would not expect Mix to become a front-end build tool by adding Gleam support. I think the workflow should be the same as it is today etc, with the desired build tool (esbuild, webpack,  Adding frontend dependencies to the BEAM application dependency tree would either be wasted work compiling and managing them, or the programmer would need to go through every dependency in the lock file and add configuration to their  
 There is no such config. A Gleam package doesn't have an explicit target, each function in the public API is available on Erlang, JavaScript, or both, and they get either compiled or eliminated as needed. Whether a package is for Erlang or JavaScript is typically a matter of how the dependant is using them, not a matter of the configuration of the dependency. There is a  | 
b91ae71    to
    c181ecd      
    Compare
  
    a18bf89    to
    26c8aff      
    Compare
  
    8a7d9fa    to
    360db23      
    Compare
  
    | I am kind of copypasting this from the Gleam discord in case someone wants to try this out before merging into main: What is this?These changes add first-class support for Gleam in Elixir's Mix, thus allowing gleam path dependencies in  What's missing?Probably nothing. Work on the gleam compiler is already merged and work on the Mix side is completed, but there might be rough edges, that's what we need to test. InstructionsMix integration will expect you to have gleam >= 1.10.0 installed and that hasn't been released yet. So: 
 If you were using  UsageAfter running  What needs to be tested?
 ThanksJust report back with your findings and thanks 🙇🏽 Note: I hope these instructions are enough and correct. Let me know if that's not the case. | 
| @Papipo thanks for all the work so far! One question: I thought that  | 
| 
 No, gleam is a single binary written in Rust. I don't know if we can provide a hex archive maybe? I don't know how these work. How is rebar installation handled? I know that mix is able to install it locally, but I am not sure what that means exactly. It's still a binary as well, right? | 
| For Rebar, we have some binaries which we upload to hex.pm, and we version control them every year or so. Although I don't think this will work for Gleam, because people want to upgrade it more frequently, and Rebar is only a build tool, not really a compiler. So I guess we need to be clear we are using the system one and it is up to them to enforce the team uses the same version across the board (which is how we deal with  | 
| 
 In fact the binary is also the LS, so you definitely want to have full control of the version you are using, etc. | 
| Quoting @lpil on the forums: 
 Apologies but I am a bit confused. We are using  The .app file has things like app name, version, description, registered processes, app environment, and module names. We would need to lift all of this information from the Gleam .toml and make assumptions on how Gleam wants those be used. Worst case scenario, couldn't Gleam support an  | 
| Yes,  From @lpil comment over elixirforum I assume the problem are colocated Elixir files within a Gleam project. The Gleam compiler knows nothing about them so any modules they define can't be written in the .app file, I guess. What I have done here is use the Mix task to generate the .app file (and inject the two options gleam.toml supports for the erlang target:  Let me know if this looks good or if I should revert it. Thanks. | 
| Yes, for collocated projects that’s the responsibility of Mix, but for packages I would say that’s Gleam responsibility. Otherwise there is even more we need to understand from Gleam TOML’s and we may need to keep track of it as it evolves. So is there a chance for it to emit an .app file either by default or via a flag? On the plus side, if Rebar wants to integrate Gleam as well, they can reuse it to emit apps too. :) | 
b70f8fd    to
    b64f23a      
    Compare
  
    | Apparently this seems to be working fine except that people sometimes need to compile twice . Could this be code path related maybe? It's probably something stupid I missed. | 
| 
 Works like a charm now :D! | 
d365e19    to
    2c51ca5      
    Compare
  
    - Add Mix.Gleam module - Add specific gleam binary version requirement - Rely on `gleam export package-info`
- shell_cmd! wasn't handling tuples - Fix documentation
This is an optional value within [erlang] in the gleam.toml file. It will be used for the `mod` value when generating a .app file
Co-authored-by: Eksperimental <[email protected]>
Co-authored-by: selenil <[email protected]>
2c51ca5    to
    da217a1      
    Compare
  
    Co-authored-by: Eksperimental <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just two minor suggestions.
Co-authored-by: Eksperimental <[email protected]>
| hi @josevalim! is this one still planned for review? if there is anything specific that you would want me to test, let me know! | 
| Yes, we have been focused on getting Elixir v1.19 out, but we will merge this once that is shipped. The best for now is to try it an actual projects and provide feedback on the PR. | 
Co-authored-by: Hans Glimmerfors <[email protected]>
This PR adds support for the gleam language.
gleam.tomlinpathdepsgleamin deps loader.deps.compilegleambinary version (hardcoded to 1.9.0 for now, see below)gleambinarymainalready but not yet released):applicationoption inMix.ProjectStack.push(thus anapplicationfunction is not needed)Notes:
gleambinary version requirements are handled automatically when executinggleam compile-package.gleam export package-infobut I can't know the reason for a bad exit status (maybe the dep path was wrong and the command was run in a dir without agleam.toml).is not yet released but has already been merged. Should land on v1.10.0.Was released on v1.10.0