Skip to content
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

Ensure users don't create a .wasp file #2418

Open
wants to merge 7 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions waspc/ChangeLog.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@

- Enabled strict null checks for the Wasp SDK which means that some of the return types are more precise now e.g. you'll need to check if some value is `null` before using it.

- Improved the error message when the user has a top level *.wasp* file.

## 0.15.2

### 🐞 Bug fixes
Expand Down
28 changes: 17 additions & 11 deletions waspc/src/Wasp/Project/WaspFile.hs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import StrongPath
castFile,
fromAbsDir,
fromRelFile,
relfile,
(</>),
)
import qualified Wasp.AppSpec as AS
Expand All @@ -28,24 +29,29 @@ import qualified Wasp.Util.IO as IOUtil

findWaspFile :: Path' Abs (Dir WaspProjectDir) -> IO (Either String WaspFilePath)
findWaspFile waspDir = do
files <- fst <$> IOUtil.listDirectory waspDir
return $ case (findWaspTsFile files, findWaspLangFile files) of
(Just _, Just _) -> Left bothFilesFoundMessage
(Nothing, Nothing) -> Left fileNotFoundMessage
(Just waspTsFile, Nothing) -> Right waspTsFile
(Nothing, Just waspLangFile) -> Right waspLangFile
let dotWaspPath = waspDir </> [relfile|.wasp|]
isFile <- IOUtil.doesFileExist dotWaspPath
if isFile
then return $ Left "Invalid file name for the .wasp file. Please rename it to [something].wasp."
else do
files <- fst <$> IOUtil.listDirectory waspDir
return $ case (findWaspTsFile files, findWaspLangFile files) of
(tsFiles, langFiles)
| not (null tsFiles) && not (null langFiles) -> Left bothFilesFoundMessage
| null tsFiles && null langFiles -> Left fileNotFoundMessage
| [waspTsFile] <- tsFiles, null langFiles -> Right waspTsFile
| null tsFiles, [waspLangFile] <- langFiles -> Right waspLangFile
| otherwise -> Left multipleFilesFoundMessage
where
findWaspTsFile files = WaspTs <$> findFileThatEndsWith ".wasp.ts" files
findWaspLangFile files = WaspLang <$> findFileThatEndsWith ".wasp" files
findFileThatEndsWith suffix files =
castFile
. (waspDir </>)
<$> find ((suffix `isSuffixOf`) . fromRelFile) files

findFileThatEndsWith suffix files = castFile . (waspDir </>) <$> findFilesThatEndWith suffix files
findFilesThatEndWith suffix files = filter ((suffix `isSuffixOf`) . fromRelFile) files
fileNotFoundMessage = "Couldn't find the *.wasp or a *.wasp.ts file in the " ++ fromAbsDir waspDir ++ " directory"
bothFilesFoundMessage =
"Found both *.wasp and *.wasp.ts files in the project directory. "
++ "You must choose how you want to define your app (using Wasp or TypeScript) and only keep one of them."
multipleFilesFoundMessage = "Found multiple *.wasp or *.wasp.ts files in the project directory. Please keep only one."

analyzeWaspFile ::
Path' Abs (Dir WaspProjectDir) ->
Expand Down
Loading