<html>
<head>
<base href="https://bugs.freedesktop.org/" />
</head>
<body><span class="vcard"><a class="email" href="mailto:Thomas.Freitag@alfa.de" title="Thomas Freitag <Thomas.Freitag@alfa.de>"> <span class="fn">Thomas Freitag</span></a>
</span> changed
<a class="bz_bug_link
bz_status_NEW "
title="NEW --- - Cleanup patch for bug 50992"
href="https://bugs.freedesktop.org/show_bug.cgi?id=59933">bug 59933</a>
<br>
<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>What</th>
<th>Removed</th>
<th>Added</th>
</tr>
<tr>
<td style="text-align:right;">Attachment #73732 is patch</td>
<td>
</td>
<td>1
</td>
</tr></table>
<p>
<div>
<b><a class="bz_bug_link
bz_status_NEW "
title="NEW --- - Cleanup patch for bug 50992"
href="https://bugs.freedesktop.org/show_bug.cgi?id=59933#c1">Comment # 1</a>
on <a class="bz_bug_link
bz_status_NEW "
title="NEW --- - Cleanup patch for bug 50992"
href="https://bugs.freedesktop.org/show_bug.cgi?id=59933">bug 59933</a>
from <span class="vcard"><a class="email" href="mailto:Thomas.Freitag@alfa.de" title="Thomas Freitag <Thomas.Freitag@alfa.de>"> <span class="fn">Thomas Freitag</span></a>
</span></b>
<pre>Comment on <span class=""><a href="attachment.cgi?id=73732" name="attach_73732" title="cleanup code">attachment 73732</a> <a href="attachment.cgi?id=73732&action=edit" title="cleanup code">[details]</a></span> <a href='page.cgi?id=splinter.html&bug=59933&attachment=73732'>[review]</a>
cleanup code
<span class="quote">>diff --git a/goo/GooMutex.h b/goo/GooMutex.h
>index 3f53a62..fbef476 100644
>--- a/goo/GooMutex.h
>+++ b/goo/GooMutex.h
>@@ -60,4 +60,20 @@ typedef pthread_mutex_t GooMutex;
>
> #endif
>
>+namespace Poppler {
>+ enum LockMode {
>+ DoNotLock, // for conditional locks: do not lock
>+ DoLock // for conditional locks: do lock
>+ };
>+
>+ class Lock {
>+ public:
>+ Lock(GooMutex *mutexA) : mutex(mutexA) { mode = DoLock; gLockMutex(mutex); }
>+ Lock(GooMutex *mutexA, LockMode modeA) : mutex(mutexA) { mode = modeA; if (mode == DoLock) gLockMutex(mutex); }
>+ ~Lock() { if (mode == DoLock) gUnlockMutex(mutex); }
>+ private:
>+ GooMutex *mutex;
>+ LockMode mode;
>+ };
>+}
> #endif
>diff --git a/poppler/Annot.cc b/poppler/Annot.cc
>index 0b3c5e4..5bc645a 100644
>--- a/poppler/Annot.cc
>+++ b/poppler/Annot.cc
>@@ -1205,7 +1205,7 @@ void Annot::initialize(PDFDoc *docA, Dict *dict) {
> if (dict->lookupNF("P", &obj1)->isRef()) {
> Ref ref = obj1.getRef();
>
>- page = doc->getCatalog()->findPage (ref.num, ref.gen, gFalse);
>+ page = doc->getCatalog()->findPage (ref.num, ref.gen, Poppler::DoNotLock);
> } else {
> page = 0;
> }
>@@ -3770,7 +3770,7 @@ AnnotWidget::~AnnotWidget() {
> void AnnotWidget::initialize(PDFDoc *docA, Dict *dict) {
> Object obj1;
>
>- form = doc->getCatalog()->getForm(gFalse);
>+ form = doc->getCatalog()->getForm(Poppler::DoNotLock);
>
> if(dict->lookup("H", &obj1)->isName()) {
> const char *modeName = obj1.getName();
>diff --git a/poppler/Array.cc b/poppler/Array.cc
>index d23ed5d..79551e6 100644
>--- a/poppler/Array.cc
>+++ b/poppler/Array.cc
>@@ -35,11 +35,9 @@
> #include "Array.h"
>
> #if MULTITHREADED
>-# define lockArray gLockMutex(&mutex)
>-# define unlockArray gUnlockMutex(&mutex)
>+# define lockArray Poppler::Lock lock(&mutex)
> #else
> # define lockArray
>-# define unlockArray
> #endif
> //------------------------------------------------------------------------
> // Array
>@@ -73,21 +71,18 @@ Object *Array::copy(XRef *xrefA, Object *obj) {
> Object obj1;
> obj->arrayAdd(elems[i].copy(&obj1));
> }
>- unlockArray;
> return obj;
> }
>
> int Array::incRef() {
> lockArray;
> ++ref;
>- unlockArray;
> return ref;
> }
>
> int Array::decRef() {
> lockArray;
> --ref;
>- unlockArray;
> return ref;
> }
>
>@@ -103,7 +98,6 @@ void Array::add(Object *elem) {
> }
> elems[length] = *elem;
> ++length;
>- unlockArray;
> }
>
> void Array::remove(int i) {
>@@ -112,13 +106,11 @@ void Array::remove(int i) {
> #ifdef DEBUG_MEM
> abort();
> #else
>- unlockArray;
> return;
> #endif
> }
> --length;
> memmove( elems + i, elems + i + 1, sizeof(elems[0]) * (length - i) );
>- unlockArray;
> }
>
> Object *Array::get(int i, Object *obj, int recursion) {
>diff --git a/poppler/Catalog.cc b/poppler/Catalog.cc
>index b7f7ede..d4584bc 100644
>--- a/poppler/Catalog.cc
>+++ b/poppler/Catalog.cc
>@@ -57,11 +57,11 @@
> #include "FileSpec.h"
>
> #if MULTITHREADED
>-# define lockCatalog gLockMutex(&mutex)
>-# define unlockCatalog gUnlockMutex(&mutex)
>+# define lockCatalog() Poppler::Lock lock(&mutex)
>+# define condLockCatalog(X) Poppler::Lock condlock(&mutex, (X))
> #else
>-# define lockCatalog
>-# define unlockCatalog
>+# define lockCatalog()
>+# define condLockCatalog(X)
> #endif
> //------------------------------------------------------------------------
> // Catalog
>@@ -191,7 +191,7 @@ GooString *Catalog::readMetadata() {
> Dict *dict;
> Object obj;
>
>- lockCatalog;
>+ lockCatalog();
> if (metadata.isNone()) {
> Object catDict;
>
>@@ -206,7 +206,6 @@ GooString *Catalog::readMetadata() {
> }
>
> if (!metadata.isStream()) {
>- unlockCatalog;
> return NULL;
> }
> dict = metadata.streamGetDict();
>@@ -218,7 +217,6 @@ GooString *Catalog::readMetadata() {
> s = new GooString();
> metadata.getStream()->fillGooString(s);
> metadata.streamClose();
>- unlockCatalog;
> return s;
> }
>
>@@ -226,31 +224,27 @@ Page *Catalog::getPage(int i)
> {
> if (i < 1) return NULL;
>
>- lockCatalog;
>+ lockCatalog();
> if (i > lastCachedPage) {
> GBool cached = cachePageTree(i);
> if ( cached == gFalse) {
>- unlockCatalog;
> return NULL;
> }
> }
>- unlockCatalog;
> return pages[i-1];
> }
>
>-Ref *Catalog::getPageRef(int i, GBool lock)
>+Ref *Catalog::getPageRef(int i, Poppler::LockMode lock)
> {
> if (i < 1) return NULL;
>
>- if (lock) lockCatalog;
>+ condLockCatalog(lock);
> if (i > lastCachedPage) {
> GBool cached = cachePageTree(i);
> if ( cached == gFalse) {
>- if (lock) unlockCatalog;
> return NULL;
> }
> }
>- if (lock) unlockCatalog;
> return &pageRefs[i-1];
> }
>
>@@ -300,7 +294,7 @@ GBool Catalog::cachePageTree(int page)
> return gFalse;
> }
>
>- pagesSize = getNumPages(gFalse);
>+ pagesSize = getNumPages(Poppler::DoLock);
> pages = (Page **)gmallocn(pagesSize, sizeof(Page *));
> pageRefs = (Ref *)gmallocn(pagesSize, sizeof(Ref));
> for (int i = 0; i < pagesSize; ++i) {
>@@ -427,7 +421,7 @@ GBool Catalog::cachePageTree(int page)
> return gFalse;
> }
>
>-int Catalog::findPage(int num, int gen, GBool lock) {
>+int Catalog::findPage(int num, int gen, Poppler::LockMode lock) {
> int i;
>
> for (i = 0; i < getNumPages(lock); ++i) {
>@@ -452,12 +446,11 @@ LinkDest *Catalog::findDest(GooString *name) {
> obj1.free();
> }
> if (!found) {
>- lockCatalog;
>+ lockCatalog();
> if (getDestNameTree()->lookup(name, &obj1))
> found = gTrue;
> else
> obj1.free();
>- unlockCatalog;
> }
> if (!found)
> return NULL;
>@@ -488,7 +481,7 @@ FileSpec *Catalog::embeddedFile(int i)
> {
> Object efDict;
> Object obj;
>- lockCatalog;
>+ lockCatalog();
> obj = getEmbeddedFileNameTree()->getValue(i);
> FileSpec *embeddedFile = 0;
> if (obj.isRef()) {
>@@ -501,7 +494,6 @@ FileSpec *Catalog::embeddedFile(int i)
> Object null;
> embeddedFile = new FileSpec(&null);
> }
>- unlockCatalog;
> return embeddedFile;
> }
>
>@@ -510,12 +502,11 @@ GooString *Catalog::getJS(int i)
> Object obj;
> // getJSNameTree()->getValue(i) returns a shallow copy of the object so we
> // do not need to free it
>- lockCatalog;
>+ lockCatalog();
> getJSNameTree()->getValue(i).fetch(xref, &obj);
>
> if (!obj.isDict()) {
> obj.free();
>- unlockCatalog;
> return 0;
> }
> Object obj2;
>@@ -527,7 +518,6 @@ GooString *Catalog::getJS(int i)
> if (strcmp(obj2.getName(), "JavaScript")) {
> obj2.free();
> obj.free();
>- unlockCatalog;
> return 0;
> }
> obj2.free();
>@@ -543,13 +533,12 @@ GooString *Catalog::getJS(int i)
> }
> obj2.free();
> obj.free();
>- unlockCatalog;
> return js;
> }
>
> Catalog::PageMode Catalog::getPageMode() {
>
>- lockCatalog;
>+ lockCatalog();
> if (pageMode == pageModeNull) {
>
> Object catDict, obj;
>@@ -560,7 +549,6 @@ Catalog::PageMode Catalog::getPageMode() {
> if (!catDict.isDict()) {
> error(errSyntaxError, -1, "Catalog object is wrong type ({0:s})", catDict.getTypeName());
> catDict.free();
>- unlockCatalog;
> return pageMode;
> }
>
>@@ -581,13 +569,12 @@ Catalog::PageMode Catalog::getPageMode() {
> obj.free();
> catDict.free();
> }
>- unlockCatalog;
> return pageMode;
> }
>
> Catalog::PageLayout Catalog::getPageLayout() {
>
>- lockCatalog;
>+ lockCatalog();
> if (pageLayout == pageLayoutNull) {
>
> Object catDict, obj;
>@@ -598,7 +585,6 @@ Catalog::PageLayout Catalog::getPageLayout() {
> if (!catDict.isDict()) {
> error(errSyntaxError, -1, "Catalog object is wrong type ({0:s})", catDict.getTypeName());
> catDict.free();
>- unlockCatalog;
> return pageLayout;
> }
>
>@@ -620,7 +606,6 @@ Catalog::PageLayout Catalog::getPageLayout() {
> obj.free();
> catDict.free();
> }
>- unlockCatalog;
> return pageLayout;
> }
>
>@@ -787,13 +772,9 @@ GBool Catalog::indexToLabel(int index, GooString *label)
> }
> }
>
>-int Catalog::getNumPages(GBool lock)
>+int Catalog::getNumPages(Poppler::LockMode lock)
> {
>- GBool locked = gFalse;
>- if (lock && numPages == -1) {
>- locked = gTrue;
>- lockCatalog;
>- }
>+ condLockCatalog((numPages == -1 && lock == Poppler::DoLock) ? lock : Poppler::DoNotLock);
> if (numPages == -1)
> {
> Object catDict, pagesDict, obj;
>@@ -802,7 +783,6 @@ int Catalog::getNumPages(GBool lock)
> if (!catDict.isDict()) {
> error(errSyntaxError, -1, "Catalog object is wrong type ({0:s})", catDict.getTypeName());
> catDict.free();
>- if (locked) unlockCatalog;
> return 0;
> }
> catDict.dictLookup("Pages", &pagesDict);
>@@ -814,7 +794,6 @@ int Catalog::getNumPages(GBool lock)
> error(errSyntaxError, -1, "Top-level pages object is wrong type ({0:s})",
> pagesDict.getTypeName());
> pagesDict.free();
>- if (locked) unlockCatalog;
> return 0;
> }
>
>@@ -832,13 +811,12 @@ int Catalog::getNumPages(GBool lock)
> pagesDict.free();
> }
>
>- if (locked) unlockCatalog;
> return numPages;
> }
>
> PageLabelInfo *Catalog::getPageLabelInfo()
> {
>- lockCatalog;
>+ lockCatalog();
> if (!pageLabelInfo) {
> Object catDict;
> Object obj;
>@@ -847,24 +825,22 @@ PageLabelInfo *Catalog::getPageLabelInfo()
> if (!catDict.isDict()) {
> error(errSyntaxError, -1, "Catalog object is wrong type ({0:s})", catDict.getTypeName());
> catDict.free();
>- unlockCatalog;
> return NULL;
> }
>
> if (catDict.dictLookup("PageLabels", &obj)->isDict()) {
>- pageLabelInfo = new PageLabelInfo(&obj, getNumPages(gFalse));
>+ pageLabelInfo = new PageLabelInfo(&obj, getNumPages(Poppler::DoLock));
> }
> obj.free();
> catDict.free();
> }
>
>- unlockCatalog;
> return pageLabelInfo;
> }
>
> Object *Catalog::getStructTreeRoot()
> {
>- lockCatalog;
>+ lockCatalog();
> if (structTreeRoot.isNone())
> {
> Object catDict;
>@@ -879,13 +855,12 @@ Object *Catalog::getStructTreeRoot()
> catDict.free();
> }
>
>- unlockCatalog;
> return &structTreeRoot;
> }
>
> Object *Catalog::getOutline()
> {
>- lockCatalog;
>+ lockCatalog();
> if (outline.isNone())
> {
> Object catDict;
>@@ -900,13 +875,12 @@ Object *Catalog::getOutline()
> catDict.free();
> }
>
>- unlockCatalog;
> return &outline;
> }
>
> Object *Catalog::getDests()
> {
>- lockCatalog;
>+ lockCatalog();
> if (dests.isNone())
> {
> Object catDict;
>@@ -921,7 +895,6 @@ Object *Catalog::getDests()
> catDict.free();
> }
>
>- unlockCatalog;
> return &dests;
> }
>
>@@ -943,9 +916,9 @@ Catalog::FormType Catalog::getFormType()
> return res;
> }
>
>-Form *Catalog::getForm(GBool lock)
>+Form *Catalog::getForm(Poppler::LockMode lock)
> {
>- if (lock) lockCatalog;
>+ condLockCatalog(lock);
> if (!form) {
> if (acroForm.isDict()) {
> form = new Form(doc, &acroForm);
>@@ -954,20 +927,18 @@ Form *Catalog::getForm(GBool lock)
> }
> }
>
>- if (lock) unlockCatalog;
> return form;
> }
>
> ViewerPreferences *Catalog::getViewerPreferences()
> {
>- lockCatalog;
>+ lockCatalog();
> if (!viewerPrefs) {
> if (viewerPreferences.isDict()) {
> viewerPrefs = new ViewerPreferences(viewerPreferences.getDict());
> }
> }
>
>- unlockCatalog;
> return viewerPrefs;
> }
>
>diff --git a/poppler/Catalog.h b/poppler/Catalog.h
>index ac7505f..0ddc30a 100644
>--- a/poppler/Catalog.h
>+++ b/poppler/Catalog.h
>@@ -107,13 +107,13 @@ public:
> GBool isOk() { return ok; }
>
> // Get number of pages.
>- int getNumPages(GBool lock = gTrue);
>+ int getNumPages(Poppler::LockMode lock = Poppler::DoLock);
>
> // Get a page.
> Page *getPage(int i);
>
> // Get the reference for a page object.
>- Ref *getPageRef(int i, GBool lock = gTrue);
>+ Ref *getPageRef(int i, Poppler::LockMode lock = Poppler::DoLock);
>
> // Return base URI, or NULL if none.
> GooString *getBaseURI() { return baseURI; }
>@@ -127,7 +127,7 @@ public:
>
> // Find a page, given its object ID. Returns page number, or 0 if
> // not found.
>- int findPage(int num, int gen, GBool lock = gTrue);
>+ int findPage(int num, int gen, Poppler::LockMode lock = Poppler::DoLock);
>
> // Find a named destination. Returns the link destination, or
> // NULL if <name> is not a destination.
>@@ -165,7 +165,7 @@ public:
> };
>
> FormType getFormType();
>- Form* getForm(GBool lock = gTrue);
>+ Form* getForm(Poppler::LockMode lock = Poppler::DoLock);
>
> ViewerPreferences *getViewerPreferences();
>
>@@ -228,7 +228,6 @@ private:
> PageMode pageMode; // page mode
> PageLayout pageLayout; // page layout
>
>- void createPages(); // create pages for caching
> GBool cachePageTree(int page); // Cache first <page> pages.
> Object *findDestInTree(Object *tree, GooString *name, Object *obj);
> </span >
></pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are the assignee for the bug.</li>
</ul>
</body>
</html>