diff options
| author | Rubenwardy <anjayward@gmail.com> | 2013-02-23 12:02:02 +0000 | 
|---|---|---|
| committer | Rubenwardy <anjayward@gmail.com> | 2013-02-23 12:02:02 +0000 | 
| commit | 96f692215eb4f937587a0721d8580820cbbef4ce (patch) | |
| tree | ccdd53842f3d63eb9bcdb7f0979758448333f8f8 | |
| parent | 0b4ac32bfb1b20426c818865edbab47f851eeab9 (diff) | |
table based triggers
| -rw-r--r-- | api.lua | 20 | ||||
| -rw-r--r-- | init.lua | 31 | ||||
| -rw-r--r-- | readme.md | 28 | ||||
| -rw-r--r-- | triggers.lua | 54 | 
4 files changed, 96 insertions, 37 deletions
| @@ -31,6 +31,24 @@ dofile(minetest.get_modpath("awards").."/triggers.lua")  -- API Functions  function awards.register_achievement(name,data_table) +	if data_table['trigger'] and data_table['trigger']['type'] then +		if data_table['trigger']['type']=="dig" then +			local tmp={ +				award=name, +			 	node=data_table['trigger']['node'], +			 	target=data_table['trigger']['target'], +			} +			table.insert(awards.onDig,tmp) +		elseif data_table['trigger']['type']=="place" then +			local tmp={ +				award=name, +			 	node=data_table['trigger']['node'], +			 	target=data_table['trigger']['target'], +			} +			table.insert(awards.onPlace,tmp) +		end +	end +  	awards['def'][name] = data_table  end @@ -84,7 +102,7 @@ minetest.register_chatcommand("list_awards", {  	params = "",  	description = "list_awards: list your awards",  	func = function(name, param) -		minetest.chat_send_player(name, "Your awards:"); +		minetest.chat_send_player(name, name.."'s awards:");  		for _, str in pairs(player_data[name].unlocked) do  			minetest.chat_send_player(name, str); @@ -10,31 +10,24 @@ dofile(minetest.get_modpath("awards").."/api.lua")  awards.register_achievement("award_mesefind",{  	title = "First Mese Find",  	description = "Found some Mese!", +	trigger={ +		type="dig", +		node="default:mese", +		target=1, +	},  })  awards.register_onDig(function(player,data) -	if not data['count']['default'] or not data['count']['default']['mese'] then -		return -	end - -	if data['count']['default']['mese'] > 0 then -		return "award_mesefind" -	end +	return nil  end) -  -- First Brick Placed!  awards.register_achievement("award_foundations",{  	title = "Foundations",  	description = "Every house starts from its foundations!", -}) - -awards.register_onPlace(function(player,data) -	if not data['place']['default'] or not data['place']['default']['brick'] then -		return -	end - -	if data['place']['default']['brick'] > 0 then -		return "award_foundations" -	end -end)
\ No newline at end of file +	trigger={ +		type="place", +		node="default:brick", +		target=1, +	}, +})
\ No newline at end of file @@ -16,27 +16,27 @@ The API  	* desciption  	* sound [optional]  	* image [optional] -	* func [optional] - see below +	* trigger [optional] [table] +		* type - "dig" or "place" +		* (for dig/place type) node - the nodes name +		* (for dig/place type) target - how many to dig / place  * awards.give_achievement(name,award)  	* -- gives an award to a player -* awards.register_onDig(func) +* awards.register_onDig(func(player,data))  	* -- return award name or null -	* -- there will be built in versions of this function -* awards.register_onPlace(func) +* awards.register_onPlace(func(player,data))  	* -- return award name or null -	* -- there will be built in versions of this function  Player Data  ===========  A list of data referenced/hashed by the player's name. - -* name [string] -* getNodeCount('node_name') [function] -* count [table] - dig counter -	* modname [table] -		* itemname [int] -* place [table] - place counter -	* modname [table] -		* itemname [int]
\ No newline at end of file +* player name +	* name [string] +	* count [table] - dig counter +		* modname [table] +			* itemname [int] +	* place [table] - place counter +		* modname [table] +			* itemname [int]
\ No newline at end of file diff --git a/triggers.lua b/triggers.lua index 2ce81de..03d7703 100644 --- a/triggers.lua +++ b/triggers.lua @@ -47,7 +47,31 @@ minetest.register_on_dignode(function(pos, oldnode, digger)  		local data=player_data[playern]  		for i=1,# awards.onDig do -			local res=awards.onDig[i](player,data) +			local res=nil +			 +			if type(awards.onDig[i]) == "function" then +				-- run the function +				print(i.." is a function") +				res=awards.onDig[i](player,data) +			elseif type(awards.onDig[i]) == "table" then +				-- handle table here +				print(i.." is a table") +				if not awards.onDig[i]['node'] or not awards.onDig[i]['target'] or not awards.onDig[i]['award'] then +					-- table running failed! +				else +					-- run the table +					local tnodedug = string.split(awards.onDig[i]['node'], ":") + +					local tmod=tnodedug[1] +					local titem=tnodedug[2] + +					if tmod==nil or titem==nil or not data['count'][tmod] or not data['count'][tmod][titem] then +						-- table running failed! +					elseif data['count'][tmod][titem] > awards.onDig[i]['target']-1 then +						res=awards.onDig[i]['award'] +					end +				end +			end  			if res~=nil then  				awards.give_achievement(playern,res) @@ -91,7 +115,31 @@ minetest.register_on_placenode(function(pos, newnode, placer)  		local data=player_data[playern]  		for i=1,# awards.onPlace do -			local res=awards.onPlace[i](player,data) +			local res=nil +			 +			if type(awards.onPlace[i]) == "function" then +				-- run the function +				print(i.." is a function") +				res=awards.onPlace[i](player,data) +			elseif type(awards.onPlace[i]) == "table" then +				-- handle table here +				print(i.." is a table") +				if not awards.onPlace[i]['node'] or not awards.onPlace[i]['target'] or not awards.onPlace[i]['award'] then +					-- table running failed! +				else +					-- run the table +					local tnodedug = string.split(awards.onPlace[i]['node'], ":") + +					local tmod=tnodedug[1] +					local titem=tnodedug[2] + +					if tmod==nil or titem==nil or not data['place'][tmod] or not data['place'][tmod][titem] then +						-- table running failed! +					elseif data['place'][tmod][titem] > awards.onPlace[i]['target']-1 then +						res=awards.onPlace[i]['award'] +					end +				end +			end  			if res~=nil then  				awards.give_achievement(playern,res) @@ -102,7 +150,7 @@ end)  minetest.register_on_newplayer(function(player)  	minetest.chat_send_player(player:get_player_name(),"[Awards] Registering you now...") -	 +  	--Player data root  	player_data[player:get_player_name()]={}  	player_data[player:get_player_name()]['name']=player:get_player_name() | 
