Skip to main content

Plugin for Ape Ethereum Framework for compiling Solidity contracts

Project description

Quick Start

Compile Solidity contracts.

Dependencies

Installation

via pip

You can install the latest release via pip:

pip install ape-solidity

via setuptools

You can clone the repository and use setuptools for the most up-to-date version:

git clone https://github.com/ApeWorX/ape-solidity.git
cd ape-solidity
python3 setup.py install

Quick Usage

In your project, make sure you have a contracts/ directory containing Solidity files (.sol).

Then, while this plugin is installed, compile your contracts:

ape compile

The byte-code and ABI for your contracts should now exist in a __local__.json file in a .build/ directory.

Solidity Versioning

By default, ape-solidity tries to use the best versions of Solidity by looking at all the source files' pragma specifications. However, it is often better to specify a version directly. If you know the best version to use, set it in your ape-config.yaml, like this:

solidity:
  version: 0.8.14

EVM Versioning

By default, ape-solidity will use whatever version of EVM rules are set as default in the compiler version that gets used. Sometimes, you might want to use a different version, such as deploying on Arbitrum or Optimism where new opcodes are not supported yet. If you want to require a different version of EVM rules to use in the configuration of the compiler, set it in your ape-config.yaml like this:

solidity:
  evm_version: paris

Dependency Mapping

By default, ape-solidity knows to look at installed dependencies for potential remapping-values and will use those when it notices you are importing them. For example, if you are using dependencies like:

dependencies:
  - name: openzeppelin
    github: OpenZeppelin/openzeppelin-contracts
    version: 4.4.2

And your source files import from openzeppelin this way:

import "@openzeppelin/contracts/token/ERC721/ERC721.sol";

Ape knows how to resolve the @openzeppelin value and find the correct source.

If you want to override this behavior or add new remappings that are not dependencies, you can add them to your ape-config.yaml under the solidity: key. For example, let's say you have downloaded openzeppelin somewhere and do not have it installed in Ape. You can map to your local install of openzeppelin this way:

solidity:
  import_remapping:
    - "@openzeppelin=path/to/openzeppelin"

Library Linking

To compile contracts that use libraries, you need to add the libraries first. Use the add_library() method from the ape-solidity compiler class to add the library. A typical flow is:

  1. Deploy the library.
  2. Call add_library() using the Solidity compiler plugin, which will also re-compile contracts that need the library.
  3. Deploy and use contracts that require the library.

For example:

import pytest


@pytest.fixture
def contract(accounts, project, compilers):
    # Deploy the library.
    account = accounts[0]
    library = project.Set.deploy(sender=account)

    # Add the library to Solidity (re-compiles contracts that use the library).
    compilers.solidity.add_library(library)

    # Deploy the contract that uses the library.
    return project.C.deploy(sender=account)

Compiler Settings

When using ape-solidity, your project's manifest's compiler settings will include standard JSON output. You should have one listed compiler per solc version used in your project. You can view your current project manifest, including the compiler settings, by doing:

from ape import project

manifest = project.extract_manifest()

for compiler_entry in manifest.compilers:
    print(compiler_entry.version)
    print(compiler_entry.settings)

NOTE: These are the settings used during contract verification when using the Etherscan plugin.

--via-IR Yul IR Compilation Pipeline

You can enable solc's --via-IR flag by adding the following values to your ape-config.yaml

solidity:
  via_ir: True

Contract Flattening

ape-solidity has contract-flattening capabilities. If you are publishing contracts using Ape, Ape automatically detects and uses the flattened-contract approach if needed.

To manually flatten a contract for your own benefit, use the following code:

from ape import compilers, project

source_path = project.source_paths[0]  # Replace with your path.
flattened_src = compilers.flatten_contract(source_path)
print(str(flattened_src))

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ape-solidity-0.8.5.tar.gz (418.3 kB view details)

Uploaded Source

Built Distribution

ape_solidity-0.8.5-py3-none-any.whl (29.0 kB view details)

Uploaded Python 3

File details

Details for the file ape-solidity-0.8.5.tar.gz.

File metadata

  • Download URL: ape-solidity-0.8.5.tar.gz
  • Upload date:
  • Size: 418.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.11.2 readme-renderer/44.0 requests/2.32.3 requests-toolbelt/1.0.0 urllib3/2.2.3 tqdm/4.66.6 importlib-metadata/8.5.0 keyring/25.5.0 rfc3986/2.0.0 colorama/0.4.6 CPython/3.10.15

File hashes

Hashes for ape-solidity-0.8.5.tar.gz
Algorithm Hash digest
SHA256 8200ca4d0d1df0608f14418a16cd98a730d65c3073450ad76e458bfda64e1535
MD5 efb1eebc55d517e7b26cacbbf9ea79a0
BLAKE2b-256 4a9b41d50b7ec9a06f58f299bbbc003b6d59e16d19050534c216151b7e65c2c8

See more details on using hashes here.

File details

Details for the file ape_solidity-0.8.5-py3-none-any.whl.

File metadata

  • Download URL: ape_solidity-0.8.5-py3-none-any.whl
  • Upload date:
  • Size: 29.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.11.2 readme-renderer/44.0 requests/2.32.3 requests-toolbelt/1.0.0 urllib3/2.2.3 tqdm/4.66.6 importlib-metadata/8.5.0 keyring/25.5.0 rfc3986/2.0.0 colorama/0.4.6 CPython/3.10.15

File hashes

Hashes for ape_solidity-0.8.5-py3-none-any.whl
Algorithm Hash digest
SHA256 75094fd996ad0914cb2425598e0ec9329adc881050d55b4224d74f75dd994794
MD5 2c69e91e75a7be13c3f5888fa62c0f08
BLAKE2b-256 6d2ed07b6dba5a86bfd4f2cced0f5ada112a55dbb886552187ddc86b94aef7d4

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page