]> git.lyx.org Git - features.git/commitdiff
Avoid duplicate checks in CoordCache
authorJean-Marc Lasgouttes <lasgouttes@lyx.org>
Wed, 6 Oct 2021 11:06:45 +0000 (13:06 +0200)
committerJean-Marc Lasgouttes <lasgouttes@lyx.org>
Fri, 8 Oct 2021 16:17:19 +0000 (18:17 +0200)
The code is written in such a way that the elements are searched
several times. This can be expensive when there are a lots of insets
in the document.

Concerning the sanity checks, they are now conditionned on the
presence of assertion.

Related to bug #12297.

src/CoordCache.h

index 44ac26c66de5232a4714cf2d7af49a8e737eab76..b99cbe6ddd1d5ccb674d8b896a901efba766bbcf 100644 (file)
@@ -26,7 +26,7 @@ class MathData;
 void lyxbreaker(void const * data, const char * hint, int size);
 
 struct Geometry {
-       Point pos;
+       Point pos = {-10000, -10000 };
        Dimension dim;
 
        bool covers(int x, int y) const
@@ -75,8 +75,6 @@ public:
 
        void add(T const * thing, Dimension const & dim)
        {
-               if (!has(thing))
-                       data_[thing].pos = Point(-10000, -10000);
                data_[thing].dim = dim;
        }
 
@@ -147,6 +145,7 @@ public:
 private:
        friend class CoordCache;
 
+#ifdef ENABLE_ASSERTIONS
        void checkDim(T const * thing, char const * hint) const
        {
                if (!hasDim(thing))
@@ -158,6 +157,11 @@ private:
                if (!has(thing))
                        lyxbreaker(thing, hint, data_.size());
        }
+#else
+       void checkDim(T const *, char const * const ) const {}
+
+       void check(T const *, char const *) const {}
+#endif
 
        typedef std::unordered_map<T const *, Geometry> cache_type;
        cache_type data_;