UNPKG

vue

Version:
93 lines (87 loc) 3.49 kB
import { compile } from '@vue/compiler-dom'; import * as runtimeDom from '@vue/runtime-dom'; import { warn, registerRuntimeCompiler } from '@vue/runtime-dom'; export * from '@vue/runtime-dom'; const range = 2; function generateCodeFrame(source, start = 0, end = source.length) { const lines = source.split(/\r?\n/); let count = 0; const res = []; for (let i = 0; i < lines.length; i++) { count += lines[i].length + 1; if (count >= start) { for (let j = i - range; j <= i + range || end > count; j++) { if (j < 0 || j >= lines.length) continue; const line = j + 1; res.push(`${line}${' '.repeat(3 - String(line).length)}| ${lines[j]}`); const lineLength = lines[j].length; if (j === i) { // push underline const pad = start - (count - lineLength) + 1; const length = Math.max(1, end > count ? lineLength - pad : end - start); res.push(` | ` + ' '.repeat(pad) + '^'.repeat(length)); } else if (j > i) { if (end > count) { const length = Math.max(Math.min(end - count, lineLength), 1); res.push(` | ` + '^'.repeat(length)); } count += lineLength + 1; } } break; } } return res.join('\n'); } const EMPTY_OBJ = (process.env.NODE_ENV !== 'production') ? Object.freeze({}) : {}; const NOOP = () => { }; const isString = (val) => typeof val === 'string'; if ( (process.env.NODE_ENV !== 'production')) { console[console.info ? 'info' : 'log'](`You are running a development build of Vue.\n` + `Make sure to use the production build (*.prod.js) when deploying for production.`); } // This entry is the "full-build" that includes both the runtime const compileCache = Object.create(null); function compileToFunction(template, options) { if (!isString(template)) { if (template.nodeType) { template = template.innerHTML; } else { (process.env.NODE_ENV !== 'production') && warn(`invalid template option: `, template); return NOOP; } } const key = template; const cached = compileCache[key]; if (cached) { return cached; } if (template[0] === '#') { const el = document.querySelector(template); if ((process.env.NODE_ENV !== 'production') && !el) { warn(`Template element not found or is empty: ${template}`); } template = el ? el.innerHTML : ``; } const { code } = compile(template, { hoistStatic: true, onError(err) { if ((process.env.NODE_ENV !== 'production')) { const message = `Template compilation error: ${err.message}`; const codeFrame = err.loc && generateCodeFrame(template, err.loc.start.offset, err.loc.end.offset); warn(codeFrame ? `${message}\n${codeFrame}` : message); } }, ...options }); const render = new Function('Vue', code)(runtimeDom); return (compileCache[key] = render); } registerRuntimeCompiler(compileToFunction); export { compileToFunction as compile };