/[zanavi_public1]/navit/navit/item.h
ZANavi

Contents of /navit/navit/item.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2 - (show annotations) (download)
Fri Oct 28 21:19:04 2011 UTC (12 years, 5 months ago) by zoff99
File MIME type: text/plain
File size: 5319 byte(s)
import files
1 /**
2 * Navit, a modular navigation system.
3 * Copyright (C) 2005-2008 Navit Team
4 *
5 * This program is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Library General Public License
7 * version 2 as published by the Free Software Foundation.
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU Library General Public License for more details.
13 *
14 * You should have received a copy of the GNU Library General Public
15 * License along with this program; if not, write to the
16 * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
17 * Boston, MA 02110-1301, USA.
18 */
19
20 #ifndef NAVIT_ITEM_H
21 #define NAVIT_ITEM_H
22
23 #ifdef __cplusplus
24 extern "C" {
25 #endif
26
27 #include <stdio.h>
28
29 enum item_type {
30 #define ITEM2(x,y) type_##y=x,
31 #define ITEM(x) type_##x,
32 #include "item_def.h"
33 #undef ITEM2
34 #undef ITEM
35 };
36
37 #define route_item_first type_street_0
38 #define route_item_last type_path
39 extern int default_flags[];
40
41 #include "attr.h"
42
43
44 /* NOTE: we treat districts as towns for now, since
45 a) navit does not implement district search yet
46 b) OSM "place=suburb" maps to type_district in maptool. with the OSM USA maps,
47 there are many "suburbs" that users will consider towns (not districts/counties);
48 we want navit's town search to find them
49 */
50 #define item_type_is_area(type) ((type) >= type_area)
51 #define item_is_town(item) ((item).type >= type_town_label && (item).type <= type_district_label_1e7)
52 #define item_is_district(item) ((item).type >= type_district_label && (item).type <= type_district_label_1e7)
53 #define item_is_poly_place(item) ((item).type >= type_poly_place1 && (item).type <= type_poly_place6)
54 #define item_is_point(item) ((item).type < type_line)
55 #define item_is_custom_poi(item) ((item).type >= type_poi_custom0 && (item).type < type_line)
56 #define item_is_street(item) (((item).type >= type_street_0 && (item).type < type_street_1_land) \
57 || (item).type == type_street_pedestrian \
58 || (item).type == type_living_street)
59
60 #define item_is_equal_id(a,b) ((a).id_hi == (b).id_hi && (a).id_lo == (b).id_lo)
61 #define item_is_equal(a,b) (item_is_equal_id(a,b) && (a).map == (b).map)
62
63 struct coord;
64
65 enum change_mode {
66 change_mode_delete,
67 change_mode_modify,
68 change_mode_append,
69 change_mode_prepend,
70 };
71
72 struct item_methods {
73 void (*item_coord_rewind)(void *priv_data);
74 int (*item_coord_get)(void *priv_data, struct coord *c, int count);
75 void (*item_attr_rewind)(void *priv_data);
76 int (*item_attr_get)(void *priv_data, enum attr_type attr_type, struct attr *attr);
77 int (*item_coord_is_node)(void *priv_data);
78 int (*item_attr_set)(void *priv_data, struct attr *attr, enum change_mode mode);
79 int (*item_coord_set)(void *priv_data, struct coord *c, int count, enum change_mode mode);
80 int (*item_type_set)(void *priv_data, enum item_type type);
81 };
82
83 struct item_id {
84 int id_hi;
85 int id_lo;
86 };
87
88 #define ITEM_ID_FMT "(0x%x,0x%x)"
89 #define ITEM_ID_ARGS(x) (x).id_hi,(x).id_lo
90
91 struct item {
92 enum item_type type;
93 int id_hi;
94 int id_lo;
95 struct map *map;
96 struct item_methods *meth;
97 void *priv_data;
98 // added flags from attr!! --> Zoff
99 long flags;
100 };
101
102 extern struct item_range {
103 enum item_type min,max;
104 } item_range_all;
105
106 extern struct item busy_item;
107
108 /* prototypes */
109 enum attr_type;
110 enum change_mode;
111 enum item_type;
112 enum projection;
113 struct attr;
114 struct coord;
115 struct item;
116 struct item_hash;
117 struct item_range;
118 struct map;
119 struct map_selection;
120 int *item_get_default_flags(enum item_type type);
121 void item_coord_rewind(struct item *it);
122 int item_coord_get(struct item *it, struct coord *c, int count);
123 int item_coord_set(struct item *it, struct coord *c, int count, enum change_mode mode);
124 int item_coord_get_within_selection(struct item *it, struct coord *c, int count, struct map_selection *sel);
125 int item_coord_get_pro(struct item *it, struct coord *c, int count, enum projection to);
126 int item_coord_is_node(struct item *it);
127 void item_attr_rewind(struct item *it);
128 int item_attr_get(struct item *it, enum attr_type attr_type, struct attr *attr);
129 int item_attr_set(struct item *it, struct attr *attr, enum change_mode mode);
130 struct item *item_new(char *type, int zoom);
131 enum item_type item_from_name(const char *name);
132 char *item_to_name(enum item_type item);
133 unsigned int item_id_hash(const void *key);
134 int item_id_equal(const void *a, const void *b);
135 struct item_hash *item_hash_new(void);
136 void item_hash_insert(struct item_hash *h, struct item *item, void *val);
137 int item_hash_remove(struct item_hash *h, struct item *item);
138 void *item_hash_lookup(struct item_hash *h, struct item *item);
139 void item_hash_destroy(struct item_hash *h);
140 int item_range_intersects_range(struct item_range *range1, struct item_range *range2);
141 int item_range_contains_item(struct item_range *range, enum item_type type);
142 void item_dump_attr(struct item *item, struct map *map, FILE *out);
143 void item_dump_filedesc(struct item *item, struct map *map, FILE *out);
144 void item_cleanup(void);
145
146 void item_dump_attr_stdout(struct item *item, struct map *map);
147
148 /* end of prototypes */
149
150
151 #ifdef __cplusplus
152 }
153 /* __cplusplus */
154 #endif
155
156 /* NAVIT_ITEM_H */
157 #endif

   
Visit the ZANavi Wiki