Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
B
baas-ide
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
JIRA
JIRA
Merge Requests
1
Merge Requests
1
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
guxukai
baas-ide
Commits
aec6f8c9
Commit
aec6f8c9
authored
Nov 17, 2016
by
yann300
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix uint, int
parent
7afdc3de
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
135 additions
and
170 deletions
+135
-170
Int.js
src/solidity/types/Int.js
+1
-18
Uint.js
src/solidity/types/Uint.js
+3
-9
util.js
src/solidity/types/util.js
+41
-8
intStorage.js
test/solidity/contracts/intStorage.js
+44
-0
storageDecoder.js
test/solidity/storageDecoder.js
+46
-135
No files found.
src/solidity/types/Int.js
View file @
aec6f8c9
'use strict'
var
util
=
require
(
'./util'
)
var
BN
=
require
(
'ethereumjs-util'
).
BN
var
ethutil
=
require
(
'ethereumjs-util'
)
function
Int
(
storageBytes
)
{
this
.
storageSlots
=
1
...
...
@@ -10,22 +8,7 @@ function Int (storageBytes) {
}
Int
.
prototype
.
decodeFromStorage
=
function
(
location
,
storageContent
)
{
var
slot
=
ethutil
.
bufferToHex
(
ethutil
.
setLengthLeft
(
location
.
slot
,
32
))
if
(
!
storageContent
[
slot
])
{
return
'0'
}
var
value
=
util
.
extractValue
(
storageContent
[
slot
],
this
.
storageBytes
,
location
)
var
bigNumber
=
new
BN
(
value
.
replace
(
'0x'
,
''
),
16
)
if
(
isNegative
(
bigNumber
,
this
.
storageBytes
))
{
return
ethutil
.
fromSigned
(
ethutil
.
toUnsigned
(
bigNumber
)).
toString
(
10
)
}
else
{
return
bigNumber
.
toString
(
10
)
}
return
util
.
decodeInt
(
location
,
storageContent
,
this
.
storageBytes
)
}
module
.
exports
=
Int
function
isNegative
(
value
,
storageBytes
)
{
var
binary
=
value
.
toString
(
2
)
return
binary
.
length
<
storageBytes
?
false
:
binary
[
0
]
===
'1'
}
src/solidity/types/Uint.js
View file @
aec6f8c9
'use strict'
var
IntType
=
require
(
'./Int'
)
var
util
=
require
(
'./util'
)
var
ethutil
=
require
(
'ethereumjs-util'
)
var
BN
=
require
(
'ethereumjs-util'
).
BN
function
Uint
(
storageBytes
)
{
this
.
storageSlots
=
1
this
.
storageBytes
=
storageBytes
this
.
typeName
=
'uint'
this
.
decodeInt
=
new
IntType
(
storageBytes
)
}
Uint
.
prototype
.
decodeFromStorage
=
function
(
location
,
storageContent
)
{
var
slot
=
ethutil
.
bufferToHex
(
ethutil
.
setLengthLeft
(
location
.
slot
,
32
))
if
(
!
storageContent
[
slot
])
{
return
'0'
}
var
value
=
util
.
extractValue
(
storageContent
[
slot
],
this
.
storageBytes
,
location
)
var
bigNumber
=
new
BN
(
value
.
replace
(
'0x'
,
''
),
16
)
return
bigNumber
.
toString
(
10
)
return
util
.
decodeInt
(
location
,
storageContent
,
this
.
storageBytes
)
}
module
.
exports
=
Uint
src/solidity/types/util.js
View file @
aec6f8c9
'use strict'
var
ethutil
=
require
(
'ethereumjs-util'
)
var
BN
=
require
(
'ethereumjs-util'
).
BN
module
.
exports
=
{
extractValue
:
function
(
slotValue
,
storageBytes
,
location
)
{
slotValue
=
slotValue
.
replace
(
'0x'
,
''
)
var
offset
=
slotValue
.
length
-
2
*
location
.
offset
-
storageBytes
/
4
if
(
offset
>=
0
)
{
return
'0x'
+
slotValue
.
substr
(
offset
,
storageBytes
/
4
)
}
else
if
(
offset
+
storageBytes
>
0
)
{
return
'0x'
+
slotValue
.
substr
(
0
,
storageBytes
/
4
+
offset
)
extractHexByteSlice
:
extractHexByteSlice
,
extractSlotValue
:
extractSlotValue
,
decodeInt
:
decodeInt
}
function
decodeInt
(
location
,
storageContent
,
byteLength
)
{
var
slotvalue
=
extractSlotValue
(
location
.
slot
,
storageContent
)
if
(
slotvalue
===
null
)
{
return
'0'
}
var
value
=
extractHexByteSlice
(
slotvalue
,
byteLength
,
location
.
offset
)
var
bigNumber
=
new
BN
(
value
,
16
)
bigNumber
=
bigNumber
.
fromTwos
(
8
*
byteLength
)
return
bigNumber
.
toString
(
10
)
}
function
extractSlotValue
(
slot
,
storageContent
)
{
var
hexSlot
=
ethutil
.
bufferToHex
(
slot
)
if
(
storageContent
[
hexSlot
]
!==
undefined
)
{
return
storageContent
[
hexSlot
]
}
else
{
hexSlot
=
ethutil
.
bufferToHex
(
ethutil
.
setLengthLeft
(
slot
,
32
))
if
(
storageContent
[
hexSlot
])
{
return
storageContent
[
hexSlot
]
}
else
{
return
'0x0'
return
null
}
}
}
function
extractHexByteSlice
(
slotValue
,
byteLength
,
offsetFromLSB
)
{
if
(
slotValue
===
undefined
)
{
slotValue
=
'0'
}
slotValue
=
slotValue
.
replace
(
'0x'
,
''
)
if
(
slotValue
.
length
<
64
)
{
slotValue
=
(
new
Array
(
64
-
slotValue
.
length
+
1
).
join
(
'0'
))
+
slotValue
}
var
offset
=
slotValue
.
length
-
2
*
offsetFromLSB
-
2
*
byteLength
return
slotValue
.
substr
(
offset
,
2
*
byteLength
)
}
test/solidity/contracts/intStorage.js
0 → 100644
View file @
aec6f8c9
'use strict'
module
.
exports
=
{
contract
:
`
contract intStorage {
uint8 ui8 = 123;
uint16 ui16 = 456;
uint32 ui32 = 4356;
uint64 ui64 = 3543543543;
uint128 ui128 = 234567;
uint256 ui256 = 234566666656;
uint ui = 123545666;
int8 i8 = -45;
int16 i16 = -1234;
int32 i32 = 3455;
int64 i64 = -35566;
int128 i128 = -444444;
int256 i256 = 3434343;
int i = -32432423423;
int32 ishrink = 2;
function intStorage () {
}
}
`
,
fullStorage
:
{
'0x0000000000000000000000000000000000000000000000000000000000000000'
:
'0x000000000000000000000000000003944700000000d3362ef70000110401c87b'
,
'0x0000000000000000000000000000000000000000000000000000000000000001'
:
'0x000000000000000000000000000000000000000000000000000000369d4349a0'
,
'0x0000000000000000000000000000000000000000000000000000000000000002'
:
'0x00000000000000000000000000000000000000000000000000000000075d2842'
,
'0x0000000000000000000000000000000000000000000000000000000000000003'
:
'0x00fffffffffffffffffffffffffff937e4ffffffffffff751200000d7ffb2ed3'
,
'0x0000000000000000000000000000000000000000000000000000000000000004'
:
'0x0000000000000000000000000000000000000000000000000000000000346767'
,
'0x0000000000000000000000000000000000000000000000000000000000000005'
:
'0xfffffffffffffffffffffffffffffffffffffffffffffffffffffff872e07e01'
,
'0x0000000000000000000000000000000000000000000000000000000000000006'
:
'0x0000000000000000000000000000000000000000000000000000000000000002'
},
shrinkedStorage
:
{
'0x00'
:
'0x03944700000000d3362ef70000110401c87b'
,
'0x01'
:
'0x369d4349a0'
,
'0x02'
:
'0x075d2842'
,
'0x03'
:
'0xfffffffffffffffffffffffffff937e4ffffffffffff751200000d7ffb2ed3'
,
'0x04'
:
'0x346767'
,
'0x05'
:
'0xfffffffffffffffffffffffffffffffffffffffffffffffffffffff872e07e01'
,
'0x06'
:
'0x02'
}
}
test/solidity/storageDecoder.js
View file @
aec6f8c9
'use strict'
var
tape
=
require
(
'tape'
)
var
compiler
=
require
(
'solc'
)
var
VM
=
require
(
'ethereumjs-vm'
)
var
Tx
=
require
(
'ethereumjs-tx'
)
var
Block
=
require
(
'ethereumjs-block'
)
var
ethUtil
=
require
(
'ethereumjs-util'
)
var
BN
=
require
(
'ethereumjs-util'
).
BN
var
stateDecoder
=
require
(
'../../src/index'
).
solidity
.
stateDecoder
tape
(
'solidity'
,
function
(
t
)
{
t
.
test
(
'storage decoder'
,
function
(
st
)
{
var
output
=
compiler
.
compile
(
intStorage
,
0
)
var
vm
=
setupVM
()
var
accountPrivateKey
=
new
Buffer
(
'3cd7232cd6f3fc66a57a6bedc1a8ed6c228fff0a327e169c2bcc5e869ed49511'
,
'hex'
)
var
address
=
ethUtil
.
privateToAddress
(
accountPrivateKey
)
vm
.
stateManager
.
putAccountBalance
(
address
,
'f00000000000000001'
,
function
cb
()
{})
var
tx
=
setupTransation
(
null
,
0
,
output
.
contracts
[
'intStorage'
].
bytecode
)
tx
.
sign
(
accountPrivateKey
)
executeTransaction
(
vm
,
tx
,
function
(
error
,
result
)
{
if
(
error
)
{
st
.
end
(
error
)
}
else
{
vm
.
stateManager
.
dumpStorage
(
result
.
createdAddress
,
function
(
storage
)
{
for
(
var
k
in
storage
)
{
if
(
storage
[
k
].
indexOf
(
'a0'
)
===
0
)
{
storage
[
k
]
=
storage
[
k
].
replace
(
'a0'
,
'0x'
)
}
else
{
storage
[
k
]
=
'0x'
+
storage
[
k
]
}
}
var
i
=
0
while
(
i
<
40
)
{
var
strK
=
ethUtil
.
bufferToHex
(
ethUtil
.
setLengthLeft
(
i
,
32
))
var
sha3
=
ethUtil
.
bufferToHex
(
ethUtil
.
sha3
(
strK
)).
replace
(
'0x'
,
''
)
if
(
storage
[
sha3
])
{
storage
[
strK
]
=
storage
[
sha3
]
}
i
++
}
var
decodedState
=
stateDecoder
.
solidityState
(
storage
,
output
.
sources
,
'intStorage'
)
checkDecodedState
(
st
,
decodedState
)
st
.
end
()
})
}
})
testIntStorage
(
st
)
})
})
function
executeTransaction
(
vm
,
tx
,
cb
)
{
var
block
=
new
Block
({
header
:
{
timestamp
:
new
Date
().
getTime
()
/
1000
|
0
},
transactions
:
[],
uncleHeaders
:
[]
})
vm
.
runTx
({
block
:
block
,
tx
:
tx
,
skipBalance
:
true
,
skipNonce
:
true
},
function
(
error
,
result
)
{
cb
(
error
,
result
)
})
}
function
setupVM
()
{
var
vm
=
new
VM
({
enableHomestead
:
true
,
activatePrecompiles
:
true
})
return
vm
}
function
setupTransation
(
to
,
value
,
data
)
{
return
new
Tx
({
nonce
:
new
BN
(
0
),
gasPrice
:
new
BN
(
1
),
gasLimit
:
new
BN
(
3000000
,
10
),
to
:
to
,
value
:
new
BN
(
value
,
10
),
data
:
new
Buffer
(
data
,
'hex'
)
})
}
var
intStorage
=
`
contract intStorage {
uint8 ui8;
uint16 ui16;
uint32 ui32;
uint64 ui64;
uint128 ui128;
uint256 ui256;
uint ui;
int8 i8;
int16 i16;
int32 i32;
int64 i64;
int128 i128;
int256 i256;
int i;
function intStorage () {
ui8 = 0;
ui16 = 0;
ui32 = 0;
ui64 = 0;
ui128 = 2;
ui256 = 0;
ui = 0;
i8 = 0;
i16 = 0;
i32 = 0;
i64 = 0;
i128 = 0;
i256 = 0;
i = 0;
}
}
`
function
checkDecodedState
(
st
,
decoded
)
{
console
.
log
(
JSON
.
stringify
(
decoded
))
function
testIntStorage
(
st
)
{
var
intStorage
=
require
(
'./contracts/intStorage'
)
var
output
=
compiler
.
compile
(
intStorage
.
contract
,
0
)
var
decoded
=
stateDecoder
.
solidityState
(
intStorage
.
fullStorage
,
output
.
sources
,
'intStorage'
)
st
.
equal
(
decoded
[
'ui8'
],
'123'
)
st
.
equal
(
decoded
[
'ui16'
],
'
354
'
)
st
.
equal
(
decoded
[
'ui32'
],
'
1000
'
)
st
.
equal
(
decoded
[
'ui64'
],
'
23456
'
)
st
.
equal
(
decoded
[
'ui16'
],
'
456
'
)
st
.
equal
(
decoded
[
'ui32'
],
'
4356
'
)
st
.
equal
(
decoded
[
'ui64'
],
'
3543543543
'
)
st
.
equal
(
decoded
[
'ui128'
],
'234567'
)
st
.
equal
(
decoded
[
'ui256'
],
'
1234566778
'
)
st
.
equal
(
decoded
[
'ui256'
],
'
234566666656
'
)
st
.
equal
(
decoded
[
'ui'
],
'123545666'
)
st
.
equal
(
decoded
[
'i8'
],
'-45'
)
st
.
equal
(
decoded
[
'i16'
],
'-1234'
)
st
.
equal
(
decoded
[
'i32'
],
'3455'
)
st
.
equal
(
decoded
[
'i64'
],
'-35566'
)
st
.
equal
(
decoded
[
'i128'
],
'-444444'
)
st
.
equal
(
decoded
[
'i256'
],
'3434343'
)
st
.
equal
(
decoded
[
'i'
],
'-32432423423'
)
st
.
equal
(
decoded
[
'ishrink'
],
'2'
)
st
.
equal
(
decoded
[
'i8'
],
'45'
)
st
.
equal
(
decoded
[
'i16'
],
'1234'
)
decoded
=
stateDecoder
.
solidityState
(
intStorage
.
shrinkedStorage
,
output
.
sources
,
'intStorage'
)
st
.
equal
(
decoded
[
'ui8'
],
'123'
)
st
.
equal
(
decoded
[
'ui16'
],
'456'
)
st
.
equal
(
decoded
[
'ui32'
],
'4356'
)
st
.
equal
(
decoded
[
'ui64'
],
'3543543543'
)
st
.
equal
(
decoded
[
'ui128'
],
'234567'
)
st
.
equal
(
decoded
[
'ui256'
],
'234566666656'
)
st
.
equal
(
decoded
[
'ui'
],
'123545666'
)
st
.
equal
(
decoded
[
'i8'
],
'-45'
)
st
.
equal
(
decoded
[
'i16'
],
'-1234'
)
st
.
equal
(
decoded
[
'i32'
],
'3455'
)
st
.
equal
(
decoded
[
'i64'
],
'-35566'
)
st
.
equal
(
decoded
[
'i128'
],
'-444444'
)
st
.
equal
(
decoded
[
'i256'
],
'3434343'
)
st
.
equal
(
decoded
[
'i'
],
'-32432423423'
)
}
st
.
equal
(
decoded
[
'ishrink'
],
'2'
)
/*
function intStorage () {
ui8 = 0;
ui16 = 0;
ui32 = 0;
ui64 = 0;
ui128 = 234567;
ui256 = 0;
ui = 123545666;
i8 = -45;
i16 = -1234;
i32 = 3455;
i64 = -35566;
i128 = -444444;
i256 = 3434343;
i = -32432423423;
}
*/
decoded
=
stateDecoder
.
solidityState
({},
output
.
sources
,
'intStorage'
)
st
.
equal
(
decoded
[
'ui8'
],
'0'
)
st
.
equal
(
decoded
[
'ui16'
],
'0'
)
st
.
equal
(
decoded
[
'ui32'
],
'0'
)
st
.
equal
(
decoded
[
'ui64'
],
'0'
)
st
.
equal
(
decoded
[
'ui128'
],
'0'
)
st
.
equal
(
decoded
[
'ui256'
],
'0'
)
st
.
equal
(
decoded
[
'ui'
],
'0'
)
st
.
equal
(
decoded
[
'i8'
],
'0'
)
st
.
equal
(
decoded
[
'i16'
],
'0'
)
st
.
equal
(
decoded
[
'i32'
],
'0'
)
st
.
equal
(
decoded
[
'i64'
],
'0'
)
st
.
equal
(
decoded
[
'i128'
],
'0'
)
st
.
equal
(
decoded
[
'i256'
],
'0'
)
st
.
equal
(
decoded
[
'i'
],
'0'
)
st
.
equal
(
decoded
[
'ishrink'
],
'0'
)
st
.
end
()
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment