// ********************************************************************** // // Copyright (c) 2003-2006 ZeroC, Inc. All rights reserved. // // This copy of Ice is licensed to you under the terms described in the // ICE_LICENSE file included in this distribution. // // ********************************************************************** #ifndef ICE_GRID_OBJECTCACHE_H #define ICE_GRID_OBJECTCACHE_H #include #include #include #include #include #include #include namespace IceGrid { class ObjectCache; class ServerEntry; typedef IceUtil::Handle ServerEntryPtr; class ObjectEntry : public Allocatable { public: ObjectEntry(ObjectCache&, const ObjectInfo&, const std::string&, bool, const AllocatablePtr&); Ice::ObjectPrx getProxy() const; std::string getType() const; std::string getApplication() const; const ObjectInfo& getObjectInfo() const; bool canRemove(); virtual void allocated(const SessionIPtr&); virtual void released(const SessionIPtr&); virtual bool canTryAllocate(); void destroy(); virtual void checkAllocatable(); private: ObjectCache& _cache; const ObjectInfo _info; const std::string _application; bool _destroyed; }; typedef IceUtil::Handle ObjectEntryPtr; class ObjectAllocationRequest : public AllocationRequest { public: ObjectAllocationRequest(const SessionIPtr& session) : AllocationRequest(session) { } virtual void response(const Ice::ObjectPrx&) = 0; virtual void exception(const AllocationException&) = 0; private: virtual bool allocated(const AllocatablePtr& allocatable, const SessionIPtr& session) { response(ObjectEntryPtr::dynamicCast(allocatable)->getObjectInfo().proxy); return true; } virtual void canceled(const AllocationException& ex) { exception(ex); } }; typedef IceUtil::Handle ObjectAllocationRequestPtr; class AdapterCache; class ObjectCache : public Cache { public: ObjectCache(const Ice::CommunicatorPtr&, AdapterCache&); void add(const ObjectInfo&, const std::string&, bool, const AllocatablePtr&); ObjectEntryPtr get(const Ice::Identity&) const; ObjectEntryPtr remove(const Ice::Identity&); void allocateByType(const std::string&, const ObjectAllocationRequestPtr&); bool canTryAllocate(const ObjectEntryPtr&); Ice::ObjectProxySeq getObjectsByType(const std::string&); ObjectInfoSeq getAll(const std::string&); ObjectInfoSeq getAllByType(const std::string&); const Ice::CommunicatorPtr& communicator() const { return _communicator; } private: class TypeEntry { public: TypeEntry(); void add(const ObjectEntryPtr&); bool remove(const ObjectEntryPtr&); void addAllocationRequest(const ObjectAllocationRequestPtr&); bool canTryAllocate(const ObjectEntryPtr&, bool); const std::vector& getObjects() const { return _objects; } bool hasAllocatables() const; private: std::vector _objects; std::list _requests; int _allocatablesCount; }; Ice::CommunicatorPtr _communicator; AdapterCache& _adapterCache; std::map _types; std::map > _allocatablesByType; static std::pointer_to_unary_function _rand; }; }; #endif