Blame view

node_modules/eslint/lib/token-store/cursors.js 3.79 KB
f7563de62   Palak Handa   first commit
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
  /**
   * @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);