File: Node.h

package info (click to toggle)
osm2pgrouting 3.0.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,036 kB
  • sloc: cpp: 3,754; python: 3,105; xml: 504; sh: 61; sql: 54; ansic: 46; makefile: 18
file content (105 lines) | stat: -rw-r--r-- 3,765 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
/***************************************************************************
 *   Copyright (C) 2016 by pgRouting developers                            *
 *   project@pgrouting.org                                                 *
 *                                                                         *
 *   This program is free software; you can redistribute it and/or modify  *
 *   it under the terms of the GNU General Public License as published by  *
 *   the Free Software Foundation; either version 2 of the License, or     *
 *   (at your option) any later version.                                   *
 *                                                                         *
 *   This program is distributed in the hope that it will be useful,       *
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
 *   GNU General Public License t &or more details.                        *
 *                                                                         *
 *   You should have received a copy of the GNU General Public License     *
 *   along with this program; if not, write to the                         *
 *   Free Software Foundation, Inc.,                                       *
 *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
 ***************************************************************************/


#ifndef SRC_NODE_H_
#define SRC_NODE_H_
#pragma once

#include <boost/lexical_cast.hpp>
#include <cstdint>
#include <string>
#include <map>
#include "./osm_element.h"

namespace osm2pgr {

class Tag;
    /**
      @code
      <node id="122603925" lat="53.0780875" lon="8.1351704"
      user="artus70" visible="true" timestamp="2007-11-18T22:18:59+00:00"/>
      </node>

      <node id="27526559" lat="45.5163189" lon="-122.7922059"
      version="22" timestamp="2012-12-20T03:29:13Z" changeset="14338804" uid="393906" user="Grant Humphries">
      <tag k="highway" v="traffic_signals"/>
      </node>

      <tag k="highway" v="traffic_signals"/>
      <tag k="highway" v="crossing"/>
      <tag k="exit_to" v="OR 217;Tigard;Salem"/>
      <tag k="highway" v="motorway_junction"/>
      <tag k="ref" v="69A"/>
      <tag k="name" v="Southwest Park &amp; Market"/>
      <tag k="public_transport" v="stop_position"/>
      <tag k="railway" v="tram_stop"/>
      <tag k="ref" v="11011"/>
      <tag k="tram" v="yes"/>
      <tag k="highway" v="turning_circle"/>

      @endcode
      */

class Node : public Element {
 public:
     Node() = default;
     Node(const Node&) = default;
     /**
      *    @param atts attributes read py the parser
      */
     explicit Node(const char **atts);
     ~Node() {};

     inline std::string geom_str(const std::string separator) const {
         return get_attribute("lon") + separator +  get_attribute("lat");
     }
     inline std::string lat() {return get_attribute("lat");}
     inline std::string lon() {return get_attribute("lon");}

     void tag_config(const Tag &tag);


     std::string get_geometry() const {
         return
             std::string("srid=4326; POINT(")
             + geom_str(" ") + ")";
     }

     inline std::string osm_id_str() {
         return boost::lexical_cast<std::string>(m_osm_id);
     }
     double getLength(const Node &previous) const;


     inline uint16_t incrementUse() {return ++m_numsOfUse;}
     inline uint16_t numsOfUse() const {return m_numsOfUse;}
     inline void numsOfUse(uint16_t val)  {m_numsOfUse = val;}

 private:
     /**
      *    counts the rate, how much this node is used in different ways
      */
     uint16_t m_numsOfUse;
};


}  // end namespace osm2pgr
#endif  // SRC_NODE_H_