-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathMain.lean
30 lines (27 loc) · 873 Bytes
/
Main.lean
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
/-
Copyright (c) 2022 Mac Malone. All rights reserved.
Released under Apache 2.0 license as described in the file LICENSE.
Authors: Mac Malone
-/
import Alloy
open Lean System Alloy
def emitCShim (module : Name) (outFile? : Option FilePath) : IO PUnit := do
let env ← Lean.importModules #[{module}] Options.empty
let shim := C.getModuleShim env module
if let some outFile := outFile? then
IO.FS.writeFile outFile shim.toString
else
IO.print shim
def main (args : List String) : IO UInt32 := do
if let module :: args := args then
try
Lean.initSearchPath (← Lean.findSysroot)
emitCShim module.toName args.head?
return 0
catch e =>
IO.eprintln s!"error: {toString e}"
return 1
else
let appName := (← IO.appPath).fileName.getD "alloy"
IO.eprintln s!"Usage: {appName} lean-file [out-file]"
return 1