wip: ignore non-ref const mutation cases in codegen
This commit is contained in:
parent
8567feb2aa
commit
64160e89cc
@ -66,7 +66,10 @@ export interface CodegenResult {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export interface CodegenContext
|
export interface CodegenContext
|
||||||
extends Omit<Required<CodegenOptions>, 'bindingMetadata' | 'inline'> {
|
extends Omit<
|
||||||
|
Required<CodegenOptions>,
|
||||||
|
'bindingMetadata' | 'inline' | 'isTS'
|
||||||
|
> {
|
||||||
source: string
|
source: string
|
||||||
code: string
|
code: string
|
||||||
line: number
|
line: number
|
||||||
@ -214,29 +217,33 @@ export function generate(
|
|||||||
genFunctionPreamble(ast, preambleContext)
|
genFunctionPreamble(ast, preambleContext)
|
||||||
}
|
}
|
||||||
|
|
||||||
// binding optimizations
|
const args = ssr ? ['_ctx', '_push', '_parent', '_attrs'] : ['_ctx', '_cache']
|
||||||
const optimizeSources =
|
if (!__BROWSER__ && options.bindingMetadata && !options.inline) {
|
||||||
options.bindingMetadata && !options.inline
|
// binding optimization args
|
||||||
? `, $props, $setup, $data, $options`
|
args.push('$props', '$setup', '$data', '$options')
|
||||||
: ``
|
}
|
||||||
|
const signature =
|
||||||
|
!__BROWSER__ && options.isTS
|
||||||
|
? args.map(arg => `${arg}: any`).join(',')
|
||||||
|
: args.join(',')
|
||||||
// enter render function
|
// enter render function
|
||||||
if (!ssr) {
|
if (!ssr) {
|
||||||
if (isSetupInlined) {
|
if (isSetupInlined) {
|
||||||
if (genScopeId) {
|
if (genScopeId) {
|
||||||
push(`${PURE_ANNOTATION}_withId(`)
|
push(`${PURE_ANNOTATION}_withId(`)
|
||||||
}
|
}
|
||||||
push(`(_ctx, _cache${optimizeSources}) => {`)
|
push(`(${signature}) => {`)
|
||||||
} else {
|
} else {
|
||||||
if (genScopeId) {
|
if (genScopeId) {
|
||||||
push(`const render = ${PURE_ANNOTATION}_withId(`)
|
push(`const render = ${PURE_ANNOTATION}_withId(`)
|
||||||
}
|
}
|
||||||
push(`function render(_ctx, _cache${optimizeSources}) {`)
|
push(`function render(${signature}) {`)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (genScopeId) {
|
if (genScopeId) {
|
||||||
push(`const ssrRender = ${PURE_ANNOTATION}_withId(`)
|
push(`const ssrRender = ${PURE_ANNOTATION}_withId(`)
|
||||||
}
|
}
|
||||||
push(`function ssrRender(_ctx, _push, _parent, _attrs${optimizeSources}) {`)
|
push(`function ssrRender(${signature}) {`)
|
||||||
}
|
}
|
||||||
indent()
|
indent()
|
||||||
|
|
||||||
|
@ -124,6 +124,10 @@ interface SharedTransformCodegenOptions {
|
|||||||
* This allows the function to directly access setup() local bindings.
|
* This allows the function to directly access setup() local bindings.
|
||||||
*/
|
*/
|
||||||
inline?: boolean
|
inline?: boolean
|
||||||
|
/**
|
||||||
|
* Indicates that transforms and codegen should try to output valid TS code
|
||||||
|
*/
|
||||||
|
isTS?: boolean
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface TransformOptions extends SharedTransformCodegenOptions {
|
export interface TransformOptions extends SharedTransformCodegenOptions {
|
||||||
@ -195,10 +199,6 @@ export interface TransformOptions extends SharedTransformCodegenOptions {
|
|||||||
* needed to render inline CSS variables on component root
|
* needed to render inline CSS variables on component root
|
||||||
*/
|
*/
|
||||||
ssrCssVars?: string
|
ssrCssVars?: string
|
||||||
/**
|
|
||||||
* Indicates that transforms should try to output valid TS code
|
|
||||||
*/
|
|
||||||
isTS?: boolean
|
|
||||||
onError?: (error: CompilerError) => void
|
onError?: (error: CompilerError) => void
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -118,38 +118,32 @@ export function processExpression(
|
|||||||
// setup inline mode
|
// setup inline mode
|
||||||
if (type === BindingTypes.SETUP_CONST) {
|
if (type === BindingTypes.SETUP_CONST) {
|
||||||
return raw
|
return raw
|
||||||
} else if (type === BindingTypes.SETUP_REF) {
|
} else if (
|
||||||
|
type === BindingTypes.SETUP_REF ||
|
||||||
|
type === BindingTypes.SETUP_MAYBE_REF
|
||||||
|
) {
|
||||||
|
// const binding that may or may not be ref
|
||||||
|
// if it's not a ref, then assignments don't make sense -
|
||||||
|
// so we ignore the non-ref assignment case and generate code
|
||||||
|
// that assumes the value to be a ref for more efficiency
|
||||||
return isAssignmentLVal || isUpdateArg
|
return isAssignmentLVal || isUpdateArg
|
||||||
? `${raw}.value`
|
? `${raw}.value`
|
||||||
: `${context.helperString(UNREF)}(${raw})`
|
: `${context.helperString(UNREF)}(${raw})`
|
||||||
} else if (
|
} else if (type === BindingTypes.SETUP_LET) {
|
||||||
type === BindingTypes.SETUP_MAYBE_REF ||
|
|
||||||
type === BindingTypes.SETUP_LET
|
|
||||||
) {
|
|
||||||
if (isAssignmentLVal) {
|
if (isAssignmentLVal) {
|
||||||
if (type === BindingTypes.SETUP_MAYBE_REF) {
|
// let binding.
|
||||||
// const binding that may or may not be ref
|
// this is a bit more tricky as we need to cover the case where
|
||||||
// if it's not a ref, then the assignment doesn't make sense so
|
// let is a local non-ref value, and we need to replicate the
|
||||||
// just no-op it
|
// right hand side value.
|
||||||
// x = y ---> !isRef(x) ? null : x.value = y
|
// x = y --> isRef(x) ? x.value = y : x = y
|
||||||
return `!${context.helperString(
|
const rVal = (parent as AssignmentExpression).right
|
||||||
IS_REF
|
const rExp = rawExp.slice(rVal.start! - 1, rVal.end! - 1)
|
||||||
)}(${raw}) ? null : ${raw}.value`
|
const rExpString = stringifyExpression(
|
||||||
} else {
|
processExpression(createSimpleExpression(rExp, false), context)
|
||||||
// let binding.
|
)
|
||||||
// this is a bit more tricky as we need to cover the case where
|
return `${context.helperString(IS_REF)}(${raw})${
|
||||||
// let is a local non-ref value, and we need to replicate the
|
context.isTS ? ` //@ts-ignore\n` : ``
|
||||||
// right hand side value.
|
} ? ${raw}.value = ${rExpString} : ${raw}`
|
||||||
// x = y --> isRef(x) ? x.value = y : x = y
|
|
||||||
const rVal = (parent as AssignmentExpression).right
|
|
||||||
const rExp = rawExp.slice(rVal.start! - 1, rVal.end! - 1)
|
|
||||||
const rExpString = stringifyExpression(
|
|
||||||
processExpression(createSimpleExpression(rExp, false), context)
|
|
||||||
)
|
|
||||||
return `${context.helperString(IS_REF)}(${raw})${
|
|
||||||
context.isTS ? ` //@ts-ignore\n` : ``
|
|
||||||
} ? ${raw}.value = ${rExpString} : ${raw}`
|
|
||||||
}
|
|
||||||
} else if (isUpdateArg) {
|
} else if (isUpdateArg) {
|
||||||
// make id replace parent in the code range so the raw update operator
|
// make id replace parent in the code range so the raw update operator
|
||||||
// is removed
|
// is removed
|
||||||
@ -158,21 +152,11 @@ export function processExpression(
|
|||||||
const { prefix: isPrefix, operator } = parent as UpdateExpression
|
const { prefix: isPrefix, operator } = parent as UpdateExpression
|
||||||
const prefix = isPrefix ? operator : ``
|
const prefix = isPrefix ? operator : ``
|
||||||
const postfix = isPrefix ? `` : operator
|
const postfix = isPrefix ? `` : operator
|
||||||
if (type === BindingTypes.SETUP_MAYBE_REF) {
|
// let binding.
|
||||||
// const binding that may or may not be ref
|
// x++ --> isRef(a) ? a.value++ : a++
|
||||||
// if it's not a ref, then the assignment doesn't make sense so
|
return `${context.helperString(IS_REF)}(${raw})${
|
||||||
// just no-op it
|
context.isTS ? ` //@ts-ignore\n` : ``
|
||||||
// x++ ---> !isRef(x) ? null : x.value++
|
} ? ${prefix}${raw}.value${postfix} : ${prefix}${raw}${postfix}`
|
||||||
return `!${context.helperString(
|
|
||||||
IS_REF
|
|
||||||
)}(${raw}) ? null : ${prefix}${raw}.value${postfix}`
|
|
||||||
} else {
|
|
||||||
// let binding.
|
|
||||||
// x++ --> isRef(a) ? a.value++ : a++
|
|
||||||
return `${context.helperString(IS_REF)}(${raw})${
|
|
||||||
context.isTS ? ` //@ts-ignore\n` : ``
|
|
||||||
} ? ${prefix}${raw}.value${postfix} : ${prefix}${raw}${postfix}`
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
return `${context.helperString(UNREF)}(${raw})`
|
return `${context.helperString(UNREF)}(${raw})`
|
||||||
}
|
}
|
||||||
|
@ -124,7 +124,9 @@ export const transformOn: DirectiveTransform = (
|
|||||||
exp = createCompoundExpression([
|
exp = createCompoundExpression([
|
||||||
`${
|
`${
|
||||||
isInlineStatement
|
isInlineStatement
|
||||||
? `$event`
|
? !__BROWSER__ && context.isTS
|
||||||
|
? `($event: any)`
|
||||||
|
: `$event`
|
||||||
: `${
|
: `${
|
||||||
!__BROWSER__ && context.isTS ? `\n//@ts-ignore\n` : ``
|
!__BROWSER__ && context.isTS ? `\n//@ts-ignore\n` : ``
|
||||||
}(...args)`
|
}(...args)`
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import {
|
import {
|
||||||
ComponentPublicInstance,
|
|
||||||
getCurrentInstance,
|
getCurrentInstance,
|
||||||
onMounted,
|
onMounted,
|
||||||
warn,
|
warn,
|
||||||
@ -14,9 +13,7 @@ import { ShapeFlags } from '@vue/shared'
|
|||||||
* Runtime helper for SFC's CSS variable injection feature.
|
* Runtime helper for SFC's CSS variable injection feature.
|
||||||
* @private
|
* @private
|
||||||
*/
|
*/
|
||||||
export function useCssVars(
|
export function useCssVars(getter: (ctx: any) => Record<string, string>) {
|
||||||
getter: (ctx: ComponentPublicInstance) => Record<string, string>
|
|
||||||
) {
|
|
||||||
const instance = getCurrentInstance()
|
const instance = getCurrentInstance()
|
||||||
/* istanbul ignore next */
|
/* istanbul ignore next */
|
||||||
if (!instance) {
|
if (!instance) {
|
||||||
|
Loading…
Reference in New Issue
Block a user