concordia-library/concordia/concordia_index.hpp

61 lines
1.8 KiB
C++
Raw Normal View History

2013-11-14 20:36:34 +01:00
#ifndef CONCORDIA_INDEX_HDR
#define CONCORDIA_INDEX_HDR
#include <boost/shared_ptr.hpp>
2013-11-20 17:43:29 +01:00
#include <fstream>
#include <iostream>
#include <sstream>
#include <vector>
2013-11-20 17:43:29 +01:00
#include "concordia/common/config.hpp"
#include "concordia/example.hpp"
2013-11-14 20:36:34 +01:00
#include "concordia/hash_generator.hpp"
#include "concordia/concordia_exception.hpp"
#include <divsufsort.h>
2013-11-14 20:36:34 +01:00
/*!
Class for creating and maintaining the index.
*/
class ConcordiaIndex {
public:
explicit ConcordiaIndex(const std::string & hashedIndexFilePath,
const std::string & markersFilePath)
2013-11-14 20:36:34 +01:00
throw(ConcordiaException);
/*! Destructor.
*/
virtual ~ConcordiaIndex();
void addExample(
boost::shared_ptr<HashGenerator> hashGenerator,
boost::shared_ptr<std::vector<sauchar_t> > T,
boost::shared_ptr<std::vector<SUFFIX_MARKER_TYPE> > markers,
const Example & example);
2013-11-14 20:36:34 +01:00
void addAllExamples(
boost::shared_ptr<HashGenerator> hashGenerator,
boost::shared_ptr<std::vector<sauchar_t> > T,
boost::shared_ptr<std::vector<SUFFIX_MARKER_TYPE> > markers,
const std::vector<Example> & examples);
2013-11-14 20:36:34 +01:00
boost::shared_ptr<std::vector<saidx_t> > generateSuffixArray(
boost::shared_ptr<std::vector<sauchar_t> > T);
2013-11-14 20:36:34 +01:00
private:
// Add example to disk index and update RAM index.
void _addSingleExample(std::ofstream & hashedIndexFile,
std::ofstream & markersFile,
boost::shared_ptr<HashGenerator> hashGenerator,
boost::shared_ptr<std::vector<sauchar_t> > T,
boost::shared_ptr<std::vector<SUFFIX_MARKER_TYPE> > markers,
const Example & example);
2013-11-20 17:43:29 +01:00
std::string _hashedIndexFilePath;
std::string _markersFilePath;
2013-11-14 20:36:34 +01:00
};
#endif