Types Simplification #15
Closed
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Development Workflow
make format
make test
make lint
Minimal API change
all the test files are untouched, and all the test passed.
Types Changes
Remove and modified custom type and opt-in for petgraph's provided types. this can
GraphConstructor
->petgraph::EdgeType
GraphConstructor
provide the two function interface:fn is_directed() -> bool
: already provided byEdgeType
trait, which bothpetgraph::Directed
andpetgraph::Undirected
already implemented, andfn new_graph() -> PetGraph<A, W, Self>
: which is used total 2 times in the codebase, which can be easily inlined.Directed
andUndirected
Directed
andUndirected
has same name type provided by petgraph.graphina's type provide:
is_directed()->bool
, which petgraph's already implementedDefault::default()
, which is never used in the code baseNodeId
andEdgeId
struct NodeId(NodeIndex)
andstruct EdgeId(EdgeIndex)
, provide no extra functionalities, it'll be easier to use as alias to the petgraph'sNodeIndex
andEdgeIndex
API change example
src/core/types.rs:202: BaseGraph::add_edge
from
to