| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 | 
							- /* -*- Mode: js; js-indent-level: 2; -*- */
 
- /*
 
-  * Copyright 2014 Mozilla Foundation and contributors
 
-  * Licensed under the New BSD license. See LICENSE or:
 
-  * http://opensource.org/licenses/BSD-3-Clause
 
-  */
 
- var util = require('./util');
 
- /**
 
-  * Determine whether mappingB is after mappingA with respect to generated
 
-  * position.
 
-  */
 
- function generatedPositionAfter(mappingA, mappingB) {
 
-   // Optimized for most common case
 
-   var lineA = mappingA.generatedLine;
 
-   var lineB = mappingB.generatedLine;
 
-   var columnA = mappingA.generatedColumn;
 
-   var columnB = mappingB.generatedColumn;
 
-   return lineB > lineA || lineB == lineA && columnB >= columnA ||
 
-          util.compareByGeneratedPositionsInflated(mappingA, mappingB) <= 0;
 
- }
 
- /**
 
-  * A data structure to provide a sorted view of accumulated mappings in a
 
-  * performance conscious manner. It trades a neglibable overhead in general
 
-  * case for a large speedup in case of mappings being added in order.
 
-  */
 
- function MappingList() {
 
-   this._array = [];
 
-   this._sorted = true;
 
-   // Serves as infimum
 
-   this._last = {generatedLine: -1, generatedColumn: 0};
 
- }
 
- /**
 
-  * Iterate through internal items. This method takes the same arguments that
 
-  * `Array.prototype.forEach` takes.
 
-  *
 
-  * NOTE: The order of the mappings is NOT guaranteed.
 
-  */
 
- MappingList.prototype.unsortedForEach =
 
-   function MappingList_forEach(aCallback, aThisArg) {
 
-     this._array.forEach(aCallback, aThisArg);
 
-   };
 
- /**
 
-  * Add the given source mapping.
 
-  *
 
-  * @param Object aMapping
 
-  */
 
- MappingList.prototype.add = function MappingList_add(aMapping) {
 
-   if (generatedPositionAfter(this._last, aMapping)) {
 
-     this._last = aMapping;
 
-     this._array.push(aMapping);
 
-   } else {
 
-     this._sorted = false;
 
-     this._array.push(aMapping);
 
-   }
 
- };
 
- /**
 
-  * Returns the flat, sorted array of mappings. The mappings are sorted by
 
-  * generated position.
 
-  *
 
-  * WARNING: This method returns internal data without copying, for
 
-  * performance. The return value must NOT be mutated, and should be treated as
 
-  * an immutable borrow. If you want to take ownership, you must make your own
 
-  * copy.
 
-  */
 
- MappingList.prototype.toArray = function MappingList_toArray() {
 
-   if (!this._sorted) {
 
-     this._array.sort(util.compareByGeneratedPositionsInflated);
 
-     this._sorted = true;
 
-   }
 
-   return this._array;
 
- };
 
- exports.MappingList = MappingList;
 
 
  |