Many fixes

This commit is contained in:
raymoo 2016-01-23 15:21:56 -08:00
parent 67a60f0805
commit 71771310ad
2 changed files with 32 additions and 22 deletions

View File

@ -63,7 +63,7 @@ local function setmap_get(setmap, index)
end end
local function setmap_insert(setmap, indices, uid) local function setmap_insert(setmap, indices, uid, record)
for index, v in pairs(indices) do for index, v in pairs(indices) do
local set = setmap[index] local set = setmap[index]
@ -73,14 +73,14 @@ local function setmap_insert(setmap, indices, uid)
setmap[index] = set setmap[index] = set
end end
set[uid] = true set[uid] = record
end end
end end
local function setmap_delete(setmap, indices, uid) local function setmap_delete(setmap, indices, uid)
for k, index in pairs(indices) do for index, v in pairs(indices) do
local set = setmap[index] local set = setmap[index]
if set ~= nil then if set ~= nil then
@ -101,7 +101,7 @@ local function set_intersect(set1,set2)
local res_set = {} local res_set = {}
for k, rec in pairs(set1) do for k in pairs(set1) do
res_set[k] = set2[k] res_set[k] = set2[k]
end end
@ -238,14 +238,14 @@ end
-- Mutates the DB to have the new record -- Mutates the DB to have the new record
local function insert_record_with_uid(uid, db, record) local function insert_record_with_uid(uid, db, record)
db.uid_table[uid] = record db.uid_table[uid] = record
setmap_insert(db.tables.player, record.players, uid) setmap_insert(db.tables.player, record.players, uid, record)
setmap_insert(db.tables.tag, record.tags, uid) setmap_insert(db.tables.tag, record.tags, uid, record)
setmap_insert(db.tables.monoid, record.monoids, uid) setmap_insert(db.tables.monoid, record.monoids, uid, record)
setmap_insert(db.tables.name, {[record.effect_type] = true}, uid) setmap_insert(db.tables.name, {[record.effect_type] = true}, uid, record)
local perm = is_perm(record) local perm = is_perm(record)
setmap_insert(db.tables.perm, {[perm] = true}, uid) setmap_insert(db.tables.perm, {[perm] = true}, uid, record)
end end

View File

@ -78,6 +78,16 @@ local function calculate_monoid_value(p_name, m_name)
local p_m_effects = effectset.set_intersect(p_effects, m_effects) local p_m_effects = effectset.set_intersect(p_effects, m_effects)
for k, rec in pairs(p_m_effects) do
local eff_type = rec.effect_type
local type_def = types[eff_type]
if type_def ~= nil then
if type_def.values[m_name] ~= nil then
p_m_effects[k] = type_def.values[m_name]
end
end
end
local fold = monoids[m_name].fold local fold = monoids[m_name].fold
@ -356,14 +366,14 @@ monoidal_effects.apply_effect = function(effect_type, dur, player_name, values)
local dyn = type_def.dynamic local dyn = type_def.dynamic
local players = {player_name} local players = {[player_name] = "true"}
local tags = type_def.tags local tags = type_def.tags
local t_monoids = type_def.monoids local t_monoids = type_def.monoids
local record = local record =
effectset.record(dyn, effect_type, players, tags, monoids, dur, values) effectset.record(dyn, effect_type, players, tags, t_monoids, dur, values)
local p_cache = monoid_cache[player_name] local p_cache = monoid_cache[player_name]
@ -435,7 +445,7 @@ monoidal_effects.cancel_effect = function(uid)
local effect = effects:get(uid) local effect = effects:get(uid)
local players = effect.players local players = effect.players
local monoids = effect.monoids local eff_monoids = effect.monoids
for i, player in ipairs(all_players) do for i, player in ipairs(all_players) do
local p_name = player:get_player_name() local p_name = player:get_player_name()
@ -451,8 +461,8 @@ monoidal_effects.cancel_effect = function(uid)
for p_name in pairs(player_set) do for p_name in pairs(player_set) do
old_vals[p_name] = {} old_vals[p_name] = {}
local p_vals = old_vals[p_name] local p_vals = old_vals[p_name]
for monoid in pairs(monoids) do for monoid in pairs(eff_monoids) do
p_vals[monoid] = get_monoid_value(monoid, player) p_vals[monoid] = get_monoid_value(monoid, p_name)
end end
end end
@ -460,9 +470,9 @@ monoidal_effects.cancel_effect = function(uid)
for p_name, player in pairs(player_set) do for p_name, player in pairs(player_set) do
local p_vals = old_vals[p_name] local p_vals = old_vals[p_name]
for monoid in pairs(monoids) do for monoid in pairs(eff_monoids) do
clear_cache(monoid, p_name) clear_cache(monoid, p_name)
local val = get_monoid_value(p_name, monoid) local val = get_monoid_value(monoid, p_name)
local mon_def = monoids[monoid] local mon_def = monoids[monoid]
if (mon_def == nil) then if (mon_def == nil) then
@ -476,9 +486,9 @@ monoidal_effects.cancel_effect = function(uid)
if p_huds ~= nil then if p_huds ~= nil then
local hudinfo = p_huds[uid] local hudinfo = p_huds[uid]
if hudinfo ~= nil then if hudinfo ~= nil then
player:remove_hud(hudinfo.text) player:hud_remove(hudinfo.text)
if hudinfo.icon ~= nil then if hudinfo.icon ~= nil then
player:remove_hud(hudinfo.icon) player:hud_remove(hudinfo.icon)
end end
end end
p_huds[uid] = nil p_huds[uid] = nil
@ -554,7 +564,7 @@ local function apply_effects(player)
local p_effects = monoidal_effects.get_player_effects(p_name) local p_effects = monoidal_effects.get_player_effects(p_name)
local monoids = {} local eff_monoids = {}
for uid in pairs(p_effects) do for uid in pairs(p_effects) do
@ -563,12 +573,12 @@ local function apply_effects(player)
if (effect ~= nil) then if (effect ~= nil) then
for monoid in pairs(effect.monoids) do for monoid in pairs(effect.monoids) do
monoids[monoid] = true eff_monoids[monoid] = true
end end
end end
end end
for monoid in pairs(monoids) do for monoid in pairs(eff_monoids) do
local mon_def = monoids[monoid] local mon_def = monoids[monoid]
if (mon_def ~= nil) then if (mon_def ~= nil) then