Skip to content

Commit

Permalink
[CI] now enables NIM_COMPILE_TO_CPP=true to run without allow_failu…
Browse files Browse the repository at this point in the history
…res (#10315)

* better fix for `nim cpp` bootstrap error: error: no member named raise_id
* [CI] now enables runs NIM_COMPILE_TO_CPP=true without allow_failures
* workaround refs #10343
  • Loading branch information
timotheecour authored and Araq committed Jan 17, 2019
1 parent 1558487 commit 42bac52
Show file tree
Hide file tree
Showing 4 changed files with 24 additions and 11 deletions.
5 changes: 3 additions & 2 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,9 @@ matrix:
- os: osx
env: NIM_COMPILE_TO_CPP=true

allow_failures:
- env: NIM_COMPILE_TO_CPP=true
# To allow failures for a failing configuration, use something like:
# allow_failures:
# - env: NIM_COMPILE_TO_CPP=true
# - os: osx

addons:
Expand Down
21 changes: 13 additions & 8 deletions koch.nim
Original file line number Diff line number Diff line change
Expand Up @@ -281,19 +281,24 @@ proc boot(args: string) =
let smartNimcache = (if "release" in args: "nimcache/r_" else: "nimcache/d_") &
hostOs & "_" & hostCpu

copyExe(findStartNim(), 0.thVersion)
for i in 0..2+ord(useCpp):
# do the first iteration in C mode in order to avoid problem #10315:
let defaultCommand = if useCpp and i > 0: "cpp" else: "c"
let nimStart = findStartNim()
copyExe(nimStart, 0.thVersion)
for i in 0..2:
let defaultCommand = if useCpp: "cpp" else: "c"
let bootOptions = if args.len == 0 or args.startsWith("-"): defaultCommand else: ""

echo "iteration: ", i+1
let extraOption = if i == 0:
"--skipUserCfg --skipParentCfg"
var extraOption = ""
if i == 0:
extraOption.add " --skipUserCfg --skipParentCfg"
# Note(D20190115T162028:here): the configs are skipped for bootstrap
# (1st iteration) to prevent newer flags from breaking bootstrap phase.
# fixes #10030.
else: ""
let ret = execCmdEx(nimStart & " --version")
doAssert ret.exitCode == 0
let version = ret.output.splitLines[0]
if version.startsWith "Nim Compiler Version 0.19.0":
extraOption.add " -d:nimBoostrapCsources0_19_0"
# remove this when csources get updated
exec i.thVersion & " $# $# $# --nimcache:$# compiler" / "nim.nim" %
[bootOptions, extraOption, args, smartNimcache]
if sameFileContent(output, i.thVersion):
Expand Down
7 changes: 6 additions & 1 deletion lib/system.nim
Original file line number Diff line number Diff line change
Expand Up @@ -569,7 +569,12 @@ type
trace: string
else:
trace: seq[StackTraceEntry]
raiseId: uint # set when exception is raised
when defined(nimBoostrapCsources0_19_0):
# see #10315, bootstrap with `nim cpp` from csources gave error:
# error: no member named 'raise_id' in 'Exception'
raise_id: uint # set when exception is raised
else:
raiseId: uint # set when exception is raised
up: ref Exception # used for stacking exceptions. Not exported!

Defect* = object of Exception ## \
Expand Down
2 changes: 2 additions & 0 deletions tests/exception/t9657.nim
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
discard """
action: run
exitcode: 1
target: "c"
"""
# todo: remove `target: "c"` workaround once #10343 is properly fixed
close stdmsg
writeLine stdmsg, "exception!"

0 comments on commit 42bac52

Please sign in to comment.