import poppler-21.01.0-12.el9
This commit is contained in:
		
						commit
						96be238c34
					
				
							
								
								
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,2 @@ | |||||||
|  | SOURCES/poppler-21.01.0.tar.xz | ||||||
|  | SOURCES/poppler-test-2021-06-14.tar.xz | ||||||
							
								
								
									
										2
									
								
								.poppler.metadata
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								.poppler.metadata
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,2 @@ | |||||||
|  | 692697b218efd08ebaeb4ff96861a4d2ad20bdc2 SOURCES/poppler-21.01.0.tar.xz | ||||||
|  | bd4b27622506278016668f7c5037f9e47a41abfb SOURCES/poppler-test-2021-06-14.tar.xz | ||||||
							
								
								
									
										279
									
								
								SOURCES/poppler-0.30.0-rotated-words-selection.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										279
									
								
								SOURCES/poppler-0.30.0-rotated-words-selection.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,279 @@ | |||||||
|  | From 0ab1f29d4ce315b0fca260c0e0f3007024d00342 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Marek Kasik <mkasik@redhat.com> | ||||||
|  | Date: Tue, 28 Jan 2014 15:13:24 +0100 | ||||||
|  | Subject: [PATCH] TextOutputDev: Respect orientation when selecting words | ||||||
|  | 
 | ||||||
|  | Take rotation into account when visiting selection. | ||||||
|  | This doesn't fix all problems (there are still problems | ||||||
|  | on line and block levels). | ||||||
|  | 
 | ||||||
|  | https://bugs.freedesktop.org/show_bug.cgi?id=16619 | ||||||
|  | ---
 | ||||||
|  |  poppler/TextOutputDev.cc | 193 ++++++++++++++++++++++++++++++++++++----------- | ||||||
|  |  1 file changed, 150 insertions(+), 43 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/poppler/TextOutputDev.cc b/poppler/TextOutputDev.cc
 | ||||||
|  | index 7c2ca78..e93908c 100644
 | ||||||
|  | --- a/poppler/TextOutputDev.cc
 | ||||||
|  | +++ b/poppler/TextOutputDev.cc
 | ||||||
|  | @@ -178,6 +178,12 @@
 | ||||||
|  |  // to read the underlying image. Issue #157 | ||||||
|  |  #define glyphlessSelectionOpacity 0.4 | ||||||
|  |   | ||||||
|  | +// Returns whether x is between a and b or equal to a or b.
 | ||||||
|  | +// a and b don't need to be sorted.
 | ||||||
|  | +#define XBetweenAB(x,a,b) (!(((x) > (a) && (x) > (b)) || \
 | ||||||
|  | +                             ((x) < (a) && (x) < (b))) ? \
 | ||||||
|  | +                           true : false)
 | ||||||
|  | +
 | ||||||
