"BANKEX" project utility token
ERC20
This contract is an ERC20 token.
Name
"BANKEX" project utility token
Symbol
BKX
Decimals
18
Total Supply
400,000,000 BKX
About
Stats
Public Functions
14
Event Types
3
Code Size
9,637 bytes
Library Use
Uses SafeMath for uint256.
Events (3) keyboard_arrow_up
State Variables (12) keyboard_arrow_up
Functions
transferOwnership keyboard_arrow_up
Modifiers help
onlyOwner checks for the following:
Source Code
function transferOwnership(address newOwner)
public
onlyOwner
returns (bool success)
{
require(newOwner != address(0));
OwnershipTransferred(owner, newOwner);
owner = newOwner;
return true;
}
transfer keyboard_arrow_up
Source Code
function transfer(address _to, uint256 _value) public unlocked returns (bool) {
require(_to != address(0));
balances[msg.sender] = balances[msg.sender].sub(_value);
balances[_to] = balances[_to].add(_value);
Transfer(msg.sender, _to, _value);
return true;
}
balanceOf keyboard_arrow_up
transferFrom keyboard_arrow_up
Requirements help
Source Code
function transferFrom(
address _from,
address _to,
uint256 _value
) public unlocked returns (bool) {
require(_to != address(0));
uint256 _allowance = allowed[_from][msg.sender];
require(_allowance >= _value);
balances[_from] = balances[_from].sub(_value);
balances[_to] = balances[_to].add(_value);
allowed[_from][msg.sender] = _allowance.sub(_value);
Transfer(_from, _to, _value);
return true;
}
approve keyboard_arrow_up
Requirements help
One or more of the following:
Source Code
function approve(address _spender, uint256 _value)
public
unlocked
returns (bool)
{
require((_value == 0) || (allowed[msg.sender][_spender] == 0));
allowed[msg.sender][_spender] = _value;
Approval(msg.sender, _spender, _value);
return true;
}
allowance keyboard_arrow_up
increaseApproval keyboard_arrow_up
Source Code
function increaseApproval(address _spender, uint256 _addedValue)
public
unlocked
returns (bool success)
{
allowed[msg.sender][_spender] = allowed[msg.sender][_spender].add(
_addedValue
);
Approval(msg.sender, _spender, allowed[msg.sender][_spender]);
return true;
}
decreaseApproval keyboard_arrow_up
Source Code
function decreaseApproval(address _spender, uint256 _subtractedValue)
public
unlocked
returns (bool success)
{
uint256 oldValue = allowed[msg.sender][_spender];
if (_subtractedValue > oldValue) {
allowed[msg.sender][_spender] = 0;
} else {
allowed[msg.sender][_spender] = oldValue.sub(_subtractedValue);
}
Approval(msg.sender, _spender, allowed[msg.sender][_spender]);
return true;
}
setLock keyboard_arrow_up
allowUpgrading keyboard_arrow_up
Modifiers help
onlyOwner checks for the following:
Source Code
function allowUpgrading(bool _newState)
public
onlyOwner
returns (bool success)
{
upgradable = _newState;
return true;
}
setUpgrader keyboard_arrow_up
Modifiers help
onlyOwner checks for the following:
Requirements help
Source Code
function setUpgrader(address _upgraderAddress)
public
onlyOwner
returns (bool success)
{
require(!upgraderSet);
require(_upgraderAddress != address(0));
upgraderSet = true;
upgrader = TokenUpgraderInterface(_upgraderAddress);
return true;
}
upgrade keyboard_arrow_up
Parameters help
This function has no parameters.
Requirements help
upgradable must be true
upgraderSet must be true
Source Code
function upgrade() public returns (bool success) {
require(upgradable);
require(upgraderSet);
require(upgrader != TokenUpgraderInterface(0));
uint256 value = balances[msg.sender];
assert(value > 0);
delete balances[msg.sender];
totalSupply = totalSupply.sub(value);
assert(upgrader.upgradeFor(msg.sender, value));
return true;
}
upgradeFor keyboard_arrow_up
Requirements help
upgradable must be true
upgraderSet must be true
Source Code
function upgradeFor(address _for, uint256 _value)
public
returns (bool success)
{
require(upgradable);
require(upgraderSet);
require(upgrader != TokenUpgraderInterface(0));
uint256 _allowance = allowed[_for][msg.sender];
require(_allowance >= _value);
balances[_for] = balances[_for].sub(_value);
allowed[_for][msg.sender] = _allowance.sub(_value);
totalSupply = totalSupply.sub(_value);
assert(upgrader.upgradeFrom(msg.sender, _for, _value));
return true;
}
Internal Functions
Internal functions are parts of the contract that can't be used directly, but instead are used by the public functions listed above.
internal Token.mint keyboard_arrow_up
Source Code
function mint(address _for, uint256 _amount) internal returns (bool success) {
_amount = _amount * decimalMultiplier;
balances[_for] = balances[_for].add(_amount);
totalSupply = totalSupply.add(_amount);
Transfer(0, _for, _amount);
return true;
}