mirror of
https://github.com/nim-lang/Nim.git
synced 2026-02-16 08:04:20 +00:00
@@ -1613,10 +1613,8 @@ proc semDefined(c: PContext, n: PNode, onlyCurrentScope: bool): PNode =
|
||||
# we replace this node by a 'true' or 'false' node:
|
||||
result = newIntNode(nkIntLit, 0)
|
||||
if not onlyCurrentScope and considerQuotedIdent(c.config, n[0], n).s == "defined":
|
||||
if n.sons[1].kind != nkIdent:
|
||||
localError(c.config, n.info, "obsolete usage of 'defined', use 'declared' instead")
|
||||
elif isDefined(c.config, n.sons[1].ident.s):
|
||||
result.intVal = 1
|
||||
let d = considerQuotedIdent(c.config, n[1], n)
|
||||
result.intVal = ord isDefined(c.config, d.s)
|
||||
elif lookUpForDefined(c, n.sons[1], onlyCurrentScope) != nil:
|
||||
result.intVal = 1
|
||||
result.info = n.info
|
||||
|
||||
46
tests/template/tdefined_overload.nim
Normal file
46
tests/template/tdefined_overload.nim
Normal file
@@ -0,0 +1,46 @@
|
||||
discard """
|
||||
output: "Valid and not defined"
|
||||
"""
|
||||
# test for issue #7997
|
||||
# checking for `when not defined` in a template for some compile time symbol
|
||||
# results in a compilation error of:
|
||||
# Error: obsolete usage of 'defined', use 'declared' instead
|
||||
# if the symbol is 'overloaded' by some variable or procedure, because in
|
||||
# that case the argument of `defined` is of kind `nkSym` instead of `nkIdent`
|
||||
# (for which was checked in `semexprs.semDefined`).
|
||||
|
||||
block:
|
||||
# check whether a proc with the same name as the argument to `defined`
|
||||
# compiles
|
||||
proc overloaded() =
|
||||
discard
|
||||
|
||||
template definedCheck(): untyped =
|
||||
when not defined(overloaded): true
|
||||
else: false
|
||||
doAssert definedCheck == true
|
||||
|
||||
block:
|
||||
# check whether a variable with the same name as the argument to `defined`
|
||||
# compiles
|
||||
var overloaded: int
|
||||
|
||||
template definedCheck(): untyped =
|
||||
when not defined(overloaded): true
|
||||
else: false
|
||||
doAssert definedCheck == true
|
||||
|
||||
block:
|
||||
# check whether a non overloaded when check still works properly
|
||||
when not defined(validIdentifier):
|
||||
echo "Valid and not defined"
|
||||
|
||||
block:
|
||||
# now check that invalid identifiers cause a compilation error
|
||||
# by using reject template.
|
||||
template reject(b) =
|
||||
static: doAssert(not compiles(b))
|
||||
|
||||
reject:
|
||||
when defined(123):
|
||||
echo "Invalid identifier! Will not be echoed"
|
||||
Reference in New Issue
Block a user