mirror of
https://github.com/nim-lang/Nim.git
synced 2026-04-19 14:00:35 +00:00
fixes yet another option type
This commit is contained in:
@@ -113,12 +113,18 @@ proc pickMaxInt(n: PNode): BiggestInt =
|
||||
internalError(n.info, "pickMaxInt")
|
||||
|
||||
proc makeRange(typ: PType, first, last: BiggestInt): PType =
|
||||
var n = newNode(nkRange)
|
||||
addSon(n, newIntNode(nkIntLit, min(first, last)))
|
||||
addSon(n, newIntNode(nkIntLit, max(first, last)))
|
||||
result = newType(tyRange, typ.owner)
|
||||
result.n = n
|
||||
addSonSkipIntLit(result, skipTypes(typ, {tyRange}))
|
||||
let minA = min(first, last)
|
||||
let maxA = max(first, last)
|
||||
let lowerNode = newIntNode(nkIntLit, minA)
|
||||
if typ.kind == tyInt and minA == maxA:
|
||||
result = getIntLitType(lowerNode)
|
||||
else:
|
||||
var n = newNode(nkRange)
|
||||
addSon(n, lowerNode)
|
||||
addSon(n, newIntNode(nkIntLit, maxA))
|
||||
result = newType(tyRange, typ.owner)
|
||||
result.n = n
|
||||
addSonSkipIntLit(result, skipTypes(typ, {tyRange}))
|
||||
|
||||
proc makeRangeF(typ: PType, first, last: BiggestFloat): PType =
|
||||
var n = newNode(nkRange)
|
||||
|
||||
@@ -385,8 +385,8 @@ proc mutateType(t: PType, iter: TTypeMutator, closure: PObject): PType =
|
||||
|
||||
proc valueToString(a: PNode): string =
|
||||
case a.kind
|
||||
of nkCharLit..nkUInt64Lit: result = $(a.intVal)
|
||||
of nkFloatLit..nkFloat128Lit: result = $(a.floatVal)
|
||||
of nkCharLit..nkUInt64Lit: result = $a.intVal
|
||||
of nkFloatLit..nkFloat128Lit: result = $a.floatVal
|
||||
of nkStrLit..nkTripleStrLit: result = a.strVal
|
||||
else: result = "<invalid value>"
|
||||
|
||||
|
||||
47
tests/objvariant/tyaoption.nim
Normal file
47
tests/objvariant/tyaoption.nim
Normal file
@@ -0,0 +1,47 @@
|
||||
discard """
|
||||
output: '''some(str), some(5), none
|
||||
some(5!)
|
||||
some(10)'''
|
||||
"""
|
||||
|
||||
import strutils
|
||||
|
||||
type Option[A] = object
|
||||
case isDefined*: Bool
|
||||
of true:
|
||||
value*: A
|
||||
of false:
|
||||
nil
|
||||
|
||||
proc some[A](value: A): Option[A] =
|
||||
Option[A](isDefined: true, value: value)
|
||||
|
||||
proc none[A](): Option[A] =
|
||||
Option[A](isDefined: false)
|
||||
|
||||
proc `$`[A](o: Option[A]): String =
|
||||
if o.isDefined:
|
||||
"some($1)" % [$o.value]
|
||||
else:
|
||||
"none"
|
||||
|
||||
let x = some("str")
|
||||
let y = some(5)
|
||||
let z = none[Int]()
|
||||
|
||||
echo x, ", ", y, ", ", z
|
||||
|
||||
proc intOrString[A : Int | String](o: Option[A]): Option[A] =
|
||||
when A is Int:
|
||||
some(o.value + 5)
|
||||
elif A is String:
|
||||
some(o.value & "!")
|
||||
else:
|
||||
o
|
||||
|
||||
#let a1 = intOrString(none[String]())
|
||||
let a2 = intOrString(some("5"))
|
||||
let a3 = intOrString(some(5))
|
||||
#echo a1
|
||||
echo a2
|
||||
echo a3
|
||||
Reference in New Issue
Block a user