forked from mtcontrib/factions
		
	Fix: crash in diplomacy cmds
This commit is contained in:
		| @@ -193,7 +193,7 @@ if factions_config.faction_user_priv == true then | |||||||
| 	def_global_privileges = {"faction_user"} | 	def_global_privileges = {"faction_user"} | ||||||
| end | end | ||||||
|  |  | ||||||
| factions.register_command ("name", { | factions.register_command("name", { | ||||||
|     faction_permissions = {"name"}, |     faction_permissions = {"name"}, | ||||||
| 	format = {"string"}, | 	format = {"string"}, | ||||||
|     description = "Change the faction's name.", |     description = "Change the faction's name.", | ||||||
| @@ -735,6 +735,11 @@ if factions_config.faction_diplomacy == true then | |||||||
| 			local target_name = args.strings[1] | 			local target_name = args.strings[1] | ||||||
| 			local target_faction = factions.factions.get(target_name) | 			local target_faction = factions.factions.get(target_name) | ||||||
|  |  | ||||||
|  | 			if not target_faction then | ||||||
|  | 				send_error(player, target_name .. " Is not a faction.") | ||||||
|  | 				return false | ||||||
|  | 			end | ||||||
|  | 			 | ||||||
| 			if faction.request_inbox[target_name] then | 			if faction.request_inbox[target_name] then | ||||||
| 				if target_name == faction.name then | 				if target_name == faction.name then | ||||||
| 					send_error(player, "You can not accept an request from own faction") | 					send_error(player, "You can not accept an request from own faction") | ||||||
| @@ -771,6 +776,11 @@ if factions_config.faction_diplomacy == true then | |||||||
| 			local target_name = args.strings[1] | 			local target_name = args.strings[1] | ||||||
| 			local target_faction = factions.factions.get(target_name) | 			local target_faction = factions.factions.get(target_name) | ||||||
|  |  | ||||||
|  | 			if not target_faction then | ||||||
|  | 				send_error(player, target_name .. " Is not a faction.") | ||||||
|  | 				return false | ||||||
|  | 			end | ||||||
|  | 			 | ||||||
| 			if faction.request_inbox[target_name] then | 			if faction.request_inbox[target_name] then | ||||||
| 				if target_name == faction.name then | 				if target_name == faction.name then | ||||||
| 					send_error(player, "You can not refuse an request from your own faction") | 					send_error(player, "You can not refuse an request from your own faction") | ||||||
| @@ -798,6 +808,11 @@ if factions_config.faction_diplomacy == true then | |||||||
| 			local target_name = args.strings[1] | 			local target_name = args.strings[1] | ||||||
| 			local target_faction = factions.factions.get(target_name) | 			local target_faction = factions.factions.get(target_name) | ||||||
|  |  | ||||||
|  | 			if not target_faction then | ||||||
|  | 				send_error(player, target_name .. " Is not a faction.") | ||||||
|  | 				return false | ||||||
|  | 			end | ||||||
|  | 			 | ||||||
| 			if not faction.enemies[target_name] then | 			if not faction.enemies[target_name] then | ||||||
| 				if target_name == faction.name then | 				if target_name == faction.name then | ||||||
| 					send_error(player, "You can not declare war on your own faction") | 					send_error(player, "You can not declare war on your own faction") | ||||||
| @@ -833,6 +848,11 @@ if factions_config.faction_diplomacy == true then | |||||||
| 			local target_name = args.strings[1] | 			local target_name = args.strings[1] | ||||||
| 			local target_faction = factions.factions.get(target_name) | 			local target_faction = factions.factions.get(target_name) | ||||||
|  |  | ||||||
|  | 			if not target_faction then | ||||||
|  | 				send_error(player, target_name .. " Is not a faction.") | ||||||
|  | 				return false | ||||||
|  | 			end | ||||||
|  | 			 | ||||||
| 			if faction.allies[target_name] then | 			if faction.allies[target_name] then | ||||||
| 				if target_name == faction.name then | 				if target_name == faction.name then | ||||||
| 					send_error(player, "You can not break an alliance from your own faction") | 					send_error(player, "You can not break an alliance from your own faction") | ||||||
| @@ -1343,13 +1363,16 @@ factions.register_command("promote", { | |||||||
| 			 | 			 | ||||||
| 			local promoter_faction, promoter_facname = factions.get_player_faction(player) | 			local promoter_faction, promoter_facname = factions.get_player_faction(player) | ||||||
| 			 | 			 | ||||||
| 			if player_faction and promoter_facname == facname then | 			if player_faction and promoter_facname == facname and player ~= name then | ||||||
| 				factions.promote(faction.name, name, rank) | 				factions.promote(faction.name, name, rank) | ||||||
| 				minetest.chat_send_player(player, "Promoted " .. name .. " to " .. rank .. "!") | 				minetest.chat_send_player(player, "Promoted " .. name .. " to " .. rank .. "!") | ||||||
| 				return true | 				return true | ||||||
| 			elseif not player_faction or promoter_facname ~= facname then | 			elseif not player_faction or promoter_facname ~= facname then | ||||||
| 				send_error(player, name .. " is not in your faction") | 				send_error(player, name .. " is not in your faction") | ||||||
| 				return false | 				return false | ||||||
|  | 			elseif player == name then | ||||||
|  | 				send_error(player, "You can not promote yourself!") | ||||||
|  | 				return false | ||||||
| 			else | 			else | ||||||
| 				send_error(player, name .. " cannot be promoted from your faction") | 				send_error(player, name .. " cannot be promoted from your faction") | ||||||
| 				return false | 				return false | ||||||
| @@ -1651,20 +1674,21 @@ local premade_help_admin = "" | |||||||
|  |  | ||||||
| local a_z = {"a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"} | local a_z = {"a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"} | ||||||
|  |  | ||||||
| for l, j in pairs(a_z) do | minetest.register_on_mods_loaded(function() | ||||||
| 	for k, v in pairs(factions.commands) do | 	for l, j in pairs(a_z) do | ||||||
| 		if k:sub(1, 1) == j then | 		for k, v in pairs(factions.commands) do | ||||||
| 			if not v.dont_show_in_help then | 			if k:sub(1, 1) == j then | ||||||
| 				if not table_Contains(v.global_privileges, "faction_admin") then | 				if not v.dont_show_in_help then | ||||||
| 					premade_help = premade_help .. "\t/f " .. k .. v.description_arg .. " " .. v.description .. "\n" | 					if not table_Contains(v.global_privileges, "faction_admin") then | ||||||
|  | 						premade_help = premade_help .. "\t/f " .. k .. v.description_arg .. " " .. v.description .. "\n" | ||||||
|  | 					end | ||||||
|  | 					premade_help_admin = premade_help_admin .. "\t/f " .. k .. v.description_arg .. " " .. v.description .. "\n" | ||||||
| 				end | 				end | ||||||
| 				premade_help_admin = premade_help_admin .. "\t/f " .. k .. v.description_arg .. " " .. v.description .. "\n" |  | ||||||
| 			end | 			end | ||||||
| 		end | 		end | ||||||
| 	end | 	end | ||||||
| end | 	a_z = nil | ||||||
|  | end) | ||||||
| a_z = nil |  | ||||||
|  |  | ||||||
| ------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- | ||||||
| -- name: show_help(playername, parameter) | -- name: show_help(playername, parameter) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user