Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Build with pdf2htmlEX #380

Merged
merged 106 commits into from
Sep 14, 2024
Merged
Show file tree
Hide file tree
Changes from 100 commits
Commits
Show all changes
106 commits
Select commit Hold shift + click to select a range
fa02f29
Build with pdf2htmlEX
ViliusSutkus89 Aug 7, 2024
ce3d376
Macos-14 image is actually arm64, not x86_64. Fix conan profile
ViliusSutkus89 Aug 7, 2024
cf15af3
Add odr to default remote position, not 0. This may reduce some load …
ViliusSutkus89 Aug 7, 2024
21d9043
Use msvc-19.40 compiler instead of 19.39
ViliusSutkus89 Aug 7, 2024
2a5baf1
Disable msvc compiler
ViliusSutkus89 Aug 8, 2024
e38d0c8
Revert "Disable msvc compiler"
ViliusSutkus89 Aug 8, 2024
0176499
Don't depend on pdf2htmlEX when building for Windows
ViliusSutkus89 Aug 8, 2024
75b9f56
Revert msvc compiler to 19.39. Remove pdf2htmlEX config from it's con…
ViliusSutkus89 Aug 8, 2024
11060cc
Add msvc-19.40, alongside 19.39
ViliusSutkus89 Aug 8, 2024
51321cb
Raise min cppstd to 20
ViliusSutkus89 Aug 8, 2024
ce3fd9b
"Fix" shared/fPIC build options. BUILD_SHARED_LIBS is already passed …
ViliusSutkus89 Aug 8, 2024
597955f
Add with_pdf2htmlEX option. Attempt to default disable for Windows. M…
ViliusSutkus89 Aug 8, 2024
2f0978d
Remove with_pdf2htmlEX option on Windows
ViliusSutkus89 Aug 8, 2024
982abb6
Link against pdf2htmlEX in CMake
ViliusSutkus89 Aug 8, 2024
7302ce1
Pass WITH_PDF2HTMLEX parameter to CMake correctly
ViliusSutkus89 Aug 8, 2024
326dab5
Merge branch 'main' into pdf2htmlex-conan
ViliusSutkus89 Aug 10, 2024
2be61ef
Merge branch 'main' into pdf2htmlex-conan
ViliusSutkus89 Aug 13, 2024
16f27e8
Merge branch 'main' into pdf2htmlex-conan
ViliusSutkus89 Aug 13, 2024
6fe7b1c
Add pdf2htmlEX_wrapper, actually call pdf2htmlEX
ViliusSutkus89 Aug 15, 2024
c4475b7
Format pdf2htmlEX_wrapper.cpp
ViliusSutkus89 Aug 15, 2024
5c37f20
Upgrade pdf2htmlEX to 20240814-git
ViliusSutkus89 Aug 15, 2024
581767d
Compile with original pdf files, even if they aren't used at runtime.…
ViliusSutkus89 Aug 15, 2024
cc091d9
Process annotation, don't process outline. Ignore drm. DRM is for cop…
ViliusSutkus89 Aug 15, 2024
71622a0
formatting
ViliusSutkus89 Aug 15, 2024
1c00561
Merge branch 'main' into pdf2htmlex-conan
ViliusSutkus89 Aug 16, 2024
b808def
Merge branch 'main' into pdf2htmlex-conan
ViliusSutkus89 Aug 16, 2024
5ff2c61
Fix macos-14 pdf2htmlEX conan profile
ViliusSutkus89 Aug 16, 2024
b7120b9
Remove pdf2htmlEX-config. Default options should work now
ViliusSutkus89 Aug 16, 2024
b0fab38
Merge branch 'main' into pdf2htmlex-conan
ViliusSutkus89 Aug 18, 2024
538fe12
Merge branch 'main' into pdf2htmlex-conan
ViliusSutkus89 Aug 21, 2024
4e65796
Build with wvWare
ViliusSutkus89 Aug 21, 2024
05af0da
inline errorPrinter
ViliusSutkus89 Aug 21, 2024
bac6e12
cmakedefine WITH_PDF2HTMLEX and WITH_WVWARE in project_info.hpp
ViliusSutkus89 Aug 21, 2024
9f3ee87
Introduce Html OpenDocumentReader::pdf2htmlEX() instead of using html…
ViliusSutkus89 Aug 21, 2024
0578221
Add and expose wvWare_wrapper
ViliusSutkus89 Aug 21, 2024
3728064
Formatting
ViliusSutkus89 Aug 21, 2024
cba968e
#include unistd.h in wvWare_wrapper.cpp to find unlink()
ViliusSutkus89 Aug 21, 2024
e5b1f72
Formatting
ViliusSutkus89 Aug 21, 2024
35298f9
Don't build dependencies in CI, they should be built already. Error o…
ViliusSutkus89 Aug 21, 2024
4e090c4
Merge branch 'main' into pdf2htmlex-conan
ViliusSutkus89 Aug 21, 2024
4299c5d
Revert accidentally changed formatting in html.cpp
ViliusSutkus89 Aug 22, 2024
1596670
Update wvWare wrapper
ViliusSutkus89 Aug 22, 2024
3e4f52b
clang format wvWare_wrapper.cpp
ViliusSutkus89 Aug 22, 2024
2e164be
Update wvWare wrapper
ViliusSutkus89 Aug 22, 2024
7dd61fc
Install .hpp files from ${CMAKE_CURRENT_BINARY_DIR}/src/ too (generat…
ViliusSutkus89 Aug 22, 2024
05cb086
Update WVDATADIR setting
ViliusSutkus89 Aug 25, 2024
9d2f359
Install .h headers too
ViliusSutkus89 Aug 25, 2024
79ac7b3
Update header installation. Install .h headers too, not just .hpp
ViliusSutkus89 Aug 25, 2024
c385c8c
Update wvWare and pdf2htmlEX wrappers
ViliusSutkus89 Aug 25, 2024
79d8117
Formatting
ViliusSutkus89 Aug 25, 2024
9bcdfe7
Allow passing passwords to pdf2htmlEX and wvWare
ViliusSutkus89 Aug 25, 2024
eab720e
Clean-up wvWare
ViliusSutkus89 Aug 25, 2024
9799978
More wvWare cleanup
ViliusSutkus89 Aug 25, 2024
2f9389a
More wvWare cleanup
ViliusSutkus89 Aug 25, 2024
f9bdad4
Fix header install
ViliusSutkus89 Aug 25, 2024
19f2a64
Update with_pdf2htmlEX and with_wvWare options, allow, but default Fa…
ViliusSutkus89 Aug 26, 2024
ae8acdc
Move wvWare.c to wvWare conan package
ViliusSutkus89 Aug 26, 2024
0322ffb
Format wvWare_wrapper.cpp
ViliusSutkus89 Aug 26, 2024
cde62f8
Unexpose pdf2htmlEX and wvWare in odr::OpenDocumentReader class
ViliusSutkus89 Aug 27, 2024
a010d3d
Add std::optional header include in wvWare_wrapper header
ViliusSutkus89 Aug 27, 2024
3343f18
Remove leftover headers from wvWare_wrapper
ViliusSutkus89 Aug 27, 2024
7f31990
Add pdf2htmlEX wrapper tests. Will probably fail, because of missing …
ViliusSutkus89 Aug 28, 2024
8466d39
[2/2] Add pdf2htmlEX wrapper tests
ViliusSutkus89 Aug 28, 2024
fa7803a
Format pdf2htmlEX_wrapper_test
ViliusSutkus89 Aug 28, 2024
04fd03d
Fix env vars in pdf2htmlEX and wvWare
ViliusSutkus89 Aug 28, 2024
7a3e1e9
add wvWare wrapper tests
ViliusSutkus89 Aug 28, 2024
ddbb7b4
Formatting
ViliusSutkus89 Aug 28, 2024
714a3b1
Don't build with pdf2htmlEX on Macos, no idea how it wasn't build bre…
ViliusSutkus89 Aug 28, 2024
c30a155
Supply password to password protected test in pdf2htmlEX wrapper test
ViliusSutkus89 Aug 28, 2024
961ccbb
Skip password protected files in wvWare wrapper test
ViliusSutkus89 Aug 28, 2024
80b356a
Disable wvWare on Macos
ViliusSutkus89 Aug 28, 2024
1d0fcd4
Fix password for encrypted_fontfile3_opentype.pdf
ViliusSutkus89 Aug 31, 2024
ed6122a
Try test on ubuntu-22.04/gcc-13
ViliusSutkus89 Sep 1, 2024
b101505
[2/2]Try test on ubuntu-22.04/gcc-13
ViliusSutkus89 Sep 1, 2024
9e7df8f
Try gcc-12 instead of gcc-13
ViliusSutkus89 Sep 1, 2024
1fb92b5
Remove gcc-12
ViliusSutkus89 Sep 1, 2024
fd01c3f
Attempt to print stacktrace to figure out what the exception is
ViliusSutkus89 Sep 1, 2024
3490508
Include execinfo header. Print test file
ViliusSutkus89 Sep 1, 2024
2d751a2
print stacktrace only on gcc
ViliusSutkus89 Sep 1, 2024
3511801
Format
ViliusSutkus89 Sep 1, 2024
76375fb
Add extra test output
ViliusSutkus89 Sep 1, 2024
a38b9ba
Print stacktrace on clang too
ViliusSutkus89 Sep 1, 2024
e4c2fff
Temporarily disable macos and msvc tests
ViliusSutkus89 Sep 1, 2024
1894686
formatting
ViliusSutkus89 Sep 1, 2024
dd67e28
Temporarily disable build-test-downstream and docker
ViliusSutkus89 Sep 1, 2024
5ed5d73
Add more instrumentation
ViliusSutkus89 Sep 1, 2024
aa4b752
Reenable tests
ViliusSutkus89 Sep 1, 2024
6fa428d
Merge branch 'main' into pdf2htmlex-conan
ViliusSutkus89 Sep 1, 2024
64cec06
[2/2] reenable tests
ViliusSutkus89 Sep 1, 2024
7706a94
Add more instrumentation
ViliusSutkus89 Sep 1, 2024
50bbb4d
Format
ViliusSutkus89 Sep 1, 2024
4e99ad4
Update test filtering
ViliusSutkus89 Sep 1, 2024
aa8e3f8
Artifact and download .conan2 dir. Test job needs this
ViliusSutkus89 Sep 2, 2024
a21fb29
test speed of compression levels
ViliusSutkus89 Sep 2, 2024
d23ae95
Set artifact compression level to 0
ViliusSutkus89 Sep 2, 2024
06903d0
Keep default compression level for first artifact
ViliusSutkus89 Sep 2, 2024
9c7b4ab
Remove previously added rdynamic cxxflag and exception stacktrace pri…
ViliusSutkus89 Sep 2, 2024
8758438
Update submodules
ViliusSutkus89 Sep 3, 2024
afbac96
Remove pdf2htmlEX ad wvWare from reference outputs, when running test…
ViliusSutkus89 Sep 3, 2024
5ea4cc1
Reduce instrumentation in pdf2htmlEX_wrapper and _test
ViliusSutkus89 Sep 3, 2024
65c3c9b
Call target_sources instead of appending source files
ViliusSutkus89 Sep 4, 2024
0f69469
Move pdf2htmlEX and wvWare test output to output-pdf2htmlEX and outpu…
ViliusSutkus89 Sep 4, 2024
a744ecd
Remove extra empty line that was previously added
ViliusSutkus89 Sep 4, 2024
637105e
Formatting
ViliusSutkus89 Sep 4, 2024
f975773
Add pdf2htmlEX workaround to screenshotter in html_render_diff
ViliusSutkus89 Sep 4, 2024
b945cbe
Update PDF2HTMLEX_DATA_DIR, POPPLER_DATA_DIR, FONTCONFIG_PATH and WVD…
ViliusSutkus89 Sep 5, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
26 changes: 26 additions & 0 deletions .github/workflows/build_test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,14 @@ jobs:
build/test/odr_test
build/test/Release/odr_test.exe

- name: Artifact .conan2/p dir
uses: actions/upload-artifact@v4
with:
name: conan2-${{ matrix.os }}-${{ matrix.compiler }}
path: ~/.conan2/p
if-no-files-found: error
compression-level: 0

docker:
needs: build
runs-on: ${{ matrix.os }}
Expand Down Expand Up @@ -177,6 +185,18 @@ jobs:
token: ${{ secrets.PAT_ANDIWAND }}
submodules: true

# @TODO: Solve this somehow better
# pdf2htmlEX and wvWare is available only on Linux (and Android)
# This means that odr_test will not produce outputs pdf2htmlEX and wvWare outputs to match what's in
# reference-outputs directory. Remove these from reference outputs, for now.
- name: Remove pdf2htmlEX and wvWare from reference outputs
if: runner.os != 'Linux'
run: |
rm -r \
test/data/reference-output/odr-private/output/pdf2htmlEX \
test/data/reference-output/odr-public/output/pdf2htmlEX \
test/data/reference-output/odr-public/output/wvWare

- name: ubuntu install tidy
if: runner.os == 'Linux'
run: sudo apt install tidy
Expand All @@ -197,6 +217,12 @@ jobs:
name: bin-${{ matrix.os }}-${{ matrix.compiler }}
path: .

- name: Download .conan2/p dir
uses: actions/download-artifact@v4
with:
name: conan2-${{ matrix.os }}-${{ matrix.compiler }}
path: ~/.conan2/p

- name: fix artifact permissions
if: runner.os != 'Windows'
run: chmod +x build/test/odr_test
Expand Down
28 changes: 26 additions & 2 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,12 @@ set(CMAKE_CXX_STANDARD 20)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
set(CMAKE_CXX_EXTENSIONS OFF)

option(BUILD_SHARED_LIBS "Build using shared libraries" ON)
option(ODR_TEST "enable tests" OFF)
option(ODR_CLI "enable command line interface" ON)
option(ODR_CLANG_TIDY "Run clang-tidy static analysis" OFF)
option(WITH_PDF2HTMLEX "Build with pdf2htmlEX" ON)
option(WITH_WVWARE "Build with wvWare" ON)

# TODO defining global compiler flags seems to be bad practice with conan
# TODO consider using conan profiles
Expand Down Expand Up @@ -37,6 +40,7 @@ find_package(uchardet REQUIRED)
find_package(utf8cpp REQUIRED)

configure_file("src/odr/internal/project_info.cpp.in" "src/odr/internal/project_info.cpp")
configure_file("src/odr/internal/project_info.hpp.in" "src/odr/internal/project_info.hpp")

set(PRE_CONFIGURE_FILE "src/odr/internal/git_info.cpp.in")
set(POST_CONFIGURE_FILE "${CMAKE_CURRENT_BINARY_DIR}/src/odr/internal/git_info.cpp")
Expand Down Expand Up @@ -171,12 +175,23 @@ set(ODR_SOURCE_FILES
"src/odr/internal/zip/zip_file.cpp"
"src/odr/internal/zip/zip_util.cpp"
)
if(WITH_PDF2HTMLEX)
LIST(APPEND ODR_SOURCE_FILES
"src/odr/internal/html/pdf2htmlEX_wrapper.cpp"
)
endif(WITH_PDF2HTMLEX)
if(WITH_WVWARE)
LIST(APPEND ODR_SOURCE_FILES
"src/odr/internal/html/wvWare_wrapper.cpp"
)
endif(WITH_WVWARE)

add_library(odr ${ODR_SOURCE_FILES})
set_target_properties(odr PROPERTIES OUTPUT_NAME odr)
target_include_directories(odr
PUBLIC
src
${CMAKE_CURRENT_BINARY_DIR}/src
)
target_link_libraries(odr
PRIVATE
Expand All @@ -189,6 +204,15 @@ target_link_libraries(odr
utf8::cpp
)

if(WITH_PDF2HTMLEX)
find_package(pdf2htmlEX REQUIRED)
target_link_libraries(odr PRIVATE pdf2htmlex::pdf2htmlex)
endif(WITH_PDF2HTMLEX)
if(WITH_WVWARE)
find_package(wvware REQUIRED)
target_link_libraries(odr PRIVATE wvware::wvware)
endif(WITH_WVWARE)

if (EXISTS "${PROJECT_SOURCE_DIR}/.git")
add_dependencies(odr check_git)
endif ()
Expand All @@ -206,8 +230,8 @@ if (ODR_CLANG_TIDY)
endif ()

install(
DIRECTORY src/
DESTINATION include/
DIRECTORY src/ ${CMAKE_CURRENT_BINARY_DIR}/src/
DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}
FILES_MATCHING PATTERN "*.hpp"
)
install(
Expand Down
32 changes: 25 additions & 7 deletions conanfile.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
from conan import ConanFile
from conan.tools.build import check_min_cppstd
from conan.tools.cmake import CMakeToolchain, CMakeDeps, CMake
from conan.tools.env import Environment
from conan.tools.env.environment import EnvVars
from conan.tools.files import copy


Expand All @@ -19,6 +21,8 @@ class OpenDocumentCoreConan(ConanFile):
options = {
"shared": [True, False],
"fPIC": [True, False],
"with_pdf2htmlEX": [True, False],
"with_wvWare": [True, False],
}
default_options = {
"shared": False,
Expand All @@ -33,6 +37,10 @@ def requirements(self):
self.requires("vincentlaucsb-csv-parser/2.3.0")
self.requires("uchardet/0.0.8")
self.requires("utfcpp/4.0.4")
if self.options.get_safe("with_pdf2htmlEX"):
self.requires("pdf2htmlex/0.18.8.rc1-20240814-git")
if self.options.get_safe("with_wvWare"):
self.requires("wvware/1.2.9")

def build_requirements(self):
self.test_requires("gtest/1.14.0")
Expand All @@ -47,6 +55,9 @@ def config_options(self):
if self.settings.os == "Windows":
del self.options.fPIC

self.options.with_pdf2htmlEX = self.settings.os not in ["Windows", "Macos"]
self.options.with_wvWare = self.settings.os not in ["Windows", "Macos"]

def configure(self):
if self.options.shared:
self.options.rm_safe("fPIC")
Expand All @@ -55,6 +66,20 @@ def generate(self):
tc = CMakeToolchain(self)
tc.variables["CMAKE_PROJECT_VERSION"] = self.version
tc.variables["ODR_TEST"] = False
tc.variables["WITH_PDF2HTMLEX"] = self.options.get_safe("with_pdf2htmlEX", False)
tc.variables["WITH_WVWARE"] = self.options.get_safe("with_wvWare", False)

# Get runenv info, exported by package_info() of dependencies
# We need to obtain PDF2HTMLEX_DATA_DIR, POPPLER_DATA_DIR, FONTCONFIG_PATH and WVDATADIR
runenv_info = Environment()
deps = self.dependencies.host.topological_sort
deps = [dep for dep in reversed(deps.values())]
for dep in deps:
runenv_info.compose_env(dep.runenv_info)
envvars = runenv_info.vars(self)
for v in ["PDF2HTMLEX_DATA_DIR", "POPPLER_DATA_DIR", "FONTCONFIG_PATH", "WVDATADIR"]:
tc.variables[v] = envvars.get(v)

tc.generate()

deps = CMakeDeps(self)
Expand All @@ -66,13 +91,6 @@ def build(self):
cmake.build()

def package(self):
copy(
self,
"*.hpp",
src=os.path.join(self.recipe_folder, "src"),
dst=os.path.join(self.export_sources_folder, "include"),
)

cmake = CMake(self)
cmake.install()

Expand Down
72 changes: 72 additions & 0 deletions src/odr/internal/html/pdf2htmlEX_wrapper.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
#include <odr/internal/html/pdf2htmlEX_wrapper.hpp>

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

#include <odr/internal/common/file.hpp>

#include <pdf2htmlEX.h>

#include <odr/internal/project_info.hpp>

namespace odr::internal {

static void ensure_env_vars() {
static const char *pdf2htmlEX_data_dir = getenv("PDF2HTMLEX_DATA_DIR");
if (nullptr == pdf2htmlEX_data_dir) {
pdf2htmlEX_data_dir = PDF2HTMLEX_DATA_DIR;
setenv("PDF2HTMLEX_DATA_DIR", pdf2htmlEX_data_dir, 0);
andiwand marked this conversation as resolved.
Show resolved Hide resolved
}

static const char *poppler_data_dir = getenv("POPPLER_DATA_DIR");
if (nullptr == poppler_data_dir) {
poppler_data_dir = POPPLER_DATA_DIR;
setenv("POPPLER_DATA_DIR", poppler_data_dir, 0);
}

static const char *fontconfig_path = getenv("FONTCONFIG_PATH");
if (nullptr == fontconfig_path) {
fontconfig_path = FONTCONFIG_PATH;
setenv("FONTCONFIG_PATH", fontconfig_path, 0);
}
}

Html html::pdf2htmlEX_wrapper(const std::string &input_path,
const std::string &output_path,
const HtmlConfig &config,
std::optional<std::string> &password) {
ensure_env_vars();

pdf2htmlEX::pdf2htmlEX pdf2htmlEX;

pdf2htmlEX.setInputFilename(input_path);
pdf2htmlEX.setDestinationDir(output_path);
auto output_file_name = "document.html";
pdf2htmlEX.setOutputFilename(output_file_name);

pdf2htmlEX.setDRM(false);
pdf2htmlEX.setProcessOutline(false);
pdf2htmlEX.setProcessAnnotation(true);

if (password.has_value()) {
pdf2htmlEX.setOwnerPassword(password.value());
pdf2htmlEX.setUserPassword(password.value());
}

try {
pdf2htmlEX.convert();
} catch (const pdf2htmlEX::EncryptionPasswordException &e) {
throw WrongPassword();
} catch (const pdf2htmlEX::DocumentCopyProtectedException &e) {
throw std::runtime_error("document is copy protected");
} catch (const pdf2htmlEX::ConversionFailedException &e) {
throw std::runtime_error(std::string("conversion error ") + e.what());
}

return {FileType::portable_document_format,
config,
{{"document", output_path + "/" + output_file_name}}};
}

} // namespace odr::internal
23 changes: 23 additions & 0 deletions src/odr/internal/html/pdf2htmlEX_wrapper.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
#ifndef ODR_INTERNAL_PDF2HTMLEX_WRAPPER_HPP
#define ODR_INTERNAL_PDF2HTMLEX_WRAPPER_HPP

#include <optional>
#include <string>

namespace odr {
class PdfFile;

struct HtmlConfig;
class Html;
} // namespace odr

namespace odr::internal::html {

Html pdf2htmlEX_wrapper(const std::string &input_path,
const std::string &output_path,
const HtmlConfig &config,
std::optional<std::string> &password);

}

#endif // ODR_INTERNAL_PDF2HTMLEX_WRAPPER_HPP
58 changes: 58 additions & 0 deletions src/odr/internal/html/wvWare_wrapper.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
#include <odr/exceptions.hpp>
#include <odr/file.hpp>
#include <odr/html.hpp>
#include <odr/internal/common/file.hpp>
#include <odr/internal/html/wvWare_wrapper.hpp>
#include <odr/internal/project_info.hpp>
#include <unistd.h>
#include <wv/wv.h>

namespace odr::internal::html {

static void ensure_env_vars() {
static const char *wvdatadir = getenv("WVDATADIR");
if (nullptr == wvdatadir) {
wvdatadir = WVDATADIR;
setenv("WVDATADIR", wvdatadir, 0);
}
}

Html wvWare_wrapper(const std::string &input_path,
const std::string &output_path, const HtmlConfig &config,
std::optional<std::string> &password) {
ensure_env_vars();

auto output_file_path = output_path + "/document.html";

char *input_file_path = strdup(input_path.c_str());
char *output_dir = strdup(output_path.c_str());

g_htmlOutputFileHandle = fopen(output_file_path.c_str(), "w");

std::string pw;
if (password.has_value()) {
pw = password.value();
}
int retVal = wvHtml_convert(input_file_path, output_dir, pw.c_str());
free(output_dir);
free(input_file_path);
fclose(g_htmlOutputFileHandle);
g_htmlOutputFileHandle = nullptr;

if (0 != retVal) {
unlink(output_file_path.c_str());

switch (retVal) {
case 100: // PasswordRequired
case 101: // Wrong Password
throw WrongPassword();
default:
throw std::runtime_error("Conversion error");
}
}

return {
FileType::legacy_word_document, config, {{"document", output_file_path}}};
}

} // namespace odr::internal::html
22 changes: 22 additions & 0 deletions src/odr/internal/html/wvWare_wrapper.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
#ifndef ODR_INTERNAL_WVWARE_WRAPPER_HPP
#define ODR_INTERNAL_WVWARE_WRAPPER_HPP

#include <optional>
#include <string>

namespace odr {
class File;

struct HtmlConfig;
class Html;
} // namespace odr

namespace odr::internal::html {

Html wvWare_wrapper(const std::string &input_path,
const std::string &output_path, const HtmlConfig &config,
std::optional<std::string> &password);

}

#endif // ODR_INTERNAL_WVWARE_WRAPPER_HPP
8 changes: 0 additions & 8 deletions src/odr/internal/project_info.hpp

This file was deleted.

15 changes: 15 additions & 0 deletions src/odr/internal/project_info.hpp.in
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
#ifndef ODR_INTERNAL_PROJECT_INFO_HPP
#define ODR_INTERNAL_PROJECT_INFO_HPP

namespace odr::internal::project_info {
const char *version() noexcept;
} // namespace odr::internal::project_info

#cmakedefine WITH_PDF2HTMLEX 1
andiwand marked this conversation as resolved.
Show resolved Hide resolved
#cmakedefine PDF2HTMLEX_DATA_DIR "@PDF2HTMLEX_DATA_DIR@"
#cmakedefine POPPLER_DATA_DIR "@POPPLER_DATA_DIR@"
#cmakedefine FONTCONFIG_PATH "@FONTCONFIG_PATH@"
#cmakedefine WITH_WVWARE 1
#cmakedefine WVDATADIR "@WVDATADIR@"

#endif // ODR_INTERNAL_PROJECT_INFO_HPP
Loading
Loading