diff options
| author | 2021-04-30 16:33:35 -0500 | |
|---|---|---|
| committer | 2021-04-30 16:33:35 -0500 | |
| commit | 4df1347156cf2632ea2f3475d3a5f8f08d197cc3 (patch) | |
| tree | 9d50de89dfe62827c32a8a4046120af4ab61dc0c /src/compiler/index.ts | |
| parent | 1d498facc8f78a3ffbfecd05cc6ecd45e8a4a1ae (diff) | |
| download | astro-4df1347156cf2632ea2f3475d3a5f8f08d197cc3.tar.gz astro-4df1347156cf2632ea2f3475d3a5f8f08d197cc3.tar.zst astro-4df1347156cf2632ea2f3475d3a5f8f08d197cc3.zip | |
Migrate to `yarn` monorepo (#157)
* chore: use monorepo
* chore: scaffold astro-scripts
* chore: move tests inside packages/astro
* chore: refactor tests, add scripts
* chore: move parser to own module
* chore: move runtime to packages/astro
* fix: move parser to own package
* test: fix prettier-plugin-astro tests
* fix: tests
* chore: update package-lock
* chore: add changesets
* fix: cleanup examples
* fix: starter example
* chore: update changeset config
* chore: update changeset config
* chore: setup changeset release workflow
* chore: bump lockfiles
* chore: prism => astro-prism
* fix: tsc --emitDeclarationOnly
* chore: final cleanup, switch to yarn
* chore: add lerna
* chore: update workflows to yarn
* chore: update workflows
* chore: remove lint workflow
* chore: add astro-dev script
* chore: add symlinked README
Diffstat (limited to 'src/compiler/index.ts')
| -rw-r--r-- | src/compiler/index.ts | 176 | 
1 files changed, 0 insertions, 176 deletions
| diff --git a/src/compiler/index.ts b/src/compiler/index.ts deleted file mode 100644 index 7e7bfc4c6..000000000 --- a/src/compiler/index.ts +++ /dev/null @@ -1,176 +0,0 @@ -import type { CompileResult, TransformResult } from '../@types/astro'; -import type { CompileOptions } from '../@types/compiler.js'; - -import path from 'path'; -import micromark from 'micromark'; -import gfmSyntax from 'micromark-extension-gfm'; -import matter from 'gray-matter'; -import gfmHtml from 'micromark-extension-gfm/html.js'; - -import { parse } from '../parser/index.js'; -import { createMarkdownHeadersCollector } from './markdown/micromark-collect-headers.js'; -import { encodeMarkdown } from './markdown/micromark-encode.js'; -import { encodeAstroMdx } from './markdown/micromark-mdx-astro.js'; -import { transform } from './transform/index.js'; -import { codegen } from './codegen/index.js'; - -/** Return Astro internal import URL */ -function internalImport(internalPath: string) { -  return `/_astro_internal/${internalPath}`; -} - -interface ConvertAstroOptions { -  compileOptions: CompileOptions; -  filename: string; -  fileID: string; -} - -/** - * .astro -> .jsx - * Core function processing .astro files. Initiates all 3 phases of compilation: - * 1. Parse - * 2. Transform - * 3. Codegen - */ -async function convertAstroToJsx(template: string, opts: ConvertAstroOptions): Promise<TransformResult> { -  const { filename } = opts; - -  // 1. Parse -  const ast = parse(template, { -    filename, -  }); - -  // 2. Transform the AST -  await transform(ast, opts); - -  // 3. Turn AST into JSX -  return await codegen(ast, opts); -} - -/** - * .md -> .astro source - */ -export async function convertMdToAstroSource(contents: string): Promise<string> { -  const { data: frontmatterData, content } = matter(contents); -  const { headers, headersExtension } = createMarkdownHeadersCollector(); -  const { htmlAstro, mdAstro } = encodeAstroMdx(); -  const mdHtml = micromark(content, { -    allowDangerousHtml: true, -    extensions: [gfmSyntax(), ...htmlAstro], -    htmlExtensions: [gfmHtml, encodeMarkdown, headersExtension, mdAstro], -  }); - -  // TODO: Warn if reserved word is used in "frontmatterData" -  const contentData: any = { -    ...frontmatterData, -    headers, -    source: content, -  }; - -  let imports = ''; -  for (let [ComponentName, specifier] of Object.entries(frontmatterData.import || {})) { -    imports += `import ${ComponentName} from '${specifier}';\n`; -  } - -  // </script> can't be anywhere inside of a JS string, otherwise the HTML parser fails. -  // Break it up here so that the HTML parser won't detect it. -  const stringifiedSetupContext = JSON.stringify(contentData).replace(/\<\/script\>/g, `</scrip" + "t>`); - -  return `--- -  ${imports} -  ${frontmatterData.layout ? `import {__renderPage as __layout} from '${frontmatterData.layout}';` : 'const __layout = undefined;'} -  export const __content = ${stringifiedSetupContext}; ---- -<section>${mdHtml}</section>`; -} - -/** - * .md -> .jsx - * Core function processing Markdown, but along the way also calls convertAstroToJsx(). - */ -async function convertMdToJsx( -  contents: string, -  { compileOptions, filename, fileID }: { compileOptions: CompileOptions; filename: string; fileID: string } -): Promise<TransformResult> { -  const raw = await convertMdToAstroSource(contents); -  const convertOptions = { compileOptions, filename, fileID }; -  return await convertAstroToJsx(raw, convertOptions); -} - -type SupportedExtensions = '.astro' | '.md'; - -/** Given a file, process it either as .astro or .md. */ -async function transformFromSource( -  contents: string, -  { compileOptions, filename, projectRoot }: { compileOptions: CompileOptions; filename: string; projectRoot: string } -): Promise<TransformResult> { -  const fileID = path.relative(projectRoot, filename); -  switch (path.extname(filename) as SupportedExtensions) { -    case '.astro': -      return await convertAstroToJsx(contents, { compileOptions, filename, fileID }); -    case '.md': -      return await convertMdToJsx(contents, { compileOptions, filename, fileID }); -    default: -      throw new Error('Not Supported!'); -  } -} - -/** Return internal code that gets processed in Snowpack */ -export async function compileComponent( -  source: string, -  { compileOptions, filename, projectRoot }: { compileOptions: CompileOptions; filename: string; projectRoot: string } -): Promise<CompileResult> { -  const result = await transformFromSource(source, { compileOptions, filename, projectRoot }); - -  // return template -  let modJsx = ` -import fetch from 'node-fetch'; - -// <script astro></script> -${result.imports.join('\n')} - -// \`__render()\`: Render the contents of the Astro module. -import { h, Fragment } from '${internalImport('h.js')}'; -const __astroRequestSymbol = Symbol('astro.request'); -async function __render(props, ...children) { -  const Astro = { -    request: props[__astroRequestSymbol] -  }; - -  ${result.script} -  return h(Fragment, null, ${result.html}); -} -export default __render; - -${result.createCollection || ''} - -// \`__renderPage()\`: Render the contents of the Astro module as a page. This is a special flow, -// triggered by loading a component directly by URL. -export async function __renderPage({request, children, props}) { -  const currentChild = { -    layout: typeof __layout === 'undefined' ? undefined : __layout, -    content: typeof __content === 'undefined' ? undefined : __content, -    __render, -  }; - -  props[__astroRequestSymbol] = request; -  const childBodyResult = await currentChild.__render(props, children); - -  // find layout, if one was given. -  if (currentChild.layout) { -    return currentChild.layout({ -      request, -      props: {content: currentChild.content}, -      children: [childBodyResult], -    }); -  } - -  return childBodyResult; -};\n`; - -  return { -    result, -    contents: modJsx, -    css: result.css, -  }; -} | 
