mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Merge pull request #8628 from ethereum/fiximmutableastexport
Export immutability.
This commit is contained in:
commit
baefab78d8
@ -7,6 +7,7 @@ Compiler Features:
|
|||||||
|
|
||||||
|
|
||||||
Bugfixes:
|
Bugfixes:
|
||||||
|
* AST export: Export `immutable` property in the field `mutability`.
|
||||||
* SMTChecker: Fix internal error in the CHC engine when calling inherited functions internally.
|
* SMTChecker: Fix internal error in the CHC engine when calling inherited functions internally.
|
||||||
|
|
||||||
|
|
||||||
|
@ -854,7 +854,17 @@ class VariableDeclaration: public Declaration
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
enum Location { Unspecified, Storage, Memory, CallData };
|
enum Location { Unspecified, Storage, Memory, CallData };
|
||||||
enum class Constantness { Mutable, Immutable, Constant };
|
enum class Mutability { Mutable, Immutable, Constant };
|
||||||
|
static std::string mutabilityToString(Mutability _mutability)
|
||||||
|
{
|
||||||
|
switch (_mutability)
|
||||||
|
{
|
||||||
|
case Mutability::Mutable: return "mutable";
|
||||||
|
case Mutability::Immutable: return "immutable";
|
||||||
|
case Mutability::Constant: return "constant";
|
||||||
|
}
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
VariableDeclaration(
|
VariableDeclaration(
|
||||||
int64_t _id,
|
int64_t _id,
|
||||||
@ -865,7 +875,7 @@ public:
|
|||||||
Visibility _visibility,
|
Visibility _visibility,
|
||||||
bool _isStateVar = false,
|
bool _isStateVar = false,
|
||||||
bool _isIndexed = false,
|
bool _isIndexed = false,
|
||||||
Constantness _constantness = Constantness::Mutable,
|
Mutability _mutability = Mutability::Mutable,
|
||||||
ASTPointer<OverrideSpecifier> const& _overrides = nullptr,
|
ASTPointer<OverrideSpecifier> const& _overrides = nullptr,
|
||||||
Location _referenceLocation = Location::Unspecified
|
Location _referenceLocation = Location::Unspecified
|
||||||
):
|
):
|
||||||
@ -874,7 +884,7 @@ public:
|
|||||||
m_value(_value),
|
m_value(_value),
|
||||||
m_isStateVariable(_isStateVar),
|
m_isStateVariable(_isStateVar),
|
||||||
m_isIndexed(_isIndexed),
|
m_isIndexed(_isIndexed),
|
||||||
m_constantness(_constantness),
|
m_mutability(_mutability),
|
||||||
m_overrides(_overrides),
|
m_overrides(_overrides),
|
||||||
m_location(_referenceLocation) {}
|
m_location(_referenceLocation) {}
|
||||||
|
|
||||||
@ -918,8 +928,9 @@ public:
|
|||||||
bool hasReferenceOrMappingType() const;
|
bool hasReferenceOrMappingType() const;
|
||||||
bool isStateVariable() const { return m_isStateVariable; }
|
bool isStateVariable() const { return m_isStateVariable; }
|
||||||
bool isIndexed() const { return m_isIndexed; }
|
bool isIndexed() const { return m_isIndexed; }
|
||||||
bool isConstant() const { return m_constantness == Constantness::Constant; }
|
Mutability mutability() const { return m_mutability; }
|
||||||
bool immutable() const { return m_constantness == Constantness::Immutable; }
|
bool isConstant() const { return m_mutability == Mutability::Constant; }
|
||||||
|
bool immutable() const { return m_mutability == Mutability::Immutable; }
|
||||||
ASTPointer<OverrideSpecifier> const& overrides() const { return m_overrides; }
|
ASTPointer<OverrideSpecifier> const& overrides() const { return m_overrides; }
|
||||||
Location referenceLocation() const { return m_location; }
|
Location referenceLocation() const { return m_location; }
|
||||||
/// @returns a set of allowed storage locations for the variable.
|
/// @returns a set of allowed storage locations for the variable.
|
||||||
@ -947,7 +958,7 @@ private:
|
|||||||
bool m_isStateVariable = false; ///< Whether or not this is a contract state variable
|
bool m_isStateVariable = false; ///< Whether or not this is a contract state variable
|
||||||
bool m_isIndexed = false; ///< Whether this is an indexed variable (used by events).
|
bool m_isIndexed = false; ///< Whether this is an indexed variable (used by events).
|
||||||
/// Whether the variable is "constant", "immutable" or non-marked (mutable).
|
/// Whether the variable is "constant", "immutable" or non-marked (mutable).
|
||||||
Constantness m_constantness = Constantness::Mutable;
|
Mutability m_mutability = Mutability::Mutable;
|
||||||
ASTPointer<OverrideSpecifier> m_overrides; ///< Contains the override specifier node
|
ASTPointer<OverrideSpecifier> m_overrides; ///< Contains the override specifier node
|
||||||
Location m_location = Location::Unspecified; ///< Location of the variable if it is of reference type.
|
Location m_location = Location::Unspecified; ///< Location of the variable if it is of reference type.
|
||||||
};
|
};
|
||||||
|
@ -378,6 +378,7 @@ bool ASTJsonConverter::visit(VariableDeclaration const& _node)
|
|||||||
make_pair("name", _node.name()),
|
make_pair("name", _node.name()),
|
||||||
make_pair("typeName", toJsonOrNull(_node.typeName())),
|
make_pair("typeName", toJsonOrNull(_node.typeName())),
|
||||||
make_pair("constant", _node.isConstant()),
|
make_pair("constant", _node.isConstant()),
|
||||||
|
make_pair("mutability", VariableDeclaration::mutabilityToString(_node.mutability())),
|
||||||
make_pair("stateVariable", _node.isStateVariable()),
|
make_pair("stateVariable", _node.isStateVariable()),
|
||||||
make_pair("storageLocation", location(_node.referenceLocation())),
|
make_pair("storageLocation", location(_node.referenceLocation())),
|
||||||
make_pair("overrides", _node.overrides() ? toJson(*_node.overrides()) : Json::nullValue),
|
make_pair("overrides", _node.overrides() ? toJson(*_node.overrides()) : Json::nullValue),
|
||||||
|
@ -411,11 +411,24 @@ ASTPointer<VariableDeclaration> ASTJsonImporter::createVariableDeclaration(Json:
|
|||||||
{
|
{
|
||||||
astAssert(_node["name"].isString(), "Expected 'name' to be a string!");
|
astAssert(_node["name"].isString(), "Expected 'name' to be a string!");
|
||||||
|
|
||||||
VariableDeclaration::Constantness constantness{};
|
VariableDeclaration::Mutability mutability{};
|
||||||
if (memberAsBool(_node, "constant"))
|
astAssert(member(_node, "mutability").isString(), "'mutability' expected to be string.");
|
||||||
constantness = VariableDeclaration::Constantness::Constant;
|
string const mutabilityStr = member(_node, "mutability").asString();
|
||||||
|
if (mutabilityStr == "constant")
|
||||||
|
{
|
||||||
|
mutability = VariableDeclaration::Mutability::Constant;
|
||||||
|
astAssert(memberAsBool(_node, "constant"), "");
|
||||||
|
}
|
||||||
else
|
else
|
||||||
constantness = VariableDeclaration::Constantness::Mutable;
|
{
|
||||||
|
astAssert(!memberAsBool(_node, "constant"), "");
|
||||||
|
if (mutabilityStr == "mutable")
|
||||||
|
mutability = VariableDeclaration::Mutability::Mutable;
|
||||||
|
else if (mutabilityStr == "immutable")
|
||||||
|
mutability = VariableDeclaration::Mutability::Immutable;
|
||||||
|
else
|
||||||
|
astAssert(false, "");
|
||||||
|
}
|
||||||
|
|
||||||
return createASTNode<VariableDeclaration>(
|
return createASTNode<VariableDeclaration>(
|
||||||
_node,
|
_node,
|
||||||
@ -425,7 +438,7 @@ ASTPointer<VariableDeclaration> ASTJsonImporter::createVariableDeclaration(Json:
|
|||||||
visibility(_node),
|
visibility(_node),
|
||||||
memberAsBool(_node, "stateVariable"),
|
memberAsBool(_node, "stateVariable"),
|
||||||
_node.isMember("indexed") ? memberAsBool(_node, "indexed") : false,
|
_node.isMember("indexed") ? memberAsBool(_node, "indexed") : false,
|
||||||
constantness,
|
mutability,
|
||||||
_node["overrides"].isNull() ? nullptr : createOverrideSpecifier(member(_node, "overrides")),
|
_node["overrides"].isNull() ? nullptr : createOverrideSpecifier(member(_node, "overrides")),
|
||||||
location(_node)
|
location(_node)
|
||||||
);
|
);
|
||||||
|
@ -695,7 +695,7 @@ ASTPointer<VariableDeclaration> Parser::parseVariableDeclaration(
|
|||||||
);
|
);
|
||||||
|
|
||||||
bool isIndexed = false;
|
bool isIndexed = false;
|
||||||
VariableDeclaration::Constantness constantness = VariableDeclaration::Constantness::Mutable;
|
VariableDeclaration::Mutability mutability = VariableDeclaration::Mutability::Mutable;
|
||||||
ASTPointer<OverrideSpecifier> overrides = nullptr;
|
ASTPointer<OverrideSpecifier> overrides = nullptr;
|
||||||
Visibility visibility(Visibility::Default);
|
Visibility visibility(Visibility::Default);
|
||||||
VariableDeclaration::Location location = VariableDeclaration::Location::Unspecified;
|
VariableDeclaration::Location location = VariableDeclaration::Location::Unspecified;
|
||||||
@ -732,15 +732,15 @@ ASTPointer<VariableDeclaration> Parser::parseVariableDeclaration(
|
|||||||
isIndexed = true;
|
isIndexed = true;
|
||||||
else if (token == Token::Constant || token == Token::Immutable)
|
else if (token == Token::Constant || token == Token::Immutable)
|
||||||
{
|
{
|
||||||
if (constantness != VariableDeclaration::Constantness::Mutable)
|
if (mutability != VariableDeclaration::Mutability::Mutable)
|
||||||
parserError(
|
parserError(
|
||||||
string("Constantness already set to ") +
|
string("Mutability already set to ") +
|
||||||
(constantness == VariableDeclaration::Constantness::Constant ? "\"constant\"" : "\"immutable\"")
|
(mutability == VariableDeclaration::Mutability::Constant ? "\"constant\"" : "\"immutable\"")
|
||||||
);
|
);
|
||||||
else if (token == Token::Constant)
|
else if (token == Token::Constant)
|
||||||
constantness = VariableDeclaration::Constantness::Constant;
|
mutability = VariableDeclaration::Mutability::Constant;
|
||||||
else if (token == Token::Immutable)
|
else if (token == Token::Immutable)
|
||||||
constantness = VariableDeclaration::Constantness::Immutable;
|
mutability = VariableDeclaration::Mutability::Immutable;
|
||||||
}
|
}
|
||||||
else if (_options.allowLocationSpecifier && TokenTraits::isLocationSpecifier(token))
|
else if (_options.allowLocationSpecifier && TokenTraits::isLocationSpecifier(token))
|
||||||
{
|
{
|
||||||
@ -800,7 +800,7 @@ ASTPointer<VariableDeclaration> Parser::parseVariableDeclaration(
|
|||||||
visibility,
|
visibility,
|
||||||
_options.isStateVariable,
|
_options.isStateVariable,
|
||||||
isIndexed,
|
isIndexed,
|
||||||
constantness,
|
mutability,
|
||||||
overrides,
|
overrides,
|
||||||
location
|
location
|
||||||
);
|
);
|
||||||
|
@ -160,6 +160,7 @@ JSON AST:
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "",
|
"name": "",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 17,
|
"scope": 17,
|
||||||
|
@ -31,6 +31,7 @@
|
|||||||
"constant": false,
|
"constant": false,
|
||||||
"functionSelector": "97682884",
|
"functionSelector": "97682884",
|
||||||
"id": 4,
|
"id": 4,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "m",
|
"name": "m",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
@ -100,6 +101,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 12,
|
"id": 12,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "a",
|
"name": "a",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
@ -241,6 +243,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 22,
|
"id": 22,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "c",
|
"name": "c",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
@ -507,6 +510,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 6,
|
"id": 6,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "arg",
|
"name": "arg",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
@ -547,6 +551,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 9,
|
"id": 9,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "r",
|
"name": "r",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -41,6 +41,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"functionSelector": "97682884",
|
"functionSelector": "97682884",
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "m",
|
"name": "m",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 39,
|
"scope": 39,
|
||||||
@ -118,6 +119,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "arg",
|
"name": "arg",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 38,
|
"scope": 38,
|
||||||
@ -157,6 +159,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "r",
|
"name": "r",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 38,
|
"scope": 38,
|
||||||
@ -206,6 +209,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "a",
|
"name": "a",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 37,
|
"scope": 37,
|
||||||
@ -359,6 +363,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "c",
|
"name": "c",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 37,
|
"scope": 37,
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 3,
|
"id": 3,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "i",
|
"name": "i",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -40,6 +40,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "i",
|
"name": "i",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 4,
|
"scope": 4,
|
||||||
|
@ -121,6 +121,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 3,
|
"id": 3,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "x",
|
"name": "x",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -77,6 +77,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "x",
|
"name": "x",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 7,
|
"scope": 7,
|
||||||
|
@ -35,6 +35,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 2,
|
"id": 2,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "x",
|
"name": "x",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
@ -72,6 +73,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 5,
|
"id": 5,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "s",
|
"name": "s",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -50,6 +50,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "x",
|
"name": "x",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 3,
|
"scope": 3,
|
||||||
@ -85,6 +86,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "s",
|
"name": "s",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 11,
|
"scope": 11,
|
||||||
|
@ -45,6 +45,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 4,
|
"id": 4,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "x",
|
"name": "x",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -101,6 +101,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "x",
|
"name": "x",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 7,
|
"scope": 7,
|
||||||
|
@ -53,6 +53,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 6,
|
"id": 6,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "x",
|
"name": "x",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
@ -85,6 +86,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 3,
|
"id": 3,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "",
|
"name": "",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
@ -139,6 +141,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 13,
|
"id": 13,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "",
|
"name": "",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
@ -171,6 +174,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 10,
|
"id": 10,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "",
|
"name": "",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -64,6 +64,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "x",
|
"name": "x",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 16,
|
"scope": 16,
|
||||||
@ -104,6 +105,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "",
|
"name": "",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 5,
|
"scope": 5,
|
||||||
@ -157,6 +159,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "",
|
"name": "",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 16,
|
"scope": 16,
|
||||||
@ -197,6 +200,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "",
|
"name": "",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 12,
|
"scope": 12,
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 2,
|
"id": 2,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "a",
|
"name": "a",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "a",
|
"name": "a",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 3,
|
"scope": 3,
|
||||||
|
@ -45,6 +45,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 4,
|
"id": 4,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "a",
|
"name": "a",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -100,6 +100,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "a",
|
"name": "a",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 9,
|
"scope": 9,
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 3,
|
"id": 3,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "a",
|
"name": "a",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
@ -87,6 +88,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 10,
|
"id": 10,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "b",
|
"name": "b",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -40,6 +40,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "a",
|
"name": "a",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 15,
|
"scope": 15,
|
||||||
@ -143,6 +144,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "b",
|
"name": "b",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 13,
|
"scope": 13,
|
||||||
|
@ -58,6 +58,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 8,
|
"id": 8,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "a",
|
"name": "a",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
@ -113,6 +114,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 12,
|
"id": 12,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "b",
|
"name": "b",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
@ -166,6 +168,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 16,
|
"id": 16,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "c",
|
"name": "c",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -80,6 +80,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "a",
|
"name": "a",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 17,
|
"scope": 17,
|
||||||
@ -134,6 +135,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "b",
|
"name": "b",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 17,
|
"scope": 17,
|
||||||
@ -186,6 +188,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "c",
|
"name": "c",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 17,
|
"scope": 17,
|
||||||
|
@ -56,6 +56,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 2,
|
"id": 2,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "i",
|
"name": "i",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -54,6 +54,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "i",
|
"name": "i",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 6,
|
"scope": 6,
|
||||||
|
@ -56,6 +56,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 2,
|
"id": 2,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "i",
|
"name": "i",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -54,6 +54,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "i",
|
"name": "i",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 6,
|
"scope": 6,
|
||||||
|
189
test/libsolidity/ASTJSON/mutability.json
Normal file
189
test/libsolidity/ASTJSON/mutability.json
Normal file
@ -0,0 +1,189 @@
|
|||||||
|
{
|
||||||
|
"absolutePath": "a",
|
||||||
|
"exportedSymbols":
|
||||||
|
{
|
||||||
|
"C":
|
||||||
|
[
|
||||||
|
10
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"id": 11,
|
||||||
|
"nodeType": "SourceUnit",
|
||||||
|
"nodes":
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"abstract": false,
|
||||||
|
"baseContracts": [],
|
||||||
|
"contractDependencies": [],
|
||||||
|
"contractKind": "contract",
|
||||||
|
"documentation": null,
|
||||||
|
"fullyImplemented": true,
|
||||||
|
"id": 10,
|
||||||
|
"linearizedBaseContracts":
|
||||||
|
[
|
||||||
|
10
|
||||||
|
],
|
||||||
|
"name": "C",
|
||||||
|
"nodeType": "ContractDefinition",
|
||||||
|
"nodes":
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"constant": false,
|
||||||
|
"functionSelector": "0dbe671f",
|
||||||
|
"id": 3,
|
||||||
|
"mutability": "immutable",
|
||||||
|
"name": "a",
|
||||||
|
"nodeType": "VariableDeclaration",
|
||||||
|
"overrides": null,
|
||||||
|
"scope": 10,
|
||||||
|
"src": "17:27:1",
|
||||||
|
"stateVariable": true,
|
||||||
|
"storageLocation": "default",
|
||||||
|
"typeDescriptions":
|
||||||
|
{
|
||||||
|
"typeIdentifier": "t_uint256",
|
||||||
|
"typeString": "uint256"
|
||||||
|
},
|
||||||
|
"typeName":
|
||||||
|
{
|
||||||
|
"id": 1,
|
||||||
|
"name": "uint",
|
||||||
|
"nodeType": "ElementaryTypeName",
|
||||||
|
"src": "17:4:1",
|
||||||
|
"typeDescriptions":
|
||||||
|
{
|
||||||
|
"typeIdentifier": "t_uint256",
|
||||||
|
"typeString": "uint256"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value":
|
||||||
|
{
|
||||||
|
"argumentTypes": null,
|
||||||
|
"hexValue": "34",
|
||||||
|
"id": 2,
|
||||||
|
"isConstant": false,
|
||||||
|
"isLValue": false,
|
||||||
|
"isPure": true,
|
||||||
|
"kind": "number",
|
||||||
|
"lValueRequested": false,
|
||||||
|
"nodeType": "Literal",
|
||||||
|
"src": "43:1:1",
|
||||||
|
"subdenomination": null,
|
||||||
|
"typeDescriptions":
|
||||||
|
{
|
||||||
|
"typeIdentifier": "t_rational_4_by_1",
|
||||||
|
"typeString": "int_const 4"
|
||||||
|
},
|
||||||
|
"value": "4"
|
||||||
|
},
|
||||||
|
"visibility": "public"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"constant": true,
|
||||||
|
"functionSelector": "4df7e3d0",
|
||||||
|
"id": 6,
|
||||||
|
"mutability": "constant",
|
||||||
|
"name": "b",
|
||||||
|
"nodeType": "VariableDeclaration",
|
||||||
|
"overrides": null,
|
||||||
|
"scope": 10,
|
||||||
|
"src": "50:26:1",
|
||||||
|
"stateVariable": true,
|
||||||
|
"storageLocation": "default",
|
||||||
|
"typeDescriptions":
|
||||||
|
{
|
||||||
|
"typeIdentifier": "t_uint256",
|
||||||
|
"typeString": "uint256"
|
||||||
|
},
|
||||||
|
"typeName":
|
||||||
|
{
|
||||||
|
"id": 4,
|
||||||
|
"name": "uint",
|
||||||
|
"nodeType": "ElementaryTypeName",
|
||||||
|
"src": "50:4:1",
|
||||||
|
"typeDescriptions":
|
||||||
|
{
|
||||||
|
"typeIdentifier": "t_uint256",
|
||||||
|
"typeString": "uint256"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value":
|
||||||
|
{
|
||||||
|
"argumentTypes": null,
|
||||||
|
"hexValue": "32",
|
||||||
|
"id": 5,
|
||||||
|
"isConstant": false,
|
||||||
|
"isLValue": false,
|
||||||
|
"isPure": true,
|
||||||
|
"kind": "number",
|
||||||
|
"lValueRequested": false,
|
||||||
|
"nodeType": "Literal",
|
||||||
|
"src": "75:1:1",
|
||||||
|
"subdenomination": null,
|
||||||
|
"typeDescriptions":
|
||||||
|
{
|
||||||
|
"typeIdentifier": "t_rational_2_by_1",
|
||||||
|
"typeString": "int_const 2"
|
||||||
|
},
|
||||||
|
"value": "2"
|
||||||
|
},
|
||||||
|
"visibility": "public"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"constant": false,
|
||||||
|
"functionSelector": "c3da42b8",
|
||||||
|
"id": 9,
|
||||||
|
"mutability": "mutable",
|
||||||
|
"name": "c",
|
||||||
|
"nodeType": "VariableDeclaration",
|
||||||
|
"overrides": null,
|
||||||
|
"scope": 10,
|
||||||
|
"src": "82:17:1",
|
||||||
|
"stateVariable": true,
|
||||||
|
"storageLocation": "default",
|
||||||
|
"typeDescriptions":
|
||||||
|
{
|
||||||
|
"typeIdentifier": "t_uint256",
|
||||||
|
"typeString": "uint256"
|
||||||
|
},
|
||||||
|
"typeName":
|
||||||
|
{
|
||||||
|
"id": 7,
|
||||||
|
"name": "uint",
|
||||||
|
"nodeType": "ElementaryTypeName",
|
||||||
|
"src": "82:4:1",
|
||||||
|
"typeDescriptions":
|
||||||
|
{
|
||||||
|
"typeIdentifier": "t_uint256",
|
||||||
|
"typeString": "uint256"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"value":
|
||||||
|
{
|
||||||
|
"argumentTypes": null,
|
||||||
|
"hexValue": "33",
|
||||||
|
"id": 8,
|
||||||
|
"isConstant": false,
|
||||||
|
"isLValue": false,
|
||||||
|
"isPure": true,
|
||||||
|
"kind": "number",
|
||||||
|
"lValueRequested": false,
|
||||||
|
"nodeType": "Literal",
|
||||||
|
"src": "98:1:1",
|
||||||
|
"subdenomination": null,
|
||||||
|
"typeDescriptions":
|
||||||
|
{
|
||||||
|
"typeIdentifier": "t_rational_3_by_1",
|
||||||
|
"typeString": "int_const 3"
|
||||||
|
},
|
||||||
|
"value": "3"
|
||||||
|
},
|
||||||
|
"visibility": "public"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"scope": 11,
|
||||||
|
"src": "0:102:1"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"src": "0:103:1"
|
||||||
|
}
|
8
test/libsolidity/ASTJSON/mutability.sol
Normal file
8
test/libsolidity/ASTJSON/mutability.sol
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
contract C
|
||||||
|
{
|
||||||
|
uint public immutable a = 4;
|
||||||
|
uint public constant b = 2;
|
||||||
|
uint public c = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----
|
195
test/libsolidity/ASTJSON/mutability_legacy.json
Normal file
195
test/libsolidity/ASTJSON/mutability_legacy.json
Normal file
@ -0,0 +1,195 @@
|
|||||||
|
{
|
||||||
|
"attributes":
|
||||||
|
{
|
||||||
|
"absolutePath": "a",
|
||||||
|
"exportedSymbols":
|
||||||
|
{
|
||||||
|
"C":
|
||||||
|
[
|
||||||
|
10
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"children":
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"attributes":
|
||||||
|
{
|
||||||
|
"abstract": false,
|
||||||
|
"baseContracts":
|
||||||
|
[
|
||||||
|
null
|
||||||
|
],
|
||||||
|
"contractDependencies":
|
||||||
|
[
|
||||||
|
null
|
||||||
|
],
|
||||||
|
"contractKind": "contract",
|
||||||
|
"documentation": null,
|
||||||
|
"fullyImplemented": true,
|
||||||
|
"linearizedBaseContracts":
|
||||||
|
[
|
||||||
|
10
|
||||||
|
],
|
||||||
|
"name": "C",
|
||||||
|
"scope": 11
|
||||||
|
},
|
||||||
|
"children":
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"attributes":
|
||||||
|
{
|
||||||
|
"constant": false,
|
||||||
|
"functionSelector": "0dbe671f",
|
||||||
|
"mutability": "immutable",
|
||||||
|
"name": "a",
|
||||||
|
"overrides": null,
|
||||||
|
"scope": 10,
|
||||||
|
"stateVariable": true,
|
||||||
|
"storageLocation": "default",
|
||||||
|
"type": "uint256",
|
||||||
|
"visibility": "public"
|
||||||
|
},
|
||||||
|
"children":
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"attributes":
|
||||||
|
{
|
||||||
|
"name": "uint",
|
||||||
|
"type": "uint256"
|
||||||
|
},
|
||||||
|
"id": 1,
|
||||||
|
"name": "ElementaryTypeName",
|
||||||
|
"src": "17:4:1"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"attributes":
|
||||||
|
{
|
||||||
|
"argumentTypes": null,
|
||||||
|
"hexvalue": "34",
|
||||||
|
"isConstant": false,
|
||||||
|
"isLValue": false,
|
||||||
|
"isPure": true,
|
||||||
|
"lValueRequested": false,
|
||||||
|
"subdenomination": null,
|
||||||
|
"token": "number",
|
||||||
|
"type": "int_const 4",
|
||||||
|
"value": "4"
|
||||||
|
},
|
||||||
|
"id": 2,
|
||||||
|
"name": "Literal",
|
||||||
|
"src": "43:1:1"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"id": 3,
|
||||||
|
"name": "VariableDeclaration",
|
||||||
|
"src": "17:27:1"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"attributes":
|
||||||
|
{
|
||||||
|
"constant": true,
|
||||||
|
"functionSelector": "4df7e3d0",
|
||||||
|
"mutability": "constant",
|
||||||
|
"name": "b",
|
||||||
|
"overrides": null,
|
||||||
|
"scope": 10,
|
||||||
|
"stateVariable": true,
|
||||||
|
"storageLocation": "default",
|
||||||
|
"type": "uint256",
|
||||||
|
"visibility": "public"
|
||||||
|
},
|
||||||
|
"children":
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"attributes":
|
||||||
|
{
|
||||||
|
"name": "uint",
|
||||||
|
"type": "uint256"
|
||||||
|
},
|
||||||
|
"id": 4,
|
||||||
|
"name": "ElementaryTypeName",
|
||||||
|
"src": "50:4:1"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"attributes":
|
||||||
|
{
|
||||||
|
"argumentTypes": null,
|
||||||
|
"hexvalue": "32",
|
||||||
|
"isConstant": false,
|
||||||
|
"isLValue": false,
|
||||||
|
"isPure": true,
|
||||||
|
"lValueRequested": false,
|
||||||
|
"subdenomination": null,
|
||||||
|
"token": "number",
|
||||||
|
"type": "int_const 2",
|
||||||
|
"value": "2"
|
||||||
|
},
|
||||||
|
"id": 5,
|
||||||
|
"name": "Literal",
|
||||||
|
"src": "75:1:1"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"id": 6,
|
||||||
|
"name": "VariableDeclaration",
|
||||||
|
"src": "50:26:1"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"attributes":
|
||||||
|
{
|
||||||
|
"constant": false,
|
||||||
|
"functionSelector": "c3da42b8",
|
||||||
|
"mutability": "mutable",
|
||||||
|
"name": "c",
|
||||||
|
"overrides": null,
|
||||||
|
"scope": 10,
|
||||||
|
"stateVariable": true,
|
||||||
|
"storageLocation": "default",
|
||||||
|
"type": "uint256",
|
||||||
|
"visibility": "public"
|
||||||
|
},
|
||||||
|
"children":
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"attributes":
|
||||||
|
{
|
||||||
|
"name": "uint",
|
||||||
|
"type": "uint256"
|
||||||
|
},
|
||||||
|
"id": 7,
|
||||||
|
"name": "ElementaryTypeName",
|
||||||
|
"src": "82:4:1"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"attributes":
|
||||||
|
{
|
||||||
|
"argumentTypes": null,
|
||||||
|
"hexvalue": "33",
|
||||||
|
"isConstant": false,
|
||||||
|
"isLValue": false,
|
||||||
|
"isPure": true,
|
||||||
|
"lValueRequested": false,
|
||||||
|
"subdenomination": null,
|
||||||
|
"token": "number",
|
||||||
|
"type": "int_const 3",
|
||||||
|
"value": "3"
|
||||||
|
},
|
||||||
|
"id": 8,
|
||||||
|
"name": "Literal",
|
||||||
|
"src": "98:1:1"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"id": 9,
|
||||||
|
"name": "VariableDeclaration",
|
||||||
|
"src": "82:17:1"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"id": 10,
|
||||||
|
"name": "ContractDefinition",
|
||||||
|
"src": "0:102:1"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"id": 11,
|
||||||
|
"name": "SourceUnit",
|
||||||
|
"src": "0:103:1"
|
||||||
|
}
|
@ -45,6 +45,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 3,
|
"id": 3,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "x",
|
"name": "x",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -100,6 +100,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "x",
|
"name": "x",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 6,
|
"scope": 6,
|
||||||
|
@ -45,6 +45,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 7,
|
"id": 7,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "x",
|
"name": "x",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -101,6 +101,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "x",
|
"name": "x",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 9,
|
"scope": 9,
|
||||||
|
@ -45,6 +45,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 8,
|
"id": 8,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "rows",
|
"name": "rows",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -101,6 +101,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "rows",
|
"name": "rows",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 10,
|
"scope": 10,
|
||||||
|
@ -45,6 +45,7 @@
|
|||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
"id": 3,
|
"id": 3,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "x",
|
"name": "x",
|
||||||
"nodeType": "VariableDeclaration",
|
"nodeType": "VariableDeclaration",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
|
@ -100,6 +100,7 @@
|
|||||||
"attributes":
|
"attributes":
|
||||||
{
|
{
|
||||||
"constant": false,
|
"constant": false,
|
||||||
|
"mutability": "mutable",
|
||||||
"name": "x",
|
"name": "x",
|
||||||
"overrides": null,
|
"overrides": null,
|
||||||
"scope": 9,
|
"scope": 9,
|
||||||
|
@ -3,5 +3,5 @@ contract C {
|
|||||||
uint immutable constant x;
|
uint immutable constant x;
|
||||||
}
|
}
|
||||||
// ----
|
// ----
|
||||||
// ParserError: (32-41): Constantness already set to "immutable"
|
// ParserError: (32-41): Mutability already set to "immutable"
|
||||||
// ParserError: (64-72): Constantness already set to "immutable"
|
// ParserError: (64-72): Mutability already set to "immutable"
|
||||||
|
Loading…
Reference in New Issue
Block a user