aboutsummaryrefslogtreecommitdiffstats
path: root/CompilerContext.cpp
diff options
context:
space:
mode:
authorLefteris Karapetsas <lefteris@refu.co>2015-02-23 23:31:36 +0800
committerLefteris Karapetsas <lefteris@refu.co>2015-02-25 00:16:22 +0800
commit38cb123a82dfa0d77c7eb629dfb9307463548a12 (patch)
tree3f3ecdcdcf40dc7b0affbf72f22adc55ae38ff1b /CompilerContext.cpp
parent820ed2dfe17d93a586ba1519333bbe79cc6b9a9c (diff)
downloaddexon-solidity-38cb123a82dfa0d77c7eb629dfb9307463548a12.tar
dexon-solidity-38cb123a82dfa0d77c7eb629dfb9307463548a12.tar.gz
dexon-solidity-38cb123a82dfa0d77c7eb629dfb9307463548a12.tar.bz2
dexon-solidity-38cb123a82dfa0d77c7eb629dfb9307463548a12.tar.lz
dexon-solidity-38cb123a82dfa0d77c7eb629dfb9307463548a12.tar.xz
dexon-solidity-38cb123a82dfa0d77c7eb629dfb9307463548a12.tar.zst
dexon-solidity-38cb123a82dfa0d77c7eb629dfb9307463548a12.zip
Adding location information to assembly items
- In order to facilitate this addition we also now have a ScopeGuard object used in the Compiler to set the currently visited node.
Diffstat (limited to 'CompilerContext.cpp')
-rw-r--r--CompilerContext.cpp28
1 files changed, 28 insertions, 0 deletions
diff --git a/CompilerContext.cpp b/CompilerContext.cpp
index 8d32a1a5..c599be5e 100644
--- a/CompilerContext.cpp
+++ b/CompilerContext.cpp
@@ -166,5 +166,33 @@ u256 CompilerContext::getStorageLocationOfVariable(const Declaration& _declarati
return it->second;
}
+CompilerContext& CompilerContext::operator<<(eth::AssemblyItem _item)
+{
+ solAssert(m_visitedNodes.size() > 0, "No node on the visited stack");
+ m_asm.append(_item);
+ return *this;
+}
+
+CompilerContext& CompilerContext::operator<<(eth::Instruction _instruction)
+{
+ solAssert(m_visitedNodes.size() > 0, "No node on the visited stack");
+ m_asm.append(_instruction);
+ return *this;
+}
+
+CompilerContext& CompilerContext::operator<<(u256 const& _value)
+{
+ solAssert(m_visitedNodes.size() > 0, "No node on the visited stack");
+ m_asm.append(_value);
+ return *this;
+}
+
+CompilerContext& CompilerContext::operator<<(bytes const& _data)
+{
+ solAssert(m_visitedNodes.size() > 0, "No node on the visited stack");
+ m_asm.append(_data);
+ return *this;
+}
+
}
}