File: FUSynchronizableObject.h

package info (click to toggle)
0ad 0.0.23.1-2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 78,292 kB
  • sloc: cpp: 245,166; ansic: 200,249; python: 13,754; sh: 6,104; perl: 4,620; makefile: 977; xml: 810; java: 533; ruby: 229; erlang: 46; pascal: 30; sql: 21; tcl: 4
file content (46 lines) | stat: -rw-r--r-- 1,166 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
/*
	Copyright (C) 2005-2007 Feeling Software Inc.
	Portions of the code are:
	Copyright (C) 2005-2007 Sony Computer Entertainment America
	
	MIT License: http://www.opensource.org/licenses/mit-license.php
*/

/**
	@file FUSynchronizableObject.h
	This file contains the FUSynchronizableObject class.
*/

#ifndef _FU_SYNCHRONIZABLE_OBJECT_H_
#define _FU_SYNCHRONIZABLE_OBJECT_H_

#ifndef _FU_CRITICAL_SECTION_H_
#include "FUCriticalSection.h"
#endif

/**
	A synchronizable object.

	A synchronizable object is an object that has the ability to lock itself so only one thread may be using it. 
	This can be done by calling the Lock and Unlock methods of the object. Be sure to Lock and Unlock around
	all the critical sections of the object to ensure mutual exclusion.

	@ingroup FUtils
*/
class FCOLLADA_EXPORT FUSynchronizableObject
{
private:
	FUCriticalSection criticalSection;

public:
	/** Destructor. */
	virtual ~FUSynchronizableObject();

	/** Locks the object, blocking if another thread has locked it. */
	virtual void Lock();

	/** Unlocks the object, allowing other threads to lock it. */
	virtual void Unlock();
};

#endif // _FU_SYNCHRONIZABLE_OBJECT_H_