diff options
author | Greg Hysen <greg.hysen@gmail.com> | 2019-01-10 16:36:42 +0800 |
---|---|---|
committer | Greg Hysen <greg.hysen@gmail.com> | 2019-01-15 02:49:44 +0800 |
commit | 80aa2884a3aeb8b6f64080d665671e22a5c453cd (patch) | |
tree | c5233e90dd47ec30f08a7b3973686fedca29c4c6 /packages/base-contract/src | |
parent | 3a28eb1c6a5e213f4874c34e8a3c85eadfe98fc9 (diff) | |
download | dexon-0x-contracts-80aa2884a3aeb8b6f64080d665671e22a5c453cd.tar.gz dexon-0x-contracts-80aa2884a3aeb8b6f64080d665671e22a5c453cd.tar.zst dexon-0x-contracts-80aa2884a3aeb8b6f64080d665671e22a5c453cd.zip |
Linter
Diffstat (limited to 'packages/base-contract/src')
-rw-r--r-- | packages/base-contract/src/index.ts | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/packages/base-contract/src/index.ts b/packages/base-contract/src/index.ts index 2471ded92..f14b9a96a 100644 --- a/packages/base-contract/src/index.ts +++ b/packages/base-contract/src/index.ts @@ -86,9 +86,13 @@ export class BaseContract { } protected static _throwIfRevertWithReasonCallResult(rawCallResult: string): void { if (rawCallResult.slice(REVERT_ERROR_SELECTOR_OFFSET, REVERT_ERROR_SELECTOR_END) === REVERT_ERROR_SELECTOR) { - const revertReason = AbiEncoder.create('(string)').decodeAsArray( + const revertReasonArray = AbiEncoder.create('(string)').decodeAsArray( ethers.utils.hexDataSlice(rawCallResult, REVERT_ERROR_SELECTOR_BYTES_LENGTH), - )[0]; + ); + if (revertReasonArray.length !== 1) { + throw new Error(`Cannot safely decode revert reason: Expected an array with one element, got ${revertReasonArray}`); + } + const revertReason = revertReasonArray[0]; throw new Error(revertReason); } } |