mirror of
git://repo.or.cz/minetest_mana.git
synced 2025-01-25 07:00:19 +01:00
Change the add and subtract functions, add new
This commit is contained in:
parent
ca87abd37b
commit
d21c370980
37
API.md
37
API.md
@ -27,7 +27,7 @@ recommended.
|
|||||||
## Functions
|
## Functions
|
||||||
Of not specified otherwise, all functions return `nil`.
|
Of not specified otherwise, all functions return `nil`.
|
||||||
`playername` always refers to the name of a player, as string.
|
`playername` always refers to the name of a player, as string.
|
||||||
`value` always refers to a number.
|
`value` always refers to a number and for most functions it must always be equal to or greater than 0.
|
||||||
|
|
||||||
|
|
||||||
### `mana.set(playername, value)`
|
### `mana.set(playername, value)`
|
||||||
@ -53,20 +53,39 @@ Returns the current maximum mana of the specified player as number.
|
|||||||
|
|
||||||
|
|
||||||
### `mana.add(playername, value)`
|
### `mana.add(playername, value)`
|
||||||
Adds the specified amount of mana to the player, but it will be capped
|
Adds the specified non-negative amount of mana to the player, but only
|
||||||
at the maximum.
|
if the sum would not be greater than the maximum,
|
||||||
|
|
||||||
|
#### Return value
|
||||||
|
* `true` on success, all mana has been added
|
||||||
|
* `false` on failure, no mana has been added
|
||||||
|
|
||||||
|
|
||||||
|
### `mana.subtract(playername, value)`
|
||||||
|
Subtracts the specified non-negative amount of mana from the player,
|
||||||
|
but only if the player has sufficient mana reservers.
|
||||||
|
|
||||||
|
#### Return value
|
||||||
|
* `true` on success, all mana has been subtracted
|
||||||
|
* `false` on failure, no mana has been subtraceed
|
||||||
|
|
||||||
|
|
||||||
|
### `mana.add_up_to(playername, value)`
|
||||||
|
Adds the specified non-negative amount of mana to the player, but it will
|
||||||
|
be capped at the maximum.
|
||||||
|
|
||||||
#### Return value
|
#### Return value
|
||||||
* `true, excess` on success, where `excess` is the amount of Mana which could not be added because it would have exceeded the maximum. `excess` equals `0` if all mana has been added
|
* `true, excess` on success, where `excess` is the amount of Mana which could not be added because it would have exceeded the maximum. `excess` equals `0` if all mana has been added
|
||||||
* `false` on failure (mana could not be added)
|
* `false` on failure (mana could not be added)
|
||||||
|
|
||||||
|
|
||||||
|
### `mana.subtract_up_to(playername, value)`
|
||||||
### `mana.subtract(playername, value)`
|
Subtracts the specified non-negative amount of mana from the player,
|
||||||
Subtracts the specified amount of mana from the player, but only
|
but if the difference is smaller than 0, the mana will be set to 0.
|
||||||
if the player has sufficient mana reservers.
|
|
||||||
|
|
||||||
#### Return value
|
#### Return value
|
||||||
* `true` on success, all mana has been subtracted
|
* `true, missing` on success, where `missing` is the amount of Mana which could not be subtracted because it would have exceeded 0. `missing` equals `0` if all mana has been subtracted
|
||||||
* `false` on failure, no mana has been subtraceed
|
* `false` on failure (mana could not be subtracted)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
57
init.lua
57
init.lua
@ -63,15 +63,16 @@ function mana.getmax(playername)
|
|||||||
end
|
end
|
||||||
|
|
||||||
--[[
|
--[[
|
||||||
Adds the specified amount of mana to the player, but will
|
Adds up to the specified amount of mana to the player.
|
||||||
respect the player's maximum.
|
If the sum would be greater than the maximum, the new
|
||||||
|
mana amount will be capped at the maximum.
|
||||||
|
|
||||||
returns:
|
returns:
|
||||||
- true, excess on success, where excess is the amount of mana which
|
- true, excess on success, where excess is the amount of mana which
|
||||||
was no
|
was no
|
||||||
- false on failure
|
- false on failure
|
||||||
]]
|
]]
|
||||||
function mana.add(playername, value)
|
function mana.add_up_to(playername, value)
|
||||||
local t = mana.playerlist[playername]
|
local t = mana.playerlist[playername]
|
||||||
if(t ~= nil and value >= 0) then
|
if(t ~= nil and value >= 0) then
|
||||||
local excess
|
local excess
|
||||||
@ -90,12 +91,31 @@ function mana.add(playername, value)
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--[[
|
||||||
|
Adds the specified amount of mana to the player,
|
||||||
|
iff it would not exceed the maximum.
|
||||||
|
|
||||||
|
returns:
|
||||||
|
- true on success, all mana has been added
|
||||||
|
- false on failure, no mana has been added
|
||||||
|
]]
|
||||||
|
function mana.add(playername, value)
|
||||||
|
local t = mana.playerlist[playername]
|
||||||
|
if(t ~= nil and ((t.mana + value) <= t.maxmana) and value >= 0) then
|
||||||
|
t.mana = t.mana + value
|
||||||
|
mana.hud_update(playername)
|
||||||
|
return true
|
||||||
|
else
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
--[[
|
--[[
|
||||||
Subtracts the specified amount of mana from the player,
|
Subtracts the specified amount of mana from the player,
|
||||||
iff the player has enough mana reserves.
|
iff the player has enough mana reserves.
|
||||||
|
|
||||||
returns:
|
returns:
|
||||||
- true on success, mana has been subtracted
|
- true on success, all mana has been subtracted
|
||||||
- false on failure, no mana has been subtracted
|
- false on failure, no mana has been subtracted
|
||||||
]]
|
]]
|
||||||
function mana.subtract(playername, value)
|
function mana.subtract(playername, value)
|
||||||
@ -110,6 +130,35 @@ function mana.subtract(playername, value)
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--[[
|
||||||
|
Subtracts up to the specified amount of mana from the player.
|
||||||
|
|
||||||
|
returns:
|
||||||
|
- true, missing on success, where missing is the amount of mana which could not been subtracted
|
||||||
|
- false on failure, no mana has been subtracted
|
||||||
|
]]
|
||||||
|
function mana.subtract_up_to(playername, value)
|
||||||
|
local t = mana.playerlist[playername]
|
||||||
|
if(t ~= nil and value >= 0) then
|
||||||
|
local missing
|
||||||
|
if((t.mana - value) < 0) then
|
||||||
|
missing = math.abs(t.mana - value)
|
||||||
|
t.mana = 0
|
||||||
|
else
|
||||||
|
missing = 0
|
||||||
|
t.mana = t.mana - value
|
||||||
|
end
|
||||||
|
mana.hud_update(playername)
|
||||||
|
return true, missing
|
||||||
|
else
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--[===[
|
--[===[
|
||||||
File handling, loading data, saving data, setting up stuff for players.
|
File handling, loading data, saving data, setting up stuff for players.
|
||||||
]===]
|
]===]
|
||||||
|
Loading…
Reference in New Issue
Block a user