diff options
author | Alex Beregszaszi <alex@rtfs.hu> | 2017-06-22 07:43:01 +0800 |
---|---|---|
committer | Alex Beregszaszi <alex@rtfs.hu> | 2017-06-23 09:52:44 +0800 |
commit | af57c083f2aa144e765a7345f15713330b192e36 (patch) | |
tree | b0c36e96f70704090fa3211eca09d56bad3b0e18 /liblll | |
parent | 1ffe286a81b9bad005cfefa3fc8672aecb0ec0f8 (diff) | |
download | dexon-solidity-af57c083f2aa144e765a7345f15713330b192e36.tar.gz dexon-solidity-af57c083f2aa144e765a7345f15713330b192e36.tar.zst dexon-solidity-af57c083f2aa144e765a7345f15713330b192e36.zip |
LLL: fix the set keyword (create symbol if not present)
Diffstat (limited to 'liblll')
-rw-r--r-- | liblll/CodeFragment.cpp | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/liblll/CodeFragment.cpp b/liblll/CodeFragment.cpp index eeb64270..7496fe83 100644 --- a/liblll/CodeFragment.cpp +++ b/liblll/CodeFragment.cpp @@ -171,13 +171,23 @@ void CodeFragment::constructOperation(sp::utree const& _t, CompilerState& _s) return string(); }; - auto varAddress = [&](string const& n) + auto varAddress = [&](string const& n, bool createMissing = false) { if (n.empty()) error<InvalidName>("Empty variable name not allowed"); auto it = _s.vars.find(n); if (it == _s.vars.end()) - error<InvalidName>(std::string("Symbol not found: ") + n); + { + if (createMissing) + { + // Create new variable + bool ok; + tie(it, ok) = _s.vars.insert(make_pair(n, make_pair(_s.stackSize, 32))); + _s.stackSize += 32; + } + else + error<InvalidName>(std::string("Symbol not found: ") + n); + } return it->second.first; }; @@ -210,7 +220,7 @@ void CodeFragment::constructOperation(sp::utree const& _t, CompilerState& _s) for (auto const& i: _t) if (c++ == 2) m_asm.append(CodeFragment(i, _s, false).m_asm); - m_asm.append((u256)varAddress(firstAsString())); + m_asm.append((u256)varAddress(firstAsString(), true)); m_asm.append(Instruction::MSTORE); } else if (us == "GET") |