aboutsummaryrefslogtreecommitdiffstats
path: root/packages/base-contract/src
diff options
context:
space:
mode:
authorGreg Hysen <greg.hysen@gmail.com>2019-01-10 16:36:42 +0800
committerGreg Hysen <greg.hysen@gmail.com>2019-01-15 02:49:44 +0800
commit80aa2884a3aeb8b6f64080d665671e22a5c453cd (patch)
treec5233e90dd47ec30f08a7b3973686fedca29c4c6 /packages/base-contract/src
parent3a28eb1c6a5e213f4874c34e8a3c85eadfe98fc9 (diff)
downloaddexon-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.ts8
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);
}
}