Package Exports
- c3-linearization
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (c3-linearization) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
c3-linearization
A package for doing Python-style C3-linearization in ECMAScript.
Usage
import { linearize } from 'c3-linearization'
linearize({
'A': ['B', 'C'],
'B': [],
'C': ['D'],
'D': []
})
// {
// 'A': ['A', 'B', 'C', 'D'],
// 'B': ['B'],
// 'C': ['C', 'D'],
// 'D': ['D']
// }
Important notes
Solidity does linearization from right to left (you write the parents from most
base-like to most derived). This is exactly the reverse as in Python, where you
put the most derived classes to the left. To get correct results with Solidity,
set the reverse
option to true.
linearize('A': ['B', 'C'], { reverse: true })
Python is also a bit more strict in the cases that it accepts. For accurate
Python MRO, set the python
option to true.
linearize('A': ['B', 'C'], { python: true })
Author
Federico Bond
License
MIT