Merge branch 'master' into better-names

This commit is contained in:
Kamil Shakirov 2020-05-24 00:37:05 +06:00
commit 278dc1ca29
11 changed files with 125 additions and 107 deletions

View File

@ -12,7 +12,7 @@ On Windows, it has been reported that installing via `MSYS2` works
(https://www.msys2.org/). On Raspberry Pi, you can bootstrap via Racket. (https://www.msys2.org/). On Raspberry Pi, you can bootstrap via Racket.
By default, code generation is via Chez Scheme. You can use Racket instead, By default, code generation is via Chez Scheme. You can use Racket instead,
by passing `CG=racket` to `make` for the commands below. by setting the environment variable `IDRIS2_CG=racket` before running `make`.
[Note: a couple of tests are currently known to fail when installing via [Note: a couple of tests are currently known to fail when installing via
Racket. This will be addressed soon!] Racket. This will be addressed soon!]

View File

@ -24,13 +24,7 @@ endif
export IDRIS2_VERSION := ${MAJOR}.${MINOR}.${PATCH} export IDRIS2_VERSION := ${MAJOR}.${MINOR}.${PATCH}
IDRIS2_SUPPORT := libidris2_support${SHLIB_SUFFIX} IDRIS2_SUPPORT := libidris2_support${SHLIB_SUFFIX}
IDRIS2_IPKG := idris2.ipkg
CG ?= ${IDRIS2_CG}
ifneq (${CG},racket)
IDRIS2_IPKG := idris2.ipkg
else
IDRIS2_IPKG := idris2rkt.ipkg
endif
ifeq ($(OS), windows) ifeq ($(OS), windows)
IDRIS2_PREFIX := $(shell cygpath -m ${PREFIX}) IDRIS2_PREFIX := $(shell cygpath -m ${PREFIX})

View File

@ -23,8 +23,8 @@ echo ${PREFIX}
IDRIS2_BOOT_PATH="${PREFIX}/idris2-0.2.0/prelude:${PREFIX}/idris2-0.2.0/base:${PREFIX}/idris2-0.2.0/contrib:${PREFIX}/idris2-0.2.0/network" IDRIS2_BOOT_PATH="${PREFIX}/idris2-0.2.0/prelude:${PREFIX}/idris2-0.2.0/base:${PREFIX}/idris2-0.2.0/contrib:${PREFIX}/idris2-0.2.0/network"
DYLIB_PATH="${PREFIX}/lib" DYLIB_PATH="${PREFIX}/lib"
make libs CG=racket PREFIX=${PREFIX} LD_LIBRARY_PATH=${DYLIB_PATH} make libs IDRIS2_CG=racket PREFIX=${PREFIX} LD_LIBRARY_PATH=${DYLIB_PATH}
make install CG=racket PREFIX=${PREFIX} LD_LIBRARY_PATH=${DYLIB_PATH} make install IDRIS2_CG=racket PREFIX=${PREFIX} LD_LIBRARY_PATH=${DYLIB_PATH}
make clean IDRIS2_BOOT=${PREFIX}/bin/idris2 LD_LIBRARY_PATH=${DYLIB_PATH} make clean IDRIS2_BOOT=${PREFIX}/bin/idris2 LD_LIBRARY_PATH=${DYLIB_PATH}
make all IDRIS2_BOOT=${PREFIX}/bin/idris2 CG=racket IDRIS2_PATH=${IDRIS2_BOOT_PATH} LD_LIBRARY_PATH=${DYLIB_PATH} make all IDRIS2_BOOT=${PREFIX}/bin/idris2 IDRIS2_CG=racket IDRIS2_PATH=${IDRIS2_BOOT_PATH} LD_LIBRARY_PATH=${DYLIB_PATH}
#make test INTERACTIVE='' IDRIS2_BOOT=${PREFIX}/bin/idris2 CG=racket IDRIS2_PATH=${IDRIS2_BOOT_PATH} IDRIS2_LIBS=${PREFIX}/idris2-0.2.0/lib LD_LIBRARY_PATH=${DYLIB_PATH} #make test INTERACTIVE='' IDRIS2_BOOT=${PREFIX}/bin/idris2 CG=racket IDRIS2_PATH=${IDRIS2_BOOT_PATH} IDRIS2_LIBS=${PREFIX}/idris2-0.2.0/lib LD_LIBRARY_PATH=${DYLIB_PATH}

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -8,9 +8,15 @@ The Gambit Scheme code generator can be accessed via the REPL command:
Main> :set cg gambit Main> :set cg gambit
Ergo, to run Idris programs with this generator, you will need to install Alternatively, you can set it via the `IDRIS2_CG` environment variable:
::
$ export IDRIS2_CG=gambit
To run Idris programs with this generator, you will need to install
`Gambit Scheme <https://gambitscheme.org>`_. Gambit Scheme is free software, `Gambit Scheme <https://gambitscheme.org>`_. Gambit Scheme is free software,
and available via most pacakge managers. and available via most package managers.
You can compile an expression ``expr`` of type ``IO ()`` to an executable as You can compile an expression ``expr`` of type ``IO ()`` to an executable as
follows, at the REPL: follows, at the REPL:

View File

@ -40,6 +40,8 @@ Again, ``expr`` must have type ``IO ()``.
There are three code generators provided in Idris 2, and (later) there will be There are three code generators provided in Idris 2, and (later) there will be
a system for plugging in new code generators for a variety of targets. The a system for plugging in new code generators for a variety of targets. The
default is to compile via Chez Scheme, with an alternative via Racket or Gambit. default is to compile via Chez Scheme, with an alternative via Racket or Gambit.
You can set the code generator at the REPL with the `:set codegen` command,
or via the `IDRIS2_CG` environment variable.
.. toctree:: .. toctree::
:maxdepth: 1 :maxdepth: 1

View File

@ -8,6 +8,12 @@ The Racket code generator is accessed via a REPL command:
Main> :set cg racket Main> :set cg racket
Alternatively, you can set it via the `IDRIS2_CG` environment variable:
::
$ export IDRIS2_CG=racket
You can compile an expression ``expr`` of type ``IO ()`` to an executable as You can compile an expression ``expr`` of type ``IO ()`` to an executable as
follows, at the REPL: follows, at the REPL:

View File

@ -71,7 +71,8 @@ schHeader chez libs
"(case (machine-type)\n" ++ "(case (machine-type)\n" ++
" [(i3le ti3le a6le ta6le) (load-shared-object \"libc.so.6\")]\n" ++ " [(i3le ti3le a6le ta6le) (load-shared-object \"libc.so.6\")]\n" ++
" [(i3osx ti3osx a6osx ta6osx) (load-shared-object \"libc.dylib\")]\n" ++ " [(i3osx ti3osx a6osx ta6osx) (load-shared-object \"libc.dylib\")]\n" ++
" [(i3nt ti3nt a6nt ta6nt) (load-shared-object \"msvcrt.dll\")]\n" ++ " [(i3nt ti3nt a6nt ta6nt) (load-shared-object \"msvcrt.dll\")" ++
" (load-shared-object \"ws2_32.dll\")]\n" ++
" [else (load-shared-object \"libc.so\")])\n\n" ++ " [else (load-shared-object \"libc.so\")])\n\n" ++
showSep "\n" (map (\x => "(load-shared-object \"" ++ escapeString x ++ "\")") libs) ++ "\n\n" ++ showSep "\n" (map (\x => "(load-shared-object \"" ++ escapeString x ++ "\")") libs) ++ "\n\n" ++
"(let ()\n" "(let ()\n"
@ -332,7 +333,7 @@ startChezWinSh chez appdir target = unlines
, "DIR=\"`realpath \"$0\"`\"" , "DIR=\"`realpath \"$0\"`\""
, "CHEZ=$(cygpath \"" ++ chez ++"\")" , "CHEZ=$(cygpath \"" ++ chez ++"\")"
, "export PATH=\"`dirname \"$DIR\"`/\"" ++ appdir ++ "\":$PATH\"" , "export PATH=\"`dirname \"$DIR\"`/\"" ++ appdir ++ "\":$PATH\""
, "\"$CHEZ\" --script \"$(dirname \"$DIR\")/" ++ target ++ "\" \"$@\"" , "$CHEZ --script \"$(dirname \"$DIR\")/" ++ target ++ "\" \"$@\""
] ]
||| Compile a TT expression to Chez Scheme ||| Compile a TT expression to Chez Scheme
@ -374,7 +375,7 @@ compileToSO chez appDirRel outSsAbs
Right () <- coreLift $ writeFile tmpFileAbs build Right () <- coreLift $ writeFile tmpFileAbs build
| Left err => throw (FileErr tmpFileAbs err) | Left err => throw (FileErr tmpFileAbs err)
coreLift $ chmodRaw tmpFileAbs 0o755 coreLift $ chmodRaw tmpFileAbs 0o755
coreLift $ system ("\"" ++ chez ++ "\" --script \"" ++ tmpFileAbs ++ "\"") coreLift $ system (chez ++ " --script \"" ++ tmpFileAbs ++ "\"")
pure () pure ()
makeSh : String -> String -> String -> Core () makeSh : String -> String -> String -> Core ()

