1 // SPDX-License-Identifier: LGPL-2.1-or-later
2 //
3 // SPDX-FileCopyrightText: 2015 Stanciu Marius-Valeriu <stanciumarius94@gmail.com>
4 //
5 
6 //Self
7 #include "OsmDocumentTagTranslator.h"
8 
9 //Marble
10 #include "OsmNodeTagWriter.h"
11 #include "OsmWayTagWriter.h"
12 #include "OsmElementDictionary.h"
13 #include "GeoDataDocument.h"
14 #include "GeoWriter.h"
15 #include "GeoDataGeometry.h"
16 #include "GeoDataPoint.h"
17 #include "GeoDataPolygon.h"
18 #include "GeoDataBuilding.h"
19 #include "GeoDataMultiGeometry.h"
20 #include "GeoDataPlacemark.h"
21 #include "GeoDataLinearRing.h"
22 #include "GeoDataTypes.h"
23 #include "osm/OsmPlacemarkData.h"
24 #include "osm/OsmObjectManager.h"
25 #include "OsmRelationTagWriter.h"
26 #include "OsmConverter.h"
27 
28 #include <QDebug>
29 
30 namespace Marble
31 {
32 
33 static GeoTagWriterRegistrar s_writerDocument( GeoTagWriter::QualifiedName( GeoDataTypes::GeoDataDocumentType,
34                                                                             osm::osmTag_version06 ),
35                                                new OsmDocumentTagTranslator() );
36 
37 
write(const GeoNode * node,GeoWriter & writer) const38 bool OsmDocumentTagTranslator::write( const GeoNode *node, GeoWriter& writer ) const
39 {
40     const GeoDataDocument *document = static_cast<const GeoDataDocument*>(node);
41 
42     OsmConverter converter;
43     converter.read(document);
44     OsmNodeTagWriter::writeAllNodes(converter.nodes(), writer);
45 
46     qint64 lastId = 0;
47     for (auto const &way: converter.ways()) {
48         if (way.second.id() != lastId) {
49             OsmWayTagWriter::writeWay(*way.first, way.second, writer);
50             lastId = way.second.id();
51         }
52     }
53 
54     for (auto const & relation: converter.relations()) {
55         if (auto placemark = geodata_cast<GeoDataPlacemark>(relation.first)) {
56             if (const auto building = geodata_cast<GeoDataBuilding>(placemark->geometry())) {
57                 auto polygon = geodata_cast<GeoDataPolygon>(&building->multiGeometry()->at(0));
58                 Q_ASSERT(polygon);
59                 OsmRelationTagWriter::writeMultipolygon(*polygon, relation.second, writer );
60             } else {
61                 auto polygon = geodata_cast<GeoDataPolygon>(placemark->geometry());
62                 Q_ASSERT(polygon);
63                 OsmRelationTagWriter::writeMultipolygon(*polygon, relation.second, writer );
64             }
65         }
66     }
67 
68     return true;
69 }
70 
71 }
72 
73