Skip to content

Commit

Permalink
implement
Browse files Browse the repository at this point in the history
  • Loading branch information
andiwand committed Jan 8, 2025
1 parent ef1697c commit 0f5e42e
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 18 deletions.
1 change: 1 addition & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,7 @@ set(ODR_SOURCE_FILES
"src/odr/exceptions.cpp"
"src/odr/file.cpp"
"src/odr/filesystem.cpp"
"src/odr/global_params.cpp"
"src/odr/html.cpp"
"src/odr/html_service.cpp"
"src/odr/open_document_reader.cpp"
Expand Down
7 changes: 7 additions & 0 deletions src/odr/global_params.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@

#include <odr/internal/project_info.hpp>

#include <poppler/GlobalParams.h>

namespace odr {

GlobalParams &GlobalParams::instance() {
Expand Down Expand Up @@ -35,6 +37,11 @@ void GlobalParams::set_fontforge_data_path(const std::string &path) {

void GlobalParams::set_poppler_data_path(const std::string &path) {
instance().m_poppler_data_path = path;

#ifdef ODR_WITH_PDF2HTMLEX
globalParams =
std::make_unique<::GlobalParams>(path.empty() ? nullptr : path.c_str());
#endif
}

void GlobalParams::set_pdf2htmlex_data_path(const std::string &path) {
Expand Down
24 changes: 6 additions & 18 deletions src/odr/internal/html/pdf2htmlex_wrapper.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

#include <odr/exceptions.hpp>
#include <odr/file.hpp>
#include <odr/global_params.hpp>
#include <odr/html.hpp>

#include <odr/internal/html/common.hpp>
Expand All @@ -13,7 +14,6 @@
#include <pdf2htmlEX/HTMLRenderer/HTMLRenderer.h>
#include <pdf2htmlEX/Param.h>

#include <poppler/GlobalParams.h>
#include <poppler/PDFDoc.h>

namespace odr::internal::html {
Expand Down Expand Up @@ -91,8 +91,8 @@ pdf2htmlEX::Param create_params(PDFDoc &pdf_doc, const HtmlConfig &config,
// misc
param.clean_tmp = 1;
param.tmp_dir = output_path;
param.data_dir = config.pdf2htmlex_data_path;
param.poppler_data_dir = config.poppler_data_path;
param.data_dir = odr::GlobalParams::pdf2htmlex_data_path();
param.poppler_data_dir = odr::GlobalParams::poppler_data_path();
param.debug = 0;
param.proof = 0;
param.quiet = 1;
Expand Down Expand Up @@ -220,19 +220,12 @@ html::create_poppler_pdf_service(const PopplerPdfFile &pdf_file,
}
}

globalParams = std::make_unique<GlobalParams>(
!html_renderer_param->poppler_data_dir.empty()
? html_renderer_param->poppler_data_dir.c_str()
: nullptr);

// TODO not sure what the `progPath` is used for. it cannot be `nullptr`
// TODO potentially just a cache dir?
auto html_renderer = std::make_shared<pdf2htmlEX::HTMLRenderer>(
config.fontforge_data_path.c_str(), *html_renderer_param);
odr::GlobalParams::fontforge_data_path().c_str(), *html_renderer_param);
html_renderer->process(&pdf_doc);

globalParams.reset();

HtmlResourceLocator resource_locator =
local_resource_locator(output_path, config);

Expand All @@ -259,17 +252,12 @@ Html html::translate_poppler_pdf_file(const PopplerPdfFile &pdf_file,
}
}

globalParams = std::make_unique<GlobalParams>(
!param.poppler_data_dir.empty() ? param.poppler_data_dir.c_str()
: nullptr);

// TODO not sure what the `progPath` is used for. it cannot be `nullptr`
// TODO potentially just a cache dir?
pdf2htmlEX::HTMLRenderer(config.fontforge_data_path.c_str(), param)
pdf2htmlEX::HTMLRenderer(odr::GlobalParams::fontforge_data_path().c_str(),
param)
.process(&pdf_doc);

globalParams.reset();

return {FileType::portable_document_format,
config,
{{"document", output_path + "/document.html"}}};
Expand Down

0 comments on commit 0f5e42e

Please sign in to comment.