/usr/include/sipxtapi/os/OsNameDb.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 | //
// 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 _OsNameDb_h_
#define _OsNameDb_h_
// SYSTEM INCLUDES
// APPLICATION INCLUDES
#include "os/OsBSem.h"
#include "os/OsRWMutex.h"
#include "os/OsStatus.h"
#include "utl/UtlHashMap.h"
// DEFINES
// MACROS
// EXTERNAL FUNCTIONS
// EXTERNAL VARIABLES
// CONSTANTS
// STRUCTS
// TYPEDEFS
// FORWARD DECLARATIONS
class UtlString;
//:Name service maintaining mappings between string names and integer values
// The OsNameDb is a singleton object that maintains a dictionary of
// mappings between string names and the associated integer values.
// Duplicate names are not allowed.
class OsNameDb
{
/* //////////////////////////// PUBLIC //////////////////////////////////// */
public:
/* ============================ CREATORS ================================== */
static OsNameDb* getNameDb();
//:Return a pointer to the singleton object, creating it if necessary
/* ============================ MANIPULATORS ============================== */
OsStatus insert(const UtlString& rKey,
const intptr_t value);
//:Add the key-value pair to the name database
// Return OS_SUCCESS if successful, OS_NAME_IN_USE if the key is
// already in the database.
OsStatus remove(const UtlString& rKey,
intptr_t* pValue = NULL);
//:Remove the indicated key-value pair from the name database
// If pValue is non-NULL, the value for the key-value pair is returned
// via pValue.<br>
// Return OS_SUCCESS if the lookup is successful, return
// OS_NOT_FOUND if there is no match for the specified key.
/* ============================ ACCESSORS ================================= */
OsStatus lookup(const UtlString& rKey,
intptr_t* pValue = NULL);
//:Retrieve the value associated with the specified key
// If pValue is non-NULL, the value is returned via pValue. <br>
// Return OS_SUCCESS if the lookup is successful, return
// OS_NOT_FOUND if there is no match for the specified key.
int numEntries();
//: Return the number of key-value pairs in the name database
/* ============================ INQUIRY =================================== */
UtlBoolean isEmpty();
//:Return TRUE if the name database is empty
/* //////////////////////////// PROTECTED ///////////////////////////////// */
protected:
friend class OsNameDBInit;
OsNameDb();
//:Default constructor (only callable from within this class)
// This class implements the singleton pattern and therefore the
// class constructor will not be called from outside the class.
// We identify this as a protected (rather than a private) method so
// that gcc doesn't complain that the class only defines a private
// constructor and has no friends.
virtual
~OsNameDb();
//:Destructor
/* //////////////////////////// PRIVATE /////////////////////////////////// */
private:
static OsNameDb* spInstance; // pointer to the single instance of the
// OsNameDb class
UtlHashMap mDict; // hash table used to store the name/value
// mappings
OsRWMutex mRWLock; // R/W mutex used to coordinate access to
// the name database by multiple tasks
OsNameDb(const OsNameDb& rOsNameDb);
//:Copy constructor (not supported for this class)
OsNameDb& operator=(const OsNameDb& rhs);
//:Assignment operator (not supported for this class)
};
/* ============================ INLINE METHODS ============================ */
#endif // _OsNameDb_h_
|