mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
parent
eb92d5f760
commit
4116704442
@ -277,7 +277,7 @@ contract ico is safeMath {
|
|||||||
|
|
||||||
function () external payable {
|
function () external payable {
|
||||||
/*
|
/*
|
||||||
Callback function. Simply calls the buy function as a beneficiary and there is no affilate address.
|
Callback function. Simply calls the buy function as a beneficiary and there is no affiliate address.
|
||||||
If they call the contract without any function then this process will be taken place.
|
If they call the contract without any function then this process will be taken place.
|
||||||
*/
|
*/
|
||||||
require( isICO() );
|
require( isICO() );
|
||||||
@ -290,9 +290,9 @@ contract ico is safeMath {
|
|||||||
|
|
||||||
If there is not at least 0.2 ether balance on the beneficiaryAddress then the amount of the ether which was intended for the purchase will be reduced by 0.2 and that will be sent to the address of the beneficiary.
|
If there is not at least 0.2 ether balance on the beneficiaryAddress then the amount of the ether which was intended for the purchase will be reduced by 0.2 and that will be sent to the address of the beneficiary.
|
||||||
From the remaining amount calculate the reward with the help of the getIcoReward function.
|
From the remaining amount calculate the reward with the help of the getIcoReward function.
|
||||||
Only that affilate address is valid which has some token on it’s account.
|
Only that affiliate address is valid which has some token on it’s account.
|
||||||
If there is a valid affilate address then calculate and credit the reward as well in the following way:
|
If there is a valid affiliate address then calculate and credit the reward as well in the following way:
|
||||||
With more than 1e12 token contract credit 5% reward based on the calculation that how many tokens did they buy when he was added as an affilate.
|
With more than 1e12 token contract credit 5% reward based on the calculation that how many tokens did they buy when he was added as an affiliate.
|
||||||
More than 1e11 token: 4%
|
More than 1e11 token: 4%
|
||||||
More than 1e10 token: 3%
|
More than 1e10 token: 3%
|
||||||
More than 1e9 token: 2% below 1%
|
More than 1e9 token: 2% below 1%
|
||||||
@ -345,7 +345,7 @@ contract ico is safeMath {
|
|||||||
/*
|
/*
|
||||||
Crediting the premium token
|
Crediting the premium token
|
||||||
|
|
||||||
@owner The corion token balance of this address will be set based on the calculation which shows that how many times can be the amount of the purchased tokens devided by 5000. So after each 5000 token we give 1 premium token.
|
@owner The corion token balance of this address will be set based on the calculation which shows that how many times can be the amount of the purchased tokens divided by 5000. So after each 5000 token we give 1 premium token.
|
||||||
*/
|
*/
|
||||||
uint256 _reward = (brought[owner].cor / 5e9) - brought[owner].corp;
|
uint256 _reward = (brought[owner].cor / 5e9) - brought[owner].corp;
|
||||||
if ( _reward > 0 ) {
|
if ( _reward > 0 ) {
|
||||||
@ -372,5 +372,5 @@ contract ico is safeMath {
|
|||||||
return startBlock <= block.number && block.number <= icoDelay && ( ! aborted ) && ( ! closed );
|
return startBlock <= block.number && block.number <= icoDelay && ( ! aborted ) && ( ! closed );
|
||||||
}
|
}
|
||||||
|
|
||||||
event EICO(address indexed Address, uint256 indexed value, address Affilate, uint256 AffilateValue);
|
event EICO(address indexed Address, uint256 indexed value, address Affiliate, uint256 AffilateValue);
|
||||||
}
|
}
|
||||||
|
@ -131,7 +131,7 @@ contract module {
|
|||||||
/*
|
/*
|
||||||
Check self for ready for functions or not.
|
Check self for ready for functions or not.
|
||||||
|
|
||||||
@success Function call was successfull or not
|
@success Function call was successful or not
|
||||||
@active Ready for functions or not
|
@active Ready for functions or not
|
||||||
*/
|
*/
|
||||||
return (true, moduleStatus == status.Connected && block.number >= disabledUntil);
|
return (true, moduleStatus == status.Connected && block.number >= disabledUntil);
|
||||||
|
@ -63,7 +63,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
function addModule(modules_s input, bool call) internal {
|
function addModule(modules_s input, bool call) internal {
|
||||||
/*
|
/*
|
||||||
Inside function for registration of the modules in the database.
|
Inside function for registration of the modules in the database.
|
||||||
If the call is false, wont happen any direct call.
|
If the call is false, won't happen any direct call.
|
||||||
|
|
||||||
@input _Structure of module.
|
@input _Structure of module.
|
||||||
@call Is connect to the module or not.
|
@call Is connect to the module or not.
|
||||||
@ -88,7 +88,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
@name Name of module.
|
@name Name of module.
|
||||||
@addr Address of module.
|
@addr Address of module.
|
||||||
@found Is there any result.
|
@found Is there any result.
|
||||||
@success Was the transaction succesfull or not.
|
@success Was the transaction successful or not.
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _found, uint256 _id) = getModuleIDByName(name);
|
(bool _success, bool _found, uint256 _id) = getModuleIDByName(name);
|
||||||
if ( _success && _found ) { return (true, true, modules[_id].addr); }
|
if ( _success && _found ) { return (true, true, modules[_id].addr); }
|
||||||
@ -204,7 +204,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
Deleting module from the database. Can be called only by the Publisher contract.
|
Deleting module from the database. Can be called only by the Publisher contract.
|
||||||
|
|
||||||
@name Name of module to delete.
|
@name Name of module to delete.
|
||||||
@bool Was the function successfull?
|
@bool Was the function successful?
|
||||||
@callCallback Call the replaceable module to confirm replacement or not.
|
@callCallback Call the replaceable module to confirm replacement or not.
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
||||||
@ -245,7 +245,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
@from from who.
|
@from from who.
|
||||||
@to to who.
|
@to to who.
|
||||||
@value amount.
|
@value amount.
|
||||||
@bool Was the function successfull?
|
@bool Was the function successful?
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
||||||
require( _success && _found && modules[_id].name == keccak256('Token') );
|
require( _success && _found && modules[_id].name == keccak256('Token') );
|
||||||
@ -264,7 +264,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
|
|
||||||
@roundID Number of Schelling round.
|
@roundID Number of Schelling round.
|
||||||
@reward Coin emission in this Schelling round.
|
@reward Coin emission in this Schelling round.
|
||||||
@bool Was the function successfull?
|
@bool Was the function successful?
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
||||||
require( _success && _found && modules[_id].name == keccak256('Schelling') );
|
require( _success && _found && modules[_id].name == keccak256('Schelling') );
|
||||||
@ -283,7 +283,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
Every module will be informed about the ModuleHandler replacement.
|
Every module will be informed about the ModuleHandler replacement.
|
||||||
|
|
||||||
@newHandler Address of the new ModuleHandler.
|
@newHandler Address of the new ModuleHandler.
|
||||||
@bool Was the function successfull?
|
@bool Was the function successful?
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
||||||
require( _success );
|
require( _success );
|
||||||
@ -304,7 +304,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
|
|
||||||
@owner address
|
@owner address
|
||||||
@value balance.
|
@value balance.
|
||||||
@success was the function successfull?
|
@success was the function successful?
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _found, uint256 _id) = getModuleIDByName('Token');
|
(bool _success, bool _found, uint256 _id) = getModuleIDByName('Token');
|
||||||
require( _success && _found );
|
require( _success && _found );
|
||||||
@ -315,7 +315,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
Query of the whole token amount.
|
Query of the whole token amount.
|
||||||
|
|
||||||
@value amount.
|
@value amount.
|
||||||
@success was the function successfull?
|
@success was the function successful?
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _found, uint256 _id) = getModuleIDByName('Token');
|
(bool _success, bool _found, uint256 _id) = getModuleIDByName('Token');
|
||||||
require( _success && _found );
|
require( _success && _found );
|
||||||
@ -326,7 +326,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
Query of ICO state
|
Query of ICO state
|
||||||
|
|
||||||
@ico Is ICO in progress?.
|
@ico Is ICO in progress?.
|
||||||
@success was the function successfull?
|
@success was the function successful?
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _found, uint256 _id) = getModuleIDByName('Token');
|
(bool _success, bool _found, uint256 _id) = getModuleIDByName('Token');
|
||||||
require( _success && _found );
|
require( _success && _found );
|
||||||
@ -337,7 +337,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
Query of number of the actual Schelling round.
|
Query of number of the actual Schelling round.
|
||||||
|
|
||||||
@round Schelling round.
|
@round Schelling round.
|
||||||
@success was the function successfull?
|
@success was the function successful?
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _found, uint256 _id) = getModuleIDByName('Schelling');
|
(bool _success, bool _found, uint256 _id) = getModuleIDByName('Schelling');
|
||||||
require( _success && _found );
|
require( _success && _found );
|
||||||
@ -350,7 +350,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
@to Place of new token
|
@to Place of new token
|
||||||
@value Token amount
|
@value Token amount
|
||||||
|
|
||||||
@success Was the function successfull?
|
@success Was the function successful?
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
||||||
require( _success && _found && modules[_id].name == keccak256('Provider') );
|
require( _success && _found && modules[_id].name == keccak256('Provider') );
|
||||||
@ -367,7 +367,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
@to To who.
|
@to To who.
|
||||||
@value Token amount.
|
@value Token amount.
|
||||||
@fee Transaction fee will be charged or not?
|
@fee Transaction fee will be charged or not?
|
||||||
@success Was the function successfull?
|
@success Was the function successful?
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
||||||
require( _success && _found );
|
require( _success && _found );
|
||||||
@ -382,7 +382,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
|
|
||||||
@from From who.
|
@from From who.
|
||||||
@value Token amount.
|
@value Token amount.
|
||||||
@success Was the function successfull?
|
@success Was the function successful?
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
||||||
require( _success && _found && modules[_id].name == keccak256('Provider') );
|
require( _success && _found && modules[_id].name == keccak256('Provider') );
|
||||||
@ -397,7 +397,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
|
|
||||||
@from From who.
|
@from From who.
|
||||||
@value Token amount.
|
@value Token amount.
|
||||||
@success Was the function successfull?
|
@success Was the function successful?
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
||||||
require( _success && _found && modules[_id].name == keccak256('Schelling') );
|
require( _success && _found && modules[_id].name == keccak256('Schelling') );
|
||||||
@ -413,7 +413,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
@moduleName Module name which will be configured
|
@moduleName Module name which will be configured
|
||||||
@aType Type of variable (announcementType).
|
@aType Type of variable (announcementType).
|
||||||
@value New value
|
@value New value
|
||||||
@success Was the function successfull?
|
@success Was the function successful?
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
(bool _success, bool _found, uint256 _id) = getModuleIDByAddress(msg.sender);
|
||||||
require( _success );
|
require( _success );
|
||||||
@ -431,7 +431,7 @@ contract moduleHandler is multiOwner, announcementTypes {
|
|||||||
function freezing(bool forever) external {
|
function freezing(bool forever) external {
|
||||||
/*
|
/*
|
||||||
Freezing CORION Platform. Can be called only by the owner.
|
Freezing CORION Platform. Can be called only by the owner.
|
||||||
Freez can not be recalled!
|
Freeze can not be recalled!
|
||||||
|
|
||||||
@forever Is it forever or not?
|
@forever Is it forever or not?
|
||||||
*/
|
*/
|
||||||
|
@ -118,7 +118,7 @@ contract premium is module, safeMath {
|
|||||||
@extraData Extra data to be received by the receiver
|
@extraData Extra data to be received by the receiver
|
||||||
@nonce Transaction count
|
@nonce Transaction count
|
||||||
|
|
||||||
@sucess Was the Function successful?
|
@success Was the Function successful?
|
||||||
*/
|
*/
|
||||||
_approve(spender, amount, nonce);
|
_approve(spender, amount, nonce);
|
||||||
require( thirdPartyPContractAbstract(spender).approvedCorionPremiumToken(msg.sender, amount, extraData) );
|
require( thirdPartyPContractAbstract(spender).approvedCorionPremiumToken(msg.sender, amount, extraData) );
|
||||||
|
@ -18,7 +18,7 @@ contract provider is module, safeMath, announcementTypes {
|
|||||||
}
|
}
|
||||||
function transferEvent(address from, address to, uint256 value) external returns (bool success) {
|
function transferEvent(address from, address to, uint256 value) external returns (bool success) {
|
||||||
/*
|
/*
|
||||||
Transaction completed. This function is ony available for the modulehandler.
|
Transaction completed. This function is only available for the modulehandler.
|
||||||
It should be checked if the sender or the acceptor does not connect to the provider or it is not a provider itself if so than the change should be recorded.
|
It should be checked if the sender or the acceptor does not connect to the provider or it is not a provider itself if so than the change should be recorded.
|
||||||
|
|
||||||
@from From whom?
|
@from From whom?
|
||||||
@ -35,7 +35,7 @@ contract provider is module, safeMath, announcementTypes {
|
|||||||
/*
|
/*
|
||||||
New schelling round. This function is only available for the moduleHandler.
|
New schelling round. This function is only available for the moduleHandler.
|
||||||
We are recording the new schelling round and we are storing the whole current quantity of the tokens.
|
We are recording the new schelling round and we are storing the whole current quantity of the tokens.
|
||||||
We generate a reward quantity of tokens directed to the providers address. The collected interest will be tranfered from this contract.
|
We generate a reward quantity of tokens directed to the providers address. The collected interest will be transferred from this contract.
|
||||||
|
|
||||||
@roundID Number of the schelling round.
|
@roundID Number of the schelling round.
|
||||||
@reward token emission
|
@reward token emission
|
||||||
@ -228,7 +228,7 @@ contract provider is module, safeMath, announcementTypes {
|
|||||||
@website Provider’s website
|
@website Provider’s website
|
||||||
@country Provider’s country
|
@country Provider’s country
|
||||||
@info Provider’s short introduction.
|
@info Provider’s short introduction.
|
||||||
@rate Rate of the emission what is going to be transfered to the client by the provider.
|
@rate Rate of the emission what is going to be transferred to the client by the provider.
|
||||||
@isForRent is for Rent or not?
|
@isForRent is for Rent or not?
|
||||||
@admin The admin’s address
|
@admin The admin’s address
|
||||||
*/
|
*/
|
||||||
@ -328,7 +328,7 @@ contract provider is module, safeMath, announcementTypes {
|
|||||||
|
|
||||||
@addr Address of the provider
|
@addr Address of the provider
|
||||||
@height Height
|
@height Height
|
||||||
@rate The rate of the emission which will be transfered to the client.
|
@rate The rate of the emission which will be transferred to the client.
|
||||||
@isForRent Rent or not.
|
@isForRent Rent or not.
|
||||||
@clientsCount Number of the clients.
|
@clientsCount Number of the clients.
|
||||||
@priv Private or not?
|
@priv Private or not?
|
||||||
@ -356,7 +356,7 @@ contract provider is module, safeMath, announcementTypes {
|
|||||||
}
|
}
|
||||||
function closeProvider() isReady external {
|
function closeProvider() isReady external {
|
||||||
/*
|
/*
|
||||||
Closing and inactivate the provider.
|
Closing and deactivating the provider.
|
||||||
It is only possible to close that active provider which is owned by the sender itself after calling the whole share of the emission.
|
It is only possible to close that active provider which is owned by the sender itself after calling the whole share of the emission.
|
||||||
Whom were connected to the provider those clients will have to disconnect after they’ve called their share of emission which was not called before.
|
Whom were connected to the provider those clients will have to disconnect after they’ve called their share of emission which was not called before.
|
||||||
*/
|
*/
|
||||||
@ -373,7 +373,7 @@ contract provider is module, safeMath, announcementTypes {
|
|||||||
/*
|
/*
|
||||||
Permition of the user to be able to connect to the provider.
|
Permition of the user to be able to connect to the provider.
|
||||||
This can only be invited by the provider’s admin.
|
This can only be invited by the provider’s admin.
|
||||||
With this kind of call only 100 address can be permited.
|
With this kind of call only 100 address can be permitted.
|
||||||
|
|
||||||
@addr Array of the addresses for whom the connection is allowed.
|
@addr Array of the addresses for whom the connection is allowed.
|
||||||
*/
|
*/
|
||||||
@ -391,7 +391,7 @@ contract provider is module, safeMath, announcementTypes {
|
|||||||
/*
|
/*
|
||||||
Disable of the user not to be able to connect to the provider.
|
Disable of the user not to be able to connect to the provider.
|
||||||
It is can called only for the admin of the provider.
|
It is can called only for the admin of the provider.
|
||||||
With this kind of call only 100 address can be permited.
|
With this kind of call only 100 address can be permitted.
|
||||||
|
|
||||||
@addr Array of the addresses for whom the connection is allowed.
|
@addr Array of the addresses for whom the connection is allowed.
|
||||||
*/
|
*/
|
||||||
@ -411,7 +411,7 @@ contract provider is module, safeMath, announcementTypes {
|
|||||||
Providers can not connect to other providers.
|
Providers can not connect to other providers.
|
||||||
If is a client at any provider, then it is not possible to connect to other provider one.
|
If is a client at any provider, then it is not possible to connect to other provider one.
|
||||||
It is only possible to connect to valid and active providers.
|
It is only possible to connect to valid and active providers.
|
||||||
If is an active provider then the client can only connect, if address is permited at the provider (Whitelist).
|
If is an active provider then the client can only connect, if address is permitted at the provider (Whitelist).
|
||||||
At private providers, the number of the client is restricted. If it reaches the limit no further clients are allowed to connect.
|
At private providers, the number of the client is restricted. If it reaches the limit no further clients are allowed to connect.
|
||||||
This process has a transaction fee based on the senders whole token quantity.
|
This process has a transaction fee based on the senders whole token quantity.
|
||||||
|
|
||||||
@ -487,12 +487,12 @@ contract provider is module, safeMath, announcementTypes {
|
|||||||
/*
|
/*
|
||||||
Polling the share from the token emission token emission for clients and for providers.
|
Polling the share from the token emission token emission for clients and for providers.
|
||||||
|
|
||||||
It is optionaly possible to give an address of a beneficiary for whom we can transfer the accumulated amount. In case we don’t enter any address then the amount will be transfered to the caller’s address.
|
It is optionally possible to give an address of a beneficiary for whom we can transfer the accumulated amount. In case we don’t enter any address then the amount will be transferred to the caller’s address.
|
||||||
As the interest should be checked at each schelling round in order to get the share from that so to avoid the overflow of the gas the number of the check-rounds should be limited.
|
As the interest should be checked at each schelling round in order to get the share from that so to avoid the overflow of the gas the number of the check-rounds should be limited.
|
||||||
Opcionalisan megadhato az ellenorzes koreinek szama. It is possible to enter optionaly the number of the check-rounds. If it is 0 then it is automatic.
|
Opcionalisan megadhato az ellenorzes koreinek szama. It is possible to enter optionally the number of the check-rounds. If it is 0 then it is automatic.
|
||||||
Provider variable should only be entered if the real owner of the provider is not the caller’s address.
|
Provider variable should only be entered if the real owner of the provider is not the caller’s address.
|
||||||
In case the client/provider was far behind then it is possible that this function should be called several times to check the total generated schelling rounds and to collect the share.
|
In case the client/provider was far behind then it is possible that this function should be called several times to check the total generated schelling rounds and to collect the share.
|
||||||
If is neighter a client nor a provider then the function is not available.
|
If is neither a client nor a provider then the function is not available.
|
||||||
The tokens will be sent to the beneficiary from the address of the provider without any transaction fees.
|
The tokens will be sent to the beneficiary from the address of the provider without any transaction fees.
|
||||||
|
|
||||||
@beneficiary Address of the beneficiary
|
@beneficiary Address of the beneficiary
|
||||||
@ -784,7 +784,7 @@ contract provider is module, safeMath, announcementTypes {
|
|||||||
/*
|
/*
|
||||||
Inner function to check the ICO status.
|
Inner function to check the ICO status.
|
||||||
|
|
||||||
@isICO Is the ICO in proccess or not?
|
@isICO Is the ICO in process or not?
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _isICO) = moduleHandler(moduleHandlerAddress).isICO();
|
(bool _success, bool _isICO) = moduleHandler(moduleHandlerAddress).isICO();
|
||||||
require( _success );
|
require( _success );
|
||||||
|
@ -264,7 +264,7 @@ contract publisher is announcementTypes, module, safeMath {
|
|||||||
function checkICO() internal returns (bool isICO) {
|
function checkICO() internal returns (bool isICO) {
|
||||||
/*
|
/*
|
||||||
Inner function to check the ICO status.
|
Inner function to check the ICO status.
|
||||||
@bool Is the ICO in proccess or not?
|
@bool Is the ICO in process or not?
|
||||||
*/
|
*/
|
||||||
(bool _success, bool _isICO) = moduleHandler(moduleHandlerAddress).isICO();
|
(bool _success, bool _isICO) = moduleHandler(moduleHandlerAddress).isICO();
|
||||||
require( _success );
|
require( _success );
|
||||||
|
@ -147,7 +147,7 @@ contract schelling is module, announcementTypes, schellingVars {
|
|||||||
@from From who
|
@from From who
|
||||||
@to To who
|
@to To who
|
||||||
@value Amount
|
@value Amount
|
||||||
@bool Was the transaction succesfull?
|
@bool Was the transaction successful?
|
||||||
*/
|
*/
|
||||||
require( super.isModuleHandler(msg.sender) );
|
require( super.isModuleHandler(msg.sender) );
|
||||||
if ( to == address(this) ) {
|
if ( to == address(this) ) {
|
||||||
@ -442,14 +442,14 @@ contract schelling is module, announcementTypes, schellingVars {
|
|||||||
if ( ! round.voted ) {
|
if ( ! round.voted ) {
|
||||||
newRound.reward = round.reward;
|
newRound.reward = round.reward;
|
||||||
}
|
}
|
||||||
uint256 aboves;
|
uint256 above;
|
||||||
for ( uint256 a=currentRound ; a>=currentRound-interestCheckRounds ; a-- ) {
|
for ( uint256 a=currentRound ; a>=currentRound-interestCheckRounds ; a-- ) {
|
||||||
if (a == 0) { break; }
|
if (a == 0) { break; }
|
||||||
prevRound = getRound(a);
|
prevRound = getRound(a);
|
||||||
if ( prevRound.totalAboveWeight > prevRound.totalBelowWeight ) { aboves++; }
|
if ( prevRound.totalAboveWeight > prevRound.totalBelowWeight ) { above++; }
|
||||||
}
|
}
|
||||||
uint256 expansion;
|
uint256 expansion;
|
||||||
if ( aboves >= interestCheckAboves ) {
|
if ( above >= interestCheckAboves ) {
|
||||||
expansion = getTotalSupply() * interestRate / interestRateM / 100;
|
expansion = getTotalSupply() * interestRate / interestRateM / 100;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -22,7 +22,7 @@ pragma solidity ^0.4.6;
|
|||||||
/// @dev This contract tracks the
|
/// @dev This contract tracks the
|
||||||
|
|
||||||
|
|
||||||
/// is rules the relation betwen a donor and a recipient
|
/// is rules the relation between a donor and a recipient
|
||||||
/// in order to guaranty to the donor that the job will be done and to guaranty
|
/// in order to guaranty to the donor that the job will be done and to guaranty
|
||||||
/// to the recipient that he will be paid
|
/// to the recipient that he will be paid
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ contract Bounty is PullPayment, Destructible {
|
|||||||
event TargetCreated(address createdAddress);
|
event TargetCreated(address createdAddress);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Fallback function allowing the contract to recieve funds, if they haven't already been claimed.
|
* @dev Fallback function allowing the contract to receive funds, if they haven't already been claimed.
|
||||||
*/
|
*/
|
||||||
function() external payable {
|
function() external payable {
|
||||||
if (claimed) {
|
if (claimed) {
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
pragma solidity ^0.4.11;
|
pragma solidity ^0.4.11;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @title Helps contracts guard agains rentrancy attacks.
|
* @title Helps contracts guard against rentrancy attacks.
|
||||||
* @author Remco Bloemen <remco@2π.com>
|
* @author Remco Bloemen <remco@2π.com>
|
||||||
* @notice If you mark a function `nonReentrant`, you should also
|
* @notice If you mark a function `nonReentrant`, you should also
|
||||||
* mark it `external`.
|
* mark it `external`.
|
||||||
|
@ -29,7 +29,7 @@ contract LimitedTransferToken is ERC20 {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Checks modifier and allows transfer if tokens are not locked.
|
* @dev Checks modifier and allows transfer if tokens are not locked.
|
||||||
* @param _to The address that will recieve the tokens.
|
* @param _to The address that will receive the tokens.
|
||||||
* @param _value The amount of tokens to be transferred.
|
* @param _value The amount of tokens to be transferred.
|
||||||
*/
|
*/
|
||||||
function transfer(address _to, uint256 _value) canTransfer(msg.sender, _value) public {
|
function transfer(address _to, uint256 _value) canTransfer(msg.sender, _value) public {
|
||||||
@ -39,7 +39,7 @@ contract LimitedTransferToken is ERC20 {
|
|||||||
/**
|
/**
|
||||||
* @dev Checks modifier and allows transfer if tokens are not locked.
|
* @dev Checks modifier and allows transfer if tokens are not locked.
|
||||||
* @param _from The address that will send the tokens.
|
* @param _from The address that will send the tokens.
|
||||||
* @param _to The address that will recieve the tokens.
|
* @param _to The address that will receive the tokens.
|
||||||
* @param _value The amount of tokens to be transferred.
|
* @param _value The amount of tokens to be transferred.
|
||||||
*/
|
*/
|
||||||
function transferFrom(address _from, address _to, uint256 _value) public canTransfer(_from, _value) {
|
function transferFrom(address _from, address _to, uint256 _value) public canTransfer(_from, _value) {
|
||||||
|
@ -27,7 +27,7 @@ contract MintableToken is StandardToken, Ownable {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Function to mint tokens
|
* @dev Function to mint tokens
|
||||||
* @param _to The address that will recieve the minted tokens.
|
* @param _to The address that will receive the minted tokens.
|
||||||
* @param _amount The amount of tokens to mint.
|
* @param _amount The amount of tokens to mint.
|
||||||
* @return A boolean that indicates if the operation was successful.
|
* @return A boolean that indicates if the operation was successful.
|
||||||
*/
|
*/
|
||||||
|
@ -18,7 +18,7 @@ contract SimpleToken is StandardToken {
|
|||||||
uint256 public INITIAL_SUPPLY = 10000;
|
uint256 public INITIAL_SUPPLY = 10000;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Contructor that gives msg.sender all of existing tokens.
|
* @dev Constructor that gives msg.sender all of existing tokens.
|
||||||
*/
|
*/
|
||||||
constructor() public {
|
constructor() public {
|
||||||
totalSupply = INITIAL_SUPPLY;
|
totalSupply = INITIAL_SUPPLY;
|
||||||
|
@ -21,7 +21,7 @@ contract StandardToken is ERC20, BasicToken {
|
|||||||
* @dev Transfer tokens from one address to another
|
* @dev Transfer tokens from one address to another
|
||||||
* @param _from address The address which you want to send tokens from
|
* @param _from address The address which you want to send tokens from
|
||||||
* @param _to address The address which you want to transfer to
|
* @param _to address The address which you want to transfer to
|
||||||
* @param _value uint256 the amout of tokens to be transfered
|
* @param _value uint256 the amount of tokens to be transferred
|
||||||
*/
|
*/
|
||||||
function transferFrom(address _from, address _to, uint256 _value) public {
|
function transferFrom(address _from, address _to, uint256 _value) public {
|
||||||
uint256 _allowance = allowed[_from][msg.sender];
|
uint256 _allowance = allowed[_from][msg.sender];
|
||||||
@ -56,7 +56,7 @@ contract StandardToken is ERC20, BasicToken {
|
|||||||
* @dev Function to check the amount of tokens that an owner allowed to a spender.
|
* @dev Function to check the amount of tokens that an owner allowed to a spender.
|
||||||
* @param _owner address The address which owns the funds.
|
* @param _owner address The address which owns the funds.
|
||||||
* @param _spender address The address which will spend the funds.
|
* @param _spender address The address which will spend the funds.
|
||||||
* @return A uint256 specifing the amount of tokens still avaible for the spender.
|
* @return A uint256 specifying the amount of tokens still available for the spender.
|
||||||
*/
|
*/
|
||||||
function allowance(address _owner, address _spender) public view returns (uint256 remaining) {
|
function allowance(address _owner, address _spender) public view returns (uint256 remaining) {
|
||||||
return allowed[_owner][_spender];
|
return allowed[_owner][_spender];
|
||||||
|
@ -69,7 +69,7 @@ contract VestedToken is StandardToken, LimitedTransferToken {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Revoke the grant of tokens of a specifed address.
|
* @dev Revoke the grant of tokens of a specified address.
|
||||||
* @param _holder The address which will have its tokens revoked.
|
* @param _holder The address which will have its tokens revoked.
|
||||||
* @param _grantId The id of the token grant.
|
* @param _grantId The id of the token grant.
|
||||||
*/
|
*/
|
||||||
@ -135,13 +135,13 @@ contract VestedToken is StandardToken, LimitedTransferToken {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Calculate amount of vested tokens at a specifc time.
|
* @dev Calculate amount of vested tokens at a specific time.
|
||||||
* @param tokens uint256 The amount of tokens grantted.
|
* @param tokens uint256 The amount of tokens granted.
|
||||||
* @param time uint64 The time to be checked
|
* @param time uint64 The time to be checked
|
||||||
* @param start uint64 A time representing the begining of the grant
|
* @param start uint64 A time representing the beginning of the grant
|
||||||
* @param cliff uint64 The cliff period.
|
* @param cliff uint64 The cliff period.
|
||||||
* @param vesting uint64 The vesting period.
|
* @param vesting uint64 The vesting period.
|
||||||
* @return An uint256 representing the amount of vested tokensof a specif grant.
|
* @return An uint256 representing the amount of vested tokens of a specific grant.
|
||||||
* transferableTokens
|
* transferableTokens
|
||||||
* | _/-------- vestedTokens rect
|
* | _/-------- vestedTokens rect
|
||||||
* | _/
|
* | _/
|
||||||
@ -186,7 +186,7 @@ contract VestedToken is StandardToken, LimitedTransferToken {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @dev Get all information about a specifc grant.
|
* @dev Get all information about a specific grant.
|
||||||
* @param _holder The address which will have its tokens revoked.
|
* @param _holder The address which will have its tokens revoked.
|
||||||
* @param _grantId The id of the token grant.
|
* @param _grantId The id of the token grant.
|
||||||
* @return Returns all the values that represent a TokenGrant(address, value, start, cliff,
|
* @return Returns all the values that represent a TokenGrant(address, value, start, cliff,
|
||||||
@ -226,7 +226,7 @@ contract VestedToken is StandardToken, LimitedTransferToken {
|
|||||||
* @dev Calculate the amount of non vested tokens at a specific time.
|
* @dev Calculate the amount of non vested tokens at a specific time.
|
||||||
* @param grant TokenGrant The grant to be checked.
|
* @param grant TokenGrant The grant to be checked.
|
||||||
* @param time uint64 The time to be checked
|
* @param time uint64 The time to be checked
|
||||||
* @return An uint256 representing the amount of non vested tokens of a specifc grant on the
|
* @return An uint256 representing the amount of non vested tokens of a specific grant on the
|
||||||
* passed time frame.
|
* passed time frame.
|
||||||
*/
|
*/
|
||||||
function nonVestedTokens(TokenGrant grant, uint64 time) private view returns (uint256) {
|
function nonVestedTokens(TokenGrant grant, uint64 time) private view returns (uint256) {
|
||||||
|
@ -385,7 +385,7 @@ contract Wallet is multisig, multiowned, daylimit {
|
|||||||
emit Deposit(msg.sender, msg.value);
|
emit Deposit(msg.sender, msg.value);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Outside-visible transact entry point. Executes transacion immediately if below daily spend limit.
|
// Outside-visible transact entry point. Executes transaction immediately if below daily spend limit.
|
||||||
// If not, goes into multisig process. We provide a hash on return to allow the sender to provide
|
// If not, goes into multisig process. We provide a hash on return to allow the sender to provide
|
||||||
// shortcuts for the other confirmations (allowing them to avoid replicating the _to, _value
|
// shortcuts for the other confirmations (allowing them to avoid replicating the _to, _value
|
||||||
// and _data arguments). They still get the option of using them if they want, anyways.
|
// and _data arguments). They still get the option of using them if they want, anyways.
|
||||||
|
@ -199,7 +199,7 @@ BOOST_AUTO_TEST_CASE(multiple_params)
|
|||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(multiple_methods_order)
|
BOOST_AUTO_TEST_CASE(multiple_methods_order)
|
||||||
{
|
{
|
||||||
// methods are expected to be in alpabetical order
|
// methods are expected to be in alphabetical order
|
||||||
char const* sourceCode = R"(
|
char const* sourceCode = R"(
|
||||||
contract test {
|
contract test {
|
||||||
function f(uint a) public returns (uint d) { return a * 7; }
|
function f(uint a) public returns (uint d) { return a * 7; }
|
||||||
|
@ -6387,9 +6387,9 @@ BOOST_AUTO_TEST_CASE(return_multiple_strings_of_various_sizes)
|
|||||||
"ABCDEFGHIJKLMNOPQRSTUVXYZABCDEFGHIJKLMNOPQRSTUVXYZABCDEFGHIJKLMNOPQRSTUVXYZ"
|
"ABCDEFGHIJKLMNOPQRSTUVXYZABCDEFGHIJKLMNOPQRSTUVXYZABCDEFGHIJKLMNOPQRSTUVXYZ"
|
||||||
"ABCDEFGHIJKLMNOPQRSTUVXYZABCDEFGHIJKLMNOPQRSTUVXYZABCDEFGHIJKLMNOPQRSTUVXYZ"
|
"ABCDEFGHIJKLMNOPQRSTUVXYZABCDEFGHIJKLMNOPQRSTUVXYZABCDEFGHIJKLMNOPQRSTUVXYZ"
|
||||||
);
|
);
|
||||||
vector<size_t> lengthes{0, 30, 32, 63, 64, 65, 210, 300};
|
vector<size_t> lengths{0, 30, 32, 63, 64, 65, 210, 300};
|
||||||
for (auto l1: lengthes)
|
for (auto l1: lengths)
|
||||||
for (auto l2: lengthes)
|
for (auto l2: lengths)
|
||||||
{
|
{
|
||||||
bytes dyn1 = encodeArgs(u256(l1), s1.substr(0, l1));
|
bytes dyn1 = encodeArgs(u256(l1), s1.substr(0, l1));
|
||||||
bytes dyn2 = encodeArgs(u256(l2), s2.substr(0, l2));
|
bytes dyn2 = encodeArgs(u256(l2), s2.substr(0, l2));
|
||||||
@ -6456,9 +6456,9 @@ BOOST_AUTO_TEST_CASE(bytes_in_function_calls)
|
|||||||
compileAndRun(sourceCode, 0, "Main");
|
compileAndRun(sourceCode, 0, "Main");
|
||||||
string s1("abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz");
|
string s1("abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz");
|
||||||
string s2("ABCDEFGHIJKLMNOPQRSTUVXYZABCDEFGHIJKLMNOPQRSTUVXYZABCDEFGHIJKLMNOPQRSTUVXYZ");
|
string s2("ABCDEFGHIJKLMNOPQRSTUVXYZABCDEFGHIJKLMNOPQRSTUVXYZABCDEFGHIJKLMNOPQRSTUVXYZ");
|
||||||
vector<size_t> lengthes{0, 31, 64, 65};
|
vector<size_t> lengths{0, 31, 64, 65};
|
||||||
for (auto l1: lengthes)
|
for (auto l1: lengths)
|
||||||
for (auto l2: lengthes)
|
for (auto l2: lengths)
|
||||||
{
|
{
|
||||||
bytes dyn1 = encodeArgs(u256(l1), s1.substr(0, l1));
|
bytes dyn1 = encodeArgs(u256(l1), s1.substr(0, l1));
|
||||||
bytes dyn2 = encodeArgs(u256(l2), s2.substr(0, l2));
|
bytes dyn2 = encodeArgs(u256(l2), s2.substr(0, l2));
|
||||||
@ -6497,8 +6497,8 @@ BOOST_AUTO_TEST_CASE(return_bytes_internal)
|
|||||||
)";
|
)";
|
||||||
compileAndRun(sourceCode, 0, "Main");
|
compileAndRun(sourceCode, 0, "Main");
|
||||||
string s1("abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz");
|
string s1("abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz");
|
||||||
vector<size_t> lengthes{0, 31, 64, 65};
|
vector<size_t> lengths{0, 31, 64, 65};
|
||||||
for (auto l1: lengthes)
|
for (auto l1: lengths)
|
||||||
{
|
{
|
||||||
bytes dyn1 = encodeArgs(u256(l1), s1.substr(0, l1));
|
bytes dyn1 = encodeArgs(u256(l1), s1.substr(0, l1));
|
||||||
bytes args1 = encodeArgs(u256(0x20)) + dyn1;
|
bytes args1 = encodeArgs(u256(0x20)) + dyn1;
|
||||||
|
@ -77,7 +77,7 @@ Declaration const& resolveDeclaration(
|
|||||||
)
|
)
|
||||||
{
|
{
|
||||||
ASTNode const* scope = &_sourceUnit;
|
ASTNode const* scope = &_sourceUnit;
|
||||||
// bracers are required, cause msvc couldnt handle this macro in for statement
|
// bracers are required, cause msvc couldn't handle this macro in for statement
|
||||||
for (string const& namePart: _namespacedName)
|
for (string const& namePart: _namespacedName)
|
||||||
{
|
{
|
||||||
auto declarations = _resolver.resolveName(namePart, scope);
|
auto declarations = _resolver.resolveName(namePart, scope);
|
||||||
@ -319,7 +319,7 @@ BOOST_AUTO_TEST_CASE(short_circuiting)
|
|||||||
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());
|
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(arithmetics)
|
BOOST_AUTO_TEST_CASE(arithmetic)
|
||||||
{
|
{
|
||||||
char const* sourceCode = R"(
|
char const* sourceCode = R"(
|
||||||
contract test {
|
contract test {
|
||||||
|
@ -104,7 +104,7 @@ public:
|
|||||||
"\nOptimized: " + toHex(optimizedOutput));
|
"\nOptimized: " + toHex(optimizedOutput));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// @returns the number of intructions in the given bytecode, not taking the metadata hash
|
/// @returns the number of instructions in the given bytecode, not taking the metadata hash
|
||||||
/// into account.
|
/// into account.
|
||||||
size_t numInstructions(bytes const& _bytecode, boost::optional<Instruction> _which = boost::optional<Instruction>{})
|
size_t numInstructions(bytes const& _bytecode, boost::optional<Instruction> _which = boost::optional<Instruction>{})
|
||||||
{
|
{
|
||||||
|
@ -55,7 +55,7 @@ BOOST_AUTO_TEST_CASE(environment_access)
|
|||||||
"this",
|
"this",
|
||||||
"address(1).balance"
|
"address(1).balance"
|
||||||
};
|
};
|
||||||
// ``block.blockhash`` and ``blockhash`` are tested seperately below because their usage will
|
// ``block.blockhash`` and ``blockhash`` are tested separately below because their usage will
|
||||||
// produce warnings that can't be handled in a generic way.
|
// produce warnings that can't be handled in a generic way.
|
||||||
vector<string> pure{
|
vector<string> pure{
|
||||||
"msg.data",
|
"msg.data",
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
// This tests a crash that occured because we did not stop for fatal errors.
|
// This tests a crash that occurred because we did not stop for fatal errors.
|
||||||
contract C {
|
contract C {
|
||||||
struct S {
|
struct S {
|
||||||
ftring a;
|
ftring a;
|
||||||
@ -8,4 +8,4 @@ contract C {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// ----
|
// ----
|
||||||
// DeclarationError: (113-119): Identifier not found or not unique.
|
// DeclarationError: (114-120): Identifier not found or not unique.
|
||||||
|
Loading…
Reference in New Issue
Block a user