db2a8b
--- poppler/glib/poppler-document.cc
db2a8b
+++ poppler/glib/poppler-document.cc
3e2f0e
@@ -3405,6 +3405,7 @@ PopplerFormField *poppler_document_get_f
3e2f0e
     unsigned fieldNum;
3e2f0e
     FormPageWidgets *widgets;
3e2f0e
     FormWidget *field;
3e2f0e
+    PopplerFormField *formField;
3e2f0e
 
3e2f0e
     FormWidget::decodeID(id, &pageNum, &fieldNum);
3e2f0e
 
3e2f0e
@@ -3417,8 +3418,14 @@ PopplerFormField *poppler_document_get_f
3e2f0e
         return nullptr;
3e2f0e
 
3e2f0e
     field = widgets->getWidget(fieldNum);
3e2f0e
-    if (field)
3e2f0e
-        return _poppler_form_field_new(document, field);
3e2f0e
+    if (field) {
3e2f0e
+        formField = _poppler_form_field_new(document, field);
3e2f0e
+        delete widgets;
db2a8b
+
3e2f0e
+        return formField;
3e2f0e
+    }
db2a8b
+
3e2f0e
+    delete widgets;
db2a8b
 
3e2f0e
     return nullptr;
db2a8b
 }
db2a8b
--- poppler/poppler/CairoOutputDev.cc
db2a8b
+++ poppler/poppler/CairoOutputDev.cc
3e2f0e
@@ -2921,8 +2921,10 @@ void CairoOutputDev::setMimeData(GfxStat
3e2f0e
 
3e2f0e
     // colorspace in stream dict may be different from colorspace in jpx
3e2f0e
     // data
3e2f0e
-    if (strKind == strJPX && colorSpace)
3e2f0e
+    if (strKind == strJPX && colorSpace) {
3e2f0e
+        delete colorSpace;
3e2f0e
         return;
3e2f0e
+    }
3e2f0e
 
3e2f0e
     // only embed mime data for gray, rgb, and cmyk colorspaces.
3e2f0e
     if (colorSpace) {
db2a8b
--- poppler/poppler/TextOutputDev.cc
db2a8b
+++ poppler/poppler/TextOutputDev.cc
3e2f0e
@@ -1619,7 +1619,6 @@ TextBlock::~TextBlock()
3e2f0e
 
3e2f0e
 void TextBlock::addWord(TextWord *word)
3e2f0e
 {
3e2f0e
-    pool->addWord(word);
3e2f0e
     if (xMin > xMax) {
3e2f0e
         xMin = word->xMin;
3e2f0e
         xMax = word->xMax;
3e2f0e
@@ -1639,6 +1638,7 @@ void TextBlock::addWord(TextWord *word)
3e2f0e
             yMax = word->yMax;
3e2f0e
         }
db2a8b
     }
3e2f0e
+    pool->addWord(word);
db2a8b
 }
db2a8b
 
3e2f0e
 void TextBlock::coalesce(const UnicodeMap *uMap, double fixedPitch)
3e2f0e
@@ -3064,11 +3064,13 @@ void TextPage::coalesce(bool physLayout,
3e2f0e
             word0 = pool->getPool(startBaseIdx);
3e2f0e
             pool->setPool(startBaseIdx, word0->next);
3e2f0e
             word0->next = nullptr;
3e2f0e
-            blk = new TextBlock(this, rot);
3e2f0e
-            blk->addWord(word0);
db2a8b
 
3e2f0e
             fontSize = word0->fontSize;
3e2f0e
             minBase = maxBase = word0->base;
db2a8b
+
3e2f0e
+            blk = new TextBlock(this, rot);
3e2f0e
+            blk->addWord(word0);
db2a8b
+
3e2f0e
             colSpace1 = minColSpacing1 * fontSize;
3e2f0e
             colSpace2 = minColSpacing2 * fontSize;
3e2f0e
             lineSpace = maxLineSpacingDelta * fontSize;
3e2f0e
@@ -3095,9 +3097,9 @@ void TextPage::coalesce(bool physLayout,
3e2f0e
                             }
3e2f0e
                             word1 = word1->next;
3e2f0e
                             word2->next = nullptr;
3e2f0e
+                            newMinBase = word2->base;
3e2f0e
                             blk->addWord(word2);
3e2f0e
                             found = true;
3e2f0e
-                            newMinBase = word2->base;
3e2f0e
                         } else {
3e2f0e
                             word0 = word1;
3e2f0e
                             word1 = word1->next;
3e2f0e
@@ -3123,9 +3125,9 @@ void TextPage::coalesce(bool physLayout,
3e2f0e
                             }
3e2f0e
                             word1 = word1->next;
3e2f0e
                             word2->next = nullptr;
3e2f0e
+                            newMaxBase = word2->base;
3e2f0e
                             blk->addWord(word2);
3e2f0e
                             found = true;
3e2f0e
-                            newMaxBase = word2->base;
3e2f0e
                         } else {
3e2f0e
                             word0 = word1;
3e2f0e
                             word1 = word1->next;
3e2f0e
@@ -3198,12 +3200,12 @@ void TextPage::coalesce(bool physLayout,
3e2f0e
                                 }
3e2f0e
                                 word1 = word1->next;
3e2f0e
                                 word2->next = nullptr;
3e2f0e
-                                blk->addWord(word2);
3e2f0e
                                 if (word2->base < minBase) {
3e2f0e
                                     minBase = word2->base;
3e2f0e
                                 } else if (word2->base > maxBase) {
3e2f0e
                                     maxBase = word2->base;
3e2f0e
                                 }
3e2f0e
+                                blk->addWord(word2);
3e2f0e
                                 found = true;
3e2f0e
                                 break;
3e2f0e
                             } else {
3e2f0e
@@ -3246,12 +3248,12 @@ void TextPage::coalesce(bool physLayout,
3e2f0e
                                 }
3e2f0e
                                 word1 = word1->next;
3e2f0e
                                 word2->next = nullptr;
3e2f0e
-                                blk->addWord(word2);
3e2f0e
                                 if (word2->base < minBase) {
3e2f0e
                                     minBase = word2->base;
3e2f0e
                                 } else if (word2->base > maxBase) {
3e2f0e
                                     maxBase = word2->base;
3e2f0e
                                 }
3e2f0e
+                                blk->addWord(word2);
3e2f0e
                                 found = true;
3e2f0e
                                 break;
3e2f0e
                             } else {
db2a8b
--- poppler/poppler/XRef.cc
db2a8b
+++ poppler/poppler/XRef.cc
3e2f0e
@@ -402,6 +402,7 @@ int XRef::reserve(int newSize)
3e2f0e
 
3e2f0e
         void *p = greallocn_checkoverflow(entries, realNewSize, sizeof(XRefEntry));
3e2f0e
         if (p == nullptr) {
3e2f0e
+            entries = nullptr;
3e2f0e
             return 0;
3e2f0e
         }
3e2f0e
 
3e2f0e
@@ -835,7 +836,6 @@ bool XRef::constructXRef(bool *wasRecons
3e2f0e
     int offset = 0;
3e2f0e
 
3e2f0e
     resize(0); // free entries properly
3e2f0e
-    gfree(entries);
3e2f0e
     capacity = 0;
3e2f0e
     size = 0;
3e2f0e
     entries = nullptr;
db2a8b
--- poppler/test/pdf-inspector.cc
db2a8b
+++ poppler/test/pdf-inspector.cc
3e2f0e
@@ -43,6 +43,7 @@ class PdfInspector
3e2f0e
 {
db2a8b
 public:
3e2f0e
     PdfInspector();
3e2f0e
+    ~PdfInspector();
db2a8b
 
3e2f0e
     void set_file_name(const char *file_name);
3e2f0e
     void load(const char *file_name);
3e2f0e
@@ -108,6 +109,11 @@ PdfInspector::PdfInspector()
3e2f0e
     load(nullptr);
db2a8b
 }
3e2f0e
 
db2a8b
+PdfInspector::~PdfInspector(void)
db2a8b
+{
3e2f0e
+    delete output;
db2a8b
+}
3e2f0e
+
3e2f0e
 void PdfInspector::set_file_name(const char *file_name)
3e2f0e
 {
3e2f0e
     GtkWidget *widget;
db2a8b
--- poppler/utils/HtmlOutputDev.cc
db2a8b
+++ poppler/utils/HtmlOutputDev.cc
3e2f0e
@@ -1337,6 +1337,7 @@ void HtmlOutputDev::drawPngImage(GfxStat
3e2f0e
     // TODO can we calculate the resolution of the image?
3e2f0e
     if (!writer->init(f1, width, height, 72, 72)) {
3e2f0e
         error(errInternal, -1, "Can't init PNG for image '{0:t}'", fName);
db2a8b
+        delete fName;
db2a8b
         delete writer;
db2a8b
         fclose(f1);
3e2f0e
         return;
db2a8b
--- poppler/utils/pdftotext.cc
db2a8b
+++ poppler/utils/pdftotext.cc
3e2f0e
@@ -329,6 +329,7 @@ int main(int argc, char *argv[])
3e2f0e
             fputs("
\n", f);
3e2f0e
             if (f != stdout) {
3e2f0e
                 fclose(f);
3e2f0e
+                f = nullptr;
3e2f0e
             }
3e2f0e
         }
db2a8b
     }
3e2f0e
@@ -348,8 +349,9 @@ int main(int argc, char *argv[])
3e2f0e
                 printWordBBox(f, doc, textOut, firstPage, lastPage);
3e2f0e
             }
3e2f0e
         }
3e2f0e
-        if (f != stdout) {
3e2f0e
+        if (f != stdout && f != nullptr) {
3e2f0e
             fclose(f);
3e2f0e
+            f = nullptr;
3e2f0e
         }
3e2f0e
     } else {
3e2f0e
         textOut = new TextOutputDev(textFileName->c_str(), physLayout, fixedPitch, rawOrder, htmlMeta, discardDiag);
3e2f0e
@@ -390,7 +392,7 @@ int main(int argc, char *argv[])
3e2f0e
             fputs("\n", f);
3e2f0e
         fputs("</body>\n", f);
3e2f0e
         fputs("</html>\n", f);
3e2f0e
-        if (f != stdout) {
3e2f0e
+        if (f != stdout && f != nullptr) {
3e2f0e
             fclose(f);
3e2f0e
         }
db2a8b
     }