Skip to content

Commit

Permalink
fixes #7167 (#11300)
Browse files Browse the repository at this point in the history
* fixes #7167
* spec: distinct types can be ordinal types
* bootstrapping issue
  • Loading branch information
Araq authored May 22, 2019
1 parent 57bc8d7 commit 1e97b42
Show file tree
Hide file tree
Showing 4 changed files with 23 additions and 4 deletions.
3 changes: 1 addition & 2 deletions compiler/semexprs.nim
Original file line number Diff line number Diff line change
Expand Up @@ -338,8 +338,7 @@ proc semLowHigh(c: PContext, n: PNode, m: TMagic): PNode =
of tyArray:
n.typ = typ.sons[0] # indextype
of tyInt..tyInt64, tyChar, tyBool, tyEnum, tyUInt8, tyUInt16, tyUInt32, tyFloat..tyFloat64:
# do not skip the range!
n.typ = n.sons[1].typ.skipTypes(abstractVar)
n.typ = n.sons[1].typ.skipTypes({tyTypeDesc})
of tyGenericParam:
# prepare this for resolving in semtypinst:
# we must use copyTree here in order to avoid creating a cycle
Expand Down
7 changes: 6 additions & 1 deletion doc/manual.rst
Original file line number Diff line number Diff line change
Expand Up @@ -827,7 +827,10 @@ Ordinal types have the following characteristics:

Integers, bool, characters and enumeration types (and subranges of these
types) belong to ordinal types. For reasons of simplicity of implementation
the types ``uint`` and ``uint64`` are not ordinal types.
the types ``uint`` and ``uint64`` are not ordinal types. (This will be changed
in later versions of the language.)

A distinct type is an ordinal type if its base type is an ordinal type.


Pre-defined integer types
Expand Down Expand Up @@ -1801,6 +1804,8 @@ and its base type. Explicit type conversions from a distinct type to its
base type and vice versa are allowed. See also ``distinctBase`` to get the
reverse operation.

A distinct type is an ordinal type if its base type is an ordinal type.


Modelling currencies
~~~~~~~~~~~~~~~~~~~~
Expand Down
2 changes: 1 addition & 1 deletion lib/pure/times.nim
Original file line number Diff line number Diff line change
Expand Up @@ -1102,7 +1102,7 @@ else:

# In case of a 32-bit time_t, we fallback to the closest available
# timezone information.
var a = clamp(unix, low(CTime), high(CTime)).CTime
var a = clamp(unix, low(CTime).int64, high(CTime).int64).CTime
let tmPtr = localtime(a)
if not tmPtr.isNil:
let tm = tmPtr[]
Expand Down
15 changes: 15 additions & 0 deletions tests/distinct/tdistinct.nim
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,10 @@ discard """
output: '''
tdistinct
25
false
false
false
false
'''
"""

Expand Down Expand Up @@ -83,3 +87,14 @@ type
const d: DistTup = DistTup((
foo:"FOO", bar:"BAR"
))


# bug #7167

type Id = distinct range[0..3]

proc `<=`(a, b: Id): bool {.borrow.}

var xs: array[Id, bool]

for x in xs: echo x # type mismatch: got (T) but expected 'bool'

0 comments on commit 1e97b42

Please sign in to comment.