mirror of
https://github.com/anoma/juvix.git
synced 2024-12-15 18:13:56 +03:00
32449e1212
The problem with readFile and writeFile from text [Data.Text.IO](https://hackage.haskell.org/package/text-2.0.2/docs/Data-Text-IO.html) is that they use the system locale to determine the text encoding format. Our assumption is that all Juvix source files are UTF-8 encoded. I cannot reproduce the issue with using the old APIs on my machine, it can be reproduced on Arch linux. I'm not sure how to write a specific test for this. * Closes https://github.com/anoma/juvix/issues/2472
54 lines
2.2 KiB
Haskell
54 lines
2.2 KiB
Haskell
module Commands.Dev.Asm.Compile where
|
|
|
|
import Commands.Base
|
|
import Commands.Dev.Asm.Compile.Options
|
|
import Commands.Extra.Compile qualified as Compile
|
|
import Data.Text.IO qualified as TIO
|
|
import Juvix.Compiler.Asm.Translation.FromSource qualified as Asm
|
|
import Juvix.Compiler.Backend qualified as Backend
|
|
import Juvix.Compiler.Backend.C qualified as C
|
|
|
|
runCommand :: forall r. (Members '[Embed IO, App] r) => AsmCompileOptions -> Sem r ()
|
|
runCommand opts = do
|
|
file <- getFile
|
|
ep <- getEntryPoint (AppPath (preFileFromAbs file) True)
|
|
tgt <- getTarget (opts ^. compileTarget)
|
|
let entryPoint :: EntryPoint
|
|
entryPoint =
|
|
ep
|
|
{ _entryPointTarget = tgt,
|
|
_entryPointDebug = opts ^. compileDebug
|
|
}
|
|
s <- readFile (toFilePath file)
|
|
case Asm.runParser (toFilePath file) s of
|
|
Left err -> exitJuvixError (JuvixError err)
|
|
Right tab -> do
|
|
case run $ runReader entryPoint $ runError $ asmToMiniC tab of
|
|
Left err -> exitJuvixError err
|
|
Right C.MiniCResult {..} -> do
|
|
buildDir <- askBuildDir
|
|
ensureDir buildDir
|
|
cFile <- inputCFile file
|
|
embed $ TIO.writeFile (toFilePath cFile) _resultCCode
|
|
Compile.runCommand opts {_compileInputFile = Just (AppPath (preFileFromAbs cFile) False)}
|
|
where
|
|
getFile :: Sem r (Path Abs File)
|
|
getFile = getMainFile (opts ^. compileInputFile)
|
|
|
|
getTarget :: CompileTarget -> Sem r Backend.Target
|
|
getTarget = \case
|
|
TargetWasm32Wasi -> return Backend.TargetCWasm32Wasi
|
|
TargetNative64 -> return Backend.TargetCNative64
|
|
TargetGeb -> exitMsg (ExitFailure 1) "error: GEB target not supported for JuvixAsm"
|
|
TargetVampIR -> exitMsg (ExitFailure 1) "error: VampIR target not supported for JuvixAsm"
|
|
TargetCore -> exitMsg (ExitFailure 1) "error: JuvixCore target not supported for JuvixAsm"
|
|
TargetAsm -> exitMsg (ExitFailure 1) "error: JuvixAsm target not supported for JuvixAsm"
|
|
|
|
inputCFile :: (Members '[App] r) => Path Abs File -> Sem r (Path Abs File)
|
|
inputCFile inputFileCompile = do
|
|
buildDir <- askBuildDir
|
|
return (buildDir <//> outputMiniCFile)
|
|
where
|
|
outputMiniCFile :: Path Rel File
|
|
outputMiniCFile = replaceExtension' ".c" (filename inputFileCompile)
|