summary refs log tree commit diff stats
path: root/compiler
diff options
context:
space:
mode:
authorAndreas Rumpf <rumpf_a@web.de>2014-07-01 03:00:38 +0200
committerAndreas Rumpf <rumpf_a@web.de>2014-07-01 03:00:38 +0200
commit0eda72e1d2345b9050dcbe22ec17baacafc66cbb (patch)
tree3d25f16da0bbd42df0f2516d9b099955634800ae /compiler
parentb1c5dc1ef937f42ff10ef6256684448c79647775 (diff)
parent55e7d91b317444d874b3ce88c44536842ef0821b (diff)
downloadNim-0eda72e1d2345b9050dcbe22ec17baacafc66cbb.tar.gz
Merge pull request #1304 from rbehrends/fix-packagenames
Fix generation of package-dependent init names.
Diffstat (limited to 'compiler')
-rw-r--r--compiler/cgen.nim1
-rw-r--r--compiler/modules.nim2
2 files changed, 2 insertions, 1 deletions
diff --git a/compiler/cgen.nim b/compiler/cgen.nim
index a5852c735..e2f3b5ab0 100644
--- a/compiler/cgen.nim
+++ b/compiler/cgen.nim
@@ -1050,6 +1050,7 @@ proc getSomeInitName(m: PSym, suffix: string): PRope =
   assert m.owner.kind == skPackage
   if {sfSystemModule, sfMainModule} * m.flags == {}:
     result = m.owner.name.s.mangle.toRope
+    result.app "_"
   result.app m.name.s
   result.app suffix
   
diff --git a/compiler/modules.nim b/compiler/modules.nim
index fb1940741..b102224cd 100644
--- a/compiler/modules.nim
+++ b/compiler/modules.nim
@@ -115,7 +115,7 @@ proc newModule(fileIdx: int32): PSym =
   new(result)
   result.id = - 1             # for better error checking
   result.kind = skModule
-  let filename = fileIdx.toFilename
+  let filename = fileIdx.toFullPath
   result.name = getIdent(splitFile(filename).name)
   if not isNimrodIdentifier(result.name.s):
     rawMessage(errInvalidModuleName, result.name.s)