mirror of
https://github.com/adambard/learnxinyminutes-docs.git
synced 2024-12-24 01:51:38 +00:00
Renamed vars and types for clarity; minor stuff; enum prefix
This commit is contained in:
parent
a261b8c445
commit
08a444ddc6
@ -20,7 +20,7 @@ var z = "Yep" # Declare and assign, with or without type annotations
|
|||||||
|
|
||||||
var # Several, with or without type annotations
|
var # Several, with or without type annotations
|
||||||
letter: char = 'n' # One byte character
|
letter: char = 'n' # One byte character
|
||||||
name = "Nimrod" # string
|
lang = "Nimrod" # string
|
||||||
truth: bool = false # Common boolean operators: `and` `not` `or`
|
truth: bool = false # Common boolean operators: `and` `not` `or`
|
||||||
seconds: int = 42
|
seconds: int = 42
|
||||||
thoughts = """
|
thoughts = """
|
||||||
@ -54,8 +54,9 @@ multiline comment
|
|||||||
# Common Operations on Basic Types
|
# Common Operations on Basic Types
|
||||||
#
|
#
|
||||||
|
|
||||||
var nim = "Nimrod is a progamming language"
|
let
|
||||||
name = nim[0..5]
|
phrase = "Nim is a progamming language"
|
||||||
|
nim = phrase[0..5]
|
||||||
|
|
||||||
# TODO More common operations?
|
# TODO More common operations?
|
||||||
|
|
||||||
@ -91,6 +92,9 @@ type
|
|||||||
Name = string # A type alias gives you a new type that is interchangable
|
Name = string # A type alias gives you a new type that is interchangable
|
||||||
Age = int # with the old type but is more descriptive.
|
Age = int # with the old type but is more descriptive.
|
||||||
Person = tuple[name: Name, age: Age] # Define data structures too.
|
Person = tuple[name: Name, age: Age] # Define data structures too.
|
||||||
|
LongTuple = tuple
|
||||||
|
fieldOne: string
|
||||||
|
secondField: int
|
||||||
|
|
||||||
var
|
var
|
||||||
john: Person = ("John B.", 17)
|
john: Person = ("John B.", 17)
|
||||||
@ -104,11 +108,11 @@ type
|
|||||||
|
|
||||||
var
|
var
|
||||||
money: Cash = 100.Cash # `.Cash` converts the int to our type
|
money: Cash = 100.Cash # `.Cash` converts the int to our type
|
||||||
desc: Desc = "Interesting".Desc
|
description: Desc = "Interesting".Desc
|
||||||
|
|
||||||
when compileBadCode:
|
when compileBadCode:
|
||||||
john.age = money # Error! age is of type int and money is Cash
|
john.age = money # Error! age is of type int and money is Cash
|
||||||
john.name = desc # Compiler says: "No way!"
|
john.name = description # Compiler says: "No way!"
|
||||||
|
|
||||||
#
|
#
|
||||||
# More Types and Data Structures
|
# More Types and Data Structures
|
||||||
@ -117,13 +121,17 @@ when compileBadCode:
|
|||||||
# Enumerations allow a type to be one of a limited number of values
|
# Enumerations allow a type to be one of a limited number of values
|
||||||
|
|
||||||
type
|
type
|
||||||
Directions = enum north, west, east, south
|
Color = enum cRed, cBlue, cGreen
|
||||||
Colors = enum red, blue, green
|
Direction = enum # Alternative formating
|
||||||
|
dNorth
|
||||||
|
dWest
|
||||||
|
dEast
|
||||||
|
dSouth
|
||||||
var
|
var
|
||||||
orient = north # `orient` is of type Directions, with the value `north`
|
orient = dNorth # `orient` is of type Direction, with the value `dNorth`
|
||||||
pixel = green # `pixel` is of type Colors, with the value `green`
|
pixel = cGreen # `pixel` is of type Color, with the value `cGreen`
|
||||||
|
|
||||||
discard north > east # Enums are usually an "ordinal" type
|
discard dNorth > dEast # Enums are usually an "ordinal" type
|
||||||
|
|
||||||
# Subranges specify a limited valid range
|
# Subranges specify a limited valid range
|
||||||
|
|
||||||
@ -139,22 +147,22 @@ when compileBadCode:
|
|||||||
|
|
||||||
type
|
type
|
||||||
RollCounter = array[DieFaces, int] # Array's are fixed length and
|
RollCounter = array[DieFaces, int] # Array's are fixed length and
|
||||||
DirNames = array[Directions, string] # indexed by any ordinal type.
|
DirNames = array[Direction, string] # indexed by any ordinal type.
|
||||||
Truths = array[42..44, bool]
|
Truths = array[42..44, bool]
|
||||||
var
|
var
|
||||||
rollCounter: RollCounter
|
counter: RollCounter
|
||||||
directions: DirNames
|
directions: DirNames
|
||||||
truths: Truths
|
possible: Truths
|
||||||
|
|
||||||
truths = [false, false, false] # Literal arrays are created with [V1,..,Vn]
|
possible = [false, false, false] # Literal arrays are created with [V1,..,Vn]
|
||||||
truths[42] = true
|
possible[42] = true
|
||||||
|
|
||||||
directions[north] = "Ahh. The Great White North!"
|
directions[dNorth] = "Ahh. The Great White North!"
|
||||||
directions[west] = "No, don't go there."
|
directions[dWest] = "No, don't go there."
|
||||||
|
|
||||||
my_roll = 13
|
my_roll = 13
|
||||||
rollCounter[my_roll] += 1
|
counter[my_roll] += 1
|
||||||
rollCounter[my_roll] += 1
|
counter[my_roll] += 1
|
||||||
|
|
||||||
var anotherArray = ["Default index", "starts at", "0"]
|
var anotherArray = ["Default index", "starts at", "0"]
|
||||||
|
|
||||||
@ -180,10 +188,10 @@ else:
|
|||||||
import strutils as str
|
import strutils as str
|
||||||
echo "I'm thinking of a number between 41 and 43. Guess which!"
|
echo "I'm thinking of a number between 41 and 43. Guess which!"
|
||||||
var
|
var
|
||||||
answer: int = 42
|
number: int = 42
|
||||||
raw_guess: string
|
raw_guess: string
|
||||||
guess: int
|
guess: int
|
||||||
while guess != answer:
|
while guess != number:
|
||||||
raw_guess = readLine(stdin)
|
raw_guess = readLine(stdin)
|
||||||
if raw_guess == "":
|
if raw_guess == "":
|
||||||
continue # `continue` restarts loop/block
|
continue # `continue` restarts loop/block
|
||||||
@ -191,9 +199,9 @@ while guess != answer:
|
|||||||
if guess == 1001:
|
if guess == 1001:
|
||||||
echo("AAAAAAGGG!")
|
echo("AAAAAAGGG!")
|
||||||
break
|
break
|
||||||
elif guess > answer:
|
elif guess > number:
|
||||||
echo("Too high.")
|
echo("Too high.")
|
||||||
elif guess < answer:
|
elif guess < number:
|
||||||
echo("Too low")
|
echo("Too low")
|
||||||
else:
|
else:
|
||||||
echo("Yeeeeeehaw!")
|
echo("Yeeeeeehaw!")
|
||||||
@ -223,16 +231,16 @@ for line in splitLines(myString):
|
|||||||
# Procedures
|
# Procedures
|
||||||
#
|
#
|
||||||
|
|
||||||
type Answer = enum yes, no
|
type Answer = enum aYes, aNo
|
||||||
|
|
||||||
proc ask(question: string): Answer =
|
proc ask(question: string): Answer =
|
||||||
echo(question, " (y/n)")
|
echo(question, " (y/n)")
|
||||||
while true:
|
while true:
|
||||||
case readLine(stdin)
|
case readLine(stdin)
|
||||||
of "y", "Y", "yes", "Yes":
|
of "y", "Y", "yes", "Yes":
|
||||||
return Answer.yes # Enums can be qualified
|
return Answer.aYes # Enums can be qualified
|
||||||
of "n", "N", "no", "No":
|
of "n", "N", "no", "No":
|
||||||
return Answer.no
|
return Answer.aNo
|
||||||
else: echo("Please be clear: yes or no")
|
else: echo("Please be clear: yes or no")
|
||||||
|
|
||||||
proc addSugar(amount: int = 2) = # Default amount is 2, returns nothing
|
proc addSugar(amount: int = 2) = # Default amount is 2, returns nothing
|
||||||
@ -240,9 +248,9 @@ proc addSugar(amount: int = 2) = # Default amount is 2, returns nothing
|
|||||||
echo a, " sugar..."
|
echo a, " sugar..."
|
||||||
|
|
||||||
case ask("Would you like sugar in your tea?")
|
case ask("Would you like sugar in your tea?")
|
||||||
of yes:
|
of aYes:
|
||||||
addSugar(3)
|
addSugar(3)
|
||||||
of no:
|
of aNo:
|
||||||
echo "Oh do take a little!"
|
echo "Oh do take a little!"
|
||||||
addSugar()
|
addSugar()
|
||||||
# No need for an `else` here. only `yes` and `no` are possible.
|
# No need for an `else` here. only `yes` and `no` are possible.
|
||||||
|
Loading…
Reference in New Issue
Block a user