View File

@ -37,11 +37,10 @@ findInput [] = Nothing
findInput (InputFile f :: fs) = Just f findInput (InputFile f :: fs) = Just f
findInput (_ :: fs) = findInput fs findInput (_ :: fs) = findInput fs
-- Add extra library directories from the "BLODWEN_PATH" -- Add extra data from the "IDRIS2_x" environment variables
-- environment variable updateEnv : {auto c : Ref Ctxt Defs} ->
updatePaths : {auto c : Ref Ctxt Defs} -> Core ()
Core () updateEnv
updatePaths
= do bprefix <- coreLift $ getEnv "IDRIS2_PREFIX" = do bprefix <- coreLift $ getEnv "IDRIS2_PREFIX"
the (Core ()) $ case bprefix of the (Core ()) $ case bprefix of
Just p => setPrefix p Just p => setPrefix p
@ -58,6 +57,13 @@ updatePaths
the (Core ()) $ case blibs of the (Core ()) $ case blibs of
Just path => do traverse_ addLibDir (map trim (split (==pathSep) path)) Just path => do traverse_ addLibDir (map trim (split (==pathSep) path))
Nothing => pure () Nothing => pure ()
cg <- coreLift $ getEnv "IDRIS2_CG"
the (Core ()) $ case cg of
Just e => case getCG e of
Just cg => setCG cg
Nothing => throw (InternalError ("Unknown code generator " ++ show e))
Nothing => pure ()
-- IDRIS2_PATH goes first so that it overrides this if there's -- IDRIS2_PATH goes first so that it overrides this if there's
-- any conflicts. In particular, that means that setting IDRIS2_PATH -- any conflicts. In particular, that means that setting IDRIS2_PATH
-- for the tests means they test the local version not the installed -- for the tests means they test the local version not the installed
@ -78,7 +84,7 @@ updateREPLOpts : {auto o : Ref ROpts REPLOpts} ->
updateREPLOpts updateREPLOpts
= do opts <- get ROpts = do opts <- get ROpts
ed <- coreLift $ getEnv "EDITOR" ed <- coreLift $ getEnv "EDITOR"
case ed of the (Core ()) $ case ed of
Just e => put ROpts (record { editor = e } opts) Just e => put ROpts (record { editor = e } opts)
Nothing => pure () Nothing => pure ()
@ -133,7 +139,7 @@ stMain opts
addPrimitives addPrimitives
setWorkingDir "." setWorkingDir "."
updatePaths updateEnv
let ide = ideMode opts let ide = ideMode opts
let ideSocket = ideModeSocket opts let ideSocket = ideModeSocket opts
let outmode = if ide then IDEMode 0 stdin stdout else REPL False let outmode = if ide then IDEMode 0 stdin stdout else REPL False

View File

@ -52,7 +52,6 @@ runClient serverPort = do
main : IO () main : IO ()
main = do main = do
when (os == "windows") (schemeCall () "load-shared-object" ["ws2_32"])
Right (serverPort, tid) <- runServer Right (serverPort, tid) <- runServer
| Left err => putStrLn $ "[server] " ++ err | Left err => putStrLn $ "[server] " ++ err
runClient serverPort runClient serverPort