This file contains a structure for creating a cross-platform Mutex. More...
#include <sys/sem.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <pthread.h>
#include <string>
#include "cxbase.h"
Go to the source code of this file.
Classes | |
class | CxUtils::Mutex |
Cross platform mutex structure for thread safe operations. This structure has been defined to work in both Windows and Linux operating systems. More... | |
class | CxUtils::Mutex::ScopedPtr< T > |
Template class for making a pointer to some data that that needs protection by a mutex. When the Ptr goes out of scope or is deleted the mutex is automatically released. More... | |
class | CxUtils::Mutex::CScopedPtr< T > |
Equivalent of the ScopedPtr class, but for constant data. More... | |
class | CxUtils::Mutex::ScopedLock |
Class for enabling a Mutex within a specific program scope which will unlock the mutex when out of scope (when object is destroyed). More... | |
union | CxUtils::Mutex::SemUnion |
Simple union structure used to create a semaphore (Global Named Mutex) in a posix compliant OS (Linux). More... | |
Namespaces | |
namespace | CxUtils |
Defines | |
#define | INFINITE 0xFFFFFFFF |
Defines the value for INFINITE if it has not already been defined. |
This file contains a structure for creating a cross-platform Mutex.
Author(s): Daniel Barber
Created: 24 April 2007
Copyright (c) 2009
Applied Cognition and Training in Immersive Virtual Environments
(ACTIVE) Laboratory
Institute for Simulation and Training (IST)
University of Central Florida (UCF)
All rights reserved.
Email: dbarber@ist.ucf.edu
Web: http://active.ist.ucf.edu
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. Neither the name of the ACTIVE LAB, IST, UCF, nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE ACTIVE LAB''AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL UCF BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Definition in file mutex.h.
#define INFINITE 0xFFFFFFFF |
Defines the value for INFINITE if it has not already been defined.