|                                                                                          |  | /** * @fileoverview Define 2 token factories; forward and backward. * @author Toru Nagashima */"use strict";
//------------------------------------------------------------------------------
// Requirements
//------------------------------------------------------------------------------
const BackwardTokenCommentCursor = require("./backward-token-comment-cursor");const BackwardTokenCursor = require("./backward-token-cursor");const FilterCursor = require("./filter-cursor");const ForwardTokenCommentCursor = require("./forward-token-comment-cursor");const ForwardTokenCursor = require("./forward-token-cursor");const LimitCursor = require("./limit-cursor");const SkipCursor = require("./skip-cursor");
//------------------------------------------------------------------------------
// Helpers
//------------------------------------------------------------------------------
/** * The cursor factory. * @private */class CursorFactory {
    /**     * Initializes this cursor.     * @param {Function} TokenCursor The class of the cursor which iterates tokens only.     * @param {Function} TokenCommentCursor The class of the cursor which iterates the mix of tokens and comments.     */    constructor(TokenCursor, TokenCommentCursor) {        this.TokenCursor = TokenCursor;        this.TokenCommentCursor = TokenCommentCursor;    }
    /**     * Creates a base cursor instance that can be decorated by createCursor.     * @param {Token[]} tokens The array of tokens.     * @param {Comment[]} comments The array of comments.     * @param {Object} indexMap The map from locations to indices in `tokens`.     * @param {number} startLoc The start location of the iteration range.     * @param {number} endLoc The end location of the iteration range.     * @param {boolean} includeComments The flag to iterate comments as well.     * @returns {Cursor} The created base cursor.     */    createBaseCursor(tokens, comments, indexMap, startLoc, endLoc, includeComments) {        const Cursor = includeComments ? this.TokenCommentCursor : this.TokenCursor;
        return new Cursor(tokens, comments, indexMap, startLoc, endLoc);    }
    /**     * Creates a cursor that iterates tokens with normalized options.     * @param {Token[]} tokens The array of tokens.     * @param {Comment[]} comments The array of comments.     * @param {Object} indexMap The map from locations to indices in `tokens`.     * @param {number} startLoc The start location of the iteration range.     * @param {number} endLoc The end location of the iteration range.     * @param {boolean} includeComments The flag to iterate comments as well.     * @param {Function|null} filter The predicate function to choose tokens.     * @param {number} skip The count of tokens the cursor skips.     * @param {number} count The maximum count of tokens the cursor iterates. Zero is no iteration for backward compatibility.     * @returns {Cursor} The created cursor.     */    createCursor(tokens, comments, indexMap, startLoc, endLoc, includeComments, filter, skip, count) {        let cursor = this.createBaseCursor(tokens, comments, indexMap, startLoc, endLoc, includeComments);
        if (filter) {            cursor = new FilterCursor(cursor, filter);        }        if (skip >= 1) {            cursor = new SkipCursor(cursor, skip);        }        if (count >= 0) {            cursor = new LimitCursor(cursor, count);        }
        return cursor;    }}
//------------------------------------------------------------------------------
// Exports
//------------------------------------------------------------------------------
exports.forward = new CursorFactory(ForwardTokenCursor, ForwardTokenCommentCursor);exports.backward = new CursorFactory(BackwardTokenCursor, BackwardTokenCommentCursor);
 |