Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add a flattener for contracts #156

Closed
sz-piotr opened this issue Nov 29, 2019 · 1 comment · Fixed by #216
Closed

Add a flattener for contracts #156

sz-piotr opened this issue Nov 29, 2019 · 1 comment · Fixed by #216
Labels
waffle-3.0.0 Part of the improvements for Waffle 3

Comments

@sz-piotr
Copy link
Contributor

No description provided.

@sz-piotr sz-piotr added the waffle-3.0.0 Part of the improvements for Waffle 3 label Dec 20, 2019
@sz-piotr sz-piotr mentioned this issue Dec 20, 2019
33 tasks
@msieczko
Copy link
Member

msieczko commented Apr 7, 2020

Current Waffle CLI usage

Waffle CLI is currently used by passing in a path to a config file and doesn't have any meaningful options.

Usage:

    waffle [config-file] [options]

    Compiles solidity source code

  Config file:

    Read more about the configuration file in the documentation
    https://ethereum-waffle.readthedocs.io

  Options:

    --help, -h      Display this message

Possible solutions

1. Add waffle flatten and waffle compile CLI options and make waffle invocation default to waffle compile.

Usage:

    waffle [compile|flatten] [config-file] [options]
    
  Config file:

    Read more about the configuration file in the documentation
    https://ethereum-waffle.readthedocs.io

  Options:

    --help, -h      Display this message

Pros:

  • Easy to transform into third approach

Cons:

  • User must provide multiple configs (for compile and flatten)
  • Increased complexity: compile and flatten configs should have separate formats to not introduce confusion. Not every field from compile config is used for flattening (e.g. compilerVersion or outputType)

2. Add single option to waffle config flattenOutputDirectory.

Usage would be the same as currently

Cons:

  • if we add flattenOutputDirectory it would make more sense to rename outputDirectory -> compileOutputDirectory
  • user may want to flatten only some of the files from sourceDirectory and would end up creating a separate config file anyway

3. Add support for multiple configurations along with waffle flatten and waffle compile commands (involves: #209)

The configuration format would now allow adding multiple configurations in an array. Passing a single configuration object would still be possible to maintain backwards compatibility.

[
  {
    name: "old contracts",
    type: "compile",
    compilerVersion: "0.4.19",
    sourceDirectory: "src/old-contracts",
    outputDirectory: "dist/old-contracts",
  },
  {
    name: "new contracts",
    type: "compile",
    compilerVersion: "0.6.3",
    sourceDirectory: "src/new-contracts",
    outputDirectory: "dist/new-contracts",
  },
  {
    name: "flatten",
    type: "flatten",
    sourceDirectory: "src/new-contracts",
    outputDirectory: "dist/new-contracts/flat",
  },
]

New optional configuration fields would be added:

  • name (default: #1 position in array) - for better printing of waffle processing progress
  • type (default: compile) - for choosing processing action: compilation or flattening of contracts from sourceDirectory

The new usage of Waffle CLI would look as follows:

Usage:

    waffle [compile|flatten] [config-file] [options]
    
  Config file:

    Read more about the configuration file in the documentation
    https://ethereum-waffle.readthedocs.io

  Options:

    --help, -h      Display this message

Invoking waffle compile command would run only configs with type compile.
Invoking waffle flatten would run only configs with type flatten.
Invoking waffle would run all specified configurations.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
waffle-3.0.0 Part of the improvements for Waffle 3
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants