put std/threads under the umbrella of nimPreviewSlimSystem (#20711)

* put `std/threads` under the umbrella of `nimPreviewSlimSystem`

* add changelog

* fixes tests

* fixes tests again

* fixes tests
This commit is contained in:
ringabout
2022-10-31 13:36:50 +08:00
committed by GitHub
parent fb2ec8d192
commit e1ddd2d524
13 changed files with 33 additions and 19 deletions

View File

@@ -15,6 +15,7 @@
- `std/formatfloat`
- `std/objectdollar`
- `std/widestrs`
- `std/threads`
In the future, these definitions will be removed from the `system` module,
and their respective modules will have to be imported to use them.

View File

@@ -24,7 +24,7 @@ when not compileOption("threads"):
import cpuinfo, cpuload, locks, os
when defined(nimPreviewSlimSystem):
import std/assertions
import std/[assertions, threads]
{.push stackTrace:off.}

View File

@@ -76,7 +76,7 @@ import algorithm, math
import std/private/since
when defined(nimPreviewSlimSystem):
import std/assertions
import std/[assertions]
include system/inclrtl
{.push debugger: off.}

View File

@@ -95,16 +95,6 @@ when defined(zephyr):
proc onThreadDestruction*(handler: proc () {.closure, gcsafe, raises: [].}) =
## Registers a *thread local* handler that is called at the thread's
## destruction.
##
## A thread is destructed when the `.thread` proc returns
## normally or when it raises an exception. Note that unhandled exceptions
## in a thread nevertheless cause the whole process to die.
nimThreadDestructionHandlers.add handler
{.push stack_trace:off.}
when defined(windows):
proc threadProcWrapper[TArg](closure: pointer): int32 {.stdcall.} =

View File

@@ -2093,9 +2093,10 @@ when not defined(js):
when hasThreadSupport:
when hostOS != "standalone":
include system/threadimpl
import std/threads
export threads
when not defined(nimPreviewSlimSystem):
{.deprecated: "threads is about to move out of system; use `-d:nimPreviewSlimSystem` and import `std/threads`".}
import std/threads
export threads
elif not defined(nogc) and not defined(nimscript):
when not defined(useNimRtl) and not defined(createNimRtl): initStackBottom()

View File

@@ -33,6 +33,15 @@ template afterThreadRuns() =
for i in countdown(nimThreadDestructionHandlers.len-1, 0):
nimThreadDestructionHandlers[i]()
proc onThreadDestruction*(handler: proc () {.closure, gcsafe, raises: [].}) =
## Registers a *thread local* handler that is called at the thread's
## destruction.
##
## A thread is destructed when the `.thread` proc returns
## normally or when it raises an exception. Note that unhandled exceptions
## in a thread nevertheless cause the whole process to die.
nimThreadDestructionHandlers.add handler
when defined(boehmgc):
type GCStackBaseProc = proc(sb: pointer, t: pointer) {.noconv.}
proc boehmGC_call_with_stack_base(sbp: GCStackBaseProc, p: pointer)

View File

@@ -29,6 +29,8 @@ import compiler / [options, commands, modules, sem,
idents, modulegraphs, prefixmatches, lineinfos, cmdlinehelper,
pathutils]
when defined(nimPreviewSlimSystem):
import std/threads
when defined(windows):
import winlean

View File

@@ -8,6 +8,9 @@ discard """
import std/atomics
when defined(nimPreviewSlimSystem):
import std/[assertions, threads]
const MemBlockSize = 256
type

View File

@@ -7,7 +7,10 @@ discard """
import std/envvars
from std/sequtils import toSeq
import stdtest/testutils
import std/assertions
import std/[assertions]
when not defined(js):
import std/threads
# "LATIN CAPITAL LETTER AE" in UTF-8 (0xc386)
const unicodeUtf8 = "\xc3\x86"

View File

@@ -5,7 +5,7 @@ discard """
"""
import os, net, nativesockets, asyncdispatch
import std/[assertions]
import std/[assertions, threads]
## Test for net.dial

View File

@@ -7,7 +7,9 @@ discard """
import std/os
from std/sequtils import toSeq
import stdtest/testutils
import std/assertions
when defined(nimPreviewSlimSystem):
import std/[assertions]
# "LATIN CAPITAL LETTER AE" in UTF-8 (0xc386)
const unicodeUtf8 = "\xc3\x86"
@@ -55,6 +57,8 @@ when defined(windows):
proc c_getenv(env: cstring): cstring {.importc: "getenv", header: "<stdlib.h>".}
when not defined(js) and not defined(nimscript):
when defined(nimPreviewSlimSystem):
import std/threads
block: # bug #18533
var thr: Thread[void]
proc threadFunc {.thread.} = putEnv("foo", "fooVal2")

View File

@@ -4,7 +4,7 @@ discard """
disabled: "openbsd"
"""
# disabled: pending bug #15713
import std/[net, nativesockets, assertions]
import std/[net, nativesockets, assertions, threads]
when defined(posix): import os, posix
else:

View File

@@ -10,6 +10,7 @@ Crashes before getting here!
"""
import std/os
import std/threads
proc whatever() {.thread, nimcall.} =
echo("TEST")