|
1
2
3
4
5
6
7
8
9
|
/*
* File: ResultsManager.cpp
* Author: mlenart
*
* Created on 24 czerwiec 2014, 17:09
*/
#include "ResultsManager.hpp"
#include "morfeusz2.h"
|
|
10
11
12
|
#include <iostream>
using namespace std;
|
|
13
14
15
16
17
|
namespace morfeusz {
static const int initialSize = 1024;
|
|
18
19
|
ResultsManager::ResultsManager(const Morfeusz* morfeusz)
: morfeusz(morfeusz), results(new InterpMorf[initialSize]()),
|
|
20
21
22
23
|
resultsArraySize(initialSize) {
}
ResultsManager::~ResultsManager() {
|
|
24
|
delete[] results;
|
|
25
26
27
28
29
30
31
32
33
34
|
}
InterpMorf* ResultsManager::convertResults(const std::vector<MorphInterpretation>& res) {
if (res.size() + 1 > resultsArraySize) {
reserve(res.size() + 1);
}
for (unsigned int i = 0; i < res.size(); i++) {
results[i] = convertOneResult(res[i]);
}
results[res.size()].p = -1;
|
|
35
|
return results;
|
|
36
37
38
39
40
41
|
}
void ResultsManager::reserve(size_t size) {
while (resultsArraySize <= size) {
resultsArraySize *= 2;
}
|
|
42
|
delete[] results;
|
|
43
44
45
46
47
|
results = new InterpMorf[resultsArraySize];
}
InterpMorf ResultsManager::convertOneResult(const MorphInterpretation& res) {
InterpMorf convertedRes;
|
|
48
49
50
51
52
|
convertedRes.p = res.startNode;
convertedRes.k = res.endNode;
convertedRes.forma = const_cast<char*>(res.orth.c_str());
convertedRes.haslo = const_cast<char*>(res.lemma.c_str());
convertedRes.interp = const_cast<char*>(morfeusz->getIdResolver().getTag(res.tagId).c_str());
|
|
53
54
55
|
return convertedRes;
}
}
|