39 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
"use strict";Object.defineProperty(exports, "__esModule", {value: true});var _keywords = require('../parser/tokenizer/keywords');
 | 
						|
 | 
						|
 | 
						|
/**
 | 
						|
 * Determine whether this optional chain or nullish coalescing operation has any await statements in
 | 
						|
 * it. If so, we'll need to transpile to an async operation.
 | 
						|
 *
 | 
						|
 * We compute this by walking the length of the operation and returning true if we see an await
 | 
						|
 * keyword used as a real await (rather than an object key or property access). Nested optional
 | 
						|
 * chain/nullish operations need to be tracked but don't silence await, but a nested async function
 | 
						|
 * (or any other nested scope) will make the await not count.
 | 
						|
 */
 | 
						|
 function isAsyncOperation(tokens) {
 | 
						|
  let index = tokens.currentIndex();
 | 
						|
  let depth = 0;
 | 
						|
  const startToken = tokens.currentToken();
 | 
						|
  do {
 | 
						|
    const token = tokens.tokens[index];
 | 
						|
    if (token.isOptionalChainStart) {
 | 
						|
      depth++;
 | 
						|
    }
 | 
						|
    if (token.isOptionalChainEnd) {
 | 
						|
      depth--;
 | 
						|
    }
 | 
						|
    depth += token.numNullishCoalesceStarts;
 | 
						|
    depth -= token.numNullishCoalesceEnds;
 | 
						|
 | 
						|
    if (
 | 
						|
      token.contextualKeyword === _keywords.ContextualKeyword._await &&
 | 
						|
      token.identifierRole == null &&
 | 
						|
      token.scopeDepth === startToken.scopeDepth
 | 
						|
    ) {
 | 
						|
      return true;
 | 
						|
    }
 | 
						|
    index += 1;
 | 
						|
  } while (depth > 0 && index < tokens.tokens.length);
 | 
						|
  return false;
 | 
						|
} exports.default = isAsyncOperation;
 |