diff options
author | Fabio Berger <me@fabioberger.com> | 2018-10-01 23:37:44 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-10-01 23:37:44 +0800 |
commit | bad6761e13d5348eccdf8ae37e83b152740dbe45 (patch) | |
tree | 9687e509f18164ac78ff612ead79ebd9eb977527 /packages/sol-doc/src/cli.ts | |
parent | ac14dd2b29b42ef4d2a46db9b70d4d30cf9bd40f (diff) | |
parent | 6ffdc318e7b15cc43f4b3e0ffc39786cdf4c5c05 (diff) | |
download | dexon-sol-tools-bad6761e13d5348eccdf8ae37e83b152740dbe45.tar dexon-sol-tools-bad6761e13d5348eccdf8ae37e83b152740dbe45.tar.gz dexon-sol-tools-bad6761e13d5348eccdf8ae37e83b152740dbe45.tar.bz2 dexon-sol-tools-bad6761e13d5348eccdf8ae37e83b152740dbe45.tar.lz dexon-sol-tools-bad6761e13d5348eccdf8ae37e83b152740dbe45.tar.xz dexon-sol-tools-bad6761e13d5348eccdf8ae37e83b152740dbe45.tar.zst dexon-sol-tools-bad6761e13d5348eccdf8ae37e83b152740dbe45.zip |
Merge pull request #1099 from 0xProject/solidityDocRefImprovements
Solidity Doc Improvements
Diffstat (limited to 'packages/sol-doc/src/cli.ts')
-rw-r--r-- | packages/sol-doc/src/cli.ts | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/packages/sol-doc/src/cli.ts b/packages/sol-doc/src/cli.ts index eb0f00bf6..11e638785 100644 --- a/packages/sol-doc/src/cli.ts +++ b/packages/sol-doc/src/cli.ts @@ -3,7 +3,7 @@ import * as yargs from 'yargs'; import { logUtils } from '@0xproject/utils'; -import { generateSolDocAsync } from './solidity_doc_generator'; +import { SolDoc } from './sol_doc'; const JSON_TAB_WIDTH = 4; @@ -20,7 +20,20 @@ const JSON_TAB_WIDTH = 4; .demandOption('contracts-dir') .array('contracts') .help().argv; - const doc = await generateSolDocAsync(argv.contractsDir, argv.contracts); + // Unfortunately, the only way to currently retrieve the declared structs within Solidity contracts + // is to tease them out of the params/return values included in the ABI. These structures do + // not include the structs actual name, so we need a mapping to assign the proper name to a + // struct. If the name is not in this mapping, the structs name will default to the param/return value + // name (which mostly coincide). + const customTypeHashToName: { [hash: string]: string } = { + '52d4a768701076c7bac06e386e430883975eb398732eccba797fd09dd064a60e': 'Order', + '46f7e8c4d144d11a72ce5338458ea37b933500d7a65e740cbca6d16e350eaa48': 'FillResults', + c22239cf0d29df1e6cf1be54f21692a8c0b3a48b9367540d4ffff4608b331ce9: 'OrderInfo', + c21e9ff31a30941c22e1cb43752114bb467c34dea58947f98966c9030fc8e4a9: 'TraderInfo', + '07c2bddc165e0b5005e6244dd4a9771fa61c78c4f42abd687d57567b0768136c': 'MatchedFillResults', + }; + const solDoc = new SolDoc(); + const doc = await solDoc.generateSolDocAsync(argv.contractsDir, argv.contracts, customTypeHashToName); process.stdout.write(JSON.stringify(doc, null, JSON_TAB_WIDTH)); })().catch(err => { logUtils.warn(err); |