Unverified Commit 19610325 by Nicolás Venturo Committed by GitHub

Merge pull request #31 from nventuro/peer-dep

Added zos-lib as a peer dependency and used its Initializable.
parents 488c3de3 fffa406a
...@@ -18,6 +18,11 @@ jobs: ...@@ -18,6 +18,11 @@ jobs:
- env: SOLIDITY_COVERAGE=true - env: SOLIDITY_COVERAGE=true
- env: SOLC_NIGHTLY=true - env: SOLC_NIGHTLY=true
include: include:
- stage: install
script: true
install:
- npm install
- npx npm-install-peers
# Run the unit test suite three times in parallel. # Run the unit test suite three times in parallel.
# The first one gets results faster and is the only one required to pass. # The first one gets results faster and is the only one required to pass.
# The second one generates the coverage report. # The second one generates the coverage report.
...@@ -25,18 +30,22 @@ jobs: ...@@ -25,18 +30,22 @@ jobs:
# upcoming solidity release. # upcoming solidity release.
- stage: tests - stage: tests
name: "unit tests" name: "unit tests"
install: npx npm-install-peers
script: npm run test script: npm run test
- stage: tests - stage: tests
name: "unit tests with coverage" name: "unit tests with coverage"
install: npx npm-install-peers
script: npm run test script: npm run test
env: SOLIDITY_COVERAGE=true env: SOLIDITY_COVERAGE=true
- stage: tests - stage: tests
name: "unit tests with solc nightly" name: "unit tests with solc nightly"
install: npx npm-install-peers
script: npm run test script: npm run test
env: SOLC_NIGHTLY=true env: SOLC_NIGHTLY=true
# solidity and javascript style tests. # solidity and javascript style tests.
- stage: tests - stage: tests
name: "static tests" name: "static tests"
install: npx npm-install-peers
script: npm run lint script: npm run lint
- stage: update docs - stage: update docs
if: tag =~ ^v[0-9]+\.[0-9]+\.[0-9]+$ if: tag =~ ^v[0-9]+\.[0-9]+\.[0-9]+$
......
pragma solidity ^0.4.24;
/**
* @title Initializable
*
* @dev Helper contract to support initializer functions. To use it, replace
* the constructor with a function that has the `initializer` modifier.
* WARNING: Unlike constructors, initializer functions must be manually
* invoked. This applies both to deploying an Initializable contract, as well
* as extending an Initializable contract via inheritance.
* WARNING: When used with inheritance, manual care must be taken to not invoke
* a parent initializer twice, because this is not dealt with automatically as
* with constructors.
*/
contract Initializable {
/**
* @dev Indicates that the contract has been initialized.
*/
bool private initialized;
/**
* @dev Indicates that the contract is in the process of being initialized.
*/
bool private initializing;
/**
* @dev Modifier to use in the initializer function of a contract.
*/
modifier initializer() {
require(initializing || isConstructor() || !initialized, "Contract instance has already been initialized");
bool wasInitializing = initializing;
initializing = true;
initialized = true;
_;
initializing = wasInitializing;
}
/// @dev Returns true if and only if the function is running in the constructor
function isConstructor() private view returns (bool) {
uint cs;
assembly { cs := extcodesize(address) }
return cs == 0;
}
uint256[50] private ______gap;
}
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../Roles.sol"; import "../Roles.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../Roles.sol"; import "../Roles.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../Roles.sol"; import "../Roles.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../Roles.sol"; import "../Roles.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../token/ERC20/IERC20.sol"; import "../token/ERC20/IERC20.sol";
import "../math/SafeMath.sol"; import "../math/SafeMath.sol";
import "../token/ERC20/SafeERC20.sol"; import "../token/ERC20/SafeERC20.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../../math/SafeMath.sol"; import "../../math/SafeMath.sol";
import "../validation/TimedCrowdsale.sol"; import "../validation/TimedCrowdsale.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../validation/TimedCrowdsale.sol"; import "../validation/TimedCrowdsale.sol";
import "../../token/ERC20/IERC20.sol"; import "../../token/ERC20/IERC20.sol";
import "../../math/SafeMath.sol"; import "../../math/SafeMath.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../../math/SafeMath.sol"; import "../../math/SafeMath.sol";
import "./FinalizableCrowdsale.sol"; import "./FinalizableCrowdsale.sol";
import "../../payment/RefundEscrow.sol"; import "../../payment/RefundEscrow.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../Crowdsale.sol"; import "../Crowdsale.sol";
import "../../token/ERC20/IERC20.sol"; import "../../token/ERC20/IERC20.sol";
import "../../token/ERC20/SafeERC20.sol"; import "../../token/ERC20/SafeERC20.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../Crowdsale.sol"; import "../Crowdsale.sol";
import "../../token/ERC20/ERC20Mintable.sol"; import "../../token/ERC20/ERC20Mintable.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../validation/TimedCrowdsale.sol"; import "../validation/TimedCrowdsale.sol";
import "../../math/SafeMath.sol"; import "../../math/SafeMath.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../../math/SafeMath.sol"; import "../../math/SafeMath.sol";
import "../Crowdsale.sol"; import "../Crowdsale.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../../math/SafeMath.sol"; import "../../math/SafeMath.sol";
import "../Crowdsale.sol"; import "../Crowdsale.sol";
import "../../access/roles/CapperRole.sol"; import "../../access/roles/CapperRole.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../../math/SafeMath.sol"; import "../../math/SafeMath.sol";
import "../Crowdsale.sol"; import "../Crowdsale.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../../token/ERC20/IERC20.sol"; import "../../token/ERC20/IERC20.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../token/ERC20/IERC20.sol"; import "../token/ERC20/IERC20.sol";
import "../token/ERC20/ERC20Mintable.sol"; import "../token/ERC20/ERC20Mintable.sol";
import "../token/ERC20/SafeERC20.sol"; import "../token/ERC20/SafeERC20.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../access/roles/SignerRole.sol"; import "../access/roles/SignerRole.sol";
import "../cryptography/ECDSA.sol"; import "../cryptography/ECDSA.sol";
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../token/ERC20/SafeERC20.sol"; import "../token/ERC20/SafeERC20.sol";
import "../ownership/Ownable.sol"; import "../ownership/Ownable.sol";
import "../math/SafeMath.sol"; import "../math/SafeMath.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../crowdsale/validation/CappedCrowdsale.sol"; import "../crowdsale/validation/CappedCrowdsale.sol";
import "../crowdsale/distribution/RefundableCrowdsale.sol"; import "../crowdsale/distribution/RefundableCrowdsale.sol";
import "../crowdsale/emission/MintedCrowdsale.sol"; import "../crowdsale/emission/MintedCrowdsale.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../token/ERC20/ERC20.sol"; import "../token/ERC20/ERC20.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./IERC165.sol"; import "./IERC165.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../access/roles/PauserRole.sol"; import "../access/roles/PauserRole.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
/** /**
* @title Ownable * @title Ownable
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
/** /**
* @title Secondary * @title Secondary
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./Escrow.sol"; import "./Escrow.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../math/SafeMath.sol"; import "../math/SafeMath.sol";
import "../ownership/Secondary.sol"; import "../ownership/Secondary.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./Escrow.sol"; import "./Escrow.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./ConditionalEscrow.sol"; import "./ConditionalEscrow.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../math/SafeMath.sol"; import "../math/SafeMath.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./IERC20.sol"; import "./IERC20.sol";
import "../../math/SafeMath.sol"; import "../../math/SafeMath.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./ERC20.sol"; import "./ERC20.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./ERC20Mintable.sol"; import "./ERC20Mintable.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./IERC20.sol"; import "./IERC20.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./ERC20.sol"; import "./ERC20.sol";
import "../../access/roles/MinterRole.sol"; import "../../access/roles/MinterRole.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./ERC20.sol"; import "./ERC20.sol";
import "../../lifecycle/Pausable.sol"; import "../../lifecycle/Pausable.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./SafeERC20.sol"; import "./SafeERC20.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./IERC721.sol"; import "./IERC721.sol";
import "./IERC721Receiver.sol"; import "./IERC721Receiver.sol";
import "../../math/SafeMath.sol"; import "../../math/SafeMath.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./ERC721.sol"; import "./ERC721.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./IERC721Enumerable.sol"; import "./IERC721Enumerable.sol";
import "./ERC721.sol"; import "./ERC721.sol";
import "../../introspection/ERC165.sol"; import "../../introspection/ERC165.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./ERC721.sol"; import "./ERC721.sol";
import "./ERC721Enumerable.sol"; import "./ERC721Enumerable.sol";
import "./ERC721Metadata.sol"; import "./ERC721Metadata.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./IERC721Receiver.sol"; import "./IERC721Receiver.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./ERC721.sol"; import "./ERC721.sol";
import "./IERC721Metadata.sol"; import "./IERC721Metadata.sol";
import "../../introspection/ERC165.sol"; import "../../introspection/ERC165.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./ERC721Metadata.sol"; import "./ERC721Metadata.sol";
import "../../access/roles/MinterRole.sol"; import "../../access/roles/MinterRole.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./ERC721.sol"; import "./ERC721.sol";
import "../../access/roles/MinterRole.sol"; import "../../access/roles/MinterRole.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./ERC721.sol"; import "./ERC721.sol";
import "../../lifecycle/Pausable.sol"; import "../../lifecycle/Pausable.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "../../introspection/IERC165.sol"; import "../../introspection/IERC165.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./IERC721.sol"; import "./IERC721.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./IERC721.sol"; import "./IERC721.sol";
import "./IERC721Enumerable.sol"; import "./IERC721Enumerable.sol";
import "./IERC721Metadata.sol"; import "./IERC721Metadata.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
import "./IERC721.sol"; import "./IERC721.sol";
......
pragma solidity ^0.4.24; pragma solidity ^0.4.24;
import "../Initializable.sol"; import "zos-lib/contracts/Initializable.sol";
/** /**
* @title Helps contracts guard against reentrancy attacks. * @title Helps contracts guard against reentrancy attacks.
......
...@@ -50,10 +50,14 @@ ...@@ -50,10 +50,14 @@
"eslint-plugin-standard": "^3.1.0", "eslint-plugin-standard": "^3.1.0",
"ethjs-abi": "^0.2.1", "ethjs-abi": "^0.2.1",
"ganache-cli": "6.1.0", "ganache-cli": "6.1.0",
"npm-install-peers": "^1.2.1",
"solidity-coverage": "^0.5.4", "solidity-coverage": "^0.5.4",
"solium": "^1.1.8", "solium": "^1.1.8",
"truffle": "^4.1.13", "truffle": "^4.1.13",
"truffle-hdwallet-provider": "0.0.5", "truffle-hdwallet-provider": "0.0.5",
"web3-utils": "^1.0.0-beta.34" "web3-utils": "^1.0.0-beta.34"
},
"peerDependencies": {
"zos-lib": "^2.0.0-alpha.3"
} }
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment