[PATCH] fix system-abseil build even with 2022 version
authorRene Engelhard <rene@rene-engelhard.de>
Fri, 15 Dec 2023 22:45:04 +0000 (23:45 +0100)
committerRene Engelhard <rene@debian.org>
Wed, 10 Jul 2024 17:15:44 +0000 (17:15 +0000)
actually it seems it was a internal abseil header from pdfium vs. system
header mismatch. Include proper absl/container/inlined_vector.h if using
system-abseil.

While at it we can also just use pkg-config, no idea why I did it
without back then. Also gets the advantage that it knows that the libs
needed for absl_inlined_vector is actually
-labsl_throw_delegate -labsl_raw_logging_internal -labsl_log_severity

This effectively reverts e89723103313ec4366ee58144c47d7a5c16bf838

Change-Id: Ide4f79860b4e0673c5c6587d503058bdd2930744

Gbp-Pq: Name fix-system-abseil-build.diff

configure.ac
external/pdfium/Library_pdfium.mk
external/pdfium/UnpackedTarball_pdfium.mk
external/pdfium/annot.patch.1
external/pdfium/system-abseil.diff [new file with mode: 0644]

index bb8f9e953883cb93bcdfa850955928c5847294ba..3079e690862d1a6053dd1f9bf906bf63f46f1a1f 100644 (file)
Binary files a/configure.ac and b/configure.ac differ
index fc0903d873d117e8fe7ed8b69e6574b373e7c6d5..85f9d953b75295765ffae0022840fadfeb0f5545 100644 (file)
@@ -40,6 +40,11 @@ $(eval $(call gb_Library_add_defs,pdfium,\
     -DUSE_SYSTEM_LIBOPENJPEG2 \
 ))
 endif
+ifeq ($(SYSTEM_ABSEIL),TRUE)
+$(eval $(call gb_Library_add_defs,pdfium,\
+    -DUSE_SYSTEM_ABSEIL \
+))
+endif
 
 
 $(eval $(call gb_Library_set_generated_cxx_suffix,pdfium,cpp))
index 73f8c2f528f4e5552e94d5457a7546652e6fceba..58ff8cea7986748a7d7aa0464c0b5681bd377ebd 100644 (file)
@@ -18,6 +18,8 @@ pdfium_patches += constexpr-template.patch
 
 pdfium_patches += annot.patch.1
 
+pdfium_patches += system-abseil.diff
+
 $(eval $(call gb_UnpackedTarball_UnpackedTarball,pdfium))
 
 $(eval $(call gb_UnpackedTarball_set_tarball,pdfium,$(PDFIUM_TARBALL)))
index 330685962b4e41b16bd568690346101b9154b55b..178bf4dc61eaf61a62fab687de559a8540c79866 100644 (file)
@@ -2,6 +2,17 @@ diff --git a/fpdfsdk/fpdf_annot.cpp b/fpdfsdk/fpdf_annot.cpp
 index bc1f7f7eb..075baf1df 100644
 --- a/fpdfsdk/fpdf_annot.cpp
 +++ b/fpdfsdk/fpdf_annot.cpp
+@@ -8,6 +8,10 @@
+ #include <sstream>
+ #include <utility>
+ #include <vector>
++#ifdef USE_SYSTEM_ABSEIL
++#include <optional>
++#include <absl/types/optional.h>
++#endif
+ #include "constants/annotation_common.h"
+ #include "core/fpdfapi/edit/cpdf_pagecontentgenerator.h"
 @@ -1366,6 +1366,42 @@ FPDFAnnot_GetFontSize(FPDF_FORMHANDLE hHandle,
    return true;
  }
@@ -32,7 +43,7 @@ index bc1f7f7eb..075baf1df 100644
 +  if (!pWidget)
 +    return false;
 +
-+  std::optional<FX_COLORREF> text_color = pWidget->GetTextColor();
++  absl::optional<FX_COLORREF> text_color = pWidget->GetTextColor();
 +  if (!text_color)
 +    return false;
 +
diff --git a/external/pdfium/system-abseil.diff b/external/pdfium/system-abseil.diff
new file mode 100644 (file)
index 0000000..841bc8c
--- /dev/null
@@ -0,0 +1,15 @@
+--- core/fpdfapi/page/cpdf_sampledfunc.cpp     2023-12-15 23:27:10.955659091 +0100
++++ core/fpdfapi/page/cpdf_sampledfunc.cpp     2023-12-15 23:27:43.420136476 +0100
+@@ -16,8 +16,11 @@
+ #include "core/fxcrt/cfx_bitstream.h"
+ #include "core/fxcrt/fx_memory_wrappers.h"
+ #include "core/fxcrt/fx_safe_types.h"
++#ifdef USE_SYSTEM_ABSEIL
++#include <absl/container/inlined_vector.h>
++#else
+ #include "third_party/abseil-cpp/absl/container/inlined_vector.h"
+-
++#endif
+ namespace {
+ // See PDF Reference 1.7, page 170, table 3.36.