/usr/include/sipxtapi/tao/TaoObjectMap.h is in libsipxtapi-dev 3.3.0~test17-2.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 | //
// Copyright (C) 2004-2006 SIPfoundry Inc.
// Licensed by SIPfoundry under the LGPL license.
//
// Copyright (C) 2004-2006 Pingtel Corp. All rights reserved.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// $$
///////////////////////////////////////////////////////////////////////////////
#ifndef _TaoObjectMap_h_
#define _TaoObjectMap_h_
#if _MSC_VER >= 1000
#pragma once
#endif // _MSC_VER >= 1000
// SYSTEM INCLUDES
// APPLICATION INCLUDES
#include <utl/UtlHashMap.h>
#include "ptapi/PtDefs.h"
#include "tao/TaoDefs.h"
#include "tao/TaoObject.h"
#include "tao/TaoMessage.h"
// DEFINES
//#define MAX_NUM_LISTENERS 20
#define MAX_NUM_TONE_LISTENERS 50
// MACROS
// EXTERNAL FUNCTIONS
// EXTERNAL VARIABLES
// CONSTANTS
// STRUCTS
// TYPEDEFS
// FORWARD DECLARATIONS
class TaoListenerDb
{
public:
TaoListenerDb();
~TaoListenerDb();
UtlString mName;
int mpListenerPtr;
int mRef;
int mId;
int mIntData;
};
//:Maintains a db of TaoObjHandle to TaoObject or PTAPI object mappings.
class TaoObjectMap
{
/* //////////////////////////// PUBLIC //////////////////////////////////// */
public:
enum TaoObjectDbInitSize { TAOOBJ_DB_INIT_SIZE = 256 };
/* ============================ CREATORS ================================== */
TaoObjectMap(int initialDbSize = TAOOBJ_DB_INIT_SIZE);
//:Default constructor
TaoObjectMap(const TaoObjectMap& rTaoObjectMap);
//:Copy constructor
TaoObjectMap& operator=(const TaoObjectMap& rhs);
//:Assignment operator
virtual
~TaoObjectMap();
//:Destructor
/* ============================ MANIPULATORS ============================== */
TaoStatus insert(TaoObjHandle objId, TaoMessage::TaoMsgTypes objValue);
//:Insert the indicated TaoObjHandle into the database of active TaoObjHandles.
// Return TAO_SUCCESS if successful, TAO_EXISTS if the key is
// already in the database.
TaoStatus insert(TaoObjHandle objId, TaoObjTypes objValue);
//:Insert the indicated TaoObjHandle into the database of active TaoObjHandles.
// Return TAO_SUCCESS if successful, TAO_EXISTS if the key is
// already in the database.
TaoStatus insert(TaoObjHandle objId, TaoObjHandle objValue);
//:Insert the indicated TaoObjHandle into the database of active TaoObjHandles.
// Return TAO_SUCCESS if successful, TAO_EXISTS if the key is
// already in the database.
TaoStatus insert(const char* key, TaoObjHandle objValue);
//:Insert the indicated TaoObjHandle into the database of active TaoObjHandles.
// Return TAO_SUCCESS if successful, TAO_EXISTS if the key is
// already in the database.
TaoStatus insert(TaoObjHandle objId, UtlString objValue);
//:Insert the indicated TaoObjHandle into the database of active TaoObjHandles.
// Return TAO_SUCCESS if successful, TAO_EXISTS if the key is
// already in the database.
TaoStatus remove(TaoObjHandle objId);
//:Remove the indicated TaoObjHandle from the database of active TaoObjHandles.
// Return TAO_SUCCESS if the indicated TaoObjHandleId is found, return
// TAO_NOT_FOUND if there is no match for the specified key.
TaoStatus remove(const char* key);
//:Remove the indicated TaoObjHandle from the database of active TaoObjHandles.
// Return TAO_SUCCESS if the indicated TaoObjHandleId is found, return
// TAO_NOT_FOUND if there is no match for the specified key.
TaoStatus removeByValue(TaoObjHandle value);
//:Find an active TaoObjHandle that has the value of the input,
// then remove the indicated TaoObjHandle from the database.
// Return TAO_SUCCESS if the indicated value is found, return
// TAO_NOT_FOUND if there is no match for the specified value.
/* ============================ ACCESSORS ================================= */
TaoStatus findValue(TaoObjHandle objId, TaoObjTypes& objValue);
//:Finds the value associated with the objId key.
// Return TAO_SUCCESS if successful, TAO_NOT_FOUND if the key is
// not found in the database.
TaoStatus findValue(TaoObjHandle objId, TaoObjHandle& objValue);
//:Finds the value associated with the objId key.
// Return TAO_SUCCESS if successful, TAO_NOT_FOUND if the key is
// not found in the database.
TaoStatus findValue(const char* key, TaoObjHandle& objValue);
//:Finds the value associated with the objId key.
// Return TAO_SUCCESS if successful, TAO_NOT_FOUND if the key is
// not found in the database.
TaoStatus findValue(TaoObjHandle key, UtlString& objValue);
//:Finds the value associated with the objId key.
// Return TAO_SUCCESS if successful, TAO_NOT_FOUND if the key is
// not found in the database.
UtlBoolean findValue(TaoObjHandle objValue);
//:Check if the value exists.
// Return TRUE if successful, FALSE if the value is
// not found in the database.
int getActiveObjects(TaoObjHandle activeObjects[], int size);
//:Get an array of pointers to the TaoObjHandles that are currently active.
// The caller provides an array that can hold up to <i>size</i> TaoObjHandles.
// This method will fill in the <i>activeObjects</i> array with
// up to <i>size</i> TaoObjHandles. The method returns the number of TaoObjHandles
// in the array that were actually filled in.
void getDbStats(unsigned& nInserts, unsigned& nRemoves) const;
//:Get the number of insertions and removals for the database.
int numEntries(void) const { return (mNumInserts - mNumRemoves); };
//:Return the number of key-value pairs in the database.
/* ============================ INQUIRY =================================== */
UtlBoolean isEmpty(void) const { return ((mNumInserts - mNumRemoves) ? TRUE : FALSE); };
//:Return TRUE if the mObjDict database is empty.
/* //////////////////////////// PROTECTED ///////////////////////////////// */
protected:
/* //////////////////////////// PRIVATE /////////////////////////////////// */
private:
UtlHashMap mDict; // hash table used to store the key/value
unsigned mNumInserts; // number of insertions into the database
unsigned mNumRemoves; // number of removals from the database
};
#endif // _TaoObjectMap_h_
|