Blame view

天文台pc/tianwentai-ui/node_modules/@emotion/babel-plugin/src/utils/transpiled-output-utils.js 2.28 KB
bc518174   王天杨   提交两个项目文件
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
  // this only works correctly in modules, but we don't run on scripts anyway, so it's fine
  // the difference is that in modules template objects are being cached per call site
  export function getTypeScriptMakeTemplateObjectPath(path) {
    if (path.node.arguments.length === 0) {
      return null
    }
  
    const firstArgPath = path.get('arguments')[0]
  
    if (
      firstArgPath.isLogicalExpression() &&
      firstArgPath.get('left').isIdentifier() &&
      firstArgPath.get('right').isAssignmentExpression() &&
      firstArgPath.get('right.right').isCallExpression() &&
      firstArgPath.get('right.right.callee').isIdentifier() &&
      firstArgPath.node.right.right.callee.name.includes('makeTemplateObject') &&
      firstArgPath.node.right.right.arguments.length === 2
    ) {
      return firstArgPath.get('right.right')
    }
  
    return null
  }
  
  // this is only used to prevent appending strings/expressions to arguments incorectly
  // we could push them to found array expressions, as we do it for TS-transpile output ¯\_(ツ)_/¯
  // it seems overly complicated though - mainly because we'd also have to check against existing stuff of a particular type (source maps & labels)
  // considering Babel double-transpilation as a valid use case seems rather far-fetched
  export function isTaggedTemplateTranspiledByBabel(path) {
    if (path.node.arguments.length === 0) {
      return false
    }
  
    const firstArgPath = path.get('arguments')[0]
  
    if (
      !firstArgPath.isCallExpression() ||
      !firstArgPath.get('callee').isIdentifier()
    ) {
      return false
    }
  
    const calleeName = firstArgPath.node.callee.name
  
    if (!calleeName.includes('templateObject')) {
      return false
    }
  
    const bindingPath = path.scope.getBinding(calleeName).path
  
    if (!bindingPath.isFunction()) {
      return false
    }
  
    const functionBody = bindingPath.get('body.body')
  
    if (!functionBody[0].isVariableDeclaration()) {
      return false
    }
  
    const declarationInit = functionBody[0].get('declarations')[0].get('init')
  
    if (!declarationInit.isCallExpression()) {
      return false
    }
  
    const declarationInitArguments = declarationInit.get('arguments')
  
    if (
      declarationInitArguments.length === 0 ||
      declarationInitArguments.length > 2 ||
      declarationInitArguments.some(argPath => !argPath.isArrayExpression())
    ) {
      return false
    }
  
    return true
  }