Skip to content
Snippets Groups Projects
Commit c2eeba45 authored by DarkGod's avatar DarkGod
Browse files

Respec'ing the last talent points can only happen in town (this will only affect new characters)

parent 79f42504
No related branches found
No related tags found
No related merge requests found
Showing
with 33 additions and 5 deletions
......@@ -86,6 +86,9 @@ newBirthDescriptor{
if not e.image then e.image = "player/"..e.descriptor.subrace:lower():gsub("[^a-z0-9_]", "_").."_"..e.descriptor.sex:lower():gsub("[^a-z0-9_]", "_")..".png" end
end,
},
game_state = {
force_town_respec = 1,
}
}
......
......@@ -79,6 +79,8 @@ break_farportal = function(self)
end
spawn_butler = function(self)
game.level.data.allow_respec = "limited"
local spot = game.level:pickSpot{type="spawn", subtype="butler"}
local butler = game.zone:makeEntityByName(game.level, "actor", "BUTLER")
game.zone:addEntity(game.level, butler, "actor", spot.x, spot.y)
......
......@@ -32,7 +32,7 @@ return {
day_night = true,
persistent = "zone",
ambient_music = {"Dreaming of Flying.ogg", "weather/town_medium_base.ogg"},
allow_respec = "limited",
min_material_level = function() return game.state:isAdvanced() and 3 or 1 end,
max_material_level = function() return game.state:isAdvanced() and 4 or 3 end,
store_levels_by_restock = { 20, 35, 45 },
......
......@@ -31,6 +31,7 @@ return {
all_lited = true,
day_night = true,
ambient_music = {"Virtue lost.ogg", "weather/town_small_base.ogg"},
allow_respec = "limited",
max_material_level = 2,
store_levels_by_restock = { 8, 25, 40 },
......
......@@ -31,6 +31,7 @@ return {
day_night = true,
all_lited = true,
ambient_music = {"Virtue lost.ogg", "weather/town_large_base.ogg"},
allow_respec = "limited",
max_material_level = 2,
store_levels_by_restock = { 8, 25, 40 },
......
......@@ -31,6 +31,7 @@ return {
all_lited = true,
day_night = true,
ambient_music = {"For the king and the country!.ogg", "weather/town_large_base.ogg"},
allow_respec = "limited",
min_material_level = 3,
max_material_level = 4,
......
......@@ -31,6 +31,7 @@ return {
day_night = true,
all_lited = true,
ambient_music = {"Virtue lost.ogg", "weather/jungle_base.ogg"},
allow_respec = "limited",
max_material_level = 2,
store_levels_by_restock = { 8, 25, 40 },
......
......@@ -30,6 +30,7 @@ return {
all_remembered = true,
all_lited = true,
ambient_music = {"Virtue lost.ogg", "weather/town_large_base.ogg"},
allow_respec = "limited",
max_material_level = 2,
store_levels_by_restock = { 8, 25, 40 },
......
......@@ -31,6 +31,7 @@ return {
all_lited = true,
day_night = true,
ambient_music = {"For the king and the country!.ogg", "weather/town_large_base.ogg"},
allow_respec = "limited",
max_material_level = 3,
store_levels_by_restock = { 20, 35, 45 },
......
......@@ -33,6 +33,7 @@ return {
ambient_music = {"Virtue lost.ogg", "weather/town_small_base.ogg"},
color_shown = {0.7, 0.6, 0.8, 1},
color_obscure = {0.7*0.6, 0.6*0.6, 0.8*0.6, 0.6},
allow_respec = "limited",
no_level_connectivity = true,
......
......@@ -31,7 +31,7 @@ return {
all_lited = true,
day_night = true,
ambient_music = {"World of Ice.ogg", "weather/town_small_base.ogg"},
allow_respec = "limited",
max_material_level = 2,
store_levels_by_restock = { 8, 25, 40 },
......
......@@ -32,6 +32,7 @@ return {
day_night = true,
all_lited = true,
ambient_music = {"Straight Into Ambush.ogg", "weather/town_large_base.ogg"},
allow_respec = "limited",
min_material_level = function() return game.state:isAdvanced() and 3 or 2 end,
max_material_level = function() return game.state:isAdvanced() and 4 or 3 end,
......
......@@ -295,7 +295,13 @@ function _M:isUnlearnable(t, limit)
local min = 1
if limit then min = math.max(1, #list - (max - 1)) end
for i = #list, min, -1 do
if list[i] == t.id then return i end
if list[i] == t.id then
if not game.state.birth.force_town_respec or (game.level and game.level.data and game.level.data.allow_respec == "limited") then
return i
else
return nil, i
end
end
end
return nil
end
......@@ -329,7 +335,12 @@ function _M:learnTalent(t_id, v)
return
end
if not self:isUnlearnable(t, true) and self.actor_dup:getTalentLevelRaw(t_id) >= self.actor:getTalentLevelRaw(t_id) then
self:simplePopup("Impossible", "You cannot unlearn this talent!")
local _, could = self:isUnlearnable(t, true)
if could then
self:simplePopup("Impossible here", "You could unlearn this talent in a quiet place, like a #{bold}#town#{normal}#.")
else
self:simplePopup("Impossible", "You cannot unlearn this talent!")
end
return
end
self.actor:unlearnTalent(t_id, nil, true, {no_unlearn=true})
......@@ -847,11 +858,15 @@ function _M:getTalentDesc(item)
else
local t = self.actor:getTalentFromId(item.talent)
if self:isUnlearnable(t, true) then
local unlearnable, could_unlearn = self:isUnlearnable(t, true)
if unlearnable then
local max = tostring(self.actor:lastLearntTalentsMax(t.generic and "generic" or "class"))
text:add({"color","LIGHT_BLUE"}, "This talent was recently learnt, you can still unlearn it.", true, "The last ", max, t.generic and " generic" or " class", " talents you learnt are always unlearnable.", {"color","LAST"}, true, true)
elseif t.no_unlearn_last then
text:add({"color","YELLOW"}, "This talent can alter the world in a permanent way, as such you can never unlearn it once known.", {"color","LAST"}, true, true)
elseif could_unlearn then
local max = tostring(self.actor:lastLearntTalentsMax(t.generic and "generic" or "class"))
text:add({"color","LIGHT_BLUE"}, "This talent was recently learnt, you can still unlearn it if you are in a quiet area like a #{bold}#town#{normal}#.", true, "The last ", max, t.generic and " generic" or " class", " talents you learnt are always unlearnable.", {"color","LAST"}, true, true)
end
local traw = self.actor:getTalentLevelRaw(t.id)
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment