blob: 398926bd3c90cf7b803cd9e1e97ee6f9412a4100 (
plain)
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
|
#include "../base/SRC_FIRST.hpp"
#include "data_factory.hpp"
#include "interval_index.hpp"
#include "old/interval_index_101.hpp"
#include "../defines.hpp"
#include "../coding/file_reader.hpp"
#include "../coding/file_container.hpp"
void LoadMapHeader(FilesContainerR const & cont, feature::DataHeader & header)
{
ModelReaderPtr r = cont.GetReader(HEADER_FILE_TAG);
if (cont.IsReaderExist(VERSION_FILE_TAG))
header.Load(r);
else
header.LoadVer1(r);
}
void LoadMapHeader(ModelReaderPtr const & reader, feature::DataHeader & header)
{
LoadMapHeader(FilesContainerR(reader), header);
}
void IndexFactory::Load(FilesContainerR const & cont)
{
LoadMapHeader(cont, m_header);
}
IntervalIndexIFace * IndexFactory::CreateIndex(ModelReaderPtr reader)
{
using namespace feature;
IntervalIndexIFace * p;
switch (m_header.GetVersion())
{
case DataHeader::v1:
p = new old_101::IntervalIndex<uint32_t, ModelReaderPtr>(reader);
break;
default:
p = new IntervalIndex<ModelReaderPtr>(reader);;
break;
}
return p;
}
|