2019-06-04 14:23:08 +02:00
|
|
|
local type = type
|
|
|
|
local tostring = tostring
|
|
|
|
local setmetatable = setmetatable
|
2019-06-04 14:58:05 +02:00
|
|
|
local getmetatable = getmetatable
|
2019-06-04 14:23:08 +02:00
|
|
|
|
2019-06-04 18:13:09 +02:00
|
|
|
--- Helper class for concatenating LocalisedStrings / strings.
|
|
|
|
-- strings and LocalisedStrings can be combined in any order.
|
|
|
|
-- Multiple calls to add will automatically split the LocalisedStrings into a linked list
|
|
|
|
-- when needed to prevent exceeding 20 parameter limit imposed by Factorio.
|
|
|
|
-- However, if you pass in LocalisedStrings that exceeds 20 parameters then it will fail.
|
|
|
|
--
|
|
|
|
-- @usage
|
|
|
|
-- LocaleBuilder = require 'utils.locale_builder'
|
2019-06-04 18:36:23 +02:00
|
|
|
--
|
|
|
|
-- local locale_string = LocaleBuilder({'common.fail_no_target', 'player_name'})
|
2019-06-04 18:13:09 +02:00
|
|
|
-- :add({'', '- a literal string'})
|
|
|
|
-- :add('- short hand for literal string')
|
|
|
|
-- :add(3):add(true) -- also works if convertable to string
|
|
|
|
--
|
2019-06-04 18:36:23 +02:00
|
|
|
-- Or construct multiple LocalisedStrings in parts and combine them.
|
2019-06-04 18:13:09 +02:00
|
|
|
-- local part1 = {'', 'part', ' ', 'one'}
|
2019-06-04 18:36:23 +02:00
|
|
|
-- local part2 = LocaleBuilder('part'):add(' '):add('two')
|
|
|
|
-- local part3 = LocaleBuilder('part'):add(' '):add('three')
|
2019-06-04 18:13:09 +02:00
|
|
|
--
|
2019-06-04 18:36:23 +02:00
|
|
|
-- local result = LocaleBuilder(part1):add(part2):add(part3)
|
2019-06-04 18:13:09 +02:00
|
|
|
--
|
|
|
|
-- If you store the LocalisedStrings in global, when you fetch from global you need to restore
|
|
|
|
-- the metatable to be able to use :add calls. To do that use
|
2019-06-04 18:36:23 +02:00
|
|
|
-- LocaleBuilder(global.stored_locale_string)
|
2019-06-04 14:23:08 +02:00
|
|
|
local Public = {}
|
|
|
|
|
|
|
|
local add
|
|
|
|
|
|
|
|
local function set_tail(self, tail)
|
|
|
|
local mt = getmetatable(self)
|
|
|
|
mt.tail = tail
|
|
|
|
end
|
|
|
|
|
|
|
|
local function new(obj)
|
|
|
|
local mt = {add = add, tail = nil}
|
|
|
|
mt.__index = mt
|
|
|
|
|
|
|
|
return setmetatable(obj, mt)
|
|
|
|
end
|
|
|
|
|
|
|
|
local function localise(item)
|
|
|
|
local t = type(item)
|
|
|
|
if t == 'table' then
|
|
|
|
return item
|
|
|
|
elseif t == 'string' then
|
|
|
|
return {'', item}
|
|
|
|
else
|
|
|
|
return {'', tostring(item)}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
function add(self, item)
|
2019-06-04 20:06:05 +02:00
|
|
|
if item == nil then
|
2019-06-04 14:23:08 +02:00
|
|
|
item = self
|
|
|
|
self = nil
|
|
|
|
end
|
|
|
|
|
|
|
|
item = localise(item)
|
|
|
|
|
|
|
|
if not self then
|
|
|
|
return new(item)
|
|
|
|
end
|
|
|
|
|
|
|
|
local tail = self.tail
|
|
|
|
if not tail then
|
2019-06-04 20:06:05 +02:00
|
|
|
if self[1] == '' then
|
|
|
|
tail = self
|
|
|
|
else
|
|
|
|
tail = {'', self}
|
|
|
|
self = new(tail)
|
|
|
|
set_tail(self, tail)
|
|
|
|
end
|
2019-06-04 14:23:08 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
local count = #tail
|
|
|
|
if count < 20 then
|
|
|
|
tail[count + 1] = item
|
|
|
|
else
|
|
|
|
local new_tail = {'', item}
|
|
|
|
tail[count + 1] = new_tail
|
|
|
|
set_tail(self, new_tail)
|
|
|
|
end
|
|
|
|
|
|
|
|
return self
|
|
|
|
end
|
|
|
|
|
|
|
|
Public.add = add
|
2019-06-07 11:25:08 +02:00
|
|
|
|
2019-06-04 18:49:33 +02:00
|
|
|
function Public.__call(_, item)
|
2019-06-04 20:06:05 +02:00
|
|
|
if item == nil then
|
|
|
|
item = {''}
|
|
|
|
end
|
|
|
|
|
2019-06-04 18:36:23 +02:00
|
|
|
return add(nil, item)
|
|
|
|
end
|
2019-06-07 11:25:08 +02:00
|
|
|
|
|
|
|
function Public.new(item)
|
|
|
|
if item == nil then
|
|
|
|
item = {''}
|
|
|
|
end
|
|
|
|
|
|
|
|
return add(nil, item)
|
|
|
|
end
|
|
|
|
|
2019-06-04 18:36:23 +02:00
|
|
|
setmetatable(Public, Public)
|
2019-06-04 14:23:08 +02:00
|
|
|
|
|
|
|
return Public
|