lib/min_io.nim
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 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 |
import
os,
strutils
import
../core/linedit,
../core/regex,
../core/parser,
../core/value,
../core/interpreter,
../core/utils
# I/O
proc io_module*(i: In) =
i.define("io")
.symbol("newline") do (i: In):
echo ""
.symbol("puts") do (i: In):
let a = i.peek
echo $$a
.symbol("column-print") do (i: In):
var n, q: MinValue
i.reqIntAndQuotation n, q
var c = 0
for s in q.qVal:
c.inc
stdout.write $$s & spaces(max(0, 15 - ($$s).len))
if c mod n.intVal == 0:
echo ""
echo ""
.symbol("gets") do (i: In):
var ed = initEditor()
i.push ed.readLine().newVal
.symbol("password") do (i: In):
var ed = initEditor()
i.push ed.password("Enter Password: ").newVal
.symbol("ask") do (i: In):
var s: MinValue
var ed = initEditor()
i.reqString s
i.push ed.readLine(s.getString & ": ").newVal
.symbol("confirm") do (i: In):
var s: MinValue
var ed = initEditor()
i.reqString s
proc confirm(): bool =
let answer = ed.readLine(s.getString & " [yes/no]: ")
if answer.match("^y(es)?$", "i"):
return true
elif answer.match("^no?$", "i"):
return false
else:
stdout.write "Invalid answer. Please enter 'yes' or 'no': "
return confirm()
i.push confirm().newVal
.symbol("choose") do (i: In):
var q, s: MinValue
var ed = initEditor()
i.reqStringLikeAndQuotation s, q
if q.qVal.len <= 0:
raiseInvalid("No choices to display")
stdout.writeLine(s.getString)
proc choose(): int =
var c = 0
for item in q.qVal:
if not item.isQuotation or not item.qVal.len == 2 or not item.qVal[0].isString or not item.qVal[1].isQuotation:
raiseInvalid("Each item of the quotation must be a quotation containing a string and a quotation")
c.inc
echo "$1 - $2" % [$c, item.qVal[0].getString]
let answer = ed.readLine("Enter your choice ($1 - $2): " % ["1", $c])
var choice: int
try:
choice = answer.parseInt
except:
choice = 0
if choice <= 0 or choice > c:
echo "Invalid choice."
return choose()
else:
return choice
let choice = choose()
i.unquote("<choose>", q.qVal[choice-1].qVal[1])
.symbol("print") do (i: In):
let a = i.peek
a.print
.symbol("fread") do (i: In):
var a: MinValue
i.reqString a
i.push newVal(a.strVal.readFile)
.symbol("fwrite") do (i: In):
var a, b: MinValue
i.reqTwoStrings a, b
a.strVal.writeFile(b.strVal)
.symbol("fappend") do (i: In):
var a, b: MinValue
i.reqTwoStrings a, b
var f:File
discard f.open(a.strVal, fmAppend)
f.write(b.strVal)
f.close()
.finalize()
|