/** * @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);