diff options
author | Araq <rumpf_a@web.de> | 2019-04-17 13:22:12 +0200 |
---|---|---|
committer | Araq <rumpf_a@web.de> | 2019-04-17 13:22:22 +0200 |
commit | 5bdab044f5c252b3e97595f87861adc58238352a (patch) | |
tree | 678540827f91bb090ad99f9ee47aeb5bf90eecad /compiler | |
parent | 14fc7437c330f36d19bc4ee707c8102f6f6bb190 (diff) | |
download | Nim-5bdab044f5c252b3e97595f87861adc58238352a.tar.gz |
fixes #11048
Diffstat (limited to 'compiler')
-rw-r--r-- | compiler/ccgexprs.nim | 9 | ||||
-rw-r--r-- | compiler/ccgliterals.nim | 4 |
2 files changed, 3 insertions, 10 deletions
diff --git a/compiler/ccgexprs.nim b/compiler/ccgexprs.nim index baf51a8f2..9f4d57359 100644 --- a/compiler/ccgexprs.nim +++ b/compiler/ccgexprs.nim @@ -808,18 +808,15 @@ proc genFieldCheck(p: BProc, e: PNode, obj: Rope, field: PSym) = v.r.add(".") v.r.add(disc.sym.loc.r) genInExprAux(p, it, u, v, test) - let id = nodeTableTestOrSet(p.module.dataCache, - newStrNode(nkStrLit, field.name.s), p.module.labels) - let strLit = if id == p.module.labels: genStringLiteralDataOnly(p.module, field.name.s, e.info) - else: p.module.tmpBase & rope(id) + let strLit = genStringLiteral(p.module, newStrNode(nkStrLit, field.name.s)) if op.magic == mNot: linefmt(p, cpsStmts, "if ($1) #raiseFieldError($2);$n", - [rdLoc(test), genStringLiteralFromData(p.module, strLit, e.info)]) + [rdLoc(test), strLit]) else: linefmt(p, cpsStmts, "if (!($1)) #raiseFieldError($2);$n", - [rdLoc(test), genStringLiteralFromData(p.module, strLit, e.info)]) + [rdLoc(test), strLit]) proc genCheckedRecordField(p: BProc, e: PNode, d: var TLoc) = if optFieldCheck in p.options: diff --git a/compiler/ccgliterals.nim b/compiler/ccgliterals.nim index f5372f050..da3668028 100644 --- a/compiler/ccgliterals.nim +++ b/compiler/ccgliterals.nim @@ -97,10 +97,6 @@ proc genStringLiteralDataOnly(m: BModule; s: string; info: TLineInfo): Rope = else: localError(m.config, info, "cannot determine how to produce code for string literal") -proc genStringLiteralFromData(m: BModule; data: Rope; info: TLineInfo): Rope = - result = ropecg(m, "((#NimStringDesc*) &$1)", - [data]) - proc genNilStringLiteral(m: BModule; info: TLineInfo): Rope = result = ropecg(m, "((#NimStringDesc*) NIM_NIL)", []) |