1
1
mirror of https://github.com/anoma/juvix.git synced 2024-12-12 14:28:08 +03:00
juvix/app/Commands
Jan Mas Rovira 2d36a65324
Make compile targets a subcommand instead of a flag (#2700)
# Changes
The main goal of this pr is to remove the `--target` flag for `juvix
compile` and use subcommands instead. The targets that are relevant to
normal users are found in `juvix compile --help`. Targets that are
relevant only to developers are found in `juvix dev compile --help`.

Below I list some of the changes in more detail.
## Compile targets for user-facing languages
- `juvix compile native`
- `juvix compile wasi`. I wasn't sure how to call this: `wasm`,
`wasm32-wasi`, etc. In the end I thought `wasi` was short and accurate,
but we can change it.
- `juvix compile vampir`
- `juvix compile anoma`
- `juvix compile cairo`
## *New* compile targets for internal languages
See `juvix dev compile --help`.

1. `dev compile core` has the same behaviour as `dev core
from-concrete`. The `dev core from-concrete` is redundant at the moment.
2. `dev compile tree` compiles to Tree and prints the InfoTable to the
output file wihout any additional checks.
3. `dev compile reg` compiles to Reg and prints the InfoTable to the
output file wihout any additional checks.
4. `dev compile asm` compiles to Asm and prints the InfoTable to the
output file wihout any additional checks.
5. 4. `dev compile casm` compiles to Asm and prints the Result to the
output file wihout any additional checks. TODO: should the Result be
printed or something else? At the moment the Result lacks a pretty
instance.
6. 
## Optional input file
1. The input file for commands that expect a .juvix file as input is now
optional. If the argument is ommited, he main file given in the
package.yaml will be used. This applies to the following commands:
   1. `juvix compile [native|wasi|geb|vampir|anoma|cairo]`
   8.  `juvix dev compile [core|reg|tree|casm|asm]`
   1. `juvix html`
   3. `juvix markdown`.
   4. `juvix dev internal [typecheck|pretty]`.
   5. `juvix dev [parse|scope]`
   7. `juvix compile [native|wasi|geb|vampir|anoma|cairo]`
   9. note that `juvix format` has not changed its behaviour.

## Refactor some C-like compiler flags
Both `juvix compile native` and `juvix compile wasi` support `--only-c`
(`-C`), `--only-preprocess` (`-E`), `--only-assemble` (`-S`). I propose
to deviate from the `gcc` style and instead use a flag with a single
argument:
- `--cstage [source|preprocess|assembly|exec(default)]`. I'm open to
suggestions. For now, I've kept the legacy flags but marked them as
deprecated in the help message.

## Remove code duplication
I've tried to reduce code duplication. This is sometimes in tension with
code readability so I've tried to find a good balance. I've tried to
make it so we don't have to jump to many different files to understand
what a single command is doing. I'm sure there is still room for
improvement.

## Other refactors
I've implemented other small refactors that I considered improved the
quality of the code.

## TODO/Future work
We should refactor commands (under `compile dev`) which still use
`module Commands.Extra.Compile` and remove it.
2024-04-09 13:29:07 +02:00
..
Clean Use Package.juvix in the global project (#2499) 2023-11-06 11:49:43 +00:00
Compile Make compile targets a subcommand instead of a flag (#2700) 2024-04-09 13:29:07 +02:00
Dependencies Use EmbedIO instead of Embed IO (#2645) 2024-02-13 18:00:01 +00:00
Dev Make compile targets a subcommand instead of a flag (#2700) 2024-04-09 13:29:07 +02:00
Doctor Global offline flag (#2335) 2023-09-05 17:11:17 +02:00
Eval Make compile targets a subcommand instead of a flag (#2700) 2024-04-09 13:29:07 +02:00
Extra Make compile targets a subcommand instead of a flag (#2700) 2024-04-09 13:29:07 +02:00
Format Add FileExt type (#2467) 2023-10-25 12:02:12 +02:00
Html Make compile targets a subcommand instead of a flag (#2700) 2024-04-09 13:29:07 +02:00
Init Add PackageDescription.Basic module Package variant (#2509) 2023-11-13 17:36:18 +00:00
Markdown Make compile targets a subcommand instead of a flag (#2700) 2024-04-09 13:29:07 +02:00
Repl Per-module compilation (#2468) 2023-12-30 20:15:35 +01:00
Typecheck Make compile targets a subcommand instead of a flag (#2700) 2024-04-09 13:29:07 +02:00
Base.hs Use writeFileEnsureLn in place of writeFile (#2604) 2024-01-31 11:15:17 +01:00
Clean.hs Use Package.juvix in the global project (#2499) 2023-11-06 11:49:43 +00:00
Compile.hs Make compile targets a subcommand instead of a flag (#2700) 2024-04-09 13:29:07 +02:00
Dependencies.hs Use EmbedIO instead of Embed IO (#2645) 2024-02-13 18:00:01 +00:00
Dev.hs Make compile targets a subcommand instead of a flag (#2700) 2024-04-09 13:29:07 +02:00
Doctor.hs Replace polysemy by effectful (#2663) 2024-03-21 12:09:34 +00:00
Eval.hs Make compile targets a subcommand instead of a flag (#2700) 2024-04-09 13:29:07 +02:00
Format.hs Make compile targets a subcommand instead of a flag (#2700) 2024-04-09 13:29:07 +02:00
Html.hs Replace polysemy by effectful (#2663) 2024-03-21 12:09:34 +00:00
Init.hs Promote use of MonadIO to minimize embed occurrences (#2694) 2024-03-20 09:56:00 +01:00
Markdown.hs Add flags for the markdown and html backend: --strip-prefix and --ext. (#2681) 2024-03-09 18:42:09 +01:00
Repl.hs Replace polysemy by effectful (#2663) 2024-03-21 12:09:34 +00:00
Typecheck.hs Use EmbedIO instead of Embed IO (#2645) 2024-02-13 18:00:01 +00:00