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 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
|
/*
* wrapper_misc.cxx
*
* OpenH323 Wrapper Library
*
* Copyright (c) 2002-2005 InAccess Networks
* Michalis Manousos <manousos@inaccessnetworks.com>
* Dimitris Economou <decon@inaccessnetworks.com>
*
* This file is part of "H.323 support for ASTERISK"
*
* "H.323 support for ASTERISK" is free software;
* you can redistribute it and/or modify it under the terms of the
* GNU General Public License as published by the Free Software Foundation;
* either version 2 of the License, or (at your option) any later version.
*
* "H.323 support for ASTERISK" is distributed in the hope that it will be
* useful, but WITHOUT ANY WARRANTY; without even the implied warranty
* of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*
* $Id: wrapper_misc.cxx,v 1.5.2.1 2005/01/14 15:33:22 manousos Exp $
*
*/
/************************************************************************/
#define cplusplus
#include "version.h"
#include "wrapper_misc.hxx"
using namespace std;
/************************************************************************/
/* Misc wrapper's internal variables and classes ************************/
int channelsOpen = 0;
/***********************************************************
* Class WrapMutex
**********************************************************/
WrapMutex::WrapMutex(char *mutex_name) :
PMutex()
{
name = PString(mutex_name);
WRAPTRACE(2, "Created mutex " << name);
}
BOOL WrapMutex::Wait(const char *file, int line, const char *function, int ms)
{
PTimeInterval timeout;
if (ms < 0)
timeout = PMaxTimeInterval;
else
timeout = PTimeInterval(ms);
WRAPTRACE(2, "Requesting mutex " << name <<
" [" << file << ", " << line << ", " << function << "]");
if (PMutex::Wait(timeout) == TRUE) {
WRAPTRACE(2, "Got mutex " << name <<
" [" << file << ", " << line << ", " << function << "]");
return TRUE;
} else {
WRAPTRACE(2, "Timeout waiting for mutex " << name <<
" [" << file << ", " << line << ", " << function << "]");
return FALSE;
}
}
void WrapMutex::Signal(const char *file, int line, const char *function)
{
PMutex::Signal();
WRAPTRACE(2, "Released mutex " << name <<
" [" << file << ", " << line << ", " << function << "]");
}
// End of file //////////////////////////////////////////////////////////////
|