Check order of elements in file and inside each contract, according to the style guide.
This rule accepts a string option of rule severity. Must be one of “error”, “warn”, “off”. Defaults to warn.
{
"rules": {
"ordering": "warn"
}
}
pragma solidity ^0.4.0;
import "./some/library.sol";
import "./some/other-library.sol";
enum MyEnum {
Foo,
Bar
}
struct MyStruct {
uint x;
uint y;
}
interface IBox {
function getValue() public;
function setValue(uint) public;
}
library MyLibrary {
function add(uint a, uint b, uint c) public returns (uint) {
return a + b + c;
}
}
contract MyContract {
struct InnerStruct {
bool flag;
}
enum InnerEnum {
A, B, C
}
uint public x;
uint public y;
event MyEvent(address a);
constructor () public {}
fallback () external {}
function myExternalFunction() external {}
function myExternalConstantFunction() external constant {}
function myPublicFunction() public {}
function myPublicConstantFunction() public constant {}
function myInternalFunction() internal {}
function myPrivateFunction() private {}
}
pragma solidity ^0.5.0;
import "./some/library.sol";
import "./some/other-library.sol";
enum MyEnum {
Foo,
Bar
}
struct MyStruct {
uint x;
uint y;
}
interface IBox {
function getValue() public;
function setValue(uint) public;
}
library MyLibrary {
function add(uint a, uint b, uint c) public returns (uint) {
return a + b + c;
}
}
contract MyContract {
using MyLibrary for uint;
struct InnerStruct {
bool flag;
}
enum InnerEnum {
A, B, C
}
address payable owner;
uint public x;
uint public y;
event MyEvent(address a);
modifier onlyOwner {
require(
msg.sender == owner,
"Only owner can call this function."
);
_;
}
constructor () public {}
fallback () external {}
function myExternalFunction() external {}
function myExternalViewFunction() external view {}
function myExternalPureFunction() external pure {}
function myPublicFunction() public {}
function myPublicViewFunction() public view {}
function myPublicPureFunction() public pure {}
function myInternalFunction() internal {}
function myInternalViewFunction() internal view {}
function myInternalPureFunction() internal pure {}
function myPrivateFunction() private {}
function myPrivateViewFunction() private view {}
function myPrivatePureFunction() private pure {}
}
pragma solidity ^0.6.0;
import "./some/library.sol";
import "./some/other-library.sol";
enum MyEnum {
Foo,
Bar
}
struct MyStruct {
uint x;
uint y;
}
interface IBox {
function getValue() public;
function setValue(uint) public;
}
library MyLibrary {
function add(uint a, uint b, uint c) public returns (uint) {
return a + b + c;
}
}
contract MyContract {
using MyLibrary for uint;
struct InnerStruct {
bool flag;
}
enum InnerEnum {
A, B, C
}
address payable owner;
uint public x;
uint public y;
event MyEvent(address a);
modifier onlyOwner {
require(
msg.sender == owner,
"Only owner can call this function."
);
_;
}
constructor () public {}
receive() external payable {}
fallback () external {}
function myExternalFunction() external {}
function myExternalViewFunction() external view {}
function myExternalPureFunction() external pure {}
function myPublicFunction() public {}
function myPublicViewFunction() public view {}
function myPublicPureFunction() public pure {}
function myInternalFunction() internal {}
function myInternalViewFunction() internal view {}
function myInternalPureFunction() internal pure {}
function myPrivateFunction() private {}
function myPrivateViewFunction() private view {}
function myPrivatePureFunction() private pure {}
}
contract MyContract {
function foo() public {}
uint a;
}
contract MyContract {}
library MyLibrary {}
library MyLibrary {}
interface MyInterface {}
contract MyContract {
uint public x;
using MyMathLib for uint;
}
contract MyContract {
function myExternalFunction() external {}
function myExternalPureFunction() external pure {}
function myExternalViewFunction() external view {}
}
contract MyContract {
function myPublicFunction() public {}
function myPublicPureFunction() public pure {}
function myPublicViewFunction() public view {}
}
contract MyContract {
function myInternalFunction() internal {}
function myInternalPureFunction() internal pure {}
function myInternalViewFunction() internal view {}
}
contract MyContract {
function myPrivateFunction() private {}
function myPrivatePureFunction() private pure {}
function myPrivateViewFunction() private view {}
}
This rule was introduced in Solhint 3.2.0