/usr/include/omniORB4/internal/inProcessIdentity.h is in libomniorb4-dev 4.2.2-0.8.
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 | // -*- Mode: C++; -*-
// Package : omniORB
// inProcessIdentity.h Created on: 16/05/2001
// Author : Duncan Grisby (dpg1)
//
// Copyright (C) 2007 Apasphere Ltd
// Copyright (C) 2001 AT&T Laboratories Cambridge
//
// This file is part of the omniORB library
//
// The omniORB library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; either
// version 2.1 of the License, or (at your option) any later version.
//
// This library 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
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library. If not, see http://www.gnu.org/licenses/
//
//
// Description:
//
// Identity for objects in the caller's address space which cannot
// be called directly. This can be because they are not activated
// yet, because they are using DSI, or because they are in a
// different language to the caller.
#ifndef __OMNIORB_INPROCESSIDENTITY_H__
#define __OMNIORB_INPROCESSIDENTITY_H__
#include <omniIdentity.h>
#ifdef _core_attr
# error "A local CPP macro _core_attr has already been defined."
#endif
#if defined(_OMNIORB_LIBRARY)
# define _core_attr
#else
# define _core_attr _OMNIORB_NTDLL_IMPORT
#endif
OMNI_NAMESPACE_BEGIN(omni)
class omniInProcessIdentity_RefHolder;
OMNI_NAMESPACE_END(omni)
class omniInProcessIdentity : public omniIdentity {
public:
inline ~omniInProcessIdentity() {
ASSERT_OMNI_TRACEDMUTEX_HELD(*omni::internalLock, 1);
if (--identity_count == 0)
lastIdentityHasBeenDeleted();
}
inline omniInProcessIdentity(omniObjKey& key)
: omniIdentity(key),
pd_refCount(0)
{
ASSERT_OMNI_TRACEDMUTEX_HELD(*omni::internalLock, 1);
++identity_count;
}
// May consume <key>.
inline omniInProcessIdentity(const _CORBA_Octet* key, int keysize)
: omniIdentity(key, keysize),
pd_refCount(0)
{
ASSERT_OMNI_TRACEDMUTEX_HELD(*omni::internalLock, 1);
++identity_count;
}
// Copies <key>.
virtual void dispatch(omniCallDescriptor&);
virtual void gainRef(omniObjRef* obj = 0);
virtual void loseRef(omniObjRef* obj = 0);
virtual omniIdentity::equivalent_fn get_real_is_equivalent() const;
// Shares omniLocalIdentity's is_equivalent function.
virtual void locateRequest(omniCallDescriptor&);
// If this returns normally, then the object exists.
// Throws OBJECT_NOT_EXIST, or omniORB::LOCATION_FORWARD
// otherwise.
// Caller must hold <internalLock>. On return or raised exception, the
// lock is released.
virtual _CORBA_Boolean inThisAddressSpace();
// Override omniIdentity.
virtual void* ptrToClass(int* cptr);
static inline omniInProcessIdentity* downcast(omniIdentity* i) {
return (omniInProcessIdentity*)i->ptrToClass(&_classid);
}
static _core_attr int _classid;
// Dynamic casting mechanism.
private:
friend class _OMNI_NS(omniInProcessIdentity_RefHolder);
omniInProcessIdentity(const omniInProcessIdentity&);
omniInProcessIdentity& operator = (const omniInProcessIdentity&);
// Not implemented.
int pd_refCount;
};
#undef _core_attr
#endif // __OMNIORB_INPROCESSIDENTITY_H__
|