智能合约编译插件(solc-gradle-plugin)使用方法

智能合约编译插件可以大大简化从solidity源码到java代码的过程,帮助开发者快速编译调用合约。
本文记录了编译0.4.25版本和0.8.11版本的使用方法。
1  创建gradle工程项目
用IDEA直接创建gradle项目:
创建后的build.gradle配置文件如下:
plugins {
    id 'java'
}

group 'org.example'
version '1.0-SNAPSHOT'

repositories {
    mavenCentral()
}

dependencies {
    testImplementation 'org.junit.jupiter:junit-jupiter-api:5.8.1'
    testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.8.1'
}

test {
    useJUnitPlatform()
}
2 引入合约编译插件
修改后的build.gradle如下,黄色标记部分是新添加的内容。
pkg参数指定了编译后的java代码包路径,可以自己修改定义。
buildscript {
    repositories {
        mavenCentral()
        maven { url "https://maven.aliyun.com/nexus/content/groups/public/"}
        maven { url "https://oss.sonatype.org/content/repositories/snapshots" }
        mavenLocal()
    }
    dependencies {
        classpath 'com.webank:solc-gradle-plugin:3.0.1-SNAPSHOT'
        //classpath 'com.webank:solc-gradle-plugin:1.0.2-SNAPSHOT'
        //默认编译0.8.11.0版本,如果想编译0.4.25版本,请添加下述依赖
        //classpath 'org.fisco-bcos:solcJ:0.4.25.0'
        //classpath 'com.webank:solc-gradle-plugin:1.0.1'
        //默认编译0.8.11.0版本,如果想编译0.6.10.0版本,请添加下述依赖
        //classpath 'org.fisco-bcos:solcJ:0.6.10.0'
        //默认编译0.8.11.0版本,如果想编译0.5.2.0版本,请添加下述依赖
        //classpath 'org.fisco-bcos:solcJ:0.5.2.0'
    }
}

plugins {
    id 'java'
}

apply plugin: 'solc-gradle-plugin'

solc{
    pkg = 'org.example.contracts'
}

group 'org.example'
version '1.0-SNAPSHOT'

repositories {
    mavenCentral()
}

dependencies {
    testImplementation 'org.junit.jupiter:junit-jupiter-api:5.8.1'
    testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.8.1'
}

test {
    useJUnitPlatform()
}
版本说明:
引入0.8.11版本: 只需要一行,默认就是0.8.11.  
classpath 'com.webank:solc-gradle-plugin:3.0.1-SNAPSHOT'
【注意】 我试验了用这行语句不能再编译其他低版本的合约。
classpath 'com.webank:solc-gradle-plugin:1.0.2-SNAPSHOT' 这个版本编译出错,合约函数不能返回结构体类型。
引入0.4.25,需要这一行,默认是0.4.25.   
classpath 'com.webank:solc-gradle-plugin:1.0.1'
文档上的这句话是不行的 classpath 'org.fisco-bcos:solcJ:0.4.25.0',会报告错误缺少solc-gradle-plugin。
引入0.5.2/0.6.10版本,需要两行,
classpath 'com.webank:solc-gradle-plugin:1.0.1'
classpath 'org.fisco-bcos:solcJ:0.5.2.0'
3 添加合约源码
智能合约源码拷贝到/src/main/contracts/下面, 以后编译成功后悔自动创建/src/main/abi,/src/main/bin目录。
打开终端,输入编译命令:
PS E:\codes\solc-example> .\gradlew.bat solc

> Task :solc
Entering solc task, pid 12344@User-20220909JV
Solidity contracts compile complete


BUILD SUCCESSFUL in 1s
1 actionable task: 1 executed
PS E:\codes\solc-example>
4  指定插件运行参数
solc-gradle-plugin插件解析后生成solc任务,在终端执行solc任务时自动调用配置文件build.gradle中的指定的任务参数,针对solc的参数说明如下:
配置项
必选
说明
pkg
如果指定onlyAbiBin为false,
则必须设置。否则无需设置
java合约包名
contracts
智能合约文件路径,默认为src/main/contracts
output
编译输出路径,默认为src/main
onlyAbiBin
是否只输出abi和bin默认false
selector
默认为空,选择所有合约;
若选择指定合约,可填所需合约文件名称,按逗号分隔,例如A.sol,B.sol
solc{
    pkg = 'org.example.contract'
    contracts='src/main/contracts'
    selector ='Users'
    output = 'src/main'
}
每次运行任务时( .\gradlew.bat solc )是对上述参数自动加载执行。
因此,如果我们只修改了部分合约,只针对生成部分合约文件,就需要手动修改上述配置参数,在终端下重新运行。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值