ares_threadsafety - Man Page

Query if c-ares was built with thread-safety

Synopsis

#include <ares.h>

ares_bool_t ares_threadsafety(void);

Description

The ares_threadsafety(3) function returns if the library was built with thread safety enabled or not.

As of c-ares 1.23.0, this simply means that every public function which references an ares_channel_t object will lock the channel on entry and release the lock on exit of the function.  This will prevent concurrent thread access to the channel, thus ensuring no corruption can occur.

As of c-ares 1.26.0, this also indicates if ARES_OPT_EVENT_THREAD can be passed to ares_init_options(3).

Return Values

ares_threadsafety(3) can return any of the following values:

ARES_TRUE

Built with thread safety.

ARES_FALSE

Built without thread safety

Availability

This function was first introduced in c-ares version 1.23.0.

See Also

ares_init(3), ares_init_options(3), ares_destroy(3), ares_dup(3), ares_library_init(3), ares_set_servers(3)

Referenced By

ares_destroy(3), ares_init_options(3), ares_queue(3), ares_reinit(3).

26 November 2023