Skip to content

Latest commit

 

History

History
44 lines (29 loc) · 2.48 KB

scale-codec-comparator.md

File metadata and controls

44 lines (29 loc) · 2.48 KB

SCALE Codec Comparator

:::danger This Request for Proposals is closed, meaning we are not looking for any more proposals on this topic at the moment. :::

Project Description 📄

To date, there are 9 published implementations of the SCALE Codec. Since each is implemented by a different team & the reference implementation still introduces small fixes, it would be beneficial to compile a table of feature-completeness. This would provide (some) assurance that the implementation in a given language is safe & sound to use.

One approach would be to provide wrappers to the Rust reference implementation, like in scale.rb and using the Foreign Function Interface (e.g. here) to call these directly from within the library.

Stage 2: To take this a step further, a GitHub action could be integrated to run all native unit tests also against the Rust lib. For repos which provide feature completeness & pass all relevant tests, a SCALE specific badge could be awarded.

Deliverables 🔩

  • Total Estimated Duration: 2+ months
  • Full-time equivalent (FTE): 1
  • Total Costs: ~ 12,000 DAI

Milestone 1: Feature-completeness & FFI to Rust

  • Estimated Duration: 2 months
  • FTE: 1
  • Costs: ~ 10,000 DAI

For each library listed on substrate.dev:

  • Create a PR, providing a FFI to Rust's reference implementation.
  • Ensure feature completeness, by ensuring there are comprehensive unit tests for each data type.

Milestone 2: Badge integration

  • Estimated Duration: 1 week

  • FTE: 1

  • Costs: ~ 2000 DAI

  • Create a GitHub badge for SCALE feature complete libs

  • Ensure that each lib listed above has the process of publishing the badge integrated into the CI workflow (e.g. GitHub action to run tests & award badge on successful run)

Note: The goal is to have your changes merged upstream. While the final decision is taken by the repo owners, you should make sure that your PRs pass all checks specific to each lib, conforms to their contributing guidelines etc.