update dev300-m58
[ooovba.git] / bridges / source / remote / urp / urp_replycontainer.hxx
blobb72fdf994bd8a32eb3b3e65949e9ee9d90163f18
1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: urp_replycontainer.hxx,v $
10 * $Revision: 1.5 $
12 * This file is part of OpenOffice.org.
14 * OpenOffice.org is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Lesser General Public License version 3
16 * only, as published by the Free Software Foundation.
18 * OpenOffice.org is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU Lesser General Public License version 3 for more details
22 * (a copy is included in the LICENSE file that accompanied this code).
24 * You should have received a copy of the GNU Lesser General Public License
25 * version 3 along with OpenOffice.org. If not, see
26 * <http://www.openoffice.org/license.html>
27 * for a copy of the LGPLv3 License.
29 ************************************************************************/
30 #include <hash_map>
31 #include <list>
33 #include <osl/mutex.hxx>
34 #include <osl/diagnose.h>
36 #include "urp_threadid.hxx"
38 namespace bridges_urp
40 class ClientJob;
41 typedef ::std::hash_map< ::rtl::ByteSequence ,
42 ::std::list < ClientJob * > ,
43 HashThreadId ,
44 EqualThreadId > Id2ClientJobStackMap;
46 class urp_ClientJobContainer
48 public:
49 void add( const ::rtl::ByteSequence &id , ClientJob *p )
51 ::osl::MutexGuard guard( m_mutex );
52 m_map[id].push_back( p );
55 ClientJob *remove( const ::rtl::ByteSequence & id )
57 ::osl::MutexGuard guard( m_mutex );
58 Id2ClientJobStackMap::iterator ii = m_map.find( id );
60 ClientJob *p = 0;
61 if( ii != m_map.end() )
63 p = (*ii).second.back();
64 (*ii).second.pop_back();
65 if( (*ii).second.empty() )
67 m_map.erase( ii );
71 return p;
74 private:
75 ::osl::Mutex m_mutex;
76 Id2ClientJobStackMap m_map;