1703877927
区块链项目开发指南 6.2.1 安装solcjs
1703877928
1703877929
solcjs可以作为solc的npm包使用。和其他npm包一样,solcjs npm包可以在本地或者全局安装。如果包安装在全局,则命令行工具solcjs可用。因此,为了安装命令行工具,运行如下命令:
1703877930
1703877931
1703877932
1703877933
1703877934
接着运行如下命令,看看如何用命令行编译器编译solidity文件:
1703877935
1703877936
1703877937
1703877938
1703877939
我们不学习solcjs命令行工具,而是学习用solcjs API编译solidity文件。
1703877940
1703877941
1703877942
solcjs默认使用的编译器版本与其自身版本匹配。例如,如果安装solcjs的0.4.8版本,则将默认使用0.4.8编译器版本进行编译。也可以配置solcjs,以使用一些其他的编译器版本。在写本书之时,solcjs的最新版本是0.4.8。
1703877943
1703877944
1703877945
1703877946
1703877948
区块链项目开发指南 6.2.2 solcjs API
1703877949
1703877950
solcjs提供了compiler方法,用于编译solidity代码。根据源代码是否有import(引用),该方法可以用于两种不同方法:如果源代码没有import,则需要两个实参,即第一个实参是字符串作solidity源代码,第二个实参是Boolean,表示是否最优化字节码。如果源字符串包含多个合约,则将编译全部。示例如下:
1703877951
1703877952
1703877953
1703877954
1703877955
如果源代码包含对其他合约的引用(imports),则第一个实参就是一个对象,它的键是文件名,值是文件内容。所以无论何时编译器看到一个import语句,它不会在文件系统中寻找文件,而是通过与文件名匹配的键在对象中寻找文件内容。示例如下:
1703877956
1703877957
1703877958
1703877959
1703877960
如果想在编译时从文件系统读取被引用的文件或者在编译时解析文件内容,则compiler方法支持第三个实参,即取文件名并返回文件内容的方法。示例如下:
1703877961
1703877962
1703877963
1703877964
1703877965
1.使用不同的编译器版本
1703877966
1703877967
为了使用不同的solidity版本编译合约,需要用useVersion方法去引用一个不同的编译器。useVersion用一个字符串,该字符串表示存储了编译器的JavaScript文件名,并在/node_modules/solc/bin目录中寻找该文件。
1703877968
1703877969
solcjs还提供另一种方式loadRemoteVersion,它用的编译器文件名与solc-bin文件库(https://github.com/etherum/solc-bin)中的solc-bin/bin目录下的文件名进行匹配,并下载和使用。
1703877970
1703877971
最后,solcjs还提供了另一个setupMethods方法,它与useVersion类似,但是可以从任意目录加载编译器。
1703877972
1703877973
下面用一个示例来演示这三个方法的用法:
1703877974
1703877975
[
上一页 ]
[ :1.703877926e+09 ]
[
下一页 ]