* Initial migration to Solidity 0.6.x - v3.0 first steps (#2063) * Initial migration, missing GSN, 721, 777 and Crowdsales. * Add _beforeTokenOperation and _afterTokenOperation. * Add documentation for hooks. * Add hooks doc * Add missing drafts * Add back ERC721 with hooks * Bring back ERC777 * Notes on hooks * Bring back GSN * Make functions virtual * Make GSN overrides explicit * Fix ERC20Pausable tests * Remove virtual from some view functions * Update linter * Delete examples * Remove unnecessary virtual * Remove roles from Pausable * Remove roles * Remove users of roles * Adapt ERC20 tests * Fix ERC721 tests * Add all ERC721 hooks * Add ERC777 hooks * Fix remaining tests * Bump compiler version * Move 721BurnableMock into mocks directory * Remove _before hooks * Fix tests * Upgrade linter * Put modifiers last * Remove _beforeTokenApproval and _beforeOperatorApproval hooks
33 lines
859 B
Solidity
33 lines
859 B
Solidity
pragma solidity ^0.6.0;
|
|
|
|
/**
|
|
* @title Strings
|
|
* @dev String operations.
|
|
*/
|
|
library Strings {
|
|
/**
|
|
* @dev Converts a `uint256` to a `string`.
|
|
* via OraclizeAPI - MIT licence
|
|
* https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol
|
|
*/
|
|
function fromUint256(uint256 value) internal pure returns (string memory) {
|
|
if (value == 0) {
|
|
return "0";
|
|
}
|
|
uint256 temp = value;
|
|
uint256 digits;
|
|
while (temp != 0) {
|
|
digits++;
|
|
temp /= 10;
|
|
}
|
|
bytes memory buffer = new bytes(digits);
|
|
uint256 index = digits - 1;
|
|
temp = value;
|
|
while (temp != 0) {
|
|
buffer[index--] = byte(uint8(48 + temp % 10));
|
|
temp /= 10;
|
|
}
|
|
return string(buffer);
|
|
}
|
|
}
|