Fixes bug where prev_mapping was not being set when file_id == 1

pull/281/head
rajeevgopalakrishna 6 years ago
parent 209d3a31af
commit 5434e6e11f
  1. 6
      slither/evm/convert.py

@ -93,6 +93,9 @@ def _generate_source_to_evm_ins_mapping(evm_instructions, srcmap_runtime, slithe
for idx, mapping in enumerate(srcmap_runtime):
# Parse srcmap_runtime according to its format
# See https://solidity.readthedocs.io/en/v0.5.9/miscellaneous.html#source-mappings
# In order to compress these source mappings especially for bytecode, the following rules are used:
# If a field is empty, the value of the preceding element is used.
# If a : is missing, all following fields are considered empty.
mapping_item = mapping.split(':')
mapping_item += prev_mapping[len(mapping_item):]
@ -102,6 +105,7 @@ def _generate_source_to_evm_ins_mapping(evm_instructions, srcmap_runtime, slithe
mapping_item[i] = int(prev_mapping[i])
offset, length, file_id, _ = mapping_item
prev_mapping = mapping_item
if file_id == '-1':
# Internal compiler-generated code snippets to be ignored
@ -116,6 +120,4 @@ def _generate_source_to_evm_ins_mapping(evm_instructions, srcmap_runtime, slithe
# Note: The order depends on how solc creates the srcmap_runtime
source_to_evm_mapping.setdefault(line_number, []).append(evm_instructions[idx].pc)
prev_mapping = mapping_item
return(source_to_evm_mapping)

Loading…
Cancel
Save