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
1703877976
1703877977
1703877978
为了运行上述代码,首先需要从solc-bin repository下载v0.4.7.commit.822622cf.js文件,并将其保存在node_modules/solc/bin目录中。然后需要下载编译器文件版本0.4.8,将其保存在文件系统中某处,并把setupMethods调用中的路径指向那个目录。
1703877979
1703877980
2.接入库
1703877981
1703877982
如果solidity源代码引用库,生成的字节码将包含被引用库真实地址的占位符。这些必须在部署合约之前,通过一个称为接入(linking)的程序更新。
1703877983
1703877984
solcjs提供了把库地址接入生成的字节码的linkByteCode方法。示例如下:
1703877985
1703877986
1703877987
1703877988
1703877989
3.更新ABI
1703877990
1703877991
合约ABI提供多种信息,这些信息不包括合约的实现。两种不同版本的编译器生成的ABI可能不匹配,因为较高版本比较低版本支持更多的solidity功能,所以ABI中有一些额外信息。例如,回退函数是在Solidity 0.4.0版本时引入的,所以使用0.4.0以下版本编译器生成的ABI没有回退函数的信息,但这些智能合约的行为就像它们有回退函数一样,只不过是空的函数体和应付修改器。所以应当更新ABI,以便让依赖于较新Solidity版本ABI的应用有关于合约的更佳信息。
1703877992
1703877993
solcjs提供了用于更新的API。示例如下:
1703877994
1703877995
1703877996
1703877997
1703877998
其中,0.3.6表示ABI是由0.3.6版本编译器生成的。因为我们正在使用solcjs版本0.4.8,将更新ABI以匹配编译器版本生成的ABI,但不能是更高的版本。
1703877999
1703878000
上述代码的输出如下:
1703878001
1703878002
1703878003
1703878004
1703878005
1703878006
1703878007
[
上一页 ]
[ :1.703877958e+09 ]
[
下一页 ]