Deprecations#
Policy#
If the behavior of the library has to be changed, a deprecation cycle must be followed to warn users.
A deprecation cycle is not necessary when:
- adding a new function, or 
- adding a new keyword argument to the end of a function signature, or 
- fixing buggy behavior 
A deprecation cycle is necessary for any breaking API change, meaning a change where the function, invoked with the same arguments, would return a different result after the change. This includes:
- changing the order of arguments or keyword arguments, or 
- adding arguments or keyword arguments to a function, or 
- changing the name of a function, class, method, etc., or 
- moving a function, class, etc. to a different module, or 
- changing the default value of a function’s arguments. 
Usually, our policy is to put in place a deprecation cycle over two minor releases (e.g., if a deprecation warning appears in 2.3, then the functionality should be removed in 2.5). For major releases we usually require that all deprecations have at least a 1-release deprecation cycle (e.g., if 3.0 occurs after 2.5, then all removed functionality in 3.0 should be deprecated in 2.5).
Note that these 1- and 2-release deprecation cycles for major and minor releases is not a strict rule and in some cases, the developers can agree on a different procedure upon justification (like when we can’t detect the change, or it involves moving or deleting an entire function for example).
Todo#
Make sure to review networkx/conftest.py after removing deprecated code.
Version 3.5#
- Remove - all_tripletsfrom- algorithms/triads.py
- Remove - random_triadfrom- algorithms/triad.py.
- Remove - d_separatedfrom- algorithms/d_separation.py.
- Remove - minimal_d_separatorfrom- algorithms/d_separation.py.
- Add - not_implemented_for("multigraph”)decorator to- k_core,- k_shell,- k_crustand- k_coronafunctions.
- Change - single_target_shortest_path_lengthin- algorithms/shortest_path/unweighted.pyto return a dict. See #6527
- Change - shortest_pathin- algorithms/shortest_path/generic.pyto return a iterator. See #6527
- Remove - total_spanning_tree_weightfrom- linalg/laplacianmatrix.py
- Remove - createkeyword argument from- nonisomorphic_treesin- generators/nonisomorphic_trees.
Version 3.6#
- Remove - compute_v_structuresfrom- algorithms/dag.py.
- Remove - linkkwarg from- readwrite/json_graph/node_link.py; Remove the- FutureWarningre: the default value of- edgesand change the default value to- "edges".