Package Exports
- toposort-class
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 (toposort-class) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
Toposort 
Sorting directed acyclic graphs, for Node.js and the browser This was originally done by Marcel Klehr. Why not checkout his original repo?
Installation
There are a few ways for installing Toposort. Here are them:
- Via NPM:
npm install toposort-class - Via Bower:
bower install toposort - Via Git:
git clone git://github.com/gustavohenke/toposort.git - Direct download for use in the browser
Example
Let's say you have the following dependency graph:
- Plugin depends on Backbone and jQuery UI Button;
- Backbone depends on jQuery and Underscore;
- jQuery UI Button depends on jQuery UI Core and jQuery UI Widget;
- jQuery UI Widget and jQuery UI Core depend on jQuery;
- jQuery and Underscore don't depend on anyone.
Now, how would you sort this in a way that each asset will be correctly placed? You'll probably need the following sorting:
jQuery,jQuery UI Core,jQuery UI Widget,jQuery UI Button,Underscore,Backbone,Plugin
You can achieve it with the following code, using toposort-class:
var Toposort = require('toposort-class'),
t = new Toposort();
t.add("jquery-ui-core", "jquery")
.add("jquery-ui-widget", "jquery")
.add("jquery-ui-button", ["jquery-ui-core", "jquery-ui-widget"])
.add("plugin", ["backbone", "jquery-ui-button"])
.add("backbone", ["underscore", "jquery"]);
console.log(t.sort().reverse());
/* Will output:
* ['jquery', 'jquery-ui-core', 'jquery-ui-widget', 'jquery-ui-button', 'underscore', 'backbone', 'plugin']
*
* And you're done.
*/API
First of all:
var Toposort = require('toposort-class'),
t = new Toposort();
// If you prefer, you can do this way also:
t = new require('toposort-class').Toposort();.add(item, deps)
- {String}
item- The name of the dependent item that is being added - {Array|String}
deps- A dependency or list of dependencies ofitem
Returns: {Toposort} The Toposort instance, for chaining.
.sort()
Returns: {Array} The list of dependencies topologically sorted.
This method will check for cyclic dependencies, like "A is dependent of A".
Legal
MIT License