refactor(compiler-sfc): adjust sfc compileScript usage

This commit is contained in:
Evan You 2020-07-15 16:27:21 -04:00
parent 03f924e48a
commit 11727b9e1e
2 changed files with 40 additions and 54 deletions

View File

@ -1,9 +1,10 @@
import { parse, SFCScriptCompileOptions } from '../src'
import { parse, SFCScriptCompileOptions, compileScript } from '../src'
import { parse as babelParse } from '@babel/parser'
import { babelParserDefautPlugins } from '@vue/shared'
function compile(src: string, options?: SFCScriptCompileOptions) {
return parse(src, options).descriptor.scriptTransformed!
const { descriptor } = parse(src)
return compileScript(descriptor, options)
}
function assertCode(code: string) {
@ -370,24 +371,23 @@ describe('SFC compile <script setup>', () => {
describe('errors', () => {
test('<script> and <script setup> must have same lang', () => {
expect(
parse(`<script>foo()</script><script setup lang="ts">bar()</script>`)
.errors[0].message
).toMatch(`<script> and <script setup> must have the same language type`)
expect(() =>
compile(`<script>foo()</script><script setup lang="ts">bar()</script>`)
).toThrow(`<script> and <script setup> must have the same language type`)
})
test('export local as default', () => {
expect(
parse(`<script setup>
expect(() =>
compile(`<script setup>
const bar = 1
export { bar as default }
</script>`).errors[0].message
).toMatch(`Cannot export locally defined variable as default`)
</script>`)
).toThrow(`Cannot export locally defined variable as default`)
})
test('export default referencing local var', () => {
expect(
parse(`<script setup>
expect(() =>
compile(`<script setup>
const bar = 1
export default {
props: {
@ -396,19 +396,19 @@ describe('SFC compile <script setup>', () => {
}
}
}
</script>`).errors[0].message
).toMatch(`cannot reference locally declared variables`)
</script>`)
).toThrow(`cannot reference locally declared variables`)
})
test('export default referencing exports', () => {
expect(
parse(`<script setup>
expect(() =>
compile(`<script setup>
export const bar = 1
export default {
props: bar
}
</script>`).errors[0].message
).toMatch(`cannot reference locally declared variables`)
</script>`)
).toThrow(`cannot reference locally declared variables`)
})
test('should allow export default referencing scope var', () => {
@ -458,19 +458,19 @@ describe('SFC compile <script setup>', () => {
})
test('error on duplicated default export', () => {
expect(
parse(`
expect(() =>
compile(`
<script>
export default {}
</script>
<script setup>
export default {}
</script>
`).errors[0].message
).toMatch(`Default export is already declared`)
`)
).toThrow(`Default export is already declared`)
expect(
parse(`
expect(() =>
compile(`
<script>
export default {}
</script>
@ -478,33 +478,33 @@ describe('SFC compile <script setup>', () => {
const x = {}
export { x as default }
</script>
`).errors[0].message
).toMatch(`Default export is already declared`)
`)
).toThrow(`Default export is already declared`)
expect(
parse(`
expect(() =>
compile(`
<script>
export default {}
</script>
<script setup>
export { x as default } from './y'
</script>
`).errors[0].message
).toMatch(`Default export is already declared`)
`)
).toThrow(`Default export is already declared`)
expect(
parse(`
expect(() =>
compile(`
<script>
export { x as default } from './y'
</script>
<script setup>
export default {}
</script>
`).errors[0].message
).toMatch(`Default export is already declared`)
`)
).toThrow(`Default export is already declared`)
expect(
parse(`
expect(() =>
compile(`
<script>
const x = {}
export { x as default }
@ -512,8 +512,8 @@ describe('SFC compile <script setup>', () => {
<script setup>
export default {}
</script>
`).errors[0].message
).toMatch(`Default export is already declared`)
`)
).toThrow(`Default export is already declared`)
})
})
})

View File

@ -9,9 +9,8 @@ import {
import * as CompilerDOM from '@vue/compiler-dom'
import { RawSourceMap, SourceMapGenerator } from 'source-map'
import { TemplateCompiler } from './compileTemplate'
import { compileScript, SFCScriptCompileOptions } from './compileScript'
export interface SFCParseOptions extends SFCScriptCompileOptions {
export interface SFCParseOptions {
filename?: string
sourceMap?: boolean
sourceRoot?: string
@ -53,7 +52,6 @@ export interface SFCDescriptor {
template: SFCTemplateBlock | null
script: SFCScriptBlock | null
scriptSetup: SFCScriptBlock | null
scriptTransformed: SFCScriptBlock | null
styles: SFCStyleBlock[]
customBlocks: SFCBlock[]
}
@ -79,8 +77,7 @@ export function parse(
filename = 'component.vue',
sourceRoot = '',
pad = false,
compiler = CompilerDOM,
babelParserPlugins
compiler = CompilerDOM
}: SFCParseOptions = {}
): SFCParseResult {
const sourceKey =
@ -96,7 +93,6 @@ export function parse(
template: null,
script: null,
scriptSetup: null,
scriptTransformed: null,
styles: [],
customBlocks: []
}
@ -198,16 +194,6 @@ export function parse(
descriptor.styles.forEach(genMap)
}
if (descriptor.script || descriptor.scriptSetup) {
try {
descriptor.scriptTransformed = compileScript(descriptor, {
babelParserPlugins
})
} catch (e) {
errors.push(e)
}
}
const result = {
descriptor,
errors