summary refs log tree commit diff stats
path: root/compiler
diff options
context:
space:
mode:
authorASVIEST <71895914+ASVIEST@users.noreply.github.com>2023-12-12 11:05:00 +0300
committerGitHub <noreply@github.com>2023-12-12 09:05:00 +0100
commitcf4cef498489f1dbbb3dea287e88a9a0d820e8b7 (patch)
tree1b2015874980f26a4ab8381e498fe7d9ac955e7f /compiler
parent0a7094450ec059e10da67d47a76d004d4972b368 (diff)
downloadNim-cf4cef498489f1dbbb3dea287e88a9a0d820e8b7.tar.gz
Ast stmt now saves its ast structure in the compiler (#23053)
see https://github.com/nim-lang/Nim/issues/23052

---------

Co-authored-by: Andreas Rumpf <rumpf_a@web.de>
Diffstat (limited to 'compiler')
-rw-r--r--compiler/ccgstmts.nim7
-rw-r--r--compiler/pragmas.nim2
2 files changed, 8 insertions, 1 deletions
diff --git a/compiler/ccgstmts.nim b/compiler/ccgstmts.nim
index 45a234332..c3d44c1d3 100644
--- a/compiler/ccgstmts.nim
+++ b/compiler/ccgstmts.nim
@@ -1489,7 +1489,12 @@ proc genTrySetjmp(p: BProc, t: PNode, d: var TLoc) =
 
 proc genAsmOrEmitStmt(p: BProc, t: PNode, isAsmStmt=false; result: var Rope) =
   var res = ""
-  for it in t.sons:
+  let offset =
+    if isAsmStmt: 1 # first son is pragmas
+    else: 0
+
+  for i in offset..<t.len:
+    let it = t[i]
     case it.kind
     of nkStrLit..nkTripleStrLit:
       res.add(it.strVal)
diff --git a/compiler/pragmas.nim b/compiler/pragmas.nim
index 0e434e6f7..35b4d63c2 100644
--- a/compiler/pragmas.nim
+++ b/compiler/pragmas.nim
@@ -599,6 +599,7 @@ proc semAsmOrEmit*(con: PContext, n: PNode, marker: char): PNode =
   case n[1].kind
   of nkStrLit, nkRStrLit, nkTripleStrLit:
     result = newNodeI(if n.kind == nkAsmStmt: nkAsmStmt else: nkArgList, n.info)
+    if n.kind == nkAsmStmt: result.add n[0] # save asm pragmas for NIR
     var str = n[1].strVal
     if str == "":
       localError(con.config, n.info, "empty 'asm' statement")
@@ -630,6 +631,7 @@ proc semAsmOrEmit*(con: PContext, n: PNode, marker: char): PNode =
   else:
     illFormedAstLocal(n, con.config)
     result = newNodeI(nkAsmStmt, n.info)
+    if n.kind == nkAsmStmt: result.add n[0]
 
 proc pragmaEmit(c: PContext, n: PNode) =
   if n.kind notin nkPragmaCallKinds or n.len != 2: