Skip to content

Commit e714294

Browse files
committed
Merge branch 'master' into release
2 parents 334bedf + e31f444 commit e714294

File tree

78 files changed

+37692
-12117
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

78 files changed

+37692
-12117
lines changed

CMakeLists.txt

+1-1
Original file line numberDiff line numberDiff line change
@@ -25,7 +25,7 @@ include(FeatureSummary)
2525

2626
# Project declaration
2727

28-
project(Mapper VERSION 0.8.0 LANGUAGES CXX C)
28+
project(Mapper VERSION 0.8.1 LANGUAGES CXX C)
2929

3030
if(Mapper_VERSION_DISPLAY)
3131
message(STATUS "Custom version display string: \"${Mapper_VERSION_DISPLAY}\"")

android/AndroidManifest.xml

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
<?xml version="1.0"?>
2-
<manifest xmlns:android="http://schemas.android.com/apk/res/android" android:versionName="0.8.0" android:versionCode="800" package="org.openorienteering.mapper" android:installLocation="auto">
2+
<manifest xmlns:android="http://schemas.android.com/apk/res/android" android:versionName="0.8.1" android:versionCode="801" package="org.openorienteering.mapper" android:installLocation="auto">
33
<application android:name="org.qtproject.qt5.android.bindings.QtApplication" android:label="@string/long_app_name" android:icon="@drawable/icon">
44
<activity android:configChanges="orientation|uiMode|screenLayout|screenSize|smallestScreenSize|locale|fontScale|keyboard|keyboardHidden|navigation"
55
android:name="org.openorienteering.mapper.MapperActivity"

doc/manual/pages/file_menu.md

+2
Original file line numberDiff line numberDiff line change
@@ -50,6 +50,8 @@ Permits the import of maps or data in other formats. Currently the following for
5050

5151
Permits the export of the currently opened map to another format. Currently pdf and raster image export are supported.
5252

53+
For raster images, Mapper may additionally create world files. A world file is a small text file which defines the image's georeferencing relative to the map's projected coordinate reference system. Note that these files contain only six numerical parameters. They do not contain an identification of the projection, coordinate system or datum they refer to. The filename is derived from the image's filename, but with a modified filename extension usually ending with letter 'w'.
54+
5355

5456
---
5557

doc/manual/pages/find_objects.md

+2-2
Original file line numberDiff line numberDiff line change
@@ -37,7 +37,7 @@ The following expressions are supported:
3737
| expr1 OR expr2 | matching expression expr1 or expr2 (or both) |
3838
| key = value | having a tag with the given key and value |
3939
| key ~= word | having a tag with the given key and a value containing "word" |
40-
| key != word | having a tag with the given key and a value different from "word" |
40+
| key != word | having a tag with the given key and a value different from "word", or not having a tag with this key |
4141

4242
AND has precedence over OR. You may use parentheses to nest operators in another way.
4343

@@ -58,7 +58,7 @@ The "Query editor" button will replace the input field with a table for entering
5858
Pressing the button again will restore the input field and make it show the query from editor view.
5959

6060

61-
## Query editor
61+
## Query editor {#query-editor}
6262

6363
![Query editor](images/query_editor.png)
6464

iwyu-mapper.imp

+9
Original file line numberDiff line numberDiff line change
@@ -17,4 +17,13 @@
1717
# ?
1818
{ include: [ "<ext/alloc_traits.h>", "private", "<memory>", "public" ] },
1919

20+
# libstdc++ debugging headers, for use with -D_GLIBCXX_DEBUG
21+
{ include: [ "<debug/map.h>", "private", "<map>", "public" ] },
22+
{ include: [ "<debug/safe_iterator.h>", "private", "<iterator>", "public" ] },
23+
{ include: [ "<debug/safe_sequence.h>", "private", "<iterator>", "public" ] },
24+
{ include: [ "<debug/set.h>", "private", "<set>", "public" ] },
25+
{ include: [ "<debug/unordered_map>", "private", "<unordered_map>", "public" ] },
26+
{ include: [ "<debug/unordered_set>", "private", "<unordered_set>", "public" ] },
27+
{ include: [ "<debug/vector>", "private", "<vector>", "public" ] },
28+
2029
]

packaging/linux/Mapper.desktop

+1-1
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,7 @@ Type=Application
33
Name=OpenOrienteering Mapper
44
Comment=A free software for drawing orienteering maps
55
Comment[cs]=Svobodný program na kreslení map pro orientační běh
6-
Comment[da]=En gratis software til tegning af orienteringskort
6+
Comment[da]=Et gratis program til tegning af orienteringskort
77
Comment[de]=Ein freies Programm zum Zeichnen von Orientierungslaufkarten
88
Comment[eo]=Libera programaro por desegni orientiĝajn mapojn
99
Comment[es]=Software libre para dibujar mapas de orientación

packaging/linux/openorienteering-mapper.xml

+6-2
Original file line numberDiff line numberDiff line change
@@ -4,14 +4,16 @@
44
<sub-class-of type="text/xml"/>
55
<comment>Orienteering map</comment>
66
<comment xml:lang="cs">Mapa pro orientační běh</comment>
7-
<comment xml:lang="da">Orienteringsløb-kort</comment>
7+
<comment xml:lang="da">Orienteringskort</comment>
88
<comment xml:lang="de">Orientierungslaufkarte</comment>
99
<comment xml:lang="eo">Orientiĝa mapo</comment>
1010
<comment xml:lang="es">Mapa de orientación</comment>
1111
<comment xml:lang="fi">Suunnistuskartta</comment>
1212
<comment xml:lang="fr">Carte d'orientation</comment>
13+
<comment xml:lang="hu">Tájfutó térkép</comment>
1314
<comment xml:lang="id">Peta orienteering</comment>
1415
<comment xml:lang="ja">オリエンテーリング地図</comment>
16+
<comment xml:lang="lv">Orientēšanās karte</comment>
1517
<comment xml:lang="nb">Orienteringskart</comment>
1618
<comment xml:lang="nl">Oriëntatiekaart</comment>
1719
<comment xml:lang="pt_BR">Mapa de orientação</comment>
@@ -25,14 +27,16 @@
2527
<mime-type type="application/x-openorienteering-ocd">
2628
<comment>Orienteering map</comment>
2729
<comment xml:lang="cs">Mapa pro orientační běh</comment>
28-
<comment xml:lang="da">Orienteringsløb-kort</comment>
30+
<comment xml:lang="da">Orienteringskort</comment>
2931
<comment xml:lang="de">Orientierungslaufkarte</comment>
3032
<comment xml:lang="eo">Orientiĝa mapo</comment>
3133
<comment xml:lang="es">Mapa de orientación</comment>
3234
<comment xml:lang="fi">Suunnistuskartta</comment>
3335
<comment xml:lang="fr">Carte d'orientation</comment>
36+
<comment xml:lang="hu">Tájfutó térkép</comment>
3437
<comment xml:lang="id">Peta orienteering</comment>
3538
<comment xml:lang="ja">オリエンテーリング地図</comment>
39+
<comment xml:lang="lv">Orientēšanās karte</comment>
3640
<comment xml:lang="nb">Orienteringskart</comment>
3741
<comment xml:lang="nl">Oriëntatiekaart</comment>
3842
<comment xml:lang="pt_BR">Mapa de orientação</comment>

src/core/map.cpp

+23-12
Original file line numberDiff line numberDiff line change
@@ -46,6 +46,7 @@
4646
#include <QSaveFile>
4747
#include <QStringList>
4848
#include <QTextDocument>
49+
#include <QTimer>
4950
#include <QTranslator>
5051

