tomo/docs/threads.md
2025-03-05 00:40:52 -05:00

1.5 KiB

Threads

Tomo supports POSIX threads (pthreads) through the Thread type. The recommended practice is to have each thread interact with other threads only through mutex-guarded datastructures.

Thread Methods

cancel

Requests the cancellation of a specified thread.

func cancel(thread: Thread)
  • thread: The thread to cancel.

Returns:
Nothing.

Example:

>> thread:cancel()

detach

Detaches a specified thread, allowing it to run independently.

func detach(thread: Thread)
  • thread: The thread to detach.

Returns:
Nothing.

Example:

>> thread:detach()

join

Waits for a specified thread to terminate.

func join(thread: Thread)
  • thread: The thread to join.

Returns:
Nothing.

Example:

>> thread:join()

new

Creates a new thread to execute a specified function.

func new(fn: func(->Void) -> Thread)
  • fn: The function to be executed by the new thread.

Returns:
A new Thread object representing the created thread.

Example:

>> jobs := |Int|
>> results := |Int|
>> thread := Thread.new(func():
    repeat:
        input := jobs:get()
        results:give(input + 10
)
= Thread<0x12345678>
>> jobs:give(10)
>> results:get()
= 11