Files
Nim/tests/int/tarithm.nim
Copilot 47d3fb28bd Resolve merge conflicts with devel branch refactoring (#25423)
The PR branch had merge conflicts with `devel` due to a major compiler
refactoring that extracted type definitions from `compiler/ast.nim` into
a new `compiler/astdef.nim` file.

## Changes

- Resolved conflict in `compiler/ast.nim` by accepting `devel`'s
refactored structure
- Merged 763 commits from `devel` branch (commit range:
`ce6a345..b3273e7`)
- Preserved original PR changes removing deprecated symbols from
`lib/core/macros.nim`

The core PR functionality (removal of deprecated macros API since
v0.18.1) remains intact while incorporating the upstream AST
refactoring.

<!-- START COPILOT CODING AGENT TIPS -->
---

💡 You can make Copilot smarter by setting up custom instructions,
customizing its development environment and configuring Model Context
Protocol (MCP) servers. Learn more [Copilot coding agent
tips](https://gh.io/copilot-coding-agent-tips) in the docs.

---------

Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com>
Co-authored-by: ringabout <43030857+ringabout@users.noreply.github.com>
2026-01-09 20:06:36 +08:00

253 lines
6.3 KiB
Nim

discard """
output: '''
int32
int32
1280
1280
3
1
2
2
3
4294967295
2
0
tUnsignedOps OK
'''
targets: "c cpp js"
nimout: "tUnsignedOps OK"
"""
import typetraits
block tand:
# bug #5216
echo(name typeof((0x0A'i8 and 0x7F'i32) shl 7'i32))
let i8 = 0x0A'i8
echo(name typeof((i8 and 0x7F'i32) shl 7'i32))
echo((0x0A'i8 and 0x7F'i32) shl 7'i32)
let ii8 = 0x0A'i8
echo((ii8 and 0x7F'i32) shl 7'i32)
block tcast:
template crossCheck(ty: untyped, exp: untyped) =
let rt = ty(exp)
const ct = ty(exp)
if $rt != $ct:
echo astToStr(exp)
echo "Got ", ct
echo "Expected ", rt
template add1(x: uint8): untyped = x + 1
template add1(x: uint16): untyped = x + 1
template add1(x: uint32): untyped = x + 1
template sub1(x: uint8): untyped = x - 1
template sub1(x: uint16): untyped = x - 1
template sub1(x: uint32): untyped = x - 1
crossCheck(int8, 0'i16 - 5'i16)
crossCheck(int16, 0'i32 - 5'i32)
crossCheck(int32, 0'i64 - 5'i64)
crossCheck(uint8, 0'u8 - 5'u8)
crossCheck(uint16, 0'u16 - 5'u16)
crossCheck(uint32, 0'u32 - 5'u32)
crossCheck(uint64, 0'u64 - 5'u64)
crossCheck(uint8, uint8.high + 5'u8)
crossCheck(uint16, uint16.high + 5'u16)
crossCheck(uint32, uint32.high + 5'u32)
crossCheck(uint64, 0xFFFFFFFFFFFFFFFF'u64 + 5'u64)
crossCheck(uint64, uint64.high + 5'u64)
doAssert $sub1(0'u8) == "255"
doAssert $sub1(0'u16) == "65535"
doAssert $sub1(0'u32) == "4294967295"
doAssert $add1(255'u8) == "0"
doAssert $add1(65535'u16) == "0"
doAssert $add1(4294967295'u32) == "0"
crossCheck(int32, high(int32))
crossCheck(int32, high(int32).int32)
crossCheck(int32, low(int32))
crossCheck(int32, low(int32).int32)
crossCheck(int64, high(int8).int16.int32.int64)
crossCheck(int64, low(int8).int16.int32.int64)
doAssert not compiles(echo int64(0xFFFFFFFFFFFFFFFF'u64))
doAssert not compiles(echo int32(0xFFFFFFFFFFFFFFFF'u64))
doAssert not compiles(echo int16(0xFFFFFFFFFFFFFFFF'u64))
doAssert not compiles(echo int8(0xFFFFFFFFFFFFFFFF'u64))
block tnot:
# Signed types
block:
const t0: int8 = not 4
const t1: int16 = not 4
const t2: int32 = not 4
const t3: int64 = not 4
const t4: int8 = not -5
const t5: int16 = not -5
const t6: int32 = not -5
const t7: int64 = not -5
doAssert t0 == -5
doAssert t1 == -5
doAssert t2 == -5
doAssert t3 == -5
doAssert t4 == 4
doAssert t5 == 4
doAssert t6 == 4
doAssert t7 == 4
# Unsigned types
block:
const t0: uint8 = not 4'u8
const t1: uint16 = not 4'u16
const t2: uint32 = not 4'u32
const t3: uint64 = not 4'u64
const t4: uint8 = not 251'u8
const t5: uint16 = not 65531'u16
const t6: uint32 = not 4294967291'u32
const t7: uint64 = not 18446744073709551611'u64
doAssert t0 == 251
doAssert t1 == 65531
doAssert t2 == 4294967291'u32
doAssert t3 == 18446744073709551611'u64
doAssert t4 == 4
doAssert t5 == 4
doAssert t6 == 4
doAssert t7 == 4
block tshr:
proc T() =
# let VI = -8
let VI64 = -8'i64
let VI32 = -8'i32
let VI16 = -8'i16
let VI8 = -8'i8
# doAssert( (VI shr 1) == 9_223_372_036_854_775_804, "Actual: " & $(VI shr 1))
doAssert( (VI64 shr 1) == -4, "Actual: " & $(VI64 shr 1))
doAssert( (VI32 shr 1) == -4, "Actual: " & $(VI32 shr 1))
doAssert( (VI16 shr 1) == -4, "Actual: " & $(VI16 shr 1))
doAssert( (VI8 shr 1) == -4, "Actual: " & $(VI8 shr 1))
T()
static:
T()
block tsubrange:
# bug #5854
type
n16 = range[0'i16..high(int16)]
var level: n16 = 1
let maxLevel: n16 = 1
level = min(level + 2, maxLevel).n16
doAssert level == 1
block tissue12177:
var a: uint16 = 1
var b: uint32 = 2
echo(b + a)
echo(b - a)
echo(b * a)
echo(b div a)
echo(a + b)
echo(a - b)
echo(a * b)
echo(a div b)
block tUnsignedOps:
proc testUnsignedOps() =
let a: int8 = -128
let b: int8 = 127
doAssert b +% 1 == -128
doAssert b -% -1 == -128
doAssert b *% 2 == -2
doAssert a /% 4 == 32
doAssert a %% 7 == 2
echo "tUnsignedOps OK"
testUnsignedOps()
static:
testUnsignedOps()
block tshl:
# Signed types
block:
const t0: int8 = 1'i8 shl 8
const t1: int16 = 1'i16 shl 16
const t2: int32 = 1'i32 shl 32
const t3: int64 = 1'i64 shl 64
doAssert t0 == 1
doAssert t1 == 1
doAssert t2 == 1
doAssert t3 == 1
# Unsigned types
block:
const t0: uint8 = 1'u8 shl 8
const t1: uint16 = 1'u16 shl 16
const t2: uint32 = 1'u32 shl 32
const t3: uint64 = 1'u64 shl 64
doAssert t0 == 1
doAssert t1 == 1
doAssert t2 == 1
doAssert t3 == 1
block bitmaking:
# test semfold (single expression)
doAssert (0x10'i8 shr 2) == (0x10'i8 shr 0b1010_1010)
doAssert (0x10'u8 shr 2) == (0x10'u8 shr 0b0101_1010)
doAssert (0x10'i16 shr 2) == (0x10'i16 shr 0b1011_0010)
doAssert (0x10'u16 shr 2) == (0x10'u16 shr 0b0101_0010)
doAssert (0x10'i32 shr 2) == (0x10'i32 shr 0b1010_0010)
doAssert (0x10'u32 shr 2) == (0x10'u32 shr 0b0110_0010)
doAssert (0x10'i64 shr 2) == (0x10'i32 shr 0b1100_0010)
doAssert (0x10'u64 shr 2) == (0x10'u32 shr 0b0100_0010)
doAssert (0x10'i8 shl 2) == (0x10'i8 shl 0b1010_1010)
doAssert (0x10'u8 shl 2) == (0x10'u8 shl 0b0101_1010)
doAssert (0x10'i16 shl 2) == (0x10'i16 shl 0b1011_0010)
doAssert (0x10'u16 shl 2) == (0x10'u16 shl 0b0101_0010)
doAssert (0x10'i32 shl 2) == (0x10'i32 shl 0b1010_0010)
doAssert (0x10'u32 shl 2) == (0x10'u32 shl 0b0110_0010)
doAssert (0x10'i64 shl 2) == (0x10'i32 shl 0b1100_0010)
doAssert (0x10'u64 shl 2) == (0x10'u32 shl 0b0100_0010)
proc testVmAndBackend[T: SomeInteger](a: T, b1, b2: int) {.sideeffect.} =
# this echo is to cause a side effect and therefore ensure this
# proc isn't evaluated at compile time when it should not.
doAssert((a shr b1) == (a shr b2))
doAssert((a shl b1) == (a shl b2))
proc callTestVmAndBackend() =
testVmAndBackend(0x10'i8, 2, 0b1010_1010)
testVmAndBackend(0x10'u8, 2, 0b0101_1010)
testVmAndBackend(0x10'i16, 2, 0b1011_0010)
testVmAndBackend(0x10'u16, 2, 0b0101_0010)
testVmAndBackend(0x10'i32, 2, 0b1010_0010)
testVmAndBackend(0x10'u32, 2, 0b0110_0010)
testVmAndBackend(0x10'i64, 2, 0b1100_0010)
testVmAndBackend(0x10'u64, 2, 0b0100_0010)
callTestVmAndBackend() # test at runtime
static:
callTestVmAndBackend() # test at compiletime