summaryrefslogtreecommitdiff
path: root/navit/map/csv/csv.c
diff options
context:
space:
mode:
authortegzed <tegzed@ffa7fe5e-494d-0410-b361-a75ebd5db220>2011-02-20 23:04:51 +0000
committertegzed <tegzed@ffa7fe5e-494d-0410-b361-a75ebd5db220>2011-02-20 23:04:51 +0000
commit8f3491f184a5ede7f844c6b240485aa14c188c49 (patch)
tree20562ee6ffcc4869e5ba9726dded796d09ad63d2 /navit/map/csv/csv.c
parentecc66af338f8415eda98ad6fd3f7be00335bf746 (diff)
downloadnavit-8f3491f184a5ede7f844c6b240485aa14c188c49.tar.gz
Fix:map/csv:added some NULL checks
git-svn-id: http://svn.code.sf.net/p/navit/code/trunk/navit@4229 ffa7fe5e-494d-0410-b361-a75ebd5db220
Diffstat (limited to 'navit/map/csv/csv.c')
-rw-r--r--navit/map/csv/csv.c17
1 files changed, 13 insertions, 4 deletions
diff --git a/navit/map/csv/csv.c b/navit/map/csv/csv.c
index b61e2d4a1..8205c6028 100644
--- a/navit/map/csv/csv.c
+++ b/navit/map/csv/csv.c
@@ -85,6 +85,11 @@ csv_attr_get(void *priv_data, enum attr_type attr_type, struct attr *attr)
{
struct map_rect_priv *mr=priv_data;
+ if(!mr || !mr->curr_item || !mr->curr_item->data) {
+ attr = NULL;
+ return 0;
+ }
+
GList* attr_list = ((struct quadtree_data*)(((struct quadtree_item*)(mr->curr_item->data))->data))->attr_list;
if (attr_type == attr_any) {
}
@@ -129,9 +134,11 @@ map_rect_new_csv(struct map_priv *map, struct map_selection *sel)
mr->item.priv_data=mr;
//convert selection to geo
- transform_to_geo(projection_mg, &sel->u.c_rect.lu, &lu);
- transform_to_geo(projection_mg, &sel->u.c_rect.rl, &rl);
- quadtree_find_rect_items(map->tree_root, lu.lng, rl.lng, rl.lat, lu.lat, &res);
+ if(sel) {
+ transform_to_geo(projection_mg, &sel->u.c_rect.lu, &lu);
+ transform_to_geo(projection_mg, &sel->u.c_rect.rl, &rl);
+ quadtree_find_rect_items(map->tree_root, lu.lng, rl.lng, rl.lat, lu.lat, &res);
+ }
mr->query_result = res;
mr->curr_item = res;
return mr;
@@ -148,7 +155,9 @@ static struct item *
map_rect_get_item_csv(struct map_rect_priv *mr)
{
if(mr->bStarted) {
- mr->curr_item = g_list_next(mr->curr_item);
+ if(mr->curr_item) {
+ mr->curr_item = g_list_next(mr->curr_item);
+ }
}
else {
mr->bStarted = 1;