Merge pull request #274 from kiwix/embedded_zim_support

Add support of embedded ft-index in zim for kiwix-serve and kiwix-search.
This commit is contained in:
Kelson
2016-08-12 12:35:37 +02:00
committed by GitHub

View File

@ -18,6 +18,12 @@
*/
#include "xapianSearcher.h"
#include <zim/zim.h>
#include <zim/file.h>
#include <zim/article.h>
#include <zim/error.h>
#include <sys/types.h>
#include <unistd.h>
namespace kiwix {
@ -30,8 +36,23 @@ namespace kiwix {
/* Open Xapian readable database */
void XapianSearcher::openIndex(const string &directoryPath) {
bool indexInZim = false;
try
{
zim::File zimFile = zim::File(directoryPath);
zim::Article xapianArticle = zimFile.getArticle('Z', "/Z/fulltextIndex/xapian");
if (xapianArticle.good())
{
zim::offset_type dbOffset = xapianArticle.getOffset();
int databasefd = open(directoryPath.c_str(), O_RDONLY);
lseek(databasefd, dbOffset, SEEK_SET);
this->readableDatabase = Xapian::Database(databasefd);
}
} catch (zim::ZimFileFormatError)
{
this->readableDatabase = Xapian::Database(directoryPath);
}
}
/* Close Xapian writable database */
void XapianSearcher::closeIndex() {