Skip to content

Commit

Permalink
make system/fatal importable (nim-lang#20719)
Browse files Browse the repository at this point in the history
  • Loading branch information
ringabout authored Nov 1, 2022
1 parent 49e793e commit d735c44
Show file tree
Hide file tree
Showing 3 changed files with 15 additions and 16 deletions.
3 changes: 1 addition & 2 deletions lib/std/assertions.nim
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,7 @@

## This module implements assertion handling.

when not declared(sysFatal):
include "system/fatal"
import system/fatal

import std/private/miscdollars
# ---------------------------------------------------------------------------
Expand Down
9 changes: 7 additions & 2 deletions lib/system.nim
Original file line number Diff line number Diff line change
Expand Up @@ -1637,8 +1637,13 @@ when not defined(nimscript):
## for debug builds. Since it's usually used for debugging, this
## is proclaimed to have no IO effect!

when not declared(sysFatal):
include "system/fatal"

when defined(nimHasExceptionsQuery):
const gotoBasedExceptions = compileOption("exceptions", "goto")
else:
const gotoBasedExceptions = false

import system/fatal

when not defined(nimscript):
{.push stackTrace: off, profiler: off.}
Expand Down
19 changes: 7 additions & 12 deletions lib/system/fatal.nim
Original file line number Diff line number Diff line change
Expand Up @@ -9,27 +9,22 @@

{.push profiler: off.}

when defined(nimHasExceptionsQuery):
const gotoBasedExceptions = compileOption("exceptions", "goto")
else:
const gotoBasedExceptions = false

when hostOS == "standalone":
include "$projectpath/panicoverride"

func sysFatal(exceptn: typedesc, message: string) {.inline.} =
func sysFatal*(exceptn: typedesc, message: string) {.inline.} =
panic(message)

func sysFatal(exceptn: typedesc, message, arg: string) {.inline.} =
func sysFatal*(exceptn: typedesc, message, arg: string) {.inline.} =
rawoutput(message)
panic(arg)

elif (defined(nimQuirky) or defined(nimPanics)) and not defined(nimscript):
import ansi_c
import system/ansi_c

func name(t: typedesc): string {.magic: "TypeTrait".}

func sysFatal(exceptn: typedesc, message, arg: string) {.inline, noreturn.} =
func sysFatal*(exceptn: typedesc, message, arg: string) {.inline, noreturn.} =
when nimvm:
# TODO when doAssertRaises works in CT, add a test for it
raise (ref exceptn)(msg: message & arg)
Expand All @@ -46,14 +41,14 @@ elif (defined(nimQuirky) or defined(nimPanics)) and not defined(nimscript):
cstderr.rawWrite buf
quit 1

func sysFatal(exceptn: typedesc, message: string) {.inline, noreturn.} =
func sysFatal*(exceptn: typedesc, message: string) {.inline, noreturn.} =
sysFatal(exceptn, message, "")

else:
func sysFatal(exceptn: typedesc, message: string) {.inline, noreturn.} =
func sysFatal*(exceptn: typedesc, message: string) {.inline, noreturn.} =
raise (ref exceptn)(msg: message)

func sysFatal(exceptn: typedesc, message, arg: string) {.inline, noreturn.} =
func sysFatal*(exceptn: typedesc, message, arg: string) {.inline, noreturn.} =
raise (ref exceptn)(msg: message & arg)

{.pop.}

0 comments on commit d735c44

Please sign in to comment.