summaryrefslogtreecommitdiff
path: root/include/osl
diff options
context:
space:
mode:
Diffstat (limited to 'include/osl')
-rw-r--r--include/osl/conditn.h35
-rw-r--r--include/osl/conditn.hxx95
2 files changed, 84 insertions, 46 deletions
diff --git a/include/osl/conditn.h b/include/osl/conditn.h
index 26d2cb103d62..a087f3504a49 100644
--- a/include/osl/conditn.h
+++ b/include/osl/conditn.h
@@ -32,9 +32,9 @@ extern "C" {
typedef void* oslCondition;
typedef enum {
- osl_cond_result_ok, /* successful completion */
- osl_cond_result_error, /* error occurred, check osl_getLastSocketError() for details */
- osl_cond_result_timeout, /* blocking operation timed out */
+ osl_cond_result_ok, /*<! Successful completion. */
+ osl_cond_result_error, /*<! Error occurred. @see osl_getLastSocketError() */
+ osl_cond_result_timeout, /*<! Blocking operation timed out. */
osl_cond_result_FORCE_EQUAL_SIZE = SAL_MAX_ENUM
} oslConditionResult;
@@ -44,38 +44,55 @@ typedef enum {
for a more robust and helpful condition.
The condition is in the reset-state.
- @retval 0 if condition could not be created.
+
+ @relates Condition
+
+ @retval osl_cond_result_error Condition could not be created.
*/
SAL_DLLPUBLIC oslCondition SAL_CALL osl_createCondition(void);
/** Free the memory used by the condition.
+
+ @relates Condition
+
@param Condition the condition handle.
*/
SAL_DLLPUBLIC void SAL_CALL osl_destroyCondition(oslCondition Condition);
/** Sets condition to True => wait() will not block, check() returns True.
- NOTE: ALL threads waiting on this condition are unblocked!
+
+ @attention @em all threads waiting on this condition are unblocked!
+
+ @relates Condition
+
@param Condition handle to a created condition.
@retval False if system-call failed.
*/
SAL_DLLPUBLIC sal_Bool SAL_CALL osl_setCondition(oslCondition Condition);
/** Sets condition to False => wait() will block, check() returns False
+
+ @relates Condition
+
@param Condition handle to a created condition.
@retval False if system-call failed.
*/
SAL_DLLPUBLIC sal_Bool SAL_CALL osl_resetCondition(oslCondition Condition);
-/** Blocks if condition is not set
- If condition has been destroyed prematurely, wait() will
- return with False.
+/** Blocks if condition is not set.
+
+ @relates Condition
+
@param Condition handle to a created condition.
@param pTimeout Timeout value or NULL for infinite waiting
- @return False if system-call failed.
+ @retval False Condition has been destroyed prematurely or system call has failed.
*/
SAL_DLLPUBLIC oslConditionResult SAL_CALL osl_waitCondition(oslCondition Condition, const TimeValue* pTimeout);
/** Queries the state of the condition without blocking.
+
+ @relates Condition
+
@param Condition handle to a created condition.
@retval True condition is set
@retval False condition is not set
diff --git a/include/osl/conditn.hxx b/include/osl/conditn.hxx
index 07d697948077..ffc7cc6b5c82 100644
--- a/include/osl/conditn.hxx
+++ b/include/osl/conditn.hxx
@@ -20,12 +20,10 @@
#ifndef INCLUDED_OSL_CONDITN_HXX
#define INCLUDED_OSL_CONDITN_HXX
-#include <sal/config.h>
-
#include <cstddef>
+#include <sal/config.h>
#include <osl/time.h>
-
#include <osl/conditn.h>
#if defined(MACOSX) && defined(__ASSERT_MACROS_DEFINE_VERSIONS_WITHOUT_UNDERSCORES)
@@ -36,63 +34,78 @@
namespace osl
{
- /**
- * A deprecated condition.
- *
- * @deprecated use C++11's std::condition_variable instead
- * for a more robust and helpful condition.
- *
- * Warning: the Condition abstraction is inadequate for any
- * situation where there may be multiple threads setting,
- * waiting, and resetting the same condition. It can only be
- * used to synchronise interactions between two threads
- * cf. lost wakeups in:
- * http://www.cs.wustl.edu/~schmidt/win32-cv-1.html
- */
+ /** Condition variable
+
+ A condition variable is essentially an object that is initially
+ cleared which a thread waits on until it is "set". It allows a
+ thread to synchronize execution by allowing other threads to wait
+ for the condition to change before that thread then continues
+ execution.
+
+ @deprecated use C++11's std::condition_variable instead
+ for a more robust and helpful condition.
+
+ @attention Warning: the Condition abstraction is inadequate for
+ any situation where there may be multiple threads setting,
+ waiting, and resetting the same condition. It can only be
+ used to synchronise interactions between two threads
+ cf. lost wakeups in http://www.cs.wustl.edu/~schmidt/win32-cv-1.html
+ */
class Condition
{
public:
-
enum Result
{
- result_ok = osl_cond_result_ok,
- result_error = osl_cond_result_error,
- result_timeout = osl_cond_result_timeout
+ result_ok = osl_cond_result_ok, /*!< Succesful completion. */
+ result_error = osl_cond_result_error, /*!< Error occurred. @see osl_getLastSocketError() */
+ result_timeout = osl_cond_result_timeout /*!< Blocking operation timed out. */
};
- /**
- * Create a condition.
- *
- * @deprecated use C++11's std::condition_variable instead
- * for a more robust and helpful condition.
- */
+ /** Create a condition.
+
+ @deprecated use C++11's std::condition_variable instead
+ for a more robust and helpful condition.
+ */
Condition()
{
condition = osl_createCondition();
}
- /* Release the OS-structures and free condition data-structure.
- */
+ /** Release the OS-structures and free condition data-structure.
+
+ @deprecated use C++11's std::condition_variable instead
+ for a more robust and helpful condition.
+ */
~Condition()
{
osl_destroyCondition(condition);
}
- /* Release all waiting threads, check returns true.
- */
+ /** Release all waiting threads, check returns true.
+
+ @deprecated use C++11's std::condition_variable instead
+ for a more robust and helpful condition.
+ */
void set()
{
osl_setCondition(condition);
}
- /* Reset condition to false: wait() will block, check() returns false.
- */
+ /** Reset condition to false: wait() will block, check() returns
+ false.
+
+ @deprecated use C++11's std::condition_variable instead
+ for a more robust and helpful condition.
+ */
void reset() {
osl_resetCondition(condition);
}
/** Blocks the calling thread until condition is set.
- */
+
+ @deprecated use C++11's std::condition_variable instead
+ for a more robust and helpful condition.
+ */
Result wait(const TimeValue *pTimeout = NULL)
{
return (Result) osl_waitCondition(condition, pTimeout);
@@ -103,7 +116,10 @@ namespace osl
#endif
/** Checks if the condition is set without blocking.
- */
+
+ @deprecated use C++11's std::condition_variable instead
+ for a more robust and helpful condition.
+ */
bool check()
{
return osl_checkCondition(condition);
@@ -115,18 +131,23 @@ namespace osl
/** The underlying oslCondition has no reference count.
- Since the underlying oslCondition is not a reference counted object, copy
- constructed Condition may work on an already destructed oslCondition object.
+ Since the underlying oslCondition is not a reference counted
+ object, copy constructed Condition may work on an already
+ destructed oslCondition object.
+ @deprecated use C++11's std::condition_variable instead
+ for a more robust and helpful condition.
*/
Condition(const Condition&) SAL_DELETED_FUNCTION;
/** This assignment operator is deleted for the same reason as
the copy constructor.
+
+ @deprecated use C++11's std::condition_variable instead
+ for a more robust and helpful condition.
*/
Condition& operator= (const Condition&) SAL_DELETED_FUNCTION;
};
-
}
#endif // INCLUDED_OSL_CONDITN_HXX