Skip to content
This repository has been archived by the owner on Aug 18, 2021. It is now read-only.

Indent - Maximum call stack size exceeded #603

Closed
Aklesk opened this issue Mar 28, 2018 · 10 comments · Fixed by #610
Closed

Indent - Maximum call stack size exceeded #603

Aklesk opened this issue Mar 28, 2018 · 10 comments · Fixed by #610
Labels

Comments

@Aklesk
Copy link

Aklesk commented Mar 28, 2018

Stumbled across an odd issue:

[email protected]
[email protected]

var a = `${() => {
  `${''}`
}}`;
var b = `${''}`;
vagrant@vagrant:~/tmp$ eslint --rule {"indent":[2]} --parser babel-eslint test.js
Maximum call stack size exceeded
RangeError: Maximum call stack size exceeded
    at RegExp.test (<anonymous>)
    at OffsetStorage.getDesiredIndent (/vagrant/node_modules/eslint/lib/rules/indent.js:445:32)
    at OffsetStorage.getDesiredIndent (/vagrant/node_modules/eslint/lib/rules/indent.js:451:45)
    at OffsetStorage.getDesiredIndent (/vagrant/node_modules/eslint/lib/rules/indent.js:451:45)
    at OffsetStorage.getDesiredIndent (/vagrant/node_modules/eslint/lib/rules/indent.js:451:45)
    at OffsetStorage.getDesiredIndent (/vagrant/node_modules/eslint/lib/rules/indent.js:451:45)
    at OffsetStorage.getDesiredIndent (/vagrant/node_modules/eslint/lib/rules/indent.js:451:45)
    at OffsetStorage.getDesiredIndent (/vagrant/node_modules/eslint/lib/rules/indent.js:451:45)
    at OffsetStorage.getDesiredIndent (/vagrant/node_modules/eslint/lib/rules/indent.js:451:45)
    at OffsetStorage.getDesiredIndent (/vagrant/node_modules/eslint/lib/rules/indent.js:451:45)

This originally happened in my application's mid-size state store file, and I reduced it down to this with the issue staying constant. I wasn't able to replicate the issue without the backticks so I'm assuming this is specific to babel-eslint and not base eslint, but I don't know for certain - happy to move this.

It's pretty easy to work around once you know what's causing the problem, as even a minor change will cause the issue to stop occurring. I ended up changing the arrow function to use parentheses instead of curly braces and it went away.

@blingerson
Copy link

I have recently run into this error as well, have yet to determine the offending code. Will update this thread if I determine what is causing it.

@j0k3r
Copy link

j0k3r commented Apr 11, 2018

Got the same error and posted a duplicate issue but it contains a snippet to reproduce the error: #609 (comment)

@rumax
Copy link

rumax commented Jun 8, 2018

package.json

"babel-eslint": "8.2.3",
"eslint": "4.19.1",

Eslint Rule:

"indent": [2, 2],

Result:

Maximum call stack size exceeded
RangeError: Maximum call stack size exceeded
    at RegExp.test (<anonymous>)

@kaicataldo
Copy link
Member

Does this happen with the default parser (Espree) too? If so, this bug should be filed with ESLint core, since that's where the code for the indent rule is.

@existentialism
Copy link
Member