|  |  namespace { | ||||||
|  |   | ||||||
|  |  inline bool isAscii7(Unicode uchar) | ||||||
|  | @@ -4411,11 +4417,37 @@ void TextSelectionSizer::visitLine (TextLine *line,
 | ||||||
|  |      PDFRectangle *rect; | ||||||
|  |      double x1, y1, x2, y2, margin; | ||||||
|  |   | ||||||
|  | -    margin = (line->yMax - line->yMin) / 8;
 | ||||||
|  | -    x1 = line->edge[edge_begin];
 | ||||||
|  | -    y1 = line->yMin - margin;
 | ||||||
|  | -    x2 = line->edge[edge_end];
 | ||||||
|  | -    y2 = line->yMax + margin;
 | ||||||
|  | +    switch (line->rot) {
 | ||||||
|  | +    default:
 | ||||||
|  | +    case 0:
 | ||||||
|  | +        margin = (line->yMax - line->yMin) / 8;
 | ||||||
|  | +        x1 = line->edge[edge_begin];
 | ||||||
|  | +        x2 = line->edge[edge_end];
 | ||||||
|  | +        y1 = line->yMin - margin;
 | ||||||
|  | +        y2 = line->yMax + margin;
 | ||||||
|  | +        break;
 | ||||||
|  | +    case 1:
 | ||||||
|  | +        margin = (line->xMax - line->xMin) / 8;
 | ||||||
|  | +        x1 = line->xMin - margin;
 | ||||||
|  | +        x2 = line->xMax + margin;
 | ||||||
|  | +        y1 = line->edge[edge_begin];
 | ||||||
|  | +        y2 = line->edge[edge_end];
 | ||||||
|  | +        break;
 | ||||||
|  | +    case 2:
 | ||||||
|  | +        margin = (line->yMax - line->yMin) / 8;
 | ||||||
|  | +        x1 = line->edge[edge_end];
 | ||||||
|  | +        x2 = line->edge[edge_begin];
 | ||||||
|  | +        y1 = line->yMin - margin;
 | ||||||
|  | +        y2 = line->yMax + margin;
 | ||||||
|  | +        break;
 | ||||||
|  | +    case 3:
 | ||||||
|  | +        margin = (line->xMax - line->xMin) / 8;
 | ||||||
|  | +        x1 = line->xMin - margin;
 | ||||||
|  | +        x2 = line->xMax + margin;
 | ||||||
|  | +        y1 = line->edge[edge_end];
 | ||||||
|  | +        y2 = line->edge[edge_begin];
 | ||||||
|  | +        break;
 | ||||||
|  | +    }
 | ||||||
|  |   | ||||||
|  |      rect = new PDFRectangle(floor(x1 * scale), floor(y1 * scale), ceil(x2 * scale), ceil(y2 * scale)); | ||||||
|  |      list->push_back(rect); | ||||||
|  | @@ -4499,19 +4531,56 @@ void TextSelectionPainter::visitLine (TextLine *line,
 | ||||||
|  |  { | ||||||
|  |      double x1, y1, x2, y2, margin; | ||||||
|  |   | ||||||
|  | -    margin = (line->yMax - line->yMin) / 8;
 | ||||||
|  | -    x1 = floor(line->edge[edge_begin]);
 | ||||||
|  | -    y1 = floor(line->yMin - margin);
 | ||||||
|  | -    x2 = ceil(line->edge[edge_end]);
 | ||||||
|  | -    y2 = ceil(line->yMax + margin);
 | ||||||
|  | +    switch (line->rot) {
 | ||||||
|  | +    default:
 | ||||||
|  | +    case 0:
 | ||||||
|  | +        margin = (line->yMax - line->yMin) / 8;
 | ||||||
|  | +        x1 = line->edge[edge_begin];
 | ||||||
|  | +        x2 = line->edge[edge_end];
 | ||||||
|  | +        y1 = line->yMin - margin;
 | ||||||
|  | +        y2 = line->yMax + margin;
 | ||||||
|  | +        break;
 | ||||||
|  | +    case 1:
 | ||||||
|  | +        margin = (line->xMax - line->xMin) / 8;
 | ||||||
|  | +        x1 = line->xMin - margin;
 | ||||||
|  | +        x2 = line->xMax + margin;
 | ||||||
|  | +        y1 = line->edge[edge_begin];
 | ||||||
|  | +        y2 = line->edge[edge_end];
 | ||||||
|  | +        break;
 | ||||||
|  | +    case 2:
 | ||||||
|  | +        margin = (line->yMax - line->yMin) / 8;
 | ||||||
|  | +        x1 = line->edge[edge_end];
 | ||||||
|  | +        x2 = line->edge[edge_begin];
 | ||||||
|  | +        y1 = line->yMin - margin;
 | ||||||
|  | +        y2 = line->yMax + margin;
 | ||||||
|  | +        break;
 | ||||||
|  | +    case 3:
 | ||||||
|  | +        margin = (line->xMax - line->xMin) / 8;
 | ||||||
|  | +        x1 = line->xMin - margin;
 | ||||||
|  | +        x2 = line->xMax + margin;
 | ||||||
|  | +        y1 = line->edge[edge_end];
 | ||||||
|  | +        y2 = line->edge[edge_begin];
 | ||||||
|  | +        break;
 | ||||||
|  | +    }
 | ||||||
|  | +
 | ||||||
|  | +    ctm.transform(x1, y1, &x1, &y1);
 | ||||||
|  | +    ctm.transform(x2, y2, &x2, &y2);
 | ||||||
|  |   | ||||||
|  | -    ctm.transform(line->edge[edge_begin], line->yMin - margin, &x1, &y1);
 | ||||||
|  | -    ctm.transform(line->edge[edge_end], line->yMax + margin, &x2, &y2);
 | ||||||
|  | +    if (x1 < x2) {
 | ||||||
|  | +        x1 = floor(x1);
 | ||||||
|  | +        x2 = ceil(x2);
 | ||||||
|  | +    } else {
 | ||||||
|  | +        x1 = ceil(x1);
 | ||||||
|  | +        x2 = floor(x2);
 | ||||||
|  | +    }
 | ||||||
|  |   | ||||||
|  | -    x1 = floor(x1);
 | ||||||
|  | -    y1 = floor(y1);
 | ||||||
|  | -    x2 = ceil(x2);
 | ||||||
|  | -    y2 = ceil(y2);
 | ||||||
|  | +    if (y1 < y2) {
 | ||||||
|  | +        y1 = floor(y1);
 | ||||||
|  | +        y2 = ceil(y2);
 | ||||||
|  | +    } else {
 | ||||||
|  | +        y1 = ceil(y1);
 | ||||||
|  | +        y2 = floor(y2);
 | ||||||
|  | +    }
 | ||||||
|  |   | ||||||
|  |      ictm.transform(x1, y1, &x1, &y1); | ||||||
|  |      ictm.transform(x2, y2, &x2, &y2); | ||||||
|  | @@ -4589,17 +4658,26 @@ void TextWord::visitSelection(TextSelectionVisitor *visitor,
 | ||||||
|  |  void TextWord::visitSelection(TextSelectionVisitor *visitor, const PDFRectangle *selection, SelectionStyle style) | ||||||
|  |  { | ||||||
|  |      int i, begin, end; | ||||||
|  | -    double mid;
 | ||||||
|  | +    double mid, s1, s2;
 | ||||||
|  | +
 | ||||||
|  | +    if (rot == 0 || rot == 2) {
 | ||||||
|  | +        s1 = selection->x1;
 | ||||||
|  | +        s2 = selection->x2;
 | ||||||
|  | +    } else {
 | ||||||
|  | +        s1 = selection->y1;
 | ||||||
|  | +        s2 = selection->y2;
 | ||||||
|  | +    }
 | ||||||
|  |   | ||||||
|  |      begin = len; | ||||||
|  |      end = 0; | ||||||
|  |      for (i = 0; i < len; i++) { | ||||||
|  |          mid = (edge[i] + edge[i + 1]) / 2; | ||||||
|  | -        if (selection->x1 < mid || selection->x2 < mid)
 | ||||||
|  | -            if (i < begin)
 | ||||||
|  | -                begin = i;
 | ||||||
|  | -        if (mid < selection->x1 || mid < selection->x2)
 | ||||||
|  | -            end = i + 1;
 | ||||||
|  | +      if (XBetweenAB (mid, s1, s2)) {
 | ||||||
|  | +          if (i < begin)
 | ||||||
|  | +              begin = i;
 | ||||||
|  | +
 | ||||||
|  | +          end = i + 1;
 | ||||||
|  | +      }
 | ||||||
|  |      } | ||||||
|  |   | ||||||
|  |      /* Skip empty selection. */ | ||||||
|  | @@ -4615,26 +4694,41 @@ void TextLine::visitSelection(TextSelectionVisitor *visitor,
 | ||||||
|  |      TextWord *p, *begin, *end, *current; | ||||||
|  |      int i, edge_begin, edge_end; | ||||||
|  |      PDFRectangle child_selection; | ||||||
|  | +    double s1, s2, p_min, p_max;
 | ||||||
|  | +
 | ||||||
|  | +    if (rot == 0 || rot == 2) {
 | ||||||
|  | +        s1 = selection->x1;
 | ||||||
|  | +        s2 = selection->x2;
 | ||||||
|  | +    } else {
 | ||||||
|  | +        s1 = selection->y1;
 | ||||||
|  | +        s2 = selection->y2;
 | ||||||
|  | +    }
 | ||||||
|  |   | ||||||
|  |      begin = nullptr; | ||||||
|  |      end = nullptr; | ||||||
|  |      current = nullptr; | ||||||
|  |      for (p = words; p != nullptr; p = p->next) { | ||||||
|  | +        if (rot == 0 || rot == 2) {
 | ||||||
|  | +            p_min = p->xMin;
 | ||||||
|  | +            p_max = p->xMax;
 | ||||||
|  | +        } else {
 | ||||||
|  | +            p_min = p->yMin;
 | ||||||
|  | +            p_max = p->yMax;
 | ||||||
|  | +        }
 | ||||||
|  | +
 | ||||||
|  |          if (blk->page->primaryLR) { | ||||||
|  | -            if ((selection->x1 < p->xMax) || (selection->x2 < p->xMax))
 | ||||||
|  | -                if (begin == nullptr)
 | ||||||
|  | -                    begin = p;
 | ||||||
|  | +            if (((s1 < p_max) || (s2 < p_max)) && begin == nullptr)
 | ||||||
|  | +                begin = p;
 | ||||||
|  |   | ||||||
|  | -            if (((selection->x1 > p->xMin) || (selection->x2 > p->xMin)) && (begin != nullptr)) {
 | ||||||
|  | +            if (((s1 > p_min) || (s2 > p_min)) && begin != nullptr) {
 | ||||||
|  |                  end = p->next; | ||||||
|  |                  current = p; | ||||||
|  |              } | ||||||
|  |          } else { | ||||||
|  | -            if ((selection->x1 > p->xMin) || (selection->x2 > p->xMin))
 | ||||||
|  | -                if (begin == nullptr)
 | ||||||
|  | -                    begin = p;
 | ||||||
|  | +            if (((s1 > p_min) || (s2 > p_min)) && begin == nullptr)
 | ||||||
|  | +                begin = p;
 | ||||||
|  |   | ||||||
|  | -            if (((selection->x1 < p->xMax) || (selection->x2 < p->xMax)) && (begin != nullptr)) {
 | ||||||
|  | +            if (((s1 < p_max) || (s2 < p_max)) && begin != nullptr) {
 | ||||||
|  |                  end = p->next; | ||||||
|  |                  current = p; | ||||||
|  |              } | ||||||
|  | @@ -4650,23 +4740,41 @@ void TextLine::visitSelection(TextSelectionVisitor *visitor,
 | ||||||
|  |   | ||||||
|  |      child_selection = *selection; | ||||||
|  |      if (style == selectionStyleWord) { | ||||||
|  | -        child_selection.x1 = begin ? begin->xMin : xMin;
 | ||||||
|  | -        if (end && end->xMax != -1) {
 | ||||||
|  | -            child_selection.x2 = current->xMax;
 | ||||||
|  | +        if (rot == 0 || rot == 2) {
 | ||||||
|  | +            child_selection.x1 = begin ? begin->xMin : xMin;
 | ||||||
|  | +            if (end && end->xMax != -1) {
 | ||||||
|  | +                child_selection.x2 = current->xMax;
 | ||||||
|  | +            } else {
 | ||||||
|  | +                child_selection.x2 = xMax;
 | ||||||
|  | +            }
 | ||||||
|  |          } else { | ||||||
|  | -            child_selection.x2 = xMax;
 | ||||||
|  | +            child_selection.y1 = begin ? begin->yMin : yMin;
 | ||||||
|  | +            if (end && end->yMax != -1) {
 | ||||||
|  | +                child_selection.y2 = current->yMax;
 | ||||||
|  | +            } else {
 | ||||||
|  | +                child_selection.y2 = yMax;
 | ||||||
|  | +            }
 | ||||||
|  |          } | ||||||
|  |      } | ||||||
|  |   | ||||||
|  | +    if (rot == 0 || rot == 2) {
 | ||||||
|  | +        s1 = child_selection.x1;
 | ||||||
|  | +        s2 = child_selection.x2;
 | ||||||
|  | +    } else {
 | ||||||
|  | +        s1 = child_selection.y1;
 | ||||||
|  | +        s2 = child_selection.y2;
 | ||||||
|  | +    }
 | ||||||
|  | +
 | ||||||
|  |      edge_begin = len; | ||||||
|  |      edge_end = 0; | ||||||
|  |      for (i = 0; i < len; i++) { | ||||||
|  |          double mid = (edge[i] + edge[i + 1]) / 2; | ||||||
|  | -        if (child_selection.x1 < mid || child_selection.x2 < mid)
 | ||||||
|  | -            if (i < edge_begin)
 | ||||||
|  | -                edge_begin = i;
 | ||||||
|  | -        if (mid < child_selection.x2 || mid < child_selection.x1)
 | ||||||
|  | -            edge_end = i + 1;
 | ||||||
|  | +        if (XBetweenAB (mid, s1, s2)) {
 | ||||||
|  | +            if (i < edge_begin)
 | ||||||
|  | +                edge_begin = i;
 | ||||||
|  | +
 | ||||||
|  | +            edge_end = i + 1;
 | ||||||
|  | +        }
 | ||||||
|  |      } | ||||||
|  |   | ||||||
|  |      /* Skip empty selection. */ | ||||||
|  | -- 
 | ||||||
|  | 1.8.4.2 | ||||||
|  | 
 | ||||||
							
								
								
									
										12
									
								
								SOURCES/poppler-0.90.0-position-independent-code.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								SOURCES/poppler-0.90.0-position-independent-code.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,12 @@ | |||||||
|  | --- poppler-0.90.0/CMakeLists.txt
 | ||||||
|  | +++ poppler-0.90.0/CMakeLists.txt
 | ||||||
|  | @@ -17,6 +17,9 @@ else()
 | ||||||
|  |    set(THREADS_PREFER_PTHREAD_FLAG TRUE) | ||||||
|  |    find_package(Threads) | ||||||
|  |  endif() | ||||||
|  | +
 | ||||||
|  | +set(CMAKE_POSITION_INDEPENDENT_CODE ON)
 | ||||||
|  | +
 | ||||||
|  |  include(TestBigEndian) | ||||||
|  |  test_big_endian(WORDS_BIGENDIAN) | ||||||
|  |  include(CheckFileOffsetBits) | ||||||
							
								
								
									
										439
									
								
								SOURCES/poppler-21.01.0-covscan.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										439
									
								
								SOURCES/poppler-21.01.0-covscan.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,439 @@ | |||||||
|  | --- poppler/glib/poppler-document.cc
 | ||||||
|  | +++ poppler/glib/poppler-document.cc
 | ||||||
|  | @@ -869,12 +869,12 @@ GTree *poppler_document_create_dests_tre
 | ||||||
|  |      // Iterate from name-dict | ||||||
|  |      const int nDests = catalog->numDests(); | ||||||
|  |      for (i = 0; i < nDests; ++i) { | ||||||
|  | -        // The names of name-dict cannot contain \0,
 | ||||||
|  | -        // so we can use strlen().
 | ||||||
|  | -        auto name = catalog->getDestsName(i);
 | ||||||
|  | -        key = poppler_named_dest_from_bytestring(reinterpret_cast<const guint8 *>(name), strlen(name));
 | ||||||
|  |          std::unique_ptr<LinkDest> link_dest = catalog->getDestsDest(i); | ||||||
|  |          if (link_dest) { | ||||||
|  | +            // The names of name-dict cannot contain \0,
 | ||||||
|  | +            // so we can use strlen().
 | ||||||
|  | +            auto name = catalog->getDestsName(i);
 | ||||||
|  | +            key = poppler_named_dest_from_bytestring(reinterpret_cast<const guint8 *>(name), strlen(name));
 | ||||||
|  |              dest = _poppler_dest_new_goto(document, link_dest.get()); | ||||||
|  |              g_tree_insert(tree, key, dest); | ||||||
|  |          } | ||||||
|  | @@ -883,10 +883,10 @@ GTree *poppler_document_create_dests_tre
 | ||||||
|  |      // Iterate form name-tree | ||||||
|  |      const int nDestsNameTree = catalog->numDestNameTree(); | ||||||
|  |      for (i = 0; i < nDestsNameTree; ++i) { | ||||||
|  | -        auto name = catalog->getDestNameTreeName(i);
 | ||||||
|  | -        key = poppler_named_dest_from_bytestring(reinterpret_cast<const guint8 *>(name->c_str()), name->getLength());
 | ||||||
|  |          std::unique_ptr<LinkDest> link_dest = catalog->getDestNameTreeDest(i); | ||||||
|  |          if (link_dest) { | ||||||
|  | +            auto name = catalog->getDestNameTreeName(i);
 | ||||||
|  | +            key = poppler_named_dest_from_bytestring(reinterpret_cast<const guint8 *>(name->c_str()), name->getLength());
 | ||||||
|  |              dest = _poppler_dest_new_goto(document, link_dest.get()); | ||||||
|  |              g_tree_insert(tree, key, dest); | ||||||
|  |          } | ||||||
|  | @@ -3405,6 +3405,7 @@ PopplerFormField *poppler_document_get_f
 | ||||||
|  |      unsigned fieldNum; | ||||||
|  |      FormPageWidgets *widgets; | ||||||
|  |      FormWidget *field; | ||||||
|  | +    PopplerFormField *formField;
 | ||||||
|  |   | ||||||
|  |      FormWidget::decodeID(id, &pageNum, &fieldNum); | ||||||
|  |   | ||||||
|  | @@ -3417,8 +3418,14 @@ PopplerFormField *poppler_document_get_f
 | ||||||
|  |          return nullptr; | ||||||
|  |   | ||||||
|  |      field = widgets->getWidget(fieldNum); | ||||||
|  | -    if (field)
 | ||||||
|  | -        return _poppler_form_field_new(document, field);
 | ||||||
|  | +    if (field) {
 | ||||||
|  | +        formField = _poppler_form_field_new(document, field);
 | ||||||
|  | +        delete widgets;
 | ||||||
|  | +
 | ||||||
|  | +        return formField;
 | ||||||
|  | +    }
 | ||||||
|  | +
 | ||||||
|  | +    delete widgets;
 | ||||||
|  |   | ||||||
|  |      return nullptr; | ||||||
|  |  } | ||||||
|  | --- poppler-21.01.0/glib/poppler-page.cc
 | ||||||
|  | +++ poppler-21.01.0/glib/poppler-page.cc
 | ||||||
|  | @@ -1530,15 +1530,18 @@ void poppler_page_add_annot(PopplerPage
 | ||||||
|  |               * first remove cropbox of the prior page before adding cropbox of the new page later */ | ||||||
|  |              quads = new_quads_from_offset_cropbox(crop_box, annot_markup->getQuadrilaterals(), FALSE); | ||||||
|  |              annot_markup->setQuadrilaterals(quads); | ||||||
|  | +            delete quads;
 | ||||||
|  |          } | ||||||
|  |          if (page_is_rotated) { | ||||||
|  |              /* Quadrilateral's coords need to be saved un-rotated (same as rect coords) */ | ||||||
|  |              quads = _page_new_quads_unrotated(page->page, annot_markup->getQuadrilaterals()); | ||||||
|  |              annot_markup->setQuadrilaterals(quads); | ||||||
|  | +            delete quads;
 | ||||||
|  |          } | ||||||
|  |          /* Add to annot's quadrilaterals the offset for the cropbox of the new page */ | ||||||
|  |          quads = new_quads_from_offset_cropbox(page_crop_box, annot_markup->getQuadrilaterals(), TRUE); | ||||||
|  |          annot_markup->setQuadrilaterals(quads); | ||||||
|  | +        delete quads;
 | ||||||
|  |      } | ||||||
|  |   | ||||||
|  |      page->page->addAnnot(annot->annot); | ||||||
|  | --- poppler-21.01.0/glib/poppler-structure-element.cc
 | ||||||
|  | +++ poppler-21.01.0/glib/poppler-structure-element.cc
 | ||||||
|  | @@ -1090,6 +1090,8 @@ static inline void convert_doubles_array
 | ||||||
|  |      for (guint i = 0; i < *n_values; i++) { | ||||||
|  |          doubles[i] = object->arrayGet(i).getNum(); | ||||||
|  |      } | ||||||
|  | +
 | ||||||
|  | +    values = &doubles;
 | ||||||
|  |  } | ||||||
|  |   | ||||||
|  |  static inline void convert_color(Object *object, PopplerColor *color) | ||||||
|  | --- poppler-21.01.0/poppler/Form.cc
 | ||||||
|  | +++ poppler-21.01.0/poppler/Form.cc
 | ||||||
|  | @@ -549,6 +549,7 @@ bool FormWidgetSignature::signDocument(c
 | ||||||
|  |      GooString *fname = new GooString(saveFilename); | ||||||
|  |      if (doc->saveAs(fname, writeForceIncremental) != errNone) { | ||||||
|  |          fprintf(stderr, "signDocument: error saving to file \"%s\"\n", saveFilename); | ||||||
|  | +        delete fname;
 | ||||||
|  |          return false; | ||||||
|  |      } | ||||||
|  |   | ||||||
|  | @@ -563,6 +564,8 @@ bool FormWidgetSignature::signDocument(c
 | ||||||
|  |      FILE *file = openFile(saveFilename, "r+b"); | ||||||
|  |      if (!updateOffsets(file, objStart, objEnd, &sigStart, &sigEnd, &fileSize)) { | ||||||
|  |          fprintf(stderr, "signDocument: unable update byte range\n"); | ||||||
|  | +        delete fname;
 | ||||||
|  | +        fclose(file);
 | ||||||
|  |          return false; | ||||||
|  |      } | ||||||
|  |   | ||||||
|  | @@ -574,15 +577,21 @@ bool FormWidgetSignature::signDocument(c
 | ||||||
|  |      // and sign it | ||||||
|  |      const std::unique_ptr<GooString> signature = sigHandler.signDetached(password); | ||||||
|  | -    if (!signature)
 | ||||||
|  | +    if (!signature) {
 | ||||||
|  | +        delete fname;
 | ||||||
|  | +        fclose(file);
 | ||||||
|  |          return false; | ||||||
|  | +    }
 | ||||||
|  |   | ||||||
|  |      // write signature to saved file | ||||||
|  |      if (!updateSignature(file, sigStart, sigEnd, signature.get())) { | ||||||
|  |          fprintf(stderr, "signDocument: unable update signature\n"); | ||||||
|  | +        delete fname;
 | ||||||
|  | +        fclose(file);
 | ||||||
|  |          return false; | ||||||
|  |      } | ||||||
|  |      signatureField->setSignature(*signature); | ||||||
|  |   | ||||||
|  | +    delete fname;
 | ||||||
|  |      fclose(file); | ||||||
|  |   | ||||||
|  |      return true; | ||||||
|  | @@ -662,22 +670,30 @@ bool FormWidgetSignature::updateOffsets(
 | ||||||
|  |          } | ||||||
|  |      } | ||||||
|  |   | ||||||
|  | -    if (*sigStart == -1 || *sigEnd == -1)
 | ||||||
|  | +    if (*sigStart == -1 || *sigEnd == -1) {
 | ||||||
|  | +        free(buf);
 | ||||||
|  |          return false; | ||||||
|  | +    }
 | ||||||
|  |   | ||||||
|  |      // Search for ByteRange array and update offsets | ||||||
|  |      for (int i = 0; i < bufSize - 10; i++) { | ||||||
|  |          if (buf[i] == '/' && strncmp(&buf[i], "/ByteRange", 10) == 0) { | ||||||
|  |              // update range | ||||||
|  |              char *p = setNextOffset(&buf[i], *sigStart); | ||||||
|  | -            if (!p)
 | ||||||
|  | +            if (!p) {
 | ||||||
|  | +                free(buf);
 | ||||||
|  |                  return false; | ||||||
|  | +            }
 | ||||||
|  |              p = setNextOffset(p, *sigEnd); | ||||||
|  | -            if (!p)
 | ||||||
|  | +            if (!p) {
 | ||||||
|  | +                free(buf);
 | ||||||
|  |                  return false; | ||||||
|  | +            }
 | ||||||
|  |              p = setNextOffset(p, *fileSize - *sigEnd); | ||||||
|  | -            if (!p)
 | ||||||
|  | +            if (!p) {
 | ||||||
|  | +                free(buf);
 | ||||||
|  |                  return false; | ||||||
|  | +            }
 | ||||||
|  |              break; | ||||||
|  |          } | ||||||
|  |      } | ||||||
|  | --- poppler-21.01.0/poppler/JBIG2Stream.cc
 | ||||||
|  | +++ poppler-21.01.0/poppler/JBIG2Stream.cc
 | ||||||
|  | @@ -2834,6 +2834,8 @@ JBIG2Bitmap *JBIG2Stream::readGenericBit
 | ||||||
|  |   | ||||||
|  |          if (unlikely(!codingLine || !refLine)) { | ||||||
|  |              error(errSyntaxError, curStr->getPos(), "Bad width in JBIG2 generic bitmap"); | ||||||
|  | +            gfree(refLine);
 | ||||||
|  | +            gfree(codingLine);
 | ||||||
|  |              delete bitmap; | ||||||
|  |              return nullptr; | ||||||
|  |          } | ||||||
|  | --- poppler-21.01.0/poppler/Lexer.cc
 | ||||||
|  | +++ poppler-21.01.0/poppler/Lexer.cc
 | ||||||
|  | @@ -461,6 +461,7 @@ Object Lexer::getObj(int objNum)
 | ||||||
|  |              } else if (n == tokBufSize) { | ||||||
|  |                  error(errSyntaxError, getPos(), "Warning: name token is longer than what the specification says it can be"); | ||||||
|  |                  *p = c; | ||||||
|  | +                delete s;
 | ||||||
|  |                  s = new GooString(tokBuf, n); | ||||||
|  |              } else { | ||||||
|  |                  s->append((char)c); | ||||||
|  | @@ -468,6 +468,7 @@ Object Lexer::getObj(int objNum)
 | ||||||
|  |          } | ||||||
|  |          if (n < tokBufSize) { | ||||||
|  |              *p = '\0'; | ||||||
|  | +            delete s;
 | ||||||
|  |              return Object(objName, tokBuf); | ||||||
|  |          } else { | ||||||
|  |              Object obj(objName, s->c_str()); | ||||||
|  | --- poppler/poppler/CairoOutputDev.cc
 | ||||||
|  | +++ poppler/poppler/CairoOutputDev.cc
 | ||||||
|  | @@ -2921,8 +2921,10 @@ void CairoOutputDev::setMimeData(GfxStat
 | ||||||
|  |   | ||||||
|  |      // colorspace in stream dict may be different from colorspace in jpx | ||||||
|  |      // data | ||||||
|  | -    if (strKind == strJPX && colorSpace)
 | ||||||
|  | +    if (strKind == strJPX && colorSpace) {
 | ||||||
|  | +        delete colorSpace;
 | ||||||
|  |          return; | ||||||
|  | +    }
 | ||||||
|  |   | ||||||
|  |      // only embed mime data for gray, rgb, and cmyk colorspaces. | ||||||
|  |      if (colorSpace) { | ||||||
|  | --- poppler/poppler/TextOutputDev.cc
 | ||||||
|  | +++ poppler/poppler/TextOutputDev.cc
 | ||||||
|  | @@ -20,7 +20,7 @@
 | ||||||
|  |  // Copyright (C) 2006 Jeff Muizelaar <jeff@infidigm.net> | ||||||
|  |  // Copyright (C) 2007, 2008, 2012, 2017 Adrian Johnson <ajohnson@redneon.com> | ||||||
|  |  // Copyright (C) 2008 Koji Otani <sho@bbr.jp> | ||||||
|  | -// Copyright (C) 2008, 2010-2012, 2014-2020 Albert Astals Cid <aacid@kde.org>
 | ||||||
|  | +// Copyright (C) 2008, 2010-2012, 2014-2021 Albert Astals Cid <aacid@kde.org>
 | ||||||
|  |  // Copyright (C) 2008 Pino Toscano <pino@kde.org> | ||||||
|  |  // Copyright (C) 2008, 2010 Hib Eris <hib@hiberis.nl> | ||||||
|  |  // Copyright (C) 2009 Ross Moore <ross@maths.mq.edu.au> | ||||||
|  | @@ -1619,7 +1619,6 @@ TextBlock::~TextBlock()
 | ||||||
|  |   | ||||||
|  |  void TextBlock::addWord(TextWord *word) | ||||||
|  |  { | ||||||
|  | -    pool->addWord(word);
 | ||||||
|  |      if (xMin > xMax) { | ||||||
|  |          xMin = word->xMin; | ||||||
|  |          xMax = word->xMax; | ||||||
|  | @@ -1639,6 +1638,7 @@ void TextBlock::addWord(TextWord *word)
 | ||||||
|  |              yMax = word->yMax; | ||||||
|  |          } | ||||||
|  |      } | ||||||
|  | +    pool->addWord(word);
 | ||||||
|  |  } | ||||||
|  |   | ||||||
|  |  void TextBlock::coalesce(const UnicodeMap *uMap, double fixedPitch) | ||||||
|  | @@ -3064,11 +3064,13 @@ void TextPage::coalesce(bool physLayout,
 | ||||||
|  |              word0 = pool->getPool(startBaseIdx); | ||||||
|  |              pool->setPool(startBaseIdx, word0->next); | ||||||
|  |              word0->next = nullptr; | ||||||
|  | -            blk = new TextBlock(this, rot);
 | ||||||
|  | -            blk->addWord(word0);
 | ||||||
|  |   | ||||||
|  |              fontSize = word0->fontSize; | ||||||
|  |              minBase = maxBase = word0->base; | ||||||
|  | +
 | ||||||
|  | +            blk = new TextBlock(this, rot);
 | ||||||
|  | +            blk->addWord(word0);
 | ||||||
|  | +
 | ||||||
|  |              colSpace1 = minColSpacing1 * fontSize; | ||||||
|  |              colSpace2 = minColSpacing2 * fontSize; | ||||||
|  |              lineSpace = maxLineSpacingDelta * fontSize; | ||||||
|  | @@ -3095,9 +3097,9 @@ void TextPage::coalesce(bool physLayout,
 | ||||||
|  |                              } | ||||||
|  |                              word1 = word1->next; | ||||||
|  |                              word2->next = nullptr; | ||||||
|  | +                            newMinBase = word2->base;
 | ||||||
|  |                              blk->addWord(word2); | ||||||
|  |                              found = true; | ||||||
|  | -                            newMinBase = word2->base;
 | ||||||
|  |                          } else { | ||||||
|  |                              word0 = word1; | ||||||
|  |                              word1 = word1->next; | ||||||
|  | @@ -3123,9 +3125,9 @@ void TextPage::coalesce(bool physLayout,
 | ||||||
|  |                              } | ||||||
|  |                              word1 = word1->next; | ||||||
|  |                              word2->next = nullptr; | ||||||
|  | +                            newMaxBase = word2->base;
 | ||||||
|  |                              blk->addWord(word2); | ||||||
|  |                              found = true; | ||||||
|  | -                            newMaxBase = word2->base;
 | ||||||
|  |                          } else { | ||||||
|  |                              word0 = word1; | ||||||
|  |                              word1 = word1->next; | ||||||
|  | @@ -3198,12 +3200,12 @@ void TextPage::coalesce(bool physLayout,
 | ||||||
|  |                                  } | ||||||
|  |                                  word1 = word1->next; | ||||||
|  |                                  word2->next = nullptr; | ||||||
|  | -                                blk->addWord(word2);
 | ||||||
|  |                                  if (word2->base < minBase) { | ||||||
|  |                                      minBase = word2->base; | ||||||
|  |                                  } else if (word2->base > maxBase) { | ||||||
|  |                                      maxBase = word2->base; | ||||||
|  |                                  } | ||||||
|  | +                                blk->addWord(word2);
 | ||||||
|  |                                  found = true; | ||||||
|  |                                  break; | ||||||
|  |                              } else { | ||||||
|  | @@ -3246,12 +3248,12 @@ void TextPage::coalesce(bool physLayout,
 | ||||||
|  |                                  } | ||||||
|  |                                  word1 = word1->next; | ||||||
|  |                                  word2->next = nullptr; | ||||||
|  | -                                blk->addWord(word2);
 | ||||||
|  |                                  if (word2->base < minBase) { | ||||||
|  |                                      minBase = word2->base; | ||||||
|  |                                  } else if (word2->base > maxBase) { | ||||||
|  |                                      maxBase = word2->base; | ||||||
|  |                                  } | ||||||
|  | +                                blk->addWord(word2);
 | ||||||
|  |                                  found = true; | ||||||
|  |                                  break; | ||||||
|  |                              } else { | ||||||
|  | @@ -4456,13 +4456,18 @@ class TextSelectionSizer : public TextSe
 | ||||||
|  |  { | ||||||
|  |  public: | ||||||
|  |      TextSelectionSizer(TextPage *page, double scale); | ||||||
|  | -    ~TextSelectionSizer() override { }
 | ||||||
|  | +    ~TextSelectionSizer() override { delete list; }
 | ||||||
|  |   | ||||||
|  |      void visitBlock(TextBlock *block, TextLine *begin, TextLine *end, const PDFRectangle *selection) override {}; | ||||||
|  |      void visitLine(TextLine *line, TextWord *begin, TextWord *end, int edge_begin, int edge_end, const PDFRectangle *selection) override; | ||||||
|  |      void visitWord(TextWord *word, int begin, int end, const PDFRectangle *selection) override {}; | ||||||
|  |   | ||||||
|  | -    std::vector<PDFRectangle *> *getRegion() { return list; }
 | ||||||
|  | +    std::vector<PDFRectangle *> *takeRegion()
 | ||||||
|  | +    {
 | ||||||
|  | +        auto aux = list;
 | ||||||
|  | +        list = nullptr;
 | ||||||
|  | +        return aux;
 | ||||||
|  | +    }
 | ||||||
|  |   | ||||||
|  |  private: | ||||||
|  |      std::vector<PDFRectangle *> *list; | ||||||
|  | @@ -5063,7 +5068,7 @@ std::vector<PDFRectangle *> *TextPage::g
 | ||||||
|  |   | ||||||
|  |      visitSelection(&sizer, selection, style); | ||||||
|  |   | ||||||
|  | -    return sizer.getRegion();
 | ||||||
|  | +    return sizer.takeRegion();
 | ||||||
|  |  } | ||||||
|  |   | ||||||
|  |  GooString *TextPage::getSelectionText(const PDFRectangle *selection, SelectionStyle style) | ||||||
|  | --- poppler/poppler/XRef.cc
 | ||||||
|  | +++ poppler/poppler/XRef.cc
 | ||||||
|  | @@ -402,6 +402,7 @@ int XRef::reserve(int newSize)
 | ||||||
|  |   | ||||||
|  |          void *p = greallocn_checkoverflow(entries, realNewSize, sizeof(XRefEntry)); | ||||||
|  |          if (p == nullptr) { | ||||||
|  | +            entries = nullptr;
 | ||||||
|  |              return 0; | ||||||
|  |          } | ||||||
|  |   | ||||||
|  | @@ -835,7 +836,6 @@ bool XRef::constructXRef(bool *wasRecons
 | ||||||
|  |      int offset = 0; | ||||||
|  |   | ||||||
|  |      resize(0); // free entries properly | ||||||
|  | -    gfree(entries);
 | ||||||
|  |      capacity = 0; | ||||||
|  |      size = 0; | ||||||
|  |      entries = nullptr; | ||||||
|  | --- poppler/test/pdf-inspector.cc
 | ||||||
|  | +++ poppler/test/pdf-inspector.cc
 | ||||||
|  | @@ -43,6 +43,7 @@ class PdfInspector
 | ||||||
|  |  { | ||||||
|  |  public: | ||||||
|  |      PdfInspector(); | ||||||
|  | +    ~PdfInspector();
 | ||||||
|  |   | ||||||
|  |      void set_file_name(const char *file_name); | ||||||
|  |      void load(const char *file_name); | ||||||
|  | @@ -108,6 +109,11 @@ PdfInspector::PdfInspector()
 | ||||||
|  |      load(nullptr); | ||||||
|  |  } | ||||||
|  |   | ||||||
|  | +PdfInspector::~PdfInspector(void)
 | ||||||
|  | +{
 | ||||||
|  | +    delete output;
 | ||||||
|  | +}
 | ||||||
|  | +
 | ||||||
|  |  void PdfInspector::set_file_name(const char *file_name) | ||||||
|  |  { | ||||||
|  |      GtkWidget *widget; | ||||||
|  | --- poppler/utils/HtmlOutputDev.cc
 | ||||||
|  | +++ poppler/utils/HtmlOutputDev.cc
 | ||||||
|  | @@ -1337,6 +1337,7 @@ void HtmlOutputDev::drawPngImage(GfxStat
 | ||||||
|  |      // TODO can we calculate the resolution of the image? | ||||||
|  |      if (!writer->init(f1, width, height, 72, 72)) { | ||||||
|  |          error(errInternal, -1, "Can't init PNG for image '{0:t}'", fName); | ||||||
|  | +        delete fName;
 | ||||||
|  |          delete writer; | ||||||
|  |          fclose(f1); | ||||||
|  |          return; | ||||||
|  | @@ -1378,6 +1378,7 @@ void HtmlOutputDev::drawPngImage(GfxStat
 | ||||||
|  |   | ||||||
|  |              if (!writer->writeRow(row_pointer)) { | ||||||
|  |                  error(errIO, -1, "Failed to write into PNG '{0:t}'", fName); | ||||||
|  | +                delete fName;
 | ||||||
|  |                  delete writer; | ||||||
|  |                  delete imgStr; | ||||||
|  |                  fclose(f1); | ||||||
|  | @@ -1413,6 +1414,7 @@ void HtmlOutputDev::drawPngImage(GfxStat
 | ||||||
|  |   | ||||||
|  |              if (!writer->writeRow(&png_row)) { | ||||||
|  |                  error(errIO, -1, "Failed to write into PNG '{0:t}'", fName); | ||||||
|  | +                delete fName;
 | ||||||
|  |                  delete writer; | ||||||
|  |                  fclose(f1); | ||||||
|  |                  gfree(png_row); | ||||||
|  | --- poppler/utils/pdftotext.cc
 | ||||||
|  | +++ poppler/utils/pdftotext.cc
 | ||||||
|  | @@ -329,6 +329,7 @@ int main(int argc, char *argv[])
 | ||||||
|  |              fputs("<pre>\n", f); | ||||||
|  |              if (f != stdout) { | ||||||
|  |                  fclose(f); | ||||||
|  | +                f = nullptr;
 | ||||||
|  |              } | ||||||
|  |          } | ||||||
|  |      } | ||||||
|  | @@ -348,8 +349,9 @@ int main(int argc, char *argv[])
 | ||||||
|  |                  printWordBBox(f, doc, textOut, firstPage, lastPage); | ||||||
|  |              } | ||||||
|  |          } | ||||||
|  | -        if (f != stdout) {
 | ||||||
|  | +        if (f != stdout && f != nullptr) {
 | ||||||
|  |              fclose(f); | ||||||
|  | +            f = nullptr;
 | ||||||
|  |          } | ||||||
|  |      } else { | ||||||
|  |          textOut = new TextOutputDev(textFileName->c_str(), physLayout, fixedPitch, rawOrder, htmlMeta, discardDiag); | ||||||
|  | @@ -390,7 +392,7 @@ int main(int argc, char *argv[])
 | ||||||
|  |              fputs("</pre>\n", f); | ||||||
|  |          fputs("</body>\n", f); | ||||||
|  |          fputs("</html>\n", f); | ||||||
|  | -        if (f != stdout) {
 | ||||||
|  | +        if (f != stdout && f != nullptr) {
 | ||||||
|  |              fclose(f); | ||||||
|  |          } | ||||||
|  |      } | ||||||
|  | @@ -533,7 +533,9 @@ void printWordBBox(FILE *f, PDFDoc *doc,
 | ||||||
|  |          for (int i = 0; i < word_length; ++i) { | ||||||
|  |              word = wordlist->get(i); | ||||||
|  |              word->getBBox(&xMinA, &yMinA, &xMaxA, &yMaxA); | ||||||
|  | -            const std::string myString = myXmlTokenReplace(word->getText()->c_str());
 | ||||||
|  | +            GooString *wordText = word->getText();
 | ||||||
|  | +            const std::string myString = myXmlTokenReplace(wordText->c_str());
 | ||||||
|  | +            delete wordText;
 | ||||||
|  |              fprintf(f, "    <word xMin=\"%f\" yMin=\"%f\" xMax=\"%f\" yMax=\"%f\">%s</word>\n", xMinA, yMinA, xMaxA, yMaxA, myString.c_str()); | ||||||
|  |          } | ||||||
|  |          fprintf(f, "  </page>\n"); | ||||||
							
								
								
									
										11
									
								
								SOURCES/poppler-21.01.0-glib-introspection.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								SOURCES/poppler-21.01.0-glib-introspection.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | |||||||
|  | --- poppler-21.01.0/glib/CMakeLists.txt
 | ||||||
|  | +++ poppler-21.01.0/glib/CMakeLists.txt
 | ||||||
|  | @@ -121,7 +121,7 @@ if (HAVE_INTROSPECTION AND BUILD_SHARED_
 | ||||||
|  |   | ||||||
|  |    # General gir: Reset object-list for introspection & load tool args | ||||||
|  |    set(INTROSPECTION_GIRS) | ||||||
|  | -  set(INTROSPECTION_SCANNER_ARGS "--add-include-path=${CMAKE_CURRENT_SOURCE_DIR}" "--warn-all")
 | ||||||
|  | +  set(INTROSPECTION_SCANNER_ARGS "--add-include-path=${CMAKE_CURRENT_SOURCE_DIR}" "--warn-all" "--sources-top-dirs=${CMAKE_SOURCE_DIR}" "--sources-top-dirs=${CMAKE_BINARY_DIR}")
 | ||||||
|  |    set(INTROSPECTION_COMPILER_ARGS "--includedir=${CMAKE_CURRENT_SOURCE_DIR}") | ||||||
|  |   | ||||||
|  |    # Poppler: Assign package to gir & export keys | ||||||
							
								
								
									
										1055
									
								
								SOURCES/poppler-21.01.0-nss.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1055
									
								
								SOURCES/poppler-21.01.0-nss.patch
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										28
									
								
								SOURCES/poppler-21.01.0-show-annotation-text.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								SOURCES/poppler-21.01.0-show-annotation-text.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,28 @@ | |||||||
|  | From 5dbe101b7c3561aedf33872e218b8d1b6984f623 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Albert Astals Cid <aacid@kde.org> | ||||||
|  | Date: Sat, 8 May 2021 00:54:13 +0200 | ||||||
|  | Subject: [PATCH] Restore setting the Encoding in createAnnotDrawFont | ||||||
|  | 
 | ||||||
|  | It was removed in 9db685f379c1c9195b5f0c9a693e7a581e6b214f and as far as | ||||||
|  | i remember the reason was that signatures created with that hung Adobe | ||||||
|  | Reader, but I can't reproduce it anymore and on top of that is causing | ||||||
|  | regressions when rendering PDF files (Issue #1070) so restore it. | ||||||
|  | ---
 | ||||||
|  |  poppler/Annot.cc | 1 + | ||||||
|  |  1 file changed, 1 insertion(+) | ||||||
|  | 
 | ||||||
|  | diff --git a/poppler/Annot.cc b/poppler/Annot.cc
 | ||||||
|  | index 5287b4dc..40b1085a 100644
 | ||||||
|  | --- a/poppler/Annot.cc
 | ||||||
|  | +++ b/poppler/Annot.cc
 | ||||||
|  | @@ -2852,6 +2852,7 @@ static GfxFont *createAnnotDrawFont(XRef *xref, Dict *fontParentDict, const char
 | ||||||
|  |      Dict *fontDict = new Dict(xref); | ||||||
|  |      fontDict->add("BaseFont", Object(objName, fontname)); | ||||||
|  |      fontDict->add("Subtype", Object(objName, "Type1")); | ||||||
|  | +    fontDict->add("Encoding", Object(objName, "WinAnsiEncoding"));
 | ||||||
|  |   | ||||||
|  |      Object fontsDictObj = fontParentDict->lookup("Font"); | ||||||
|  |      if (!fontsDictObj.isDict()) { | ||||||
|  | -- 
 | ||||||
|  | 2.31.1 | ||||||
|  | 
 | ||||||
							
								
								
									
										27
									
								
								SOURCES/poppler-gcc11.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								SOURCES/poppler-gcc11.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,27 @@ | |||||||
|  | diff --git a/glib/poppler-enums.c.template b/glib/poppler-enums.c.template
 | ||||||
|  | index 26a51b4..27be2b9 100644
 | ||||||
|  | --- a/glib/poppler-enums.c.template
 | ||||||
|  | +++ b/glib/poppler-enums.c.template
 | ||||||
|  | @@ -15,7 +15,7 @@
 | ||||||
|  |  GType | ||||||
|  |  @enum_name@_get_type (void) | ||||||
|  |  { | ||||||
|  | -  static volatile gsize g_define_type_id__volatile = 0;
 | ||||||
|  | +  static gsize g_define_type_id__volatile = 0;
 | ||||||
|  |    | ||||||
|  |    if (g_once_init_enter (&g_define_type_id__volatile)) { | ||||||
|  |      static const G@Type@Value values[] = { | ||||||
|  | 
 | ||||||
|  | diff --git a/glib/poppler-private.h b/glib/poppler-private.h
 | ||||||
|  | index 7726ec7..436bca5 100644
 | ||||||
|  | --- a/glib/poppler-private.h
 | ||||||
|  | +++ b/glib/poppler-private.h
 | ||||||
|  | @@ -167,7 +167,7 @@ gboolean _poppler_convert_pdf_date_to_gtime (const GooString *date,
 | ||||||
|  |  #define POPPLER_DEFINE_BOXED_TYPE(TypeName, type_name, copy_func, free_func)                                                                                                                                                                   \ | ||||||
|  |      GType type_name##_get_type(void)                                                                                                                                                                                                           \ | ||||||
|  |      {                                                                                                                                                                                                                                          \ | ||||||
|  | -        static volatile gsize g_define_type_id__volatile = 0;                                                                                                                                                                                  \
 | ||||||
|  | +        static gsize g_define_type_id__volatile = 0;                                                                                                                                                                                           \
 | ||||||
|  |          if (g_once_init_enter(&g_define_type_id__volatile)) {                                                                                                                                                                                  \ | ||||||
|  |              GType g_define_type_id = g_boxed_type_register_static(g_intern_static_string(#TypeName), (GBoxedCopyFunc)copy_func, (GBoxedFreeFunc)free_func);                                                                                    \ | ||||||
|  |              g_once_init_leave(&g_define_type_id__volatile, g_define_type_id);                                                                                                                                                                  \ | ||||||
							
								
								
									
										1148
									
								
								SPECS/poppler.spec
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1148
									
								
								SPECS/poppler.spec
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Loading…
	
		Reference in New Issue
	
	Block a user