From 9a20e8e614ee2db58c1865e6eeddf19d1d23250e Mon Sep 17 00:00:00 2001 From: systemed Date: Thu, 10 Dec 2020 11:02:04 +0000 Subject: [PATCH] Profile debug script to fetch a way from OSM --- profiles/debug_way.lua | 44 +++++++++++++++++++++++++++++++ profiles/lib/profile_debugger.lua | 7 +++-- 2 files changed, 49 insertions(+), 2 deletions(-) create mode 100644 profiles/debug_way.lua diff --git a/profiles/debug_way.lua b/profiles/debug_way.lua new file mode 100644 index 000000000..c1ac4dbab --- /dev/null +++ b/profiles/debug_way.lua @@ -0,0 +1,44 @@ +-- +-- Fetch a way from the OpenStreetMap API and run the given profile over it. +-- +-- You'll need to install luasec and xml2lua first: +-- > luarocks-5.1 install xml2lua +-- > luarocks-5.1 install luasec +-- [may require admin privileges] +-- +-- Then to test way 2606296 using the foot profile: +-- > lua5.1 debug_way.lua foot 2606296 +-- + +-- initialise libraries +local pprint = require('lib/pprint') +local Debug = require('lib/profile_debugger') +local xml2lua = require('xml2lua') +local handler = require('xmlhandler.tree') +local https = require('ssl.https') + +-- load the profile +Debug.load_profile(arg[1]) + +-- load way from the OSM API +local url = 'https://www.openstreetmap.org/api/0.6/way/'..arg[2] +local body, statusCode, headers, statusText = https.request(url) + +-- parse way tags +local parser = xml2lua.parser(handler) +parser:parse(body) + +-- convert XML-flavoured table to a simple k/v table +local way = {} +for i, p in pairs(handler.root.osm.way.tag) do + way[p._attr.k] = p._attr.v +end + +-- call the way function +local result = {} +Debug.process_way(way,result) + +-- print input and output +pprint(way) +print("=>") +pprint(result) diff --git a/profiles/lib/profile_debugger.lua b/profiles/lib/profile_debugger.lua index 15f835609..276850160 100644 --- a/profiles/lib/profile_debugger.lua +++ b/profiles/lib/profile_debugger.lua @@ -52,7 +52,7 @@ end function canonicalizeStringList(str) return str end - + -- debug helper @@ -123,11 +123,14 @@ function Debug.process_way(way,result) result.forward_classes = {} result.backward_classes = {} - -- intercept tag function normally provided via C++ + -- intercept tag functions normally provided via C++ function way:get_value_by_key(k) Debug.register_tag_fetch(k) return self[k] end + function way:get_location_tag(k) + return nil + end -- reset tag counts Debug:reset_tag_fetch_counts()