eosio.token.cpp部分代码的解析(eosi.token.hpp实现)加资产的函数
#include <eosio.token/eosio.token.hpp>
namespace eosio{
//owner 要被增加资产的账户
// value 要增加资产的数量
//st 当前资产的状态(是否被锁定,是否在白名单) &左值引用 &&右值引用
//ram_payer 是用来支付(交易)数据库操作的内存资源的账户
void token::add_balance(account_name owner,asset value,const currency_states& st,account_name ram_payer){
accounts = to_acnst(_self ,owner);
//accounts 就是程序(智能合约)和数据库之间交互的工具
//_self 智能合约的拥有者(智能合约的名字),他拥有读写数据库的权限。
//owner 数据库保存在哪个账户下面
auto to = to_acnts.find(value.symbol.name());
//在数据库中查找某人名下的资产(account 定义资产持有人的资料)
//to 就是一个迭代器
if(to==to_acnts.end())//找到最后没有查找到, 需要在该用户新增这种资产
{
//新增之前要检查白名单
eosio_assert(!st.enforce_whilelist,"can only transfer to white lists accounts");
//如果这种资产没有做白名单 ,该用户名下没有这种资产(说明该用户无法拥有这种货币),就报错误信息。
//拓展说明:如果需要拥有这种货币,那么就需要在开始发币的时候,打开白名单。
to_acnts.emplace(ram_payer,[&](auto &a) {
a.balance = value; //既有值又有单位
});
//ram_payer 支付这个内存资源的拥有者,
}else //用户拥有这种资产,就只需要数目增加,不用再增加这种资产
{
eosio_assert(!st.enforce_whitelist || to->whitelist,“receiver requires whitelist by issuer”);
//如果这种资产没有开白名单,要么在这个白名单里,如果都不成立的话,那么被拉黑了。会报错误信息。
to_acnts.modify(to,0,[&](auto &a){
a.balance.amount += value.amount; //增加资产数值,单位不变。
//a.balance +=value //这样也可以,更简洁
});
}
}
}