Various updates and fixes
This commit is contained in:
@@ -0,0 +1,5 @@
|
||||
AUX inkscape-1.4-gcc15.patch 1088 BLAKE2B 56e9e4e14d87d20d7a03e388105ccdaa219fc26146c771c2c6942ca82abee54fb43d0807ce0ddf59cc77ec6e5184db5e628980209f5eda651ac6ee09af96f74e SHA512 b6f18c645c9946a7052c2d93df1475f1d9db626f200754b767f4372c17e056389c93fc129385d1c9ed3f0e329866696adfb8a61f6e4bc4058c23f20324287072
|
||||
AUX inkscape-1.4-poppler-24.10-fix-backport.patch 19196 BLAKE2B 02f58958180e2362f1e11a1cbacd72611b37cdaa41abd922df6106ef5485f243ef105286a92727b5731a4d0f607846a3e0a48fa53e3b9542d3667f136fd07f9b SHA512 6283ccd63157bc8ccdcf6127afa72cb50a72a9f09ec2327a5f180f0eb2d212e5600ed0f3d31df845cf6d20c2fe84d01f1edb126f39456a27de36cca616495fb9
|
||||
DIST inkscape-1.4.tar.xz 46321868 BLAKE2B 3f21402019995122f043f5ebd8f07e1c9548c507f27c494e4214e090c46acae016c21f950609c95cef2e1b0011693e6629326d733b257402391e2d919bcd0303 SHA512 3b81306b81416597073e7eda2a103112cee63493bcf96fa737bb1edfbd682ebb329e415bbbbfda877aef2a78dc376460040ebc5c0cc2c90c0fe60db5d7d12368
|
||||
EBUILD inkscape-1.4.ebuild 5562 BLAKE2B 42c0b1b622d2ad1c2c25921693379c9863615c344e7f5d8ac49026dd030f606f6dff7bedeaa3774c0482cfa30a779b02e96b6d5ab6b1da1b588109f05c30f342 SHA512 921678f6be488dea5d2de172c505f5faf7600b76f35888c20b9dc386a1e0588acea6c8a431dfe28f8f26159f742d7a0776e722ba4e0b8f993b4fd13a7480fd7e
|
||||
MISC metadata.xml 982 BLAKE2B f44f534865614c8dd7bf71e92ce69cff708fc08e3eb701765bf93144b433ec52df52a506b69cc98969909c695015881b60592cccdf27613c6fe82812fc50727b SHA512 2963a9b473f139d06cefd1c3231ef148045c005adb4688850522c183f39ba15a36331b7eae7752e9bf15a26e6370f2af14ec02e59735f1753246c45821c0cdbc
|
||||
@@ -0,0 +1,21 @@
|
||||
https://bugs.gentoo.org/941674
|
||||
https://gitlab.com/inkscape/inkscape/-/commit/eb6dadcf1a5c660167ba43f3606c8e7cc6529787
|
||||
|
||||
From eb6dadcf1a5c660167ba43f3606c8e7cc6529787 Mon Sep 17 00:00:00 2001
|
||||
From: Liam <byteslice@airmail.cc>
|
||||
Date: Sat, 12 Oct 2024 05:22:29 -0400
|
||||
Subject: [PATCH] gobjectptr: fix member name
|
||||
|
||||
--- a/src/util/gobjectptr.h
|
||||
+++ b/src/util/gobjectptr.h
|
||||
@@ -20,7 +20,7 @@ public:
|
||||
GObjectPtr() = default;
|
||||
explicit GObjectPtr(T *p, bool add_ref = false) : _p(p) { if (add_ref) _ref(); }
|
||||
GObjectPtr(GObjectPtr const &other) : _p(other._p) { _ref(); }
|
||||
- GObjectPtr &operator=(GObjectPtr const &other) { if (&other != this) { _unref(); _p = other.p; _ref(); } return *this; }
|
||||
+ GObjectPtr &operator=(GObjectPtr const &other) { if (&other != this) { _unref(); _p = other._p; _ref(); } return *this; }
|
||||
GObjectPtr(GObjectPtr &&other) noexcept : _p(other._p) { other._p = nullptr; }
|
||||
GObjectPtr &operator=(GObjectPtr &&other) { if (&other != this) { _unref(); _p = other._p; other._p = nullptr; } return *this; }
|
||||
~GObjectPtr() { _unref(); }
|
||||
--
|
||||
GitLab
|
||||
@@ -0,0 +1,432 @@
|
||||
https://bugs.gentoo.org/941933
|
||||
|
||||
From 22304ae8034d067670a9f95022083a75fac92b4c Mon Sep 17 00:00:00 2001
|
||||
From: PBS <pbs3141@gmail.com>
|
||||
Date: Tue, 22 Oct 2024 14:48:31 +0100
|
||||
Subject: [PATCH] Future-proof against poppler 24.10 changes
|
||||
|
||||
---
|
||||
.../internal/pdfinput/pdf-parser.cpp | 120 ++++++++----------
|
||||
src/extension/internal/pdfinput/pdf-parser.h | 4 +-
|
||||
.../pdfinput/poppler-transition-api.h | 6 +
|
||||
3 files changed, 61 insertions(+), 69 deletions(-)
|
||||
|
||||
diff --git a/src/extension/internal/pdfinput/pdf-parser.cpp b/src/extension/internal/pdfinput/pdf-parser.cpp
|
||||
index 97b2909218a..28000a87b0c 100644
|
||||
--- a/src/extension/internal/pdfinput/pdf-parser.cpp
|
||||
+++ b/src/extension/internal/pdfinput/pdf-parser.cpp
|
||||
@@ -817,11 +817,11 @@ void PdfParser::opSetExtGState(Object args[], int /*numArgs*/)
|
||||
_POPPLER_FREE(obj3);
|
||||
if (_POPPLER_CALL_ARGS_DEREF(obj3, obj2.dictLookup, "G").isStream()) {
|
||||
if (_POPPLER_CALL_ARGS_DEREF(obj4, obj3.streamGetDict()->lookup, "Group").isDict()) {
|
||||
- GfxColorSpace *blendingColorSpace = nullptr;
|
||||
+ std::unique_ptr<GfxColorSpace> blendingColorSpace;
|
||||
GBool isolated = gFalse;
|
||||
GBool knockout = gFalse;
|
||||
if (!_POPPLER_CALL_ARGS_DEREF(obj5, obj4.dictLookup, "CS").isNull()) {
|
||||
- blendingColorSpace = GfxColorSpace::parse(nullptr, &obj5, nullptr, state);
|
||||
+ blendingColorSpace = std::unique_ptr<GfxColorSpace>(GfxColorSpace::parse(nullptr, &obj5, nullptr, state));
|
||||
}
|
||||
_POPPLER_FREE(obj5);
|
||||
if (_POPPLER_CALL_ARGS_DEREF(obj5, obj4.dictLookup, "I").isBool()) {
|
||||
@@ -842,7 +842,7 @@ void PdfParser::opSetExtGState(Object args[], int /*numArgs*/)
|
||||
}
|
||||
}
|
||||
}
|
||||
- doSoftMask(&obj3, alpha, blendingColorSpace, isolated, knockout, funcs[0], &backdropColor);
|
||||
+ doSoftMask(&obj3, alpha, blendingColorSpace.get(), isolated, knockout, funcs[0], &backdropColor);
|
||||
if (funcs[0]) {
|
||||
delete funcs[0];
|
||||
}
|
||||
@@ -927,9 +927,6 @@ void PdfParser::doSoftMask(Object *str, GBool alpha,
|
||||
alpha, transferFunc, backdropColor);
|
||||
--formDepth;
|
||||
|
||||
- if (blendingColorSpace) {
|
||||
- delete blendingColorSpace;
|
||||
- }
|
||||
_POPPLER_FREE(obj1);
|
||||
}
|
||||
|
||||
@@ -946,42 +943,43 @@ void PdfParser::opSetRenderingIntent(Object /*args*/[], int /*numArgs*/)
|
||||
*
|
||||
* Maintains a cache for named color spaces to avoid expensive re-parsing.
|
||||
*/
|
||||
-GfxColorSpace *PdfParser::lookupColorSpaceCopy(Object &arg)
|
||||
+std::unique_ptr<GfxColorSpace> PdfParser::lookupColorSpaceCopy(Object &arg)
|
||||
{
|
||||
assert(!arg.isNull());
|
||||
- GfxColorSpace *colorSpace = nullptr;
|
||||
|
||||
if (char const *name = arg.isName() ? arg.getName() : nullptr) {
|
||||
auto const cache_name = std::to_string(formDepth) + "-" + name;
|
||||
- if ((colorSpace = colorSpacesCache[cache_name].get())) {
|
||||
- return colorSpace->copy();
|
||||
+ if (auto cached = colorSpacesCache[cache_name].get()) {
|
||||
+ return std::unique_ptr<GfxColorSpace>(cached->copy());
|
||||
}
|
||||
|
||||
- Object obj = res->lookupColorSpace(name);
|
||||
- if (obj.isNull()) {
|
||||
- colorSpace = GfxColorSpace::parse(res, &arg, nullptr, state);
|
||||
+ std::unique_ptr<GfxColorSpace> colorSpace;
|
||||
+ if (auto obj = res->lookupColorSpace(name); !obj.isNull()) {
|
||||
+ colorSpace = std::unique_ptr<GfxColorSpace>(GfxColorSpace::parse(res, &obj, nullptr, state));
|
||||
} else {
|
||||
- colorSpace = GfxColorSpace::parse(res, &obj, nullptr, state);
|
||||
+ colorSpace = std::unique_ptr<GfxColorSpace>(GfxColorSpace::parse(res, &arg, nullptr, state));
|
||||
}
|
||||
|
||||
if (colorSpace && colorSpace->getMode() != csPattern) {
|
||||
- colorSpacesCache[cache_name].reset(colorSpace->copy());
|
||||
+ colorSpacesCache[cache_name] = std::unique_ptr<GfxColorSpace>(colorSpace->copy());
|
||||
}
|
||||
+
|
||||
+ return colorSpace;
|
||||
} else {
|
||||
// We were passed in an object directly.
|
||||
- colorSpace = GfxColorSpace::parse(res, &arg, nullptr, state);
|
||||
+ return std::unique_ptr<GfxColorSpace>(GfxColorSpace::parse(res, &arg, nullptr, state));
|
||||
}
|
||||
- return colorSpace;
|
||||
}
|
||||
|
||||
/**
|
||||
* Look up pattern/gradients from the GfxResource dictionary
|
||||
*/
|
||||
-GfxPattern *PdfParser::lookupPattern(Object *obj, GfxState *state)
|
||||
+std::unique_ptr<GfxPattern> PdfParser::lookupPattern(Object *obj, GfxState *state)
|
||||
{
|
||||
- if (!obj->isName())
|
||||
- return nullptr;
|
||||
- return res->lookupPattern(obj->getName(), nullptr, state);
|
||||
+ if (!obj->isName()) {
|
||||
+ return {};
|
||||
+ }
|
||||
+ return std::unique_ptr<GfxPattern>(res->lookupPattern(obj->getName(), nullptr, state));
|
||||
}
|
||||
|
||||
// TODO not good that numArgs is ignored but args[] is used:
|
||||
@@ -990,7 +988,7 @@ void PdfParser::opSetFillGray(Object args[], int /*numArgs*/)
|
||||
GfxColor color;
|
||||
builder->beforeStateChange(state);
|
||||
state->setFillPattern(nullptr);
|
||||
- state->setFillColorSpace(new GfxDeviceGrayColorSpace());
|
||||
+ state->setFillColorSpace(_POPPLER_CONSUME_UNIQPTR_ARG(std::make_unique<GfxDeviceGrayColorSpace>()));
|
||||
color.c[0] = dblToCol(args[0].getNum());
|
||||
state->setFillColor(&color);
|
||||
builder->updateStyle(state);
|
||||
@@ -1002,7 +1000,7 @@ void PdfParser::opSetStrokeGray(Object args[], int /*numArgs*/)
|
||||
GfxColor color;
|
||||
builder->beforeStateChange(state);
|
||||
state->setStrokePattern(nullptr);
|
||||
- state->setStrokeColorSpace(new GfxDeviceGrayColorSpace());
|
||||
+ state->setStrokeColorSpace(_POPPLER_CONSUME_UNIQPTR_ARG(std::make_unique<GfxDeviceGrayColorSpace>()));
|
||||
color.c[0] = dblToCol(args[0].getNum());
|
||||
state->setStrokeColor(&color);
|
||||
builder->updateStyle(state);
|
||||
@@ -1015,7 +1013,7 @@ void PdfParser::opSetFillCMYKColor(Object args[], int /*numArgs*/)
|
||||
int i;
|
||||
builder->beforeStateChange(state);
|
||||
state->setFillPattern(nullptr);
|
||||
- state->setFillColorSpace(new GfxDeviceCMYKColorSpace());
|
||||
+ state->setFillColorSpace(_POPPLER_CONSUME_UNIQPTR_ARG(std::make_unique<GfxDeviceCMYKColorSpace>()));
|
||||
for (i = 0; i < 4; ++i) {
|
||||
color.c[i] = dblToCol(args[i].getNum());
|
||||
}
|
||||
@@ -1029,7 +1027,7 @@ void PdfParser::opSetStrokeCMYKColor(Object args[], int /*numArgs*/)
|
||||
GfxColor color;
|
||||
builder->beforeStateChange(state);
|
||||
state->setStrokePattern(nullptr);
|
||||
- state->setStrokeColorSpace(new GfxDeviceCMYKColorSpace());
|
||||
+ state->setStrokeColorSpace(_POPPLER_CONSUME_UNIQPTR_ARG(std::make_unique<GfxDeviceCMYKColorSpace>()));
|
||||
for (int i = 0; i < 4; ++i) {
|
||||
color.c[i] = dblToCol(args[i].getNum());
|
||||
}
|
||||
@@ -1043,7 +1041,7 @@ void PdfParser::opSetFillRGBColor(Object args[], int /*numArgs*/)
|
||||
GfxColor color;
|
||||
builder->beforeStateChange(state);
|
||||
state->setFillPattern(nullptr);
|
||||
- state->setFillColorSpace(new GfxDeviceRGBColorSpace());
|
||||
+ state->setFillColorSpace(_POPPLER_CONSUME_UNIQPTR_ARG(std::make_unique<GfxDeviceRGBColorSpace>()));
|
||||
for (int i = 0; i < 3; ++i) {
|
||||
color.c[i] = dblToCol(args[i].getNum());
|
||||
}
|
||||
@@ -1056,7 +1054,7 @@ void PdfParser::opSetStrokeRGBColor(Object args[], int /*numArgs*/) {
|
||||
GfxColor color;
|
||||
builder->beforeStateChange(state);
|
||||
state->setStrokePattern(nullptr);
|
||||
- state->setStrokeColorSpace(new GfxDeviceRGBColorSpace());
|
||||
+ state->setStrokeColorSpace(_POPPLER_CONSUME_UNIQPTR_ARG(std::make_unique<GfxDeviceRGBColorSpace>()));
|
||||
for (int i = 0; i < 3; ++i) {
|
||||
color.c[i] = dblToCol(args[i].getNum());
|
||||
}
|
||||
@@ -1068,14 +1066,14 @@ void PdfParser::opSetStrokeRGBColor(Object args[], int /*numArgs*/) {
|
||||
void PdfParser::opSetFillColorSpace(Object args[], int numArgs)
|
||||
{
|
||||
assert(numArgs >= 1);
|
||||
- GfxColorSpace *colorSpace = lookupColorSpaceCopy(args[0]);
|
||||
+ auto colorSpace = lookupColorSpaceCopy(args[0]);
|
||||
builder->beforeStateChange(state);
|
||||
state->setFillPattern(nullptr);
|
||||
|
||||
if (colorSpace) {
|
||||
GfxColor color;
|
||||
- state->setFillColorSpace(colorSpace);
|
||||
colorSpace->getDefaultColor(&color);
|
||||
+ state->setFillColorSpace(_POPPLER_CONSUME_UNIQPTR_ARG(colorSpace));
|
||||
state->setFillColor(&color);
|
||||
builder->updateStyle(state);
|
||||
} else {
|
||||
@@ -1089,14 +1087,14 @@ void PdfParser::opSetStrokeColorSpace(Object args[], int numArgs)
|
||||
assert(numArgs >= 1);
|
||||
builder->beforeStateChange(state);
|
||||
|
||||
- GfxColorSpace *colorSpace = lookupColorSpaceCopy(args[0]);
|
||||
+ auto colorSpace = lookupColorSpaceCopy(args[0]);
|
||||
|
||||
state->setStrokePattern(nullptr);
|
||||
|
||||
if (colorSpace) {
|
||||
GfxColor color;
|
||||
- state->setStrokeColorSpace(colorSpace);
|
||||
colorSpace->getDefaultColor(&color);
|
||||
+ state->setStrokeColorSpace(_POPPLER_CONSUME_UNIQPTR_ARG(colorSpace));
|
||||
state->setStrokeColor(&color);
|
||||
builder->updateStyle(state);
|
||||
} else {
|
||||
@@ -1159,7 +1157,7 @@ void PdfParser::opSetFillColorN(Object args[], int numArgs) {
|
||||
builder->updateStyle(state);
|
||||
}
|
||||
if (auto pattern = lookupPattern(&(args[numArgs - 1]), state)) {
|
||||
- state->setFillPattern(pattern);
|
||||
+ state->setFillPattern(_POPPLER_CONSUME_UNIQPTR_ARG(pattern));
|
||||
builder->updateStyle(state);
|
||||
}
|
||||
|
||||
@@ -1202,7 +1200,7 @@ void PdfParser::opSetStrokeColorN(Object args[], int numArgs) {
|
||||
builder->updateStyle(state);
|
||||
}
|
||||
if (auto pattern = lookupPattern(&(args[numArgs - 1]), state)) {
|
||||
- state->setStrokePattern(pattern);
|
||||
+ state->setStrokePattern(_POPPLER_CONSUME_UNIQPTR_ARG(pattern));
|
||||
builder->updateStyle(state);
|
||||
}
|
||||
|
||||
@@ -1579,11 +1577,11 @@ void PdfParser::doShadingPatternFillFallback(GfxShadingPattern *sPat,
|
||||
// TODO not good that numArgs is ignored but args[] is used:
|
||||
void PdfParser::opShFill(Object args[], int /*numArgs*/)
|
||||
{
|
||||
- GfxShading *shading = nullptr;
|
||||
GfxPath *savedPath = nullptr;
|
||||
bool savedState = false;
|
||||
|
||||
- if (!(shading = res->lookupShading(args[0].getName(), nullptr, state))) {
|
||||
+ auto shading = std::unique_ptr<GfxShading>(res->lookupShading(args[0].getName(), nullptr, state));
|
||||
+ if (!shading) {
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -1615,19 +1613,19 @@ void PdfParser::opShFill(Object args[], int /*numArgs*/)
|
||||
// do shading type-specific operations
|
||||
switch (shading->getType()) {
|
||||
case 1: // Function-based shading
|
||||
- doFunctionShFill(static_cast<GfxFunctionShading *>(shading));
|
||||
+ doFunctionShFill(static_cast<GfxFunctionShading *>(shading.get()));
|
||||
break;
|
||||
case 2: // Axial shading
|
||||
case 3: // Radial shading
|
||||
- builder->addClippedFill(shading, stateToAffine(state));
|
||||
+ builder->addClippedFill(shading.get(), stateToAffine(state));
|
||||
break;
|
||||
case 4: // Free-form Gouraud-shaded triangle mesh
|
||||
case 5: // Lattice-form Gouraud-shaded triangle mesh
|
||||
- doGouraudTriangleShFill(static_cast<GfxGouraudTriangleShading *>(shading));
|
||||
+ doGouraudTriangleShFill(static_cast<GfxGouraudTriangleShading *>(shading.get()));
|
||||
break;
|
||||
case 6: // Coons patch mesh
|
||||
case 7: // Tensor-product patch mesh
|
||||
- doPatchMeshShFill(static_cast<GfxPatchMeshShading *>(shading));
|
||||
+ doPatchMeshShFill(static_cast<GfxPatchMeshShading *>(shading.get()));
|
||||
break;
|
||||
}
|
||||
|
||||
@@ -1636,8 +1634,6 @@ void PdfParser::opShFill(Object args[], int /*numArgs*/)
|
||||
restoreState();
|
||||
state->setPath(savedPath);
|
||||
}
|
||||
-
|
||||
- delete shading;
|
||||
}
|
||||
|
||||
void PdfParser::doFunctionShFill(GfxFunctionShading *shading) {
|
||||
@@ -2528,7 +2524,7 @@ void PdfParser::doImage(Object * /*ref*/, Stream *str, GBool inlineImg)
|
||||
|
||||
} else {
|
||||
// get color space and color map
|
||||
- GfxColorSpace *colorSpace;
|
||||
+ std::unique_ptr<GfxColorSpace> colorSpace;
|
||||
_POPPLER_CALL_ARGS(obj1, dict->lookup, "ColorSpace");
|
||||
if (obj1.isNull()) {
|
||||
_POPPLER_FREE(obj1);
|
||||
@@ -2537,13 +2533,11 @@ void PdfParser::doImage(Object * /*ref*/, Stream *str, GBool inlineImg)
|
||||
if (!obj1.isNull()) {
|
||||
colorSpace = lookupColorSpaceCopy(obj1);
|
||||
} else if (csMode == streamCSDeviceGray) {
|
||||
- colorSpace = new GfxDeviceGrayColorSpace();
|
||||
+ colorSpace = std::make_unique<GfxDeviceGrayColorSpace>();
|
||||
} else if (csMode == streamCSDeviceRGB) {
|
||||
- colorSpace = new GfxDeviceRGBColorSpace();
|
||||
+ colorSpace = std::make_unique<GfxDeviceRGBColorSpace>();
|
||||
} else if (csMode == streamCSDeviceCMYK) {
|
||||
- colorSpace = new GfxDeviceCMYKColorSpace();
|
||||
- } else {
|
||||
- colorSpace = nullptr;
|
||||
+ colorSpace = std::make_unique<GfxDeviceCMYKColorSpace>();
|
||||
}
|
||||
_POPPLER_FREE(obj1);
|
||||
if (!colorSpace) {
|
||||
@@ -2554,10 +2548,9 @@ void PdfParser::doImage(Object * /*ref*/, Stream *str, GBool inlineImg)
|
||||
_POPPLER_FREE(obj1);
|
||||
_POPPLER_CALL_ARGS(obj1, dict->lookup, "D");
|
||||
}
|
||||
- GfxImageColorMap *colorMap = new GfxImageColorMap(bits, &obj1, colorSpace);
|
||||
+ auto colorMap = std::make_unique<GfxImageColorMap>(bits, &obj1, _POPPLER_CONSUME_UNIQPTR_ARG(colorSpace));
|
||||
_POPPLER_FREE(obj1);
|
||||
if (!colorMap->isOk()) {
|
||||
- delete colorMap;
|
||||
goto err1;
|
||||
}
|
||||
|
||||
@@ -2568,7 +2561,7 @@ void PdfParser::doImage(Object * /*ref*/, Stream *str, GBool inlineImg)
|
||||
int maskWidth = 0;
|
||||
int maskHeight = 0;
|
||||
maskInvert = gFalse;
|
||||
- GfxImageColorMap *maskColorMap = nullptr;
|
||||
+ std::unique_ptr<GfxImageColorMap> maskColorMap;
|
||||
_POPPLER_CALL_ARGS(maskObj, dict->lookup, "Mask");
|
||||
_POPPLER_CALL_ARGS(smaskObj, dict->lookup, "SMask");
|
||||
Dict* maskDict;
|
||||
@@ -2624,7 +2617,7 @@ void PdfParser::doImage(Object * /*ref*/, Stream *str, GBool inlineImg)
|
||||
_POPPLER_FREE(obj1);
|
||||
_POPPLER_CALL_ARGS(obj1, maskDict->lookup, "CS");
|
||||
}
|
||||
- GfxColorSpace *maskColorSpace = lookupColorSpaceCopy(obj1);
|
||||
+ auto maskColorSpace = lookupColorSpaceCopy(obj1);
|
||||
_POPPLER_FREE(obj1);
|
||||
if (!maskColorSpace || maskColorSpace->getMode() != csDeviceGray) {
|
||||
goto err1;
|
||||
@@ -2634,10 +2627,9 @@ void PdfParser::doImage(Object * /*ref*/, Stream *str, GBool inlineImg)
|
||||
_POPPLER_FREE(obj1);
|
||||
_POPPLER_CALL_ARGS(obj1, maskDict->lookup, "D");
|
||||
}
|
||||
- maskColorMap = new GfxImageColorMap(maskBits, &obj1, maskColorSpace);
|
||||
+ maskColorMap = std::make_unique<GfxImageColorMap>(maskBits, &obj1, _POPPLER_CONSUME_UNIQPTR_ARG(maskColorSpace));
|
||||
_POPPLER_FREE(obj1);
|
||||
if (!maskColorMap->isOk()) {
|
||||
- delete maskColorMap;
|
||||
goto err1;
|
||||
}
|
||||
//~ handle the Matte entry
|
||||
@@ -2718,17 +2710,15 @@ void PdfParser::doImage(Object * /*ref*/, Stream *str, GBool inlineImg)
|
||||
|
||||
// draw it
|
||||
if (haveSoftMask) {
|
||||
- builder->addSoftMaskedImage(state, str, width, height, colorMap, interpolate,
|
||||
- maskStr, maskWidth, maskHeight, maskColorMap, maskInterpolate);
|
||||
- delete maskColorMap;
|
||||
+ builder->addSoftMaskedImage(state, str, width, height, colorMap.get(), interpolate,
|
||||
+ maskStr, maskWidth, maskHeight, maskColorMap.get(), maskInterpolate);
|
||||
} else if (haveExplicitMask) {
|
||||
- builder->addMaskedImage(state, str, width, height, colorMap, interpolate,
|
||||
+ builder->addMaskedImage(state, str, width, height, colorMap.get(), interpolate,
|
||||
maskStr, maskWidth, maskHeight, maskInvert, maskInterpolate);
|
||||
} else {
|
||||
- builder->addImage(state, str, width, height, colorMap, interpolate,
|
||||
- haveColorKeyMask ? maskColors : static_cast<int *>(nullptr));
|
||||
+ builder->addImage(state, str, width, height, colorMap.get(), interpolate,
|
||||
+ haveColorKeyMask ? maskColors : nullptr);
|
||||
}
|
||||
- delete colorMap;
|
||||
|
||||
_POPPLER_FREE(maskObj);
|
||||
_POPPLER_FREE(smaskObj);
|
||||
@@ -2746,7 +2736,6 @@ void PdfParser::doForm(Object *str, double *offset)
|
||||
{
|
||||
Dict *dict;
|
||||
GBool transpGroup, isolated, knockout;
|
||||
- GfxColorSpace *blendingColorSpace;
|
||||
Object matrixObj, bboxObj;
|
||||
double m[6], bbox[4];
|
||||
Object resObj;
|
||||
@@ -2812,12 +2801,12 @@ void PdfParser::doForm(Object *str, double *offset)
|
||||
|
||||
// check for a transparency group
|
||||
transpGroup = isolated = knockout = gFalse;
|
||||
- blendingColorSpace = nullptr;
|
||||
+ std::unique_ptr<GfxColorSpace> blendingColorSpace;
|
||||
if (_POPPLER_CALL_ARGS_DEREF(obj1, dict->lookup, "Group").isDict()) {
|
||||
if (_POPPLER_CALL_ARGS_DEREF(obj2, obj1.dictLookup, "S").isName("Transparency")) {
|
||||
transpGroup = gTrue;
|
||||
if (!_POPPLER_CALL_ARGS_DEREF(obj3, obj1.dictLookup, "CS").isNull()) {
|
||||
- blendingColorSpace = GfxColorSpace::parse(nullptr, &obj3, nullptr, state);
|
||||
+ blendingColorSpace = std::unique_ptr<GfxColorSpace>(GfxColorSpace::parse(nullptr, &obj3, nullptr, state));
|
||||
}
|
||||
_POPPLER_FREE(obj3);
|
||||
if (_POPPLER_CALL_ARGS_DEREF(obj3, obj1.dictLookup, "I").isBool()) {
|
||||
@@ -2835,12 +2824,9 @@ void PdfParser::doForm(Object *str, double *offset)
|
||||
|
||||
// draw it
|
||||
++formDepth;
|
||||
- doForm1(str, resDict, m, bbox, transpGroup, gFalse, blendingColorSpace, isolated, knockout);
|
||||
+ doForm1(str, resDict, m, bbox, transpGroup, gFalse, blendingColorSpace.get(), isolated, knockout);
|
||||
--formDepth;
|
||||
|
||||
- if (blendingColorSpace) {
|
||||
- delete blendingColorSpace;
|
||||
- }
|
||||
_POPPLER_FREE(resObj);
|
||||
}
|
||||
|
||||
diff --git a/src/extension/internal/pdfinput/pdf-parser.h b/src/extension/internal/pdfinput/pdf-parser.h
|
||||
index c7c10caefed..8325ea24364 100644
|
||||
--- a/src/extension/internal/pdfinput/pdf-parser.h
|
||||
+++ b/src/extension/internal/pdfinput/pdf-parser.h
|
||||
@@ -137,7 +137,7 @@ public:
|
||||
void loadPatternColorProfiles(Dict *resources);
|
||||
void loadColorProfile();
|
||||
void loadColorSpaceProfile(GfxColorSpace *space, Object *obj);
|
||||
- GfxPattern *lookupPattern(Object *obj, GfxState *state);
|
||||
+ std::unique_ptr<GfxPattern> lookupPattern(Object *obj, GfxState *state);
|
||||
|
||||
std::shared_ptr<CairoFontEngine> getFontEngine();
|
||||
|
||||
@@ -176,7 +176,7 @@ private:
|
||||
//! Caches color spaces by name
|
||||
std::map<std::string, std::unique_ptr<GfxColorSpace>> colorSpacesCache;
|
||||
|
||||
- GfxColorSpace *lookupColorSpaceCopy(Object &);
|
||||
+ std::unique_ptr<GfxColorSpace> lookupColorSpaceCopy(Object &);
|
||||
|
||||
void setDefaultApproximationPrecision(); // init color deltas
|
||||
void pushOperator(const char *name);
|
||||
diff --git a/src/extension/internal/pdfinput/poppler-transition-api.h b/src/extension/internal/pdfinput/poppler-transition-api.h
|
||||
index 481aefadf46..8f03aa17779 100644
|
||||
--- a/src/extension/internal/pdfinput/poppler-transition-api.h
|
||||
+++ b/src/extension/internal/pdfinput/poppler-transition-api.h
|
||||
@@ -15,6 +15,12 @@
|
||||
#include <glib/poppler-features.h>
|
||||
#include <poppler/UTF.h>
|
||||
|
||||
+#if POPPLER_CHECK_VERSION(24, 10, 0)
|
||||
+#define _POPPLER_CONSUME_UNIQPTR_ARG(value) std::move(value)
|
||||
+#else
|
||||
+#define _POPPLER_CONSUME_UNIQPTR_ARG(value) value.release()
|
||||
+#endif
|
||||
+
|
||||
#if POPPLER_CHECK_VERSION(24, 5, 0)
|
||||
#define _POPPLER_HAS_UNICODE_BOM(value) (hasUnicodeByteOrderMark(value->toStr()))
|
||||
#define _POPPLER_HAS_UNICODE_BOMLE(value) (hasUnicodeByteOrderMarkLE(value->toStr()))
|
||||
--
|
||||
GitLab
|
||||
|
||||
@@ -0,0 +1,205 @@
|
||||
# Copyright 1999-2024 Gentoo Authors
|
||||
# Distributed under the terms of the GNU General Public License v2
|
||||
|
||||
EAPI=8
|
||||
|
||||
PYTHON_COMPAT=( python3_{10..13} )
|
||||
PYTHON_REQ_USE="xml(+)"
|
||||
|
||||
inherit cmake flag-o-matic xdg toolchain-funcs python-single-r1
|
||||
|
||||
MY_P="${P/_/}"
|
||||
DESCRIPTION="SVG based generic vector-drawing program"
|
||||
HOMEPAGE="https://inkscape.org/ https://gitlab.com/inkscape/inkscape/"
|
||||
|
||||
if [[ ${PV} = 9999* ]]; then
|
||||
inherit git-r3
|
||||
EGIT_REPO_URI="https://gitlab.com/inkscape/inkscape.git"
|
||||
else
|
||||
SRC_URI="https://media.inkscape.org/dl/resources/file/${MY_P}.tar.xz"
|
||||
KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~loong ~ppc ~ppc64 ~riscv ~sparc ~x86"
|
||||
fi
|
||||
|
||||
S="${WORKDIR}/${MY_P}"
|
||||
|
||||
LICENSE="GPL-2 LGPL-2.1"
|
||||
SLOT="0"
|
||||
IUSE="cdr dia exif graphicsmagick imagemagick inkjar jpeg openmp postscript readline sourceview spell svg2 test visio wpg X"
|
||||
REQUIRED_USE="${PYTHON_REQUIRED_USE}"
|
||||
# Lots of test failures which need investigating, bug #871621
|
||||
RESTRICT="!test? ( test ) test"
|
||||
|
||||
BDEPEND="
|
||||
dev-util/glib-utils
|
||||
>=sys-devel/gettext-0.17
|
||||
virtual/pkgconfig
|
||||
test? ( virtual/imagemagick-tools )
|
||||
"
|
||||
COMMON_DEPEND="${PYTHON_DEPS}
|
||||
>=app-text/poppler-0.57.0:=[cairo]
|
||||
>=dev-cpp/cairomm-1.12:0
|
||||
>=dev-cpp/glibmm-2.58:2
|
||||
dev-cpp/gtkmm:3.0
|
||||
>=dev-cpp/pangomm-2.40:1.4
|
||||
>=dev-libs/boehm-gc-7.1:=
|
||||
dev-libs/boost:=[stacktrace(-)]
|
||||
dev-libs/double-conversion:=
|
||||
>=dev-libs/glib-2.41
|
||||
>=dev-libs/libsigc++-2.8:2
|
||||
>=dev-libs/libxml2-2.7.4
|
||||
>=dev-libs/libxslt-1.1.25
|
||||
dev-libs/popt
|
||||
media-gfx/potrace
|
||||
media-libs/libepoxy
|
||||
media-libs/fontconfig
|
||||
media-libs/freetype:2
|
||||
media-libs/lcms:2
|
||||
media-libs/libpng:0=
|
||||
sci-libs/gsl:=
|
||||
>=x11-libs/pango-1.44
|
||||
x11-libs/gtk+:3[X?]
|
||||
X? ( x11-libs/libX11 )
|
||||
$(python_gen_cond_dep '
|
||||
dev-python/appdirs[${PYTHON_USEDEP}]
|
||||
dev-python/cachecontrol[${PYTHON_USEDEP}]
|
||||
dev-python/cssselect[${PYTHON_USEDEP}]
|
||||
dev-python/filelock[${PYTHON_USEDEP}]
|
||||
dev-python/lockfile[${PYTHON_USEDEP}]
|
||||
dev-python/lxml[${PYTHON_USEDEP}]
|
||||
dev-python/pillow[jpeg?,tiff,webp,${PYTHON_USEDEP}]
|
||||
media-gfx/scour[${PYTHON_USEDEP}]
|
||||
')
|
||||
cdr? (
|
||||
app-text/libwpg:0.3
|
||||
dev-libs/librevenge
|
||||
media-libs/libcdr
|
||||
)
|
||||
exif? ( media-libs/libexif )
|
||||
imagemagick? (
|
||||
!graphicsmagick? ( media-gfx/imagemagick:=[cxx] )
|
||||
graphicsmagick? ( media-gfx/graphicsmagick:=[cxx] )
|
||||
)
|
||||
jpeg? ( media-libs/libjpeg-turbo:= )
|
||||
readline? ( sys-libs/readline:= )
|
||||
sourceview? ( x11-libs/gtksourceview:4 )
|
||||
spell? ( app-text/gspell )
|
||||
visio? (
|
||||
app-text/libwpg:0.3
|
||||
dev-libs/librevenge
|
||||
media-libs/libvisio
|
||||
)
|
||||
wpg? (
|
||||
app-text/libwpg:0.3
|
||||
dev-libs/librevenge
|
||||
)
|
||||
"
|
||||
# These only use executables provided by these packages
|
||||
# See share/extensions for more details. inkscape can tell you to
|
||||
# install these so we could of course just not depend on those and rely
|
||||
# on that.
|
||||
RDEPEND="${COMMON_DEPEND}
|
||||
$(python_gen_cond_dep '
|
||||
dev-python/numpy[${PYTHON_USEDEP}]
|
||||
')
|
||||
dia? ( app-office/dia )
|
||||
postscript? ( app-text/ghostscript-gpl )
|
||||
"
|
||||
DEPEND="${COMMON_DEPEND}
|
||||
test? ( dev-cpp/gtest )
|
||||
"
|
||||
|
||||
PATCHES=(
|
||||
"${FILESDIR}"/${PN}-1.4-gcc15.patch
|
||||
"${FILESDIR}"/${PN}-1.4-poppler-24.10-fix-backport.patch
|
||||
)
|
||||
|
||||
pkg_pretend() {
|
||||
[[ ${MERGE_TYPE} != binary ]] && use openmp && tc-check-openmp
|
||||
}
|
||||
|
||||
pkg_setup() {
|
||||
[[ ${MERGE_TYPE} != binary ]] && use openmp && tc-check-openmp
|
||||
python-single-r1_pkg_setup
|
||||
}
|
||||
|
||||
src_unpack() {
|
||||
if [[ ${PV} = 9999* ]]; then
|
||||
git-r3_src_unpack
|
||||
else
|
||||
default
|
||||
fi
|
||||
[[ -d "${S}" ]] || mv -v "${WORKDIR}/${P/_/-}_202"?-??-* "${S}" || die
|
||||
}
|
||||
|
||||
src_prepare() {
|
||||
cmake_src_prepare
|
||||
sed -i "/install.*COPYING/d" CMakeScripts/ConfigCPack.cmake || die
|
||||
}
|
||||
|
||||
src_configure() {
|
||||
# ODR violation (https://gitlab.com/inkscape/lib2geom/-/issues/71, bug #859628)
|
||||
filter-lto
|
||||
# Aliasing unsafe (bug #310393)
|
||||
append-flags -fno-strict-aliasing
|
||||
|
||||
local mycmakeargs=(
|
||||
# -DWITH_LPETOOL # Compile with LPE Tool and experimental LPEs enabled
|
||||
-DWITH_NLS=ON
|
||||
-DENABLE_POPPLER=ON
|
||||
-DENABLE_POPPLER_CAIRO=ON
|
||||
-DWITH_PROFILING=OFF
|
||||
-DWITH_INTERNAL_2GEOM=ON
|
||||
-DBUILD_TESTING=$(usex test)
|
||||
-DWITH_LIBCDR=$(usex cdr)
|
||||
-DWITH_IMAGE_MAGICK=$(usex imagemagick $(usex !graphicsmagick)) # requires ImageMagick 6, only IM must be enabled
|
||||
-DWITH_GRAPHICS_MAGICK=$(usex graphicsmagick $(usex imagemagick)) # both must be enabled to use GraphicsMagick
|
||||
-DWITH_GNU_READLINE=$(usex readline)
|
||||
-DWITH_GSPELL=$(usex spell)
|
||||
-DWITH_JEMALLOC=OFF
|
||||
-DENABLE_LCMS=ON
|
||||
-DWITH_OPENMP=$(usex openmp)
|
||||
-DBUILD_SHARED_LIBS=ON
|
||||
-DWITH_GSOURCEVIEW=$(usex sourceview)
|
||||
-DWITH_SVG2=$(usex svg2)
|
||||
-DWITH_LIBVISIO=$(usex visio)
|
||||
-DWITH_LIBWPG=$(usex wpg)
|
||||
-DWITH_X11=$(usex X)
|
||||
)
|
||||
|
||||
cmake_src_configure
|
||||
}
|
||||
|
||||
src_test() {
|
||||
CMAKE_SKIP_TESTS=(
|
||||
# render_text*: needs patched Cairo / maybe upstream changes
|
||||
# not yet in a release.
|
||||
# test_lpe/test_lpe64: precision differences b/c of new GCC?
|
||||
# cli_export-png-color-mode-gray-8_png_check_output: ditto?
|
||||
render_test-use
|
||||
render_test-glyph-y-pos
|
||||
render_text-glyphs-combining
|
||||
render_text-glyphs-vertical
|
||||
render_test-rtl-vertical
|
||||
test_lpe
|
||||
test_lpe64
|
||||
cli_export-png-color-mode-gray-8_png_check_output
|
||||
)
|
||||
|
||||
# bug #871621
|
||||
cmake_src_compile tests
|
||||
cmake_src_test -j1
|
||||
}
|
||||
|
||||
src_install() {
|
||||
cmake_src_install
|
||||
|
||||
find "${ED}" -type f -name "*.la" -delete || die
|
||||
find "${ED}"/usr/share/man -type f -maxdepth 3 -name '*.bz2' -exec bzip2 -d {} \; || die
|
||||
find "${ED}"/usr/share/man -type f -maxdepth 3 -name '*.gz' -exec gzip -d {} \; || die
|
||||
|
||||
local extdir="${ED}"/usr/share/${PN}/extensions
|
||||
if [[ -e "${extdir}" ]] && [[ -n $(find "${extdir}" -mindepth 1) ]]; then
|
||||
python_fix_shebang "${ED}"/usr/share/${PN}/extensions
|
||||
python_optimize "${ED}"/usr/share/${PN}/extensions
|
||||
fi
|
||||
}
|
||||
@@ -0,0 +1,20 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!DOCTYPE pkgmetadata SYSTEM "https://www.gentoo.org/dtd/metadata.dtd">
|
||||
<pkgmetadata>
|
||||
<maintainer type="person">
|
||||
<email>dilfridge@gentoo.org</email>
|
||||
<name>Andreas K. Hüttel</name>
|
||||
</maintainer>
|
||||
<use>
|
||||
<flag name="cdr">Enable support for CorelDRAW files via <pkg>media-libs/libcdr</pkg></flag>
|
||||
<flag name="dia">Enable DIA flow chart import via <pkg>app-office/dia</pkg></flag>
|
||||
<flag name="inkjar">Enable support for OpenOffice.org SVG jar files</flag>
|
||||
<flag name="sourceview">Enable syntax highlighting support via <pkg>x11-libs/gtksourceview</pkg></flag>
|
||||
<flag name="svg2">Enable support for new SVG2 features</flag>
|
||||
<flag name="visio">Enable support for Microsoft Visio diagrams via <pkg>media-libs/libvisio</pkg></flag>
|
||||
<flag name="wpg">Enable support for WordPerfect graphics via <pkg>app-text/libwpg</pkg></flag>
|
||||
</use>
|
||||
<upstream>
|
||||
<remote-id type="gitlab">inkscape/inkscape</remote-id>
|
||||
</upstream>
|
||||
</pkgmetadata>
|
||||
Reference in New Issue
Block a user