This file is indexed.

/usr/include/mia-2.2/mia/core/datapool.hh is in libmia-2.2-dev 2.2.2-1+b1.

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
/* -*- mia-c++  -*-
 *
 * This file is part of MIA - a toolbox for medical image analysis 
 * Copyright (c) Leipzig, Madrid 1999-2014 Gert Wollny
 *
 * MIA is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program 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 General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with MIA; if not, see <http://www.gnu.org/licenses/>.
 *
 */

#ifndef mia_core_datapool_hh
#define mia_core_datapool_hh

#include <map>
#include <boost/any.hpp>

#include <mia/core/defines.hh>
#include <tbb/recursive_mutex.h>


NS_MIA_BEGIN

/**
   \ingroup io

   \brief temporary data storage to avoid storing on disk

   This class implements a data storage pool as a singelton
   that can be used to store some
   data temporarly like if it would be stored on disk.
   Each IO plugin automatically defines an interface to store in and load
   from this pool. The extension, by which this behaviour is triggered is ".@".

   \todo add delete key function,
   \todo add automatic key generation
   \todo (maybe) all plugins that load data should load to the pool first to enable
   loading from temporarly generated data
*/

class EXPORT_CORE CDatapool {
public:

	/**
	   add some data to the pool, if the key already exists, the value  is replaced
	   \param key unique identifier
	   \param value value to be stored
	 */
	void add(const std::string& key, boost::any value);
	/**
	   \param key: key of data to be retrieved
	   \returns value indexed by key, and throws \a invalid argument if value not exists
	 */
	boost::any get(const std::string& key) const;

	/**
	   gets some data and remove this data from the pool
	   \param key key of data to be retrieved
	   \returns value indexed by key, and throws \a invalid argument if value not exists
	 */
	boost::any get_and_remove(const std::string& key);

	/**
	   \param key 
	   \returns \a true if key exists in pool and \a false if not
	*/
	bool has_key(const std::string& key) const;
	/**
	   \returns the unique instance of the data pool
	 */
	static CDatapool& instance();

	/**
	   function to be used for debugging purpouses
	   \returns true if the pool has some data that was not uses
	*/
	bool has_unused_data() const;

	/**
	   Remove all stored data from the pool. 
	 */
	void clear();
private:

	CDatapool();
	CDatapool(const CDatapool& other);
	typedef std::map<std::string, boost::any> Anymap;
	typedef Anymap::const_iterator const_iterator;
	const_iterator get_iterator(const std::string& key) const;
	Anymap m_map;
	typedef std::map<std::string,bool> Usagemap;
	mutable Usagemap m_usage;
	static tbb::recursive_mutex m_mutex; 
};

NS_MIA_END

#endif