# MutexDirect¶

from panda3d.core import MutexDirect

class MutexDirect

This class implements a standard mutex by making direct calls to the underlying implementation layer. It doesn’t perform any debugging operations.

Inheritance diagram

acquire()None

Grabs the mutex if it is available. If it is not available, blocks until it becomes available, then grabs it. In either case, the function does not return until the mutex is held; you should then call unlock().

This method is considered const so that you can lock and unlock const mutexes, mainly to allow thread-safe access to otherwise const data.

Also see MutexHolder.

clearName()None

The mutex name is only defined when compiling in DEBUG_THREADS mode.

debugIsLocked()bool

Returns true if the current thread has locked the Mutex, false otherwise. This method is only intended for use in debugging, hence the method name; in the MutexDirect case, it always returns true, since there’s not a reliable way to determine this otherwise.

getName()str

The mutex name is only defined when compiling in DEBUG_THREADS mode.

hasName()bool

The mutex name is only defined when compiling in DEBUG_THREADS mode.

output(out: ostream)None

This method is declared virtual in MutexDebug, but non-virtual in MutexDirect.

release()None

Releases the mutex. It is an error to call this if the mutex was not already locked.

This method is considered const so that you can lock and unlock const mutexes, mainly to allow thread-safe access to otherwise const data.

setName(name: str)None

The mutex name is only defined when compiling in DEBUG_THREADS mode.

tryAcquire()bool

Returns immediately, with a true value indicating the mutex has been acquired, and false indicating it has not.