Skip to content

Ethereum compatibility layer for Substrate.

License

Notifications You must be signed in to change notification settings

NoirHQ/frontier

This branch is 19 commits behind polkadot-evm/frontier:master.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

931a708 · Jan 15, 2025
Dec 20, 2024
Jan 13, 2025
Dec 23, 2024
Jan 15, 2025
Dec 23, 2024
Jan 13, 2025
Apr 3, 2024
Dec 11, 2024
Dec 13, 2024
Oct 2, 2020
Feb 3, 2021
Jan 13, 2025
Jan 13, 2025
May 8, 2023
Apr 3, 2024
Nov 20, 2020
Nov 20, 2020
Apr 3, 2024
Apr 6, 2024
Sep 1, 2021
Oct 8, 2024
Mar 16, 2023
Aug 1, 2023
Jan 12, 2023

Repository files navigation

Polkadot Frontier

GitHub Workflow Status Matrix

Frontier is the EVM backbone of Polkadot.

Features

Frontier provides a compatibility layer of EVM, so that you can run any Ethereum dapps on Polkadot, unmodified. Using Frontier, you get access to all the Ethereum RPC APIs you are already familiar with, and therefore you can continue to develop your dapps in your favourite Ethereum developer tools. As a bonus, you can even run many Ethereum L2s inside Frontier! For those looking to become acquainted with Frontier, consult the documentation provided here. Additionally, a template node is available to facilitate a more comprehensive technical exploration.

Frontier is also a migration framework. Besides the common strategy of direct state export/import and transaction-level replays, Frontier's Pre-Log Wrapper Block feature provides a possible method for a zero-downtime live migration.

Development workflow

Pull request

All changes (except new releases) are handled through pull requests.

Versioning

Frontier follows Semantic Versioning. An unreleased crate in the repository will have the -dev suffix in the end, and we do rolling releases.

When you make a pull request against this repository, please also update the affected crates' versions, using the following rules. Note that the rules should be applied recursively -- if a change modifies any upper crate's dependency (even just the Cargo.toml file), then the upper crate will also need to apply those rules.

Additionally, if your change is notable, then you should also modify the corresponding CHANGELOG.md file, in the "Unreleased" section.

If the affected crate already has -dev suffix:

  • If your change is a patch, then you do not have to update any versions.
  • If your change introduces a new feature, please check if the local version already had its minor version bumped, if not, bump it.
  • If your change modifies the current interface, please check if the local version already had its major version bumped, if not, bump it.

If the affected crate does not yet have -dev suffix:

  • If your change is a patch, then bump the patch version, and add -dev suffix.
  • If your change introduces a new feature, then bump the minor version, and add -dev suffix.
  • If your change modifies the current interface, then bump the major version, and add -dev suffix.

If your pull request introduces a new crate, please set its version to 1.0.0-dev.

About

Ethereum compatibility layer for Substrate.

Resources

License

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 86.6%
  • TypeScript 12.3%
  • Solidity 0.4%
  • Handlebars 0.3%
  • JavaScript 0.2%
  • Makefile 0.1%
  • Other 0.1%