@kaicataldo it looks like its an issue related to how we convert Babylon template tokens, I published a PR for a fix if you want to review (#610)!

existentialism added a commit that referenced this issue Jun 18, 2018
Fixes #603 (and the fixture from #609 works).

Reworks our code that converts the format of Babylon template tokens to be a bit more robust, especially with things like nested templates with arrows.

(Adapted the logic from https://github.com/eslint/espree/blob/master/lib/token-translator.js)
@existentialism
Copy link
Member

Just published 8.2.4, which should fix this issue!

@zhangtemplar
Copy link

Still can reproduce this bug. @existentialism

@existentialism
Copy link
Member

@zhangtemplar please give a reduced test case and I’ll look into it

@zhangtemplar
Copy link

zhangtemplar commented Jun 26, 2018

@existentialism Sure, check this one:

/* eslint-disable */
import {
  createUser, deleteUser, deleteUserUser,
  queryMore, queryReportee, queryReporter,
  queryUser,
  queryUserByProject, queryUserFrom, queryUserTo,
  queryUserUser,
  updateUser,
} from '../services/api';
import { getCurrentUser } from '../utils/authority';
import { setGroup } from '../utils/group';

/**
 * Builds the query to perform aggregation query for user.
 *
 * @param payload an object for the query
 * @return {{}}
 */
function buildQueryForAggeregation(payload) {
  const query = {
    $projection: {
      'user.id': 1,
      'user.name': 1,
      'user.keyword': 1,
      'user.abstract': 1,
      'user.time': 1,
      'user.logo': 1,
      id: 1,
      fromId: 1,
      toId: 1,
      name: 1,
      time: 1,
      type: 1,
    },
  };
  if (payload !== null) {
    query.$where = payload;
  } else {
    query.$where = {};
  }
  return query;
}

function merge(response) {
  const list = {};
  response._items.forEach((relationship) => {
    relationship.user.forEach((user) => { list[user.id] = user; });
  });
  return {
    ...response,
    _items: Object.values(list),
  };
}

export default {
  namespace: 'user',

  state: {
    list: null,
    currentUser: null,
    item: null,
    // meta data associated with this query, e.g., total number of results available to query.
    meta: null,
    // links for navigation purpose.
    links: null,
    // the groups and its members
    group: null,
  },

  /** 数据字典 */
  FIELDS : {
    ch :{
      id: { name: 'ID', hint: '用户唯一标识' },
      name: { name: '用户名', hint: '用户名不能为空' },
      abstract: { name: '简介', hint: '个人简介,不超过20字' },
      detail: { name: '详细介绍', hint: '详细介绍,不超过200字' },
      type: { name: '用户类型', hint: '用户类型' },
      keyword: { name: '关键词', hint: '多个词语请用逗号分隔' },
      email: { name: '邮箱', hint: '' },
      phone: { name: '手机', hint: '' },
      password: { name: '密码', hint: '密码' },
      website: { name: '网站', hint: '网站URL' },
      address: { name: '住址', hint: '常用住址' },
      capital: { name: '总投资额', hint: '总投资额' },
      netCapital: { name: '单项投资额', hint: '单项投资额' },
      title: { name: '头衔', hint: '头衔' },
      company: { name: '公司', hint: '公司' },
      education: { name: '学历', hint: '学历' },
      credit: { name: '信用', hint: '保留' },
    },
    en :{
      id: { name: 'ID', hint: 'User uniquely identifier.' },
      name: { name: 'Name', hint: 'Username cannot be empty.' },
      abstract: { name: 'Abstract', hint: 'Your personal profile, not more than 20 words' },
      detail: { name: 'Detail', hint: 'Your detailed introduction, not more than 200 words.' },
      type: { name: 'Type', hint: 'User type.' },
      keyword: { name: 'Keyword', hint: 'Please use a comma to separate.' },
      email: { name: 'Email', hint: '' },
      phone: { name: 'Phone', hint: '' },
      password: { name: 'Password', hint: 'Password' },
      website: { name: 'Website', hint: 'Website URL' },
      address: { name: 'Address', hint: 'Common Address' },
      capital: { name: 'Capital', hint: 'Total Investment' },
      netCapital: { name: 'Net Capital', hint: 'Single Investment' },
      title: { name: 'Title', hint: 'Title' },
      company: { name: 'Company', hint: 'Company' },
      education: { name: 'Education', hint: 'Education' },
      credit: { name: 'Reserved', hint: 'Reserved' },
    },
  },

  /**
   * User types on a bit map.
   */
  USER_TYPES: {
    expert: 1,
    investor: 2,
    service: 4,
    government: 8,
    entrepenuer: 16,
    angel: 32,
    competitor: 64,
    judges: 128,
    // Those two types are not supposed to change by an user.
    admin: 1073741824,
    group: 2147483648,
  },

  /**
   * @return object 标准的user数据结构
   * */
  getTemplate: () => {
    return {
      id: '',
      name: '',
      abstract: '',
      detail: '',
      creationTime: 0,
      type: 0,
      keyword: [],
      email: '',
      phone: '',
      password: '',
      website: '',
      address: '',
      capital: 0.0,
      netCapital: 0.0,
      title: '',
      company: '',
      education: '',
      credit: 0.0,
    }
  },

  effects: {
    *update({ payload, callback }, { call, put }) {
      let response = null;
      if (payload.href) {
        console.log('update user for %o', payload);
        response = yield call(updateUser, payload);
      } else {
        console.log('create user for %o', payload);
        response = yield call(createUser, payload.body);
      }
      if (callback) {
        callback(response);
      } else {
        yield put({
          type: 'queryItem',
          payload: response,
        });
      }
    },
    *fetchCurrent({ payload, callback }, { put }) {
      if (callback) {
        callback(getCurrentUser());
      } else {
        yield put({
          type: 'saveCurrentUser',
          payload: getCurrentUser(),
        });
      }
    },
    *verifyId({ payload, callback }, { call, put }) {
      console.log('search user with: %o', payload);
      const response = yield call(queryUser, `where=${
        encodeURIComponent(JSON.stringify({ id: payload }))}&projection=${
        encodeURIComponent(JSON.stringify({ id: 1, name: 1 }))}`);
      if (callback) {
        callback(response);
      } else {
        yield put({
          type: 'queryList',
          payload: response,
        });
      }
    },
    *fetchByName({ payload, callback }, { call, put }) {
      console.log('search user with: %o', payload);
      const response = yield call(queryUser, `where=${
        encodeURIComponent(JSON.stringify({ name: { $regex: `(?i)^${payload}` } }))}&projection=${
        encodeURIComponent(JSON.stringify({ id: 1, name: 1 }))}`);
      if (callback) {
        callback(response);
      } else {
        yield put({
          type: 'queryList',
          payload: response,
        });
      }
    },
    *fetchById({ payload, callback }, { call, put }) {
      const id = typeof payload === 'string' ? payload : payload.id;
      console.log('request user with %s', id);
      const response = yield call(queryUser, `where=${
        encodeURIComponent(JSON.stringify({ id }))}`);
      if (callback) {
        callback(response);
      } else {
        yield put({
          type: 'queryItem',
          payload: response,
        });
      }
    },
    *fetchMore({ payload, callback }, { call, put }) {
      const response = yield call(queryMore, payload);
      const result = payload.includes('project/from') ||
        payload.includes('user/from') ||
        payload.includes('user/to')
        ? merge(response)
        : response;
      if (callback) {
        callback(result);
      } else {
        yield put({
          type: 'queryList',
          payload: result,
        });
      }
    },
    *fetchByType({ payload, callback }, { call, put }) {
      console.log('search user with: %o', payload);
      const query = payload === null ? null : { type: { $bitsAnySet: payload } };
      yield put({
        type: 'search',
        payload: query,
        callback,
      })
    },
    *fetchByProject({ payload, callback }, { call, put }) {
      console.log('search user by project with: %o', payload);
      const query = buildQueryForAggeregation(payload);
      const response = yield call(
        queryUserByProject,
        `aggregate=${encodeURIComponent(JSON.stringify(query))}`);
      const result = merge(response);
      if (callback) {
        callback(result);
      } else {
        yield put({
          type: 'queryList',
          payload: result,
        });
      }
    },
    *fetchAsFrom({ payload, callback }, { call, put }) {
      console.log('search user as fromId with: %o', payload);
      const query = buildQueryForAggeregation(payload);
      const response = yield call(
        queryUserFrom,
        `aggregate=${encodeURIComponent(JSON.stringify(query))}`);
      const result = merge(response);
      if (callback) {
        callback(result);
      } else {
        yield put({
          type: 'queryList',
          payload: result,
        });
      }
    },
    *fetchAsTo({ payload, callback }, { call, put }) {
      console.log('search user as toId with: %o', payload);
      const query = buildQueryForAggeregation(payload);
      const response = yield call(
        queryUserTo,
        `aggregate=${encodeURIComponent(JSON.stringify(query))}`);
      const result = merge(response);
      if (callback) {
        callback(result);
      } else {
        yield put({
          type: 'queryList',
          payload: result,
        });
      }
    },
    *search({ payload, callback }, { call, put }) {
      console.log('search project with: %o', payload);
      const query = payload === null
        ? ''
        : `where=${encodeURIComponent(JSON.stringify(payload))}&`;
      const response = yield call(queryUser, `${query}projection=${
        encodeURIComponent(JSON.stringify({
          id: 1,
          name: 1,
          keyword: 1,
          abstract: 1,
          time: 1,
          logo: 1,
        }))}`);
      if (callback) {
        callback(response);
      } else {
        yield put({
          type: 'queryList',
          payload: response,
        });
      }
    },
    *deleteGroup({ payload, callback }, { call, put }) {
      console.log('delete group and user-user relationship with: %o', payload);
      // Find all the relationship related to this group.
      const response = yield call(
        queryUserUser,
        `where=${encodeURIComponent(JSON.stringify({
          $or: [
            { fromId: payload.id },
            { toId: payload.id }
          ],
          type: 4
        }))}`);
      // Remove the group
      console.log('delete group %o', payload._id);
      yield call(deleteUser, { href: payload._id, etag: null } );
      // Remove all the related relationship
      for (let item of response._items) {
        console.log('delete user user relationship %o', item._id);
        yield call(deleteUserUser, { href: item._id, etag: null });
      }
      if (callback) {
        callback(response);
      } else {
        yield put({
          type: 'queryItem',
          payload: response,
        });
      }
    },
    *fetchColleague({ payload, callback }, { call, put }) {
      const reporteeQuery = {
        fromId: payload,
        type: 4,
      };
      const projection = {
        'manager.id': 1,
        'manager.user.id': 1,
        'manager.user.name': 1,
        'manager.user.abstract': 1,
        'member.id': 1,
        'member.user.id': 1,
        'member.user.name': 1,
        'member.user.abstract': 1,
      };
      const reportee = yield call(queryReportee, `aggregate=${
        encodeURIComponent(JSON.stringify({
          $where: reporteeQuery, $projection: projection }))}`);
      const reporterQuery = {
        toId: payload,
        type: 4,
      };
      const reporter = yield call(queryReporter, `aggregate=${
        encodeURIComponent(JSON.stringify({
          $where: reporterQuery, $projection: projection }))}`);
      // merge the groups.
      const groups = {};
      const reduce = (data, from, to) => {
        data._items[0][from].forEach(item => {
          const { id, user } = item;
          if (!Object.prototype.hasOwnProperty.call(groups, id)) {
            groups[id] = { managers: [], members: [] };
          }
          groups[id][to].push(...user);
        });
      };
      reduce(reportee, 'manager', 'managers');
      reduce(reportee, 'member', 'members');
      reduce(reporter, 'manager', 'managers');
      reduce(reporter, 'member', 'members');
      setGroup(groups);
      /* eslint-enable no-param-reassign,prefer-destructuring */
      if (callback) {
        callback(groups);
      } else {
        yield put({
          type: 'queryGroup',
          payload: groups,
        });
      }
    },
  },

  reducers: {
    /**
     * Saves the results to list.
     *
     * @return state/list
     */
    queryList(state, action) {
      console.log('%d users are fetched', action.payload._items.length);
      return {
        ...state,
        list: action.payload._items,
        meta: Object.prototype.hasOwnProperty.call(action.payload, '_meta')
          ? action.payload._meta
          : null,
        links: Object.prototype.hasOwnProperty.call(action.payload, '_links')
          ? action.payload._links
          : null,
      };
    },
    /**
     * Saves the result to item.
     *
     * @return state/item
     */
    queryItem(state, action) {
      return {
        ...state,
        item: Object.prototype.hasOwnProperty.call(action.payload, '_items') &&
        action.payload._items.length > 0
          ? action.payload._items[0]
          : action.payload,
      };
    },
    save(state, action) {
      return {
        ...state,
        list: action.payload,
      };
    },
    saveCurrentUser(state, action) {
      return {
        ...state,
        currentUser: action.payload,
      };
    },
    changeNotifyCount(state, action) {
      return {
        ...state,
        currentUser: {
          ...state.currentUser,
          notifyCount: action.payload,
        },
      };
    },
    queryGroup(state, action) {
      return {
        ...state,
        group: action.payload,
      };
    },
  },
};

@MasterAlex
Copy link

MasterAlex commented Jul 10, 2018

this code work:

return props.error ? 'border-bottom: 1px solid ' + color.red : 'border-bottom: 1px solid rgba(0, 0, 0, 0.12)'

this code falls with Maximum call stack size exceeded:

return props.error ? `border-bottom: 1px solid ${color.red}`: `border-bottom: 1px solid rgba(0, 0, 0, 0.12)`;

different single quotes

wcjohnson added a commit to wcjohnson/lightscript-eslint that referenced this issue Sep 20, 2018
commit 6aa8b6f
Author: Henry Zhu <[email protected]>
Date:   Mon Aug 27 18:09:21 2018 -0400

    9.0.0

commit c7ee9ae
Author: Brian Ng <[email protected]>
Date:   Mon Aug 27 17:04:26 2018 -0500

    Bump to [email protected] 🎉 (babel#676)

commit 3ece549
Author: Ed Morley <[email protected]>
Date:   Thu Aug 23 06:23:06 2018 +0100

    Docs: Make the default parserOptions more explicit (babel#673)

    In particular, previously the `.eslintrc` example implied that the default value for `codeFrame` was `false`, when in fact it is `true`:
    https://github.com/babel/babel-eslint/blob/v9.0.0-beta.3/lib/parse.js#L14

commit 0b36951
Author: Alexandre Borela <[email protected]>
Date:   Thu Aug 23 02:21:45 2018 -0300

    Add logical assignment plugin (babel#674)

    Fix babel#672

commit 5856ff5
Author: Brian Ng <[email protected]>
Date:   Tue Aug 21 15:18:02 2018 -0500

    Bump some devDeps

commit 45938d9
Author: Leo Yin <[email protected]>
Date:   Wed Aug 22 04:00:17 2018 +0800

    build(deps): upgrade @babel/* to 7.0.0-rc.2 (babel#668)

commit bc97875
Author: Henry Zhu <[email protected]>
Date:   Thu Jul 12 09:50:58 2018 -0400

    9.0.0-beta.3

commit 74c5d62
Author: Henry Zhu <[email protected]>
Date:   Thu Jul 12 09:50:30 2018 -0400

    update lock

commit 6a45632
Author: Mark Tse <[email protected]>
Date:   Thu Jul 12 09:49:43 2018 -0400

    chore - fixing eslint-scope to a safe version; resolves babel#656. (babel#657)

commit e0119e0
Author: Brian Ng <[email protected]>
Date:   Fri Jul 6 11:24:45 2018 -0500

    9.0.0-beta.2

commit 198964b
Merge: 8948d83 9b06e1f
Author: Rubén Norte <[email protected]>
Date:   Fri Jul 6 17:20:52 2018 +0100

    Merge pull request babel#645 from rubennorte/support-new-flow-syntax-in-scope-analysis

    Support new flow syntax in scope analysis

commit 9b06e1f
Author: Rubén Norte <[email protected]>
Date:   Fri Jul 6 11:33:37 2018 +0100

    Added failing test for variables used in type parameters

commit 8948d83
Author: Rubén Norte <[email protected]>
Date:   Fri Jul 6 14:50:59 2018 +0100

    Upgrade Babel to v7.0.0-beta.52 (babel#650)

    * Upgrade Babel to v7.0.0-beta.52

    * Fixed failing test

commit 4882b29
Author: Brian Ng <[email protected]>
Date:   Fri Jun 29 08:37:18 2018 -0500

    9.0.0-beta.1

commit 15e8d6f
Author: Rubén Norte <[email protected]>
Date:   Fri Jun 29 14:26:43 2018 +0100

    Breaking: Upgraded Babel to 7.0.0-beta.51 (babel#642)

    * Upgraded Babel to 7.0.0-beta.51, with changes to decorators

    * Removed support for Node 4 and added it for Node 10

    * nit: fix typo [skip ci]

commit e865104
Author: Brian Ng <[email protected]>
Date:   Sat Jun 23 08:20:40 2018 -0500

    8.2.5

commit 10a402c
Author: Brian Ng <[email protected]>
Date:   Sat Jun 23 08:20:08 2018 -0500

    Revert bump to babel 51 (babel#640)

commit 2bd8508
Author: Brian Ng <[email protected]>
Date:   Fri Jun 22 13:39:23 2018 -0500

    8.2.4

commit 5881648
Author: Brian Ng <[email protected]>
Date:   Fri Jun 22 11:12:54 2018 -0500

    Add test for template string with object with template string inside (babel#639)

    Closes babel#538.
    Fixes babel#537.

    Now that babel#610 has landed, I wanted to make sure this case was covered.

commit 476426a
Author: Brian Ng <[email protected]>
Date:   Fri Jun 22 11:03:15 2018 -0500

    Support OptionalMemberExpression with scope too (babel#634)

commit 92874d4
Author: Brian Ng <[email protected]>
Date:   Fri Jun 15 16:39:58 2018 -0500

    Drop node4 in travis

commit d2ac299
Author: Brian Ng <[email protected]>
Date:   Mon Jun 11 08:47:15 2018 -0500

    Bump Babel deps

commit e63962d
Author: Cristian Pallarés <[email protected]>
Date:   Wed Jun 6 00:18:13 2018 +0200

    refactor: rename babylon to @babel/parser

commit 873f02f
Author: Brian Ng <[email protected]>
Date:   Mon Jun 18 16:46:31 2018 -0500

    Fix converting template types to handle nested templates (babel#610)

    Fixes babel#603 (and the fixture from babel#609 works).

    Reworks our code that converts the format of Babylon template tokens to be a bit more robust, especially with things like nested templates with arrows.

    (Adapted the logic from https://github.com/eslint/espree/blob/master/lib/token-translator.js)

commit 74a3207
Author: Rubén Norte <[email protected]>
Date:   Fri Jun 15 15:42:05 2018 +0100

    Fix token types for experimental operators (babel#632)

    * Added failing tests

    * Recognized nullish coalescing, optional chaining and pipeline operators as Punctuator tokens

commit e802577
Author: Rubén Norte <[email protected]>
Date:   Fri Jun 15 15:31:43 2018 +0100

    Add support for the optional chaining operator (babel#630)

commit ebc46e1
Author: jmurretxactly <[email protected]>
Date:   Tue May 8 05:52:59 2018 -0600

    don't require unpad per test fixture, fixes babel#572 (babel#618)

commit 9641e4b
Author: Ankur Oberoi <[email protected]>
Date:   Fri Apr 13 09:26:41 2018 -0700

    updates readme for latest eslint & babel-eslint (babel#607) [skip ci]

commit aaeb46b
Author: Henry Zhu <[email protected]>
Date:   Fri Apr 13 11:25:03 2018 -0400

    8.2.3

commit afc3c87
Author: Henry Zhu <[email protected]>
Date:   Fri Apr 13 11:23:59 2018 -0400

    lock to beta.44

commit 92202be
Author: Bary Levi <[email protected]>
Date:   Fri Apr 13 18:23:03 2018 +0300

    Save babel beta packages as exact versions (babel#606) [skip ci]

commit 9a6d663
Author: Daniel Tschinder <[email protected]>
Date:   Tue Feb 20 11:57:07 2018 +0100

    8.2.2

commit 51afa9e
Author: Daniel Tschinder <[email protected]>
Date:   Tue Feb 20 11:56:40 2018 +0100

    Allow newer versions of babel

commit 7928722
Author: Daniel Tschinder <[email protected]>
Date:   Tue Feb 20 11:54:09 2018 +0100

    Update dependencies

commit f958995
Author: Daniel Tschinder <[email protected]>
Date:   Tue Feb 20 11:49:19 2018 +0100

    chore(package): update lint-staged to version 6.1.1 (babel#592)

    Closes babel#539

commit 29b12ab
Author: Brian Ng <[email protected]>
Date:   Thu Feb 15 21:39:42 2018 -0600

    Bump deps (babel#591)

commit 236adb8
Author: Toru Nagashima <[email protected]>
Date:   Wed Jan 17 15:10:55 2018 +0900

    Fix: wrong token type of ! and ~ (fixes babel#576) (babel#577)

commit bf27f60
Author: Henry Zhu <[email protected]>
Date:   Mon Jan 8 19:15:40 2018 -0500

    8.2.1

commit d96ce55
Author: Henry Zhu <[email protected]>
Date:   Mon Jan 8 19:15:22 2018 -0500

    fix export change (babel#571)

commit ef27670
Author: Kai Cataldo <[email protected]>
Date:   Mon Jan 8 18:06:57 2018 -0500

    8.2.0

commit eba5920
Author: Henry Zhu <[email protected]>
Date:   Mon Jan 8 17:46:57 2018 -0500

    Add other parser plugins, update yarn.lock (babel#569)

commit e201fb4
Author: Kai Cataldo <[email protected]>
Date:   Mon Jan 8 17:45:24 2018 -0500

    Make 2018 the default ecmaVersion for rules relying on parserOptions (babel#556)

commit 1dedd1b
Author: jony89 <[email protected]>
Date:   Tue Jan 9 00:40:11 2018 +0200

    update babel packages (babel#565)

    * update babel packages

    There is some critical bug fixes in version babylon#7.0.0-beta.33 regard `async` - `await` syntax which is needed pretty immediately :)

    * remove test 42 (test for import type *)

    `import type *` is invalid, since the namespace can't be a type

commit 36bf8b4
Author: Toru Nagashima <[email protected]>
Date:   Tue Dec 26 10:59:19 2017 +0900

    8.1.2

commit 5aaf0e1
Author: Toru Nagashima <[email protected]>
Date:   Tue Dec 26 10:50:13 2017 +0900

    Fix: add Literal type to visitorKeys (babel#562)

    * Fix: add Literal type to visitorKeys
    * Fix: use ./visitor-keys

commit bf9092a
Author: Toru Nagashima <[email protected]>
Date:   Tue Dec 26 10:49:36 2017 +0900

    Fix: ignore eval (fixes babel#560) (babel#561)

commit d84b236
Author: Toru Nagashima <[email protected]>
Date:   Mon Dec 25 15:57:19 2017 +0900

    8.1.1

commit e4bed5a
Author: Teddy Katz <[email protected]>
Date:   Mon Dec 25 01:52:36 2017 -0500

    Fix: Prevent parseForESLint() behavior from changing after parse() is called (fixes babel#558)(babel#559)

    * Prevent parseForESLint() behavior from changing after parse() is called

    (fixes babel#558, fixes eslint/eslint#9767)

    * Avoid using the enhanced referencer after monkeypatching

    * Chore: add test for babel#558

    * Pass correct scope analyzer options

    * fix escope patch and improve tests

    * remove process.exit(1)

commit 893a5e3
Author: Teddy Katz <[email protected]>
Date:   Sun Dec 24 02:02:44 2017 -0500

    8.1.0

commit bba9d00
Author: Teddy Katz <[email protected]>
Date:   Sun Dec 24 02:00:29 2017 -0500

    Re-add parseNoPatch function (accidentally removed) (babel#557)

commit dbc6546
Author: Toru Nagashima <[email protected]>
Date:   Sun Dec 24 15:42:17 2017 +0900

    Use new scopeManager/visitorKeys APIs (babel#542)

    (fixes eslint/eslint#9762)

commit 1f220c2
Author: Logan Smyth <[email protected]>
Date:   Fri Dec 1 10:06:40 2017 -0800

    8.0.3

commit cf5ab03
Author: Logan Smyth <[email protected]>
Date:   Fri Dec 1 10:06:24 2017 -0800

    Fix mocha command path.

commit 0609da8
Author: Logan Smyth <[email protected]>
Date:   Fri Dec 1 10:05:34 2017 -0800

    Lock down dependency versions.

commit a0fbd50
Author: Henry Zhu <[email protected]>
Date:   Mon Nov 6 15:00:41 2017 -0500

    8.0.2

commit 2004b91
Author: Henry Zhu <[email protected]>
Date:   Mon Nov 6 14:57:56 2017 -0500

    require correct deps

commit fa56d21
Author: Henry Zhu <[email protected]>
Date:   Mon Nov 6 12:51:19 2017 -0500

    Always use unpad (babel#535)

commit 295091d
Author: Henry Zhu <[email protected]>
Date:   Mon Nov 6 12:47:47 2017 -0500

    Allow ^ version for babel dependencies (babel#534)

commit d3b8519
Author: greenkeeper[bot] <greenkeeper[bot]@users.noreply.github.com>
Date:   Mon Nov 6 12:25:35 2017 -0500

    fix(package): update babylon to version 7.0.0-beta.31 (babel#533)

commit 54ab4ac
Author: Henry Zhu <[email protected]>
Date:   Tue Sep 26 16:18:43 2017 -0400

    8.0.1

commit c1a7882
Author: Clement Hoang <[email protected]>
Date:   Tue Oct 31 11:50:35 2017 -0700

    Update README.md support (babel#531) [skip ci]

    #linting channel is now archived in babel slack.

commit 51100c9
Author: greenkeeper[bot] <greenkeeper[bot]@users.noreply.github.com>
Date:   Wed Oct 11 14:14:29 2017 +0200

    chore(package): update mocha to version 4.0.0 (babel#524)

commit 5742b71
Author: Jordan Gensler <[email protected]>
Date:   Tue Sep 26 13:17:44 2017 -0700

    Adding optionalCatchBinding to plugins. (babel#521)

commit 905887c
Author: Henry Zhu <[email protected]>
Date:   Tue Sep 12 09:44:23 2017 -0400

    8.0.0

commit 49493e4
Author: Henry Zhu <[email protected]>
Date:   Tue Sep 12 09:42:30 2017 -0400

    update to beta.0

commit 42d0c5b
Author: Daniel Tschinder <[email protected]>
Date:   Wed Aug 2 14:37:01 2017 +0200

    Remove already fixed workaround (babel#508)

commit 25bd208
Author: Henry Zhu <[email protected]>
Date:   Wed Jul 26 16:19:29 2017 -0400

    8.0.0-alpha.17

commit 1468905
Author: Henry Zhu <[email protected]>
Date:   Wed Jul 26 16:18:45 2017 -0400

    alpha.17

commit 57c133e
Author: Henry Zhu <[email protected]>
Date:   Thu Jul 13 13:01:31 2017 -0400

    8.0.0-alpha.15

commit 1e41162
Author: Henry Zhu <[email protected]>
Date:   Thu Jul 13 12:58:45 2017 -0400

    update (babel#504)

commit c31b577
Author: Evan Brodie <[email protected]>
Date:   Sun Jul 9 21:03:59 2017 -0400

    Readme update usage section (babel#501) [skip ci]

    * Updates README: Consolidates versioning table

    Basically a revert of 52b4a13. It is easier to read a single table instead of two locations in the README for the version compatabilities between ESLint and babel-eslint

    * Updates README: Add yarn command for installation

    * [skip ci]

commit c2626f9
Author: greenkeeper[bot] <greenkeeper[bot]@users.noreply.github.com>
Date:   Sun Jun 25 08:30:29 2017 -0700

    Update eslint to the latest version 🚀 (babel#500)

    * chore(package): update eslint to version 4.1.0

    * escope -> eslint-scope

    * Fix linting

commit 3c6b2de
Author: greenkeeper[bot] <greenkeeper[bot]@users.noreply.github.com>
Date:   Thu Jun 22 13:18:47 2017 -0700

    chore(package): update husky to version 0.14.0 (babel#498)

commit e052d5a
Author: Kevin Mårtensson <[email protected]>
Date:   Tue Jun 20 23:49:46 2017 +0200

    Update install instructions to use latest stable release (babel#497) [skip ci]

commit 8e3e088
Author: Henry Zhu <[email protected]>
Date:   Sun Jun 18 18:33:40 2017 -0400

    8.0.0-alpha.13

commit f757e22
Merge: 37f9242 5736be6
Author: Henry Zhu <[email protected]>
Date:   Sun Jun 18 18:30:59 2017 -0400

    Merge pull request babel#493 from danez/regression-test

    Test for babylon regression

commit 5736be6
Author: Daniel Tschinder <[email protected]>
Date:   Sun Jun 18 23:12:08 2017 +0200

    Update babylon

commit 37f9242
Author: Brian Ng <[email protected]>
Date:   Sat Jun 17 14:14:42 2017 -0500

    Add Prettier (babel#491)

commit d0c3223
Author: Daniel Tschinder <[email protected]>
Date:   Sat Jun 17 21:12:07 2017 +0200

    Test for babylon regression

commit 945f00a
Author: Henry Zhu <[email protected]>
Date:   Fri Jun 16 16:56:32 2017 -0400

    8.0.0-alpha.12

commit 39b4a6a
Author: Daniel Tschinder <[email protected]>
Date:   Thu Jun 15 23:03:02 2017 +0200

    Use babylon estree and ranges (babel#489)

commit 1aedb95
Author: Mark Banner <[email protected]>
Date:   Thu Jun 8 17:23:08 2017 +0100

    Fix: allow options to be optional when monkey patching escope.analyze (fixes babel#470). (babel#484)

commit a8003c0
Author: Reyad Attiyat <[email protected]>
Date:   Tue Jun 6 20:38:49 2017 -0500

    Use Node 8 and drop Node 5 from travis (babel#483)

    * Use Node 8 and drop Node 5 from travis

    * switch the order [skip ci]

commit c66ec51
Author: Reyad Attiyat <[email protected]>
Date:   Tue Jun 6 20:37:57 2017 -0500

    Update to Babylon 7 (fixes babel#481) (babel#482)

    * Update to Babylon 7 (fixes babel#481)

    * Pin dependencies to alpha version

    * fix deprecation, add other plugins

    * oops

    * Update index.js

    * Add tests for private class properties with rules no-undef no-unused-vars

commit 54ed517
Author: Reyad Attiyat <[email protected]>
Date:   Mon May 29 20:41:14 2017 -0500

    Fix: Convert RegExpLieteral value to RegExp object (fixes babel#477) (babel#478)

commit 94bb5a1
Author: Sebastian McKenzie <[email protected]>
Date:   Fri Apr 21 22:14:19 2017 +0100

    7.2.3

commit dfaff04
Author: Andres Suarez <[email protected]>
Date:   Fri Apr 21 11:48:52 2017 -0400

    Fix flow type spread handling (babel#465)

commit f59d200
Author: Henry Zhu <[email protected]>
Date:   Wed Apr 12 12:07:05 2017 -0400

    7.2.2

commit 8622009
Author: Vitor Balocco <[email protected]>
Date:   Wed Apr 12 17:59:23 2017 +0200

    Fix: use eslint-scope instead of escope if present (babel#461)

commit 0f611b8
Author: Andres Suarez <[email protected]>
Date:   Thu Mar 30 13:49:51 2017 -0400

    Separate finding peer deps from monkeypatching (babel#460)

commit 1201e12
Author: Andres Suarez <[email protected]>
Date:   Sat Mar 25 19:36:10 2017 -0400

    Remove unused .gitmodules (babel#457)

commit a750684
Author: Andres Suarez <[email protected]>
Date:   Sat Mar 25 19:32:05 2017 -0400

    Use dedent for unpadding (babel#456)

commit cdb92fe
Merge: 21dac73 ec14787
Author: Henry Zhu <[email protected]>
Date:   Sat Mar 25 19:15:23 2017 -0400

    Merge pull request babel#455 from babel/babylon-to-espree-tidy

    Tidy up babylon-to-espree

commit ec14787
Author: Andres Suarez <[email protected]>
Date:   Sat Mar 25 18:03:17 2017 -0400

    Enable strict mode in all of babylon-to-espree

commit 6c5beec
Author: Andres Suarez <[email protected]>
Date:   Sat Mar 25 18:01:13 2017 -0400

    Move ast convert steps to babylon-to-espree

commit d2ce789
Author: Andres Suarez <[email protected]>
Date:   Sat Mar 25 17:42:51 2017 -0400

    Use for-loop for template literal conversion

commit 539af05
Author: Andres Suarez <[email protected]>
Date:   Sat Mar 25 17:36:20 2017 -0400

    Only iterate over tokens once

commit 06c3a31
Author: Andres Suarez <[email protected]>
Date:   Sat Mar 25 17:28:01 2017 -0400

    Inline fixDirectives and use for-loop

commit 5d32ad0
Author: Andres Suarez <[email protected]>
Date:   Sat Mar 25 17:07:41 2017 -0400

    Consolidate versions of "convertComments"

commit 2541fc9
Author: Andres Suarez <[email protected]>
Date:   Sat Mar 25 00:18:57 2017 -0400

    toAst pass "source" in state instead of keeping in scope

commit 21dac73
Author: Andres Suarez <[email protected]>
Date:   Thu Mar 23 15:46:48 2017 -0400

    Add type parameter scope tests (babel#454)

commit 3cda62e
Author: Henry Zhu <[email protected]>
Date:   Thu Mar 23 14:03:23 2017 -0400

    7.2.1

commit 5626de1
Author: Andres Suarez <[email protected]>
Date:   Thu Mar 23 14:02:24 2017 -0400

    Remove left over eslint 2 estraverse code (babel#452)

    This was missed in babel#361

commit b5fb53b
Author: Andres Suarez <[email protected]>
Date:   Thu Mar 23 12:49:19 2017 -0400

    Fix type param and interface declaration scoping (babel#449)

commit f1cee0f
Author: Andres Suarez <[email protected]>
Date:   Wed Mar 22 22:35:31 2017 -0400

    Remove lodash dependency (babel#450)

commit eb05812
Author: Andres Suarez <[email protected]>
Date:   Wed Mar 22 22:34:13 2017 -0400

    Format non-regression errors for legibility (babel#451)

commit 7972a05
Author: Luís Couto <[email protected]>
Date:   Tue Mar 21 00:11:30 2017 +0000

    Update README.md with codeFrame option (babel#448)

commit 4db4db5
Author: Henry Zhu <[email protected]>
Date:   Mon Mar 20 17:53:26 2017 -0400

    7.2.0

commit 4499412
Author: wtgtybhertgeghgtwtg <[email protected]>
Date:   Mon Mar 20 14:50:09 2017 -0700

    Use `lodash` instead of `lodash.pickby`. (babel#435)

commit a2c3b30
Author: Alex Rattray <[email protected]>
Date:   Mon Mar 20 14:46:07 2017 -0700

    [flow] Process polymorphic type bounds on functions (babel#444)

commit 515adef
Author: Luís Couto <[email protected]>
Date:   Mon Mar 20 21:45:11 2017 +0000

    Add option to disable code frame. (babel#446)

    * Add option to disable code hightlight.

    * Rename codeHighlight with codeFrame

    * Add codeFrame tests

    * Remove colors from test assertions

commit ce66e73
Merge: bdeb86f b49ab20
Author: Henry Zhu <[email protected]>
Date:   Mon Mar 20 11:44:33 2017 -0400

    Merge pull request babel#447 from kaicataldo/clean-up-eslint

    Chore: Clean up and upgrades

commit b49ab20
Author: Kai Cataldo <[email protected]>
Date:   Mon Mar 20 10:33:14 2017 -0400

    Updates ESLint version/remove unnecessary config

commit 702d6b8
Author: Kai Cataldo <[email protected]>
Date:   Mon Mar 20 10:27:28 2017 -0400

    Remove broken ESLint tests

commit 6b4c4ca
Author: Kai Cataldo <[email protected]>
Date:   Sat Mar 11 22:15:47 2017 -0500

    Upgrade outdated dependencies
kaicataldo pushed a commit to babel/babel that referenced this issue Nov 14, 2019
Fixes babel/babel-eslint#603 (and the fixture from babel/babel-eslint#609 works).

Reworks our code that converts the format of Babylon template tokens to be a bit more robust, especially with things like nested templates with arrows.

(Adapted the logic from https://github.com/eslint/espree/blob/master/lib/token-translator.js)
nicolo-ribaudo pushed a commit to babel/babel that referenced this issue Nov 14, 2019
…-eslint#610)

Fixes babel/babel-eslint#603 (and the fixture from babel/babel-eslint#609 works).

Reworks our code that converts the format of Babylon template tokens to be a bit more robust, especially with things like nested templates with arrows.

(Adapted the logic from https://github.com/eslint/espree/blob/master/lib/token-translator.js)
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
Projects
None yet
Development

Successfully merging a pull request may close this issue.

8 participants