-
-
Notifications
You must be signed in to change notification settings - Fork 719
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #3615 from lonvia/overhaul-osm2pgsql-style
Overhaul osm2pgsql style
- Loading branch information
Showing
39 changed files
with
2,150 additions
and
1,343 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
-- This is just an alias for the Nominatim themepark theme module | ||
local flex = require('themes/nominatim/init') | ||
|
||
function flex.load_topic(name, cfg) | ||
local topic_file = debug.getinfo(1, "S").source:sub(2):match("(.*/)") .. 'themes/nominatim/topics/'.. name .. '.lua' | ||
|
||
if topic_file == nil then | ||
error('Cannot find topic: ' .. name) | ||
end | ||
|
||
loadfile(topic_file)(nil, flex, cfg or {}) | ||
end | ||
|
||
return flex |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
-- This is just an alias for the Nominatim themepark address topic | ||
local flex = require('flex-base') | ||
|
||
flex.load_topic('address') | ||
|
||
return flex |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
-- This is just an alias for the Nominatim themepark admin topic | ||
local flex = require('flex-base') | ||
|
||
flex.load_topic('admin') | ||
|
||
return flex |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
-- This is just an alias for the Nominatim themepark full topic | ||
local flex = require('flex-base') | ||
|
||
flex.load_topic('full', {with_extratags = true}) | ||
|
||
return flex |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
-- This is just an alias for the Nominatim themepark full topic | ||
local flex = require('flex-base') | ||
|
||
flex.load_topic('full') | ||
|
||
return flex |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
-- This is just an alias for the Nominatim themepark street topic | ||
local flex = require('flex-base') | ||
|
||
flex.load_topic('street') | ||
|
||
return flex |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,118 @@ | ||
-- Prints taginfo project description in the standard output | ||
-- | ||
|
||
-- create fake "osm2pgsql" table for flex-base, originally created by the main C++ program | ||
osm2pgsql = {} | ||
function osm2pgsql.define_table(...) end | ||
|
||
-- provide path to flex-style lua file | ||
package.path = arg[0]:match("(.*/)") .. "?.lua;" .. package.path | ||
local flex = require('import-' .. (arg[1] or 'extratags')) | ||
local json = require ('dkjson') | ||
|
||
local NAME_DESCRIPTIONS = { | ||
'Searchable auxiliary name of the place', | ||
main = 'Searchable primary name of the place', | ||
house = 'House name part of an address, searchable' | ||
} | ||
local ADDRESS_DESCRIPTIONS = { | ||
'Used to determine the address of a place', | ||
main = 'Primary key for an address point', | ||
postcode = 'Used to determine the postcode of a place', | ||
country = 'Used to determine country of a place (only if written as two-letter code)', | ||
interpolation = 'Primary key for an address interpolation line' | ||
} | ||
|
||
------------ helper functions --------------------- | ||
-- Sets the key order for the resulting JSON table | ||
local function set_keyorder(table, order) | ||
setmetatable(table, { | ||
__jsonorder = order | ||
}) | ||
end | ||
|
||
local function get_key_description(key, description) | ||
local desc = {} | ||
desc.key = key | ||
desc.description = description | ||
set_keyorder(desc, {'key', 'description'}) | ||
return desc | ||
end | ||
|
||
local function get_key_value_description(key, value, description) | ||
local desc = {key = key, value = value, description = description} | ||
set_keyorder(desc, {'key', 'value', 'description'}) | ||
return desc | ||
end | ||
|
||
local function group_table_to_keys(tags, data, descriptions) | ||
for group, values in pairs(data) do | ||
local desc = descriptions[group] or descriptions[1] | ||
for _, key in pairs(values) do | ||
if key:sub(1, 1) ~= '*' and key:sub(#key, #key) ~= '*' then | ||
table.insert(tags, get_key_description(key, desc)) | ||
end | ||
end | ||
end | ||
end | ||
|
||
-- Prints the collected tags in the required format in JSON | ||
local function print_taginfo() | ||
local taginfo = flex.get_taginfo() | ||
local tags = {} | ||
|
||
for k, values in pairs(taginfo.main) do | ||
if values[1] == nil or values[1] == 'delete' or values[1] == 'extra' then | ||
for v, group in pairs(values) do | ||
if type(v) == 'string' and group ~= 'delete' and group ~= 'extra' then | ||
local text = 'POI/feature in the search database' | ||
if type(group) ~= 'function' then | ||
text = 'Fallback ' .. text | ||
end | ||
table.insert(tags, get_key_value_description(k, v, text)) | ||
end | ||
end | ||
elseif type(values[1]) == 'function' or values[1] == 'fallback' then | ||
local desc = 'POI/feature in the search database' | ||
if values[1] == 'fallback' then | ||
desc = 'Fallback ' .. desc | ||
end | ||
local excp = {} | ||
for v, group in pairs(values) do | ||
if group == 'delete' or group == 'extra' then | ||
table.insert(excp, v) | ||
end | ||
end | ||
if next(excp) ~= nil then | ||
desc = desc .. string.format(' (except for values: %s)', | ||
table.concat(excp, ', ')) | ||
end | ||
table.insert(tags, get_key_description(k, desc)) | ||
end | ||
end | ||
|
||
group_table_to_keys(tags, taginfo.name, NAME_DESCRIPTIONS) | ||
group_table_to_keys(tags, taginfo.address, ADDRESS_DESCRIPTIONS) | ||
|
||
local format = { | ||
data_format = 1, | ||
data_url = 'https://nominatim.openstreetmap.org/taginfo.json', | ||
project = { | ||
name = 'Nominatim', | ||
description = 'OSM search engine.', | ||
project_url = 'https://nominatim.openstreetmap.org', | ||
doc_url = 'https://nominatim.org/release-docs/develop/', | ||
contact_name = 'Sarah Hoffmann', | ||
contact_email = '[email protected]' | ||
} | ||
} | ||
format.tags = tags | ||
|
||
set_keyorder(format, {'data_format', 'data_url', 'project', 'tags'}) | ||
set_keyorder(format.project, {'name', 'description', 'project_url', 'doc_url', | ||
'contact_name', 'contact_email'}) | ||
|
||
print(json.encode(format)) | ||
end | ||
|
||
print_taginfo() |
Oops, something went wrong.