Truffle 5 手册

Truffle命令
命令行概述 truffle build - 构建项目 truffle compile - 编译合约 truffle config - 分析功能开关 truffle console - 启动控制台 truffle create - 创建新构件 truffle debug - 调试链上交易 truffle deploy - 部署合约 truffle develop - 启动开发控制台 truffle exec - 执行JS脚本 truffle help - 帮助信息 truffle init - 初始化项目 truffle install - 安装以太坊包 truffle migrate - 部署合约 truffle networks - 检查网络构件 truffle opcode - 显示合约操作码 truffle publish - 发布以太坊包 truffle run - 运行插件命令 truffle test - 执行测试 truffle unbox - 下载项目模板 truffle version - 显示i版本信息 truffle watch - 自动重新构建
Truffle配置文件
配置文件概述 networks - 网络配置 contracts_directory - 合约目录配置 contracts_build_directory - 合约构建目录配置 migrations_directory - 迁移脚本目录配置 mocha - 测试配置 compilers.solc - Solidity编译器配置 compilers.external - 外部编译器配置
合约抽象层API
合约抽象对象概述 MyContract.new - 部署新合约 MyContract.at - 载入已部署合约 MyContract.deployed - 载入默认合约 MyContract.link - 链接合约库 MyContract.networks - 获取网络列表 MyContract.setProvider - 设置web3提供器 MyContract.setNetwork - 设置网络 MyContract.hasNetwork - 检测指定网络 MyContract.defaults - 实例默认值 MyContract.clone - 克隆合约抽象 MyContract.numberFormat - 数值格式 MyContract.timeout - 交易超时区块数 MyContract.autoGas - 是否自动估算gas MyContract.gasMultiplier - 设置gas估算倍数
Truffle Box API
Truffle Box概述 Truffle Box配置文件 Truffle Box图像规范 Truffle Box发布流程
使用指南
在Truffle中使用Metamask

external compilers - 外部编译器配置

可以使用外部编译器配置用于以更高级的方式生成Truffle构件, 格式如下:

module.exports = {
  compilers: {
    external: {
      command: "./compile-contracts",
      targets: [{
        /* compilation output */
      }]
    }
  }
}

当运行truffle compile时,Truffle将运行配置的命令,并查看targets指定的合约构件。

应用场景

这个新的Truffle配置项主要用来支持以下的应用场景。

  • 编译命令直接生成构件
  • 编译命令生成构件元素,truffle生成最终的构件
  • 指定合约的属性,truffle生成最终的构件

编译命令直接生成构件

如果编译命令直接生成构件,或者编译输出中包含构件的所有信息,那么可以如下配置:

module.exports = {
  compilers: {
    external: {
      command: "./compile-contracts",
      targets: [{
        path: "./path/to/artifacts/*.json"
      }]
    }
  }
}

Truffle将执行上述脚本,然后扩展glob(*)并查找列出的目录中的所有.json文件, 并拷贝到build/contracts/目录。

编译命令生成构件元素,truffle生成最终的构件

如果编译命令生成构件的各组成部分,你希望Truffle帮你生成最终的构件,那么可以 配置target来运行任意后处理命令:

module.exports = {
  compilers: {
    external: {
      command: "./compile-contracts",
      targets: [{
        path: "./path/to/preprocessed-artifacts/*.json",
        command: "./process-artifact"
      }]
    }
  }
}

这个配置将为每个匹配的.json文件运行./process-artifact./process-artifact 命令将在stdout输出完整的Truffle构件。

指定合约的属性,truffle生成最终的构件

也可以指定合约的具体属性,然后由Truffle生成构件:

module.exports = {
  compilers: {
    external: {
      command: "./compile-contracts",
      targets: [{
        properties: {
          contractName: "MyContract",
          /* other literal properties */
        },
        fileProperties: {
          abi: "./output/contract.abi",
          bytecode: "./output/contract.bytecode",
          /* other properties encoded in output files */
        }
      }]
    }
  }
}

使用workingDirectory配置项来自定义工作目录。例如, ./proj/compile-contracts然后读取./proj/output/contract.abi

module.exports = {
  compilers: {
    external: {
      command: "./compile-contracts",
      workingDirectory: "./proj",
      targets: [{
        fileProperties: {
          abi: "./output/contract.abi",
          bytecode: "./output/contract.bytecode",
        }
      }]
    }
  }
}