{
  "url": "https://unifast.dev/pt-BR/docs/introduction/key-concepts/",
  "locale": "pt-BR",
  "title": "Conceitos Principais",
  "description": "Entenda a pipeline de compilação multi-estágio do unifast, os passes integrados e como funcionam as transformações de MdAst e HAst.",
  "section": "introduction",
  "body": "O unifast compila Markdown através de uma pipeline multi-estágio. Entender esses estágios te ajuda a configurar o compilador e a escolher os plugins certos.\n\n### Pipeline de Compilação\n\n```\nInput text\n  → Parse (Markdown or MDX)\n  → IR0: MdAst (Markdown structure)\n  → Normalize + Built-in MdAst passes\n  → Lower to IR1: HAst (HTML structure)\n  → HAst passes (sanitize, highlight, etc.)\n  → Emit (HTML string)\n```\n\nCada estágio transforma o documento através de uma representação intermediária (IR).\n\n### Representações Intermediárias\n\n| IR | Nome | Propósito |\n|----|------|---------|\n| **IR0** | MdAst | Estrutura Markdown - headings, parágrafos, listas, code blocks |\n| **IR1** | HAst | Estrutura HTML - elementos, atributos, nós de texto |\n| **IR2** | JsAst | Apenas MDX - imports ESM e expressões JSX |\n\nO parser produz **MdAst**, que é então rebaixado para **HAst** para a emissão de HTML. Entradas MDX produzem adicionalmente nós **JsAst** para saída JavaScript.\n\n### Passes\n\nPasses são transformações aplicadas ao AST em fases específicas. O unifast tem passes integrados para tarefas comuns:\n\n**Passes MdAst** (antes do rebaixamento para HTML):\n\n- **Normalize** - Estrutura consistente para os passes posteriores\n- **Slug** - Gera IDs de headings a partir do conteúdo textual\n- **TOC** - Extrai a table of contents a partir dos headings\n- **Definition Resolution** - Resolve definições de referências de links/imagens\n\n**Passes HAst** (após o rebaixamento para HTML):\n\n- **Sanitize** - Remove elementos e atributos HTML não permitidos\n- **Highlight** - Aplica syntax highlighting aos code blocks\n- **Cleanup** - Remove nós e whitespace desnecessários\n\nOs passes são ordenados por fase - você não precisa se preocupar com a ordem de execução.\n\n### Plugins\n\nPlugins são pacotes TypeScript que configuram os passes integrados. Eles não executam JavaScript arbitrário durante a compilação - em vez disso, definem opções que controlam como o core em Rust processa seu documento.\n\n```ts\nimport { compile, gfm, sanitize } from \"@unifast/node\";\n\nconst result = compile(source, {\n  plugins: [gfm(), sanitize()],\n});\n```\n\nCada plugin retorna um objeto de configuração que é mesclado nas opções de compilação antes do core em Rust rodar. Isso mantém o hot path inteiramente em código nativo.\n\n### Formatos de Saída\n\nO compilador suporta múltiplos formatos de saída via a opção `outputKind`:\n\n| Formato | Descrição |\n|--------|-------------|\n| `\"html\"` | String HTML (padrão) |\n| `\"hast\"` | JSON HAst - o AST HTML para renderização customizada |\n| `\"mdast\"` | JSON MdAst - o AST Markdown para análise |\n| `\"mdx-js\"` | String de módulo JavaScript (apenas MDX) |\n\n### Diagnósticos\n\nO compilador reporta problemas via o array `diagnostics` no resultado. Cada diagnóstico inclui um nível de severidade, mensagem e um span de origem opcional para localização precisa do erro.\n\n```ts\nconst result = compile(source);\n\nfor (const d of result.diagnostics) {\n  console.warn(`[${d.level}] ${d.message}`);\n}\n```",
  "alternates": [
    {
      "locale": "en",
      "url": "https://unifast.dev/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/docs/introduction/key-concepts.json"
    },
    {
      "locale": "ja",
      "url": "https://unifast.dev/ja/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/ja/docs/introduction/key-concepts.json"
    },
    {
      "locale": "zh-CN",
      "url": "https://unifast.dev/zh-CN/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/zh-CN/docs/introduction/key-concepts.json"
    },
    {
      "locale": "zh-TW",
      "url": "https://unifast.dev/zh-TW/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/zh-TW/docs/introduction/key-concepts.json"
    },
    {
      "locale": "ko",
      "url": "https://unifast.dev/ko/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/ko/docs/introduction/key-concepts.json"
    },
    {
      "locale": "fr",
      "url": "https://unifast.dev/fr/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/fr/docs/introduction/key-concepts.json"
    },
    {
      "locale": "it",
      "url": "https://unifast.dev/it/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/it/docs/introduction/key-concepts.json"
    },
    {
      "locale": "es",
      "url": "https://unifast.dev/es/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/es/docs/introduction/key-concepts.json"
    },
    {
      "locale": "pt-BR",
      "url": "https://unifast.dev/pt-BR/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/pt-BR/docs/introduction/key-concepts.json"
    },
    {
      "locale": "de",
      "url": "https://unifast.dev/de/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/de/docs/introduction/key-concepts.json"
    },
    {
      "locale": "ru",
      "url": "https://unifast.dev/ru/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/ru/docs/introduction/key-concepts.json"
    },
    {
      "locale": "hi",
      "url": "https://unifast.dev/hi/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/hi/docs/introduction/key-concepts.json"
    },
    {
      "locale": "id",
      "url": "https://unifast.dev/id/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/id/docs/introduction/key-concepts.json"
    },
    {
      "locale": "tr",
      "url": "https://unifast.dev/tr/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/tr/docs/introduction/key-concepts.json"
    },
    {
      "locale": "vi",
      "url": "https://unifast.dev/vi/docs/introduction/key-concepts/",
      "api": "https://unifast.dev//api/vi/docs/introduction/key-concepts.json"
    }
  ]
}
