1
1
mirror of https://github.com/anoma/juvix.git synced 2025-01-07 08:08:44 +03:00

Propogate formatter results when traversing subdirs (#2207)

Previously if a project looked like (where `Unformatted.juvix` contains
unformatted code, and `Formatted.juvix` is fully formatted):

```
Dir
|- juvix.yaml
|- Unformatted.juvix
|- Subdir
   |- Formatted.juvix
```

and the user ran `juvix format Dir/` then the command would return exit
code 0 instead of exit code 1. This is because only the result from
formatting files within `Subdir` was used, the result from `Dir` was
discarded.

This PR fixes this, the results of formatting all subdirectories in a
project are combined appropriately.
This commit is contained in:
Paul Cadman 2023-06-19 18:42:28 +01:00 committed by GitHub
parent 7840f9fa79
commit fa4c92c7a5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 6 additions and 4 deletions

View File

@ -100,10 +100,10 @@ formatProject p = do
[Path Rel File] -> [Path Rel File] ->
FormatResult -> FormatResult ->
Sem r (FormatResult, Recurse Rel) Sem r (FormatResult, Recurse Rel)
handler cd _ files _ = do handler cd _ files res = do
let juvixFiles = [cd <//> f | f <- files, isJuvixFile f] let juvixFiles = [cd <//> f | f <- files, isJuvixFile f]
res <- combineResults <$> mapM format juvixFiles subRes <- combineResults <$> mapM format juvixFiles
return (res, RecurseFilter (\hasJuvixYaml d -> not hasJuvixYaml && not (isHiddenDirectory d))) return (res <> subRes, RecurseFilter (\hasJuvixYaml d -> not hasJuvixYaml && not (isHiddenDirectory d)))
formatPath :: Members [Reader Text, ScopeEff] r => Path Abs File -> Sem r (NonEmpty AnsiText) formatPath :: Members [Reader Text, ScopeEff] r => Path Abs File -> Sem r (NonEmpty AnsiText)
formatPath p = do formatPath p = do

View File

@ -110,7 +110,7 @@ tests:
stdout: '' stdout: ''
exit-status: 0 exit-status: 0
- name: format-dir-containing-unformatted - name: format-dir-containing-unformatted-and-formatted
command: command:
shell: shell:
- bash - bash
@ -121,6 +121,8 @@ tests:
cp positive/Format.juvix $temp cp positive/Format.juvix $temp
cd $temp cd $temp
echo "module Foo ;" >> Foo.juvix echo "module Foo ;" >> Foo.juvix
mkdir Subdir
echo "module Subdir.Bar;" >> Subdir/Bar.juvix
juvix format $temp juvix format $temp
stdout: stdout:
contains: 'Foo.juvix' contains: 'Foo.juvix'