mirror of
https://github.com/nim-lang/Nim.git
synced 2026-01-10 06:54:16 +00:00
Merge pull request #233 from gradha/more_cross_calculator_interfaces
More cross calculator interfaces
This commit is contained in:
2
.gitignore
vendored
2
.gitignore
vendored
@@ -15,11 +15,13 @@ compiler/c2nim/nimcache
|
||||
compiler/pas2nim/nimcache
|
||||
misc
|
||||
doc/*.html
|
||||
doc/*.idx
|
||||
web/upload/*.html
|
||||
koch
|
||||
compiler/nimrod*
|
||||
build/[0-9]_[0-9]
|
||||
bin/nimrod
|
||||
examples/cross_calculator/nimrod_commandline/nimcalculator
|
||||
|
||||
# iOS specific wildcards.
|
||||
*.mode1v3
|
||||
|
||||
110
examples/cross_calculator/nimrod_commandline/nimcalculator.nim
Normal file
110
examples/cross_calculator/nimrod_commandline/nimcalculator.nim
Normal file
@@ -0,0 +1,110 @@
|
||||
# Implements a command line interface against the backend.
|
||||
|
||||
import backend
|
||||
import parseopt
|
||||
import strutils
|
||||
|
||||
const
|
||||
USAGE = """nimcalculator - Nimrod cross platform calculator
|
||||
(beta version, only integer addition is supported!)
|
||||
|
||||
Usage:
|
||||
nimcalculator [options] [-a=value -b=value]
|
||||
Options:
|
||||
-a=value sets the integer value of the a parameter
|
||||
-b=value sets the integer value of the b parameter
|
||||
-h, --help shows this help
|
||||
|
||||
If no options are used, an interactive mode is entered.
|
||||
"""
|
||||
|
||||
type
|
||||
TAction = enum # The possible types of operation
|
||||
rtParams, # Two valid parameters were provided
|
||||
rtInteractive # No parameters were provided, run interactive mode
|
||||
|
||||
TParamConfig = object of TObject
|
||||
action: TAction # store the type of operation
|
||||
paramA, paramB: int # possibly store the valid parameters
|
||||
|
||||
|
||||
proc parseCmdLine(): TParamConfig =
|
||||
## Parses the commandline.
|
||||
##
|
||||
## Returns a TParamConfig structure filled with the proper values or directly
|
||||
## calls quit() with the appropriate error message.
|
||||
var
|
||||
hasA = false
|
||||
hasB = false
|
||||
p = initOptParser()
|
||||
key, val : TaintedString
|
||||
|
||||
result.action = rtInteractive # By default presume interactive mode.
|
||||
try:
|
||||
while true:
|
||||
next(p)
|
||||
key = p.key
|
||||
val = p.val
|
||||
|
||||
case p.kind
|
||||
of cmdArgument:
|
||||
stdout.write(USAGE)
|
||||
quit("Erroneous argument detected: " & key, 1)
|
||||
of cmdLongOption, cmdShortOption:
|
||||
case normalize(key)
|
||||
of "help", "h":
|
||||
stdout.write(USAGE)
|
||||
quit(0)
|
||||
of "a":
|
||||
result.paramA = val.parseInt
|
||||
hasA = true
|
||||
of "b":
|
||||
result.paramB = val.parseInt
|
||||
hasB = true
|
||||
else:
|
||||
stdout.write(USAGE)
|
||||
quit("Unexpected option: " & key, 2)
|
||||
of cmdEnd: break
|
||||
except EInvalidValue:
|
||||
stdout.write(USAGE)
|
||||
quit("Invalid value " & val & " for parameter " & key, 3)
|
||||
|
||||
if hasA and hasB:
|
||||
result.action = rtParams
|
||||
elif hasA or hasB:
|
||||
stdout.write(USAGE)
|
||||
quit("Error: provide both A and B to operate in param mode", 4)
|
||||
|
||||
|
||||
proc parseUserInput(question: string): int =
|
||||
## Parses a line of user input, showing question to the user first.
|
||||
##
|
||||
## If the user input is an empty line quit() is called. Returns the value
|
||||
## parsed as an integer.
|
||||
while true:
|
||||
echo(question)
|
||||
let input = stdin.readLine
|
||||
try:
|
||||
result = input.parseInt
|
||||
break
|
||||
except EInvalidValue:
|
||||
if input.len < 1: quit("Blank line detected, quitting.", 0)
|
||||
echo("Sorry, `$1' doesn't seem to be a valid integer" % input)
|
||||
|
||||
proc interactiveMode() =
|
||||
## Asks the user for two integer values, adds them and exits.
|
||||
let paramA = parseUserInput("Enter the first parameter (blank to exit):")
|
||||
let paramB = parseUserInput("Enter the second parameter (blank to exit):")
|
||||
echo("Calculating... $1 + $2 = $3" % [$paramA, $paramB,
|
||||
$backend.myAdd(paramA, paramB)])
|
||||
|
||||
|
||||
when isMainModule:
|
||||
## Main entry point.
|
||||
let opt = parseCmdLine()
|
||||
if rtParams == opt.action:
|
||||
echo("Param mode: $1 + $2 = $3" % [$opt.paramA, $opt.paramB,
|
||||
$backend.myAdd(opt.paramA, opt.paramB)])
|
||||
else:
|
||||
echo("Entering interactive addition mode")
|
||||
interactiveMode()
|
||||
9
examples/cross_calculator/nimrod_commandline/readme.txt
Normal file
9
examples/cross_calculator/nimrod_commandline/readme.txt
Normal file
@@ -0,0 +1,9 @@
|
||||
In this directory you will find the nimrod commandline version of the
|
||||
cross-calculator sample.
|
||||
|
||||
The commandline interface can be used non interactively through switches, or
|
||||
interactively when running the command without parameters.
|
||||
|
||||
Compilation is fairly easy, just include the path to the backend in your
|
||||
compilation command. A basic build.sh is provided for unix like platforms with
|
||||
the correct parameters.
|
||||
Reference in New Issue
Block a user