5152
#include "core/georeferencing.h"
@@ -221,8 +222,12 @@ MapColorMap Map::MapColorSet::importSet(const Map::MapColorSet& other, std::vect
221222
{
222223
colors.reserve(colors.size() + import_count);
223224

224-
MapColorSetMergeList merge_list;
225-
merge_list.resize(other.colors.size());
225+
// The conflict resolution algorithm below is simplified by setting
226+
// iterator `selected_item` to a real list element which is not related
227+
// to the actual color sets we are merging. This is the extra element
228+
// identified as `end_of_merge_list`.
229+
MapColorSetMergeList merge_list{other.colors.size() + 1};
230+
const auto end_of_merge_list = end(merge_list) - 1;
226231

227232
bool priorities_changed = false;
228233

@@ -249,15 +254,15 @@ MapColorMap Map::MapColorSet::importSet(const Map::MapColorSet& other, std::vect
249254
}
250255
++merge_list_item;
251256
}
252-
Q_ASSERT(merge_list_item == merge_list.end());
257+
Q_ASSERT(merge_list_item == end_of_merge_list);
253258

254259
size_t iteration_number = 1;
255260
while (true)
256261
{
257262
// Evaluate bounds and conflicting order of colors
258263
int max_conflict_reduction = 0;
259-
auto selected_item = merge_list.end();
260-
for (merge_list_item = merge_list.begin(); merge_list_item != merge_list.end(); ++merge_list_item)
264+
auto selected_item = end_of_merge_list; // Note: non-const copy of an iterator
265+
for (merge_list_item = begin(merge_list); merge_list_item != end_of_merge_list; ++merge_list_item)
261266
{
262267
// Check all lower colors for a higher dest_index
263268
std::size_t& lower_bound(merge_list_item->lower_bound);
@@ -281,7 +286,7 @@ MapColorMap Map::MapColorSet::importSet(const Map::MapColorSet& other, std::vect
281286
// Check all higher colors for a lower dest_index
282287
std::size_t& upper_bound(merge_list_item->upper_bound);
283288
upper_bound = merge_list_item->dest_color ? merge_list_item->dest_index : colors.size();
284-
for (++it; it != merge_list.end(); ++it)
289+
for (++it; it != end_of_merge_list; ++it)
285290
{
286291
if (it->dest_color)
287292
{
@@ -319,7 +324,7 @@ MapColorMap Map::MapColorSet::importSet(const Map::MapColorSet& other, std::vect
319324
int conflict_reduction = merge_list_item->lower_errors;
320325
// Check new conflicts with insertion index: (selected_item->lower_bound+1)
321326
it = merge_list_item;
322-
for (++it; it != merge_list.end(); ++it)
327+
for (++it; it != end_of_merge_list; ++it)
323328
{
324329
if (it->dest_color && (selected_item->lower_bound+1) > it->dest_index)
325330
--conflict_reduction;
@@ -337,8 +342,8 @@ MapColorMap Map::MapColorSet::importSet(const Map::MapColorSet& other, std::vect
337342
// Abort if no conflicts or maximum iteration count reached.
338343
// The latter condition is just to prevent endless loops in
339344
// case of bugs and should not occur theoretically.
340-
if (selected_item == merge_list.end() ||
341-
iteration_number > merge_list.size())
345+
if (selected_item == end_of_merge_list
346+
|| iteration_number > merge_list.size())
342347
break;
343348

344349
// Solve selected conflict item
@@ -365,6 +370,8 @@ MapColorMap Map::MapColorSet::importSet(const Map::MapColorSet& other, std::vect
365370
++iteration_number;
366371
}
367372

373+
merge_list.erase(end_of_merge_list); // no longer needed
374+
368375
// Some missing colors may be spot color compositions which can be
369376
// resolved to new colors only after all colors have been created.
370377
// That is why we create all missing colors first.
@@ -448,9 +455,6 @@ Map::Map()
448455
georeferencing.reset(new Georeferencing());
449456
init();
450457

451-
connect(this, &Map::symbolAdded, this, &Map::updateSymbolIconZoom, Qt::QueuedConnection);
452-
connect(this, &Map::symbolChanged, this, &Map::updateSymbolIconZoom, Qt::QueuedConnection);
453-
connect(this, &Map::symbolDeleted, this, &Map::updateSymbolIconZoom, Qt::QueuedConnection);
454458
connect(this, &Map::colorAdded, this, &Map::checkSpotColorPresence);
455459
connect(this, &Map::colorChanged, this, &Map::checkSpotColorPresence);
456460
connect(this, &Map::colorDeleted, this, &Map::checkSpotColorPresence);
@@ -1884,6 +1888,11 @@ int Map::findSymbolIndex(const Symbol* symbol) const
18841888

18851889
void Map::setSymbolsDirty()
18861890
{
1891+
if (symbol_icon_scale > 0)
1892+
{
1893+
symbol_icon_scale = 0;
1894+
QTimer::singleShot(0, this, SLOT(updateSymbolIconZoom()));
1895+
}
18871896
symbols_dirty = true;
18881897
setHasUnsavedChanges(true);
18891898
}
@@ -1980,6 +1989,8 @@ void Map::updateSymbolIconZoom()
19801989
values.reserve(symbols.size());
19811990
for (const auto symbol : symbols)
19821991
{
1992+
if (symbol->isHelperSymbol())
1993+
continue;
19831994
auto size = symbol->dimensionForIcon();
19841995
if (size > 0)
19851996
values.push_back(size);

src/core/map.h

+2
Original file line numberDiff line numberDiff line change
@@ -595,6 +595,7 @@ friend class XMLFileExporter;
595595
*/
596596
qreal symbolIconZoom() const;
597597

598+
public slots:
598599
/**
599600
* Updates the symbol icon zoom from the current set of symbols.
600601
*
@@ -605,6 +606,7 @@ friend class XMLFileExporter;
605606
void updateSymbolIconZoom();
606607

607608

609+
public:
608610
// Templates
609611

610612
/** Returns the number of templates in this map. */

src/core/map_view.cpp

+3-3
Original file line numberDiff line numberDiff line change
@@ -113,7 +113,7 @@ void MapView::load(QIODevice* file, int version)
113113
{
114114
center_pos = MapCoord::fromNative64withOffset(center_x, center_y);
115115
}
116-
catch (std::range_error)
116+
catch (std::range_error&)
117117
{
118118
// leave center_pos unchanged
119119
}
@@ -199,7 +199,7 @@ void MapView::load(QXmlStreamReader& xml)
199199
{
200200
center_pos = MapCoord::fromNative64withOffset(center_x, center_y);
201201
}
202-
catch (std::range_error)
202+
catch (std::range_error&)
203203
{
204204
// leave center_pos unchanged
205205
}
@@ -341,7 +341,7 @@ void MapView::finishPanning(QPoint offset)
341341
auto move = MapCoord{ rotated_offset_f };
342342
setCenter(center() + move);
343343
}
344-
catch (std::range_error)
344+
catch (std::range_error&)
345345
{
346346
// Do nothing
347347
}

src/core/objects/boolean_tool.cpp

+1-1
Original file line numberDiff line numberDiff line change
@@ -336,7 +336,7 @@ void BooleanTool::outerPolyNodeToPathObjects(const ClipperLib::PolyNode& node, P
336336

337337
out_objects.push_back(object.release());
338338
}
339-
catch (std::range_error)
339+
catch (std::range_error&)
340340
{
341341
// Do nothing
342342
}

0 commit comments

Comments
 (0)