<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>CLI on Allyson Oliveira</title><link>https://www.allysonoliveira.com.br/tags/cli/</link><description>Recent content in CLI on Allyson Oliveira</description><generator>Hugo -- gohugo.io</generator><language>pt-br</language><lastBuildDate>Mon, 20 Apr 2026 10:00:00 +0000</lastBuildDate><atom:link href="https://www.allysonoliveira.com.br/tags/cli/index.xml" rel="self" type="application/rss+xml"/><item><title>Kiro: da IDE ao terminal — spec-driven development, agents e o ecossistema completo</title><link>https://www.allysonoliveira.com.br/posts/kiro-cli-features/</link><pubDate>Mon, 20 Apr 2026 10:00:00 +0000</pubDate><guid>https://www.allysonoliveira.com.br/posts/kiro-cli-features/</guid><description>&lt;p>O &lt;strong>Kiro&lt;/strong> é um ecossistema de desenvolvimento assistido por IA criado pela AWS que existe em duas formas: uma &lt;strong>IDE&lt;/strong> (fork do VS Code) focada em spec-driven development, e uma &lt;strong>CLI&lt;/strong> poderosa que roda direto no terminal. Ambas compartilham conceitos como agents, steering files, hooks e MCP servers, mas cada uma tem seu ponto forte. Neste post vou apresentar as principais features de ambas.&lt;/p>
&lt;h2 id="kiro-ide-spec-driven-development">Kiro IDE: spec-driven development
&lt;/h2>&lt;p>O Kiro IDE foi lançado em preview em julho de 2025. É um fork do Code OSS (a base open-source do VS Code) e faz uma aposta específica: o maior problema das ferramentas de IA para código não é que elas não conseguem gerar código — é que geram código &lt;strong>sem um plano&lt;/strong>.&lt;/p>
&lt;h3 id="o-que-é-spec-driven-development-sdd">O que é Spec-Driven Development (SDD)
&lt;/h3>&lt;p>Enquanto o &amp;ldquo;vibe coding&amp;rdquo; (prompting direto e ver o que sai) funciona bem para protótipos, ele tem problemas sérios em projetos reais: código verboso, inconsistente, sem aderência a padrões de arquitetura e sem testes. O SDD resolve isso adicionando uma &lt;strong>fase de planejamento antes de qualquer código ser escrito&lt;/strong>.&lt;/p>
&lt;p>O fluxo funciona assim:&lt;/p>
&lt;ol>
&lt;li>&lt;strong>Você descreve a feature&lt;/strong> em linguagem natural — &amp;ldquo;Adicionar um sistema de reviews para produtos&amp;rdquo; já é suficiente&lt;/li>
&lt;li>&lt;strong>Kiro gera três artefatos&lt;/strong> dentro de &lt;code>.kiro/specs/&amp;lt;feature&amp;gt;/&lt;/code>:
&lt;ul>
&lt;li>&lt;code>requirements.md&lt;/code> — user stories com critérios de aceitação usando notação EARS&lt;/li>
&lt;li>&lt;code>design.md&lt;/code> — documento de design técnico com diagramas e schemas&lt;/li>
&lt;li>&lt;code>tasks.md&lt;/code> — lista numerada de tarefas de implementação&lt;/li>
&lt;/ul>
&lt;/li>
&lt;li>&lt;strong>Você revisa e edita&lt;/strong> os specs antes de qualquer código ser escrito&lt;/li>
&lt;li>&lt;strong>O agent implementa&lt;/strong> tarefa por tarefa, seguindo o plano&lt;/li>
&lt;/ol>
&lt;p>O ponto crítico: a revisão do spec acontece &lt;strong>antes&lt;/strong> de qualquer código. Corrigir um spec leva 5 minutos. Corrigir três dias de código construído sobre uma premissa errada leva muito mais.&lt;/p>
&lt;h3 id="autopilot">Autopilot
&lt;/h3>&lt;p>Por padrão, o agent pede aprovação a cada ação significativa. O modo &lt;strong>Autopilot&lt;/strong> remove esses checkpoints — o agent executa a lista de tarefas do spec sem pausar. Útil quando você revisou o spec com cuidado e confia no plano de implementação.&lt;/p>
&lt;h3 id="modelos-e-preços">Modelos e preços
&lt;/h3>&lt;p>O Kiro IDE usa Claude Sonnet 4.5 como modelo principal e tem um modo &lt;strong>Auto&lt;/strong> que roteia para o modelo mais custo-efetivo dependendo da complexidade do prompt. O pricing começa com um tier gratuito (50 interações/mês), Pro a $19/mês (1.000 interações) e Pro+ a $39/mês (3.000 interações).&lt;/p>
&lt;h3 id="compatibilidade">Compatibilidade
&lt;/h3>&lt;p>Por ser baseado no Code OSS, o Kiro IDE aceita configurações do VS Code e plugins compatíveis com Open VSX. Se você já tem um &lt;code>.vscode/settings.json&lt;/code>, ele funciona direto.&lt;/p>
&lt;h2 id="kiro-cli-o-poder-no-terminal">Kiro CLI: o poder no terminal
&lt;/h2>&lt;p>O Kiro CLI é a versão terminal do ecossistema. Você inicia uma conversa com &lt;code>kiro-cli chat&lt;/code> e a partir daí pode criar arquivos, refatorar código, rodar testes, investigar bugs, fazer chamadas à AWS e muito mais — tudo sem sair do terminal.&lt;/p>
&lt;p>O diferencial é que ele não é um assistente genérico: você pode configurá-lo profundamente para se adaptar ao seu projeto, stack e fluxo de trabalho.&lt;/p>
&lt;h2 id="agents-personalidades-especializadas">Agents: personalidades especializadas
&lt;/h2>&lt;p>Uma das features mais poderosas do Kiro são os &lt;strong>agents&lt;/strong>. Um agent é um arquivo JSON que define o comportamento do assistente: quais ferramentas ele pode usar, qual o system prompt, quais arquivos de contexto ele carrega e quais integrações ele tem.&lt;/p>
&lt;h3 id="exemplo-agent-de-segurança">Exemplo: agent de segurança
&lt;/h3>&lt;p>Imagine que você quer um agent especializado em security review. Crie &lt;code>.kiro/agents/sec-reviewer.json&lt;/code>:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-json" data-lang="json">&lt;span style="display:flex;">&lt;span>{
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;name&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;sec-reviewer&amp;#34;&lt;/span>,
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;description&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;Security reviewer - analisa código buscando vulnerabilidades&amp;#34;&lt;/span>,
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;prompt&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;You are a senior security engineer. Analyze code for vulnerabilities: injection flaws, broken auth, secrets exposure, insecure dependencies, missing input validation, and OWASP Top 10 issues. Be specific about the risk and suggest fixes with code examples. Never modify files directly — only report findings.&amp;#34;&lt;/span>,
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;tools&amp;#34;&lt;/span>: [&lt;span style="color:#e6db74">&amp;#34;fs_read&amp;#34;&lt;/span>, &lt;span style="color:#e6db74">&amp;#34;grep&amp;#34;&lt;/span>, &lt;span style="color:#e6db74">&amp;#34;glob&amp;#34;&lt;/span>, &lt;span style="color:#e6db74">&amp;#34;code&amp;#34;&lt;/span>],
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;allowedTools&amp;#34;&lt;/span>: [&lt;span style="color:#e6db74">&amp;#34;fs_read&amp;#34;&lt;/span>, &lt;span style="color:#e6db74">&amp;#34;grep&amp;#34;&lt;/span>, &lt;span style="color:#e6db74">&amp;#34;glob&amp;#34;&lt;/span>, &lt;span style="color:#e6db74">&amp;#34;code&amp;#34;&lt;/span>],
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;resources&amp;#34;&lt;/span>: [&lt;span style="color:#e6db74">&amp;#34;file://src/**/*&amp;#34;&lt;/span>, &lt;span style="color:#e6db74">&amp;#34;file://package.json&amp;#34;&lt;/span>, &lt;span style="color:#e6db74">&amp;#34;file://**/requirements.txt&amp;#34;&lt;/span>],
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;keyboardShortcut&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;ctrl+shift+s&amp;#34;&lt;/span>,
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;welcomeMessage&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;Security reviewer ativo. Qual código você quer que eu analise?&amp;#34;&lt;/span>
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>}
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Note que esse agent tem &lt;strong>apenas ferramentas de leitura&lt;/strong> — ele não pode escrever arquivos nem executar comandos. Isso é intencional: um reviewer não deve modificar código, apenas reportar.&lt;/p>
&lt;h3 id="workflow-com-o-agent-de-segurança">Workflow com o agent de segurança
&lt;/h3>&lt;ol>
&lt;li>&lt;strong>Ative o agent&lt;/strong> — &lt;code>/agent swap sec-reviewer&lt;/code> ou &lt;code>Ctrl+Shift+S&lt;/code>&lt;/li>
&lt;li>&lt;strong>Peça a análise&lt;/strong> — &amp;ldquo;Analise o módulo de autenticação em src/auth/&amp;rdquo;&lt;/li>
&lt;li>&lt;strong>O agent investiga&lt;/strong> — ele lê os arquivos, busca padrões perigosos com grep e code intelligence&lt;/li>
&lt;li>&lt;strong>Receba o relatório&lt;/strong> — vulnerabilidades encontradas com severidade, explicação e sugestão de fix&lt;/li>
&lt;li>&lt;strong>Volte ao agent de dev&lt;/strong> — &lt;code>/agent swap&lt;/code> ou o atalho do seu agent principal para implementar as correções&lt;/li>
&lt;/ol>
&lt;p>Você pode ir além e criar um &lt;strong>hook&lt;/strong> que roda o sec-reviewer automaticamente antes de cada commit, ou usar &lt;strong>sub-agents&lt;/strong> para criar um pipeline: dev implementa → sec-reviewer analisa → dev corrige.&lt;/p>
&lt;h3 id="agents-built-in">Agents built-in
&lt;/h3>&lt;p>Existem também agents que já vêm com o Kiro:&lt;/p>
&lt;ul>
&lt;li>&lt;strong>kiro_default&lt;/strong> — o agent padrão com acesso a todas as ferramentas&lt;/li>
&lt;li>&lt;strong>kiro_guide&lt;/strong> — responde perguntas sobre o próprio Kiro usando a documentação embutida&lt;/li>
&lt;li>&lt;strong>kiro_planner&lt;/strong> — ajuda a quebrar ideias em planos de implementação (acessível via &lt;code>/plan&lt;/code>)&lt;/li>
&lt;/ul>
&lt;h2 id="steering-guiando-o-comportamento-do-agente">Steering: guiando o comportamento do agente
&lt;/h2>&lt;p>Os &lt;strong>steering files&lt;/strong> são arquivos Markdown que ficam em &lt;code>.kiro/steering/&lt;/code> e são carregados automaticamente no contexto do agent padrão. Eles servem para dar instruções persistentes ao Kiro sobre como ele deve se comportar no seu projeto — é como um &amp;ldquo;manual do projeto&amp;rdquo; que o assistente sempre consulta.&lt;/p>
&lt;p>Exemplo de um &lt;code>.kiro/steering/project.md&lt;/code>:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-markdown" data-lang="markdown">&lt;span style="display:flex;">&lt;span># Stack
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>&lt;span style="color:#66d9ef">-&lt;/span> Python 3.12, FastAPI, Pydantic v2
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>&lt;span style="color:#66d9ef">-&lt;/span> DynamoDB single-table design (table: AppTable, region: us-east-1)
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>&lt;span style="color:#66d9ef">-&lt;/span> Lambda + API Gateway, deployed via AWS SAM
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>&lt;span style="color:#66d9ef">-&lt;/span> Structured logging via structlog, JSON output
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span># Convenções de código
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>&lt;span style="color:#66d9ef">-&lt;/span> Todas as funções têm type annotations
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>&lt;span style="color:#66d9ef">-&lt;/span> Error responses: {&amp;#34;error&amp;#34;: &amp;#34;SNAKE_CASE_CODE&amp;#34;, &amp;#34;message&amp;#34;: &amp;#34;texto legível&amp;#34;}
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>&lt;span style="color:#66d9ef">-&lt;/span> Testes usam pytest com pytest-anyio para async; fixtures em conftest.py
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>&lt;span style="color:#66d9ef">-&lt;/span> Sem print() — usar logger.info() com campos estruturados
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span># AWS
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>&lt;span style="color:#66d9ef">-&lt;/span> Dev account: 123456789012
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>&lt;span style="color:#66d9ef">-&lt;/span> Prod account: 987654321098
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>&lt;span style="color:#66d9ef">-&lt;/span> IAM com least-privilege; sem wildcard resources em Lambda execution roles
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Com esse arquivo, toda sugestão do Kiro — código, specs, reviews — já segue as convenções do seu projeto. Sem steering files, você corrige as mesmas coisas repetidamente. Com eles, o agent já sabe suas preferências antes de você abrir a boca.&lt;/p>
&lt;h2 id="hooks-automação-em-pontos-chave">Hooks: automação em pontos-chave
&lt;/h2>&lt;p>O sistema de &lt;strong>hooks&lt;/strong> permite executar comandos em momentos específicos do ciclo de vida do agent:&lt;/p>
&lt;ul>
&lt;li>&lt;strong>agentSpawn&lt;/strong> — quando o agent inicializa (ex: rodar &lt;code>git status&lt;/code> para dar contexto)&lt;/li>
&lt;li>&lt;strong>userPromptSubmit&lt;/strong> — quando o usuário envia uma mensagem&lt;/li>
&lt;li>&lt;strong>preToolUse&lt;/strong> — antes de executar uma ferramenta (pode bloquear a execução!)&lt;/li>
&lt;li>&lt;strong>postToolUse&lt;/strong> — depois de executar uma ferramenta&lt;/li>
&lt;li>&lt;strong>stop&lt;/strong> — quando o assistente termina de responder&lt;/li>
&lt;/ul>
&lt;p>Um exemplo prático: você pode criar um hook &lt;code>preToolUse&lt;/code> que valida toda escrita de arquivo antes de acontecer, ou um hook &lt;code>stop&lt;/code> que roda o linter automaticamente depois de cada resposta do Kiro.&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-json" data-lang="json">&lt;span style="display:flex;">&lt;span>{
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;hooks&amp;#34;&lt;/span>: {
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;preToolUse&amp;#34;&lt;/span>: [
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> {
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;matcher&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;fs_write&amp;#34;&lt;/span>,
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;command&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;~/.kiro/hooks/validate-write.sh&amp;#34;&lt;/span>
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> }
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> ],
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;stop&amp;#34;&lt;/span>: [
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> { &lt;span style="color:#f92672">&amp;#34;command&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;cargo fmt --check&amp;#34;&lt;/span> }
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> ]
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> }
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>}
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;h2 id="knowledge-base-memória-persistente-com-busca-semântica">Knowledge Base: memória persistente com busca semântica
&lt;/h2>&lt;p>Por padrão, o Kiro só tem acesso ao que está na janela de contexto — os arquivos carregados, o histórico da conversa e as ferramentas. A &lt;strong>knowledge base&lt;/strong> expande isso: você indexa arquivos do projeto e o Kiro consegue buscar informação relevante sob demanda, sem precisar carregar tudo no contexto de uma vez.&lt;/p>
&lt;p>Na prática, funciona assim: você indexa um diretório de documentação e depois, quando faz uma pergunta, o Kiro busca semanticamente nos arquivos indexados e traz os trechos mais relevantes. É como dar ao assistente uma &amp;ldquo;memória de longo prazo&amp;rdquo; sobre o seu projeto.&lt;/p>
&lt;pre tabindex="0">&lt;code>/knowledge add api-docs docs/api/
/knowledge add architecture docs/architecture/
&lt;/code>&lt;/pre>&lt;p>Para ativar:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-bash" data-lang="bash">&lt;span style="display:flex;">&lt;span>kiro-cli settings chat.enableKnowledge true
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Existem dois tipos de índice:&lt;/p>
&lt;ul>
&lt;li>&lt;strong>Fast&lt;/strong> (BM25) — busca por palavras-chave, rápido e leve. Ideal para logs, configs e codebases grandes&lt;/li>
&lt;li>&lt;strong>Best&lt;/strong> (all-MiniLM-L6-v2) — busca semântica com embeddings, entende contexto e significado. Ideal para documentação e pesquisa&lt;/li>
&lt;/ul>
&lt;p>Cada agent tem sua própria knowledge base &lt;strong>isolada&lt;/strong> — o agent de infra pode ter docs da AWS indexados enquanto o agent de backend tem docs da API. O conteúdo persiste entre sessões, então você indexa uma vez e usa sempre.&lt;/p>
&lt;h2 id="mcp-servers-integrações-externas">MCP Servers: integrações externas
&lt;/h2>&lt;p>O Kiro suporta &lt;strong>MCP (Model Context Protocol) servers&lt;/strong>, que são integrações externas que adicionam ferramentas ao assistente. O ecossistema MCP é compartilhado com outras ferramentas como Claude Code e Cursor, então servidores configurados para uma ferramenta funcionam nas outras.&lt;/p>
&lt;h3 id="mcp-servers-da-aws">MCP Servers da AWS
&lt;/h3>&lt;p>A AWS mantém mais de 60 MCP servers oficiais no &lt;a class="link" href="https://github.com/awslabs/mcp" target="_blank" rel="noopener"
>awslabs/mcp&lt;/a>. Alguns dos mais úteis:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-json" data-lang="json">&lt;span style="display:flex;">&lt;span>{
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;mcpServers&amp;#34;&lt;/span>: {
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;aws-docs&amp;#34;&lt;/span>: {
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;command&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;uvx&amp;#34;&lt;/span>,
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;args&amp;#34;&lt;/span>: [&lt;span style="color:#e6db74">&amp;#34;awslabs.aws-documentation-mcp-server@latest&amp;#34;&lt;/span>]
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> },
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;aws-iac&amp;#34;&lt;/span>: {
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;command&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;uvx&amp;#34;&lt;/span>,
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;args&amp;#34;&lt;/span>: [&lt;span style="color:#e6db74">&amp;#34;awslabs.aws-iac-mcp-server@latest&amp;#34;&lt;/span>]
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> },
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;cfn&amp;#34;&lt;/span>: {
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;command&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;uvx&amp;#34;&lt;/span>,
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;args&amp;#34;&lt;/span>: [&lt;span style="color:#e6db74">&amp;#34;awslabs.cfn-mcp-server@latest&amp;#34;&lt;/span>]
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> }
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> }
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>}
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;ul>
&lt;li>&lt;strong>aws-documentation&lt;/strong> — puxa documentação oficial da AWS em tempo real. Útil para serviços que mudam frequentemente&lt;/li>
&lt;li>&lt;strong>aws-iac&lt;/strong> — assistência para CDK e CloudFormation: validação de templates, troubleshooting de deploys e best practices&lt;/li>
&lt;li>&lt;strong>cfn&lt;/strong> — cria e gerencia mais de 1.100 recursos AWS via Cloud Control API usando linguagem natural&lt;/li>
&lt;/ul>
&lt;h3 id="terraform-mcp-server">Terraform MCP Server
&lt;/h3>&lt;p>O MCP server oficial da HashiCorp conecta o Kiro ao ecossistema Terraform:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-json" data-lang="json">&lt;span style="display:flex;">&lt;span>{
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;mcpServers&amp;#34;&lt;/span>: {
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;terraform&amp;#34;&lt;/span>: {
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;command&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;npx&amp;#34;&lt;/span>,
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;args&amp;#34;&lt;/span>: [&lt;span style="color:#e6db74">&amp;#34;-y&amp;#34;&lt;/span>, &lt;span style="color:#e6db74">&amp;#34;terraform-mcp-server@latest&amp;#34;&lt;/span>]
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> }
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> }
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>}
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Com ele, o Kiro consulta a documentação de providers e módulos do Terraform Registry em tempo real ao gerar configurações de infraestrutura.&lt;/p>
&lt;h3 id="git-e-github">Git e GitHub
&lt;/h3>&lt;div class="highlight">&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-json" data-lang="json">&lt;span style="display:flex;">&lt;span>{
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;mcpServers&amp;#34;&lt;/span>: {
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;git&amp;#34;&lt;/span>: {
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;command&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;mcp-server-git&amp;#34;&lt;/span>,
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;args&amp;#34;&lt;/span>: [&lt;span style="color:#e6db74">&amp;#34;--stdio&amp;#34;&lt;/span>]
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> },
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;github&amp;#34;&lt;/span>: {
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;command&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;npx&amp;#34;&lt;/span>,
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;args&amp;#34;&lt;/span>: [&lt;span style="color:#e6db74">&amp;#34;-y&amp;#34;&lt;/span>, &lt;span style="color:#e6db74">&amp;#34;@modelcontextprotocol/server-github&amp;#34;&lt;/span>],
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;env&amp;#34;&lt;/span>: { &lt;span style="color:#f92672">&amp;#34;GITHUB_TOKEN&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;$GITHUB_TOKEN&amp;#34;&lt;/span> }
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> }
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> }
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>}
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Suporta tanto servidores locais (stdio) quanto remotos (HTTP), com autenticação OAuth quando necessário.&lt;/p>
&lt;h2 id="code-intelligence-entendendo-o-código-de-verdade">Code Intelligence: entendendo o código de verdade
&lt;/h2>&lt;p>O Kiro tem um sistema de &lt;strong>code intelligence&lt;/strong> com duas camadas:&lt;/p>
&lt;ul>
&lt;li>&lt;strong>Tree-sitter (built-in)&lt;/strong> — funciona sem configuração para 18 linguagens. Busca de símbolos com fuzzy matching, pattern search/rewrite via AST e overview do codebase.&lt;/li>
&lt;li>&lt;strong>LSP (opcional)&lt;/strong> — com &lt;code>/code init&lt;/code>, ele conecta language servers para ter find references, go to definition, rename, diagnostics e mais.&lt;/li>
&lt;/ul>
&lt;p>Um exemplo poderoso é o &lt;strong>pattern rewrite&lt;/strong> via AST. Quer converter todos os &lt;code>var&lt;/code> para &lt;code>const&lt;/code> no seu projeto JavaScript?&lt;/p>
&lt;pre tabindex="0">&lt;code>pattern: var $N = $V
replacement: const $N = $V
language: javascript
&lt;/code>&lt;/pre>&lt;p>Ele faz isso entendendo a estrutura do código, não com regex frágil.&lt;/p>
&lt;h2 id="sub-agents-pipelines-de-trabalho">Sub-agents: pipelines de trabalho
&lt;/h2>&lt;p>O Kiro pode orquestrar &lt;strong>múltiplos agents em pipeline&lt;/strong> usando o sistema de sub-agents. Você define estágios com dependências e eles executam em paralelo quando possível:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-json" data-lang="json">&lt;span style="display:flex;">&lt;span>{
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;task&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;Add CSV export to the reports page&amp;#34;&lt;/span>,
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#f92672">&amp;#34;stages&amp;#34;&lt;/span>: [
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> {&lt;span style="color:#f92672">&amp;#34;name&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;research&amp;#34;&lt;/span>, &lt;span style="color:#f92672">&amp;#34;role&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;research-agent&amp;#34;&lt;/span>, &lt;span style="color:#f92672">&amp;#34;prompt_template&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;Gather requirements for {task}&amp;#34;&lt;/span>},
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> {&lt;span style="color:#f92672">&amp;#34;name&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;implement&amp;#34;&lt;/span>, &lt;span style="color:#f92672">&amp;#34;role&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;code-agent&amp;#34;&lt;/span>, &lt;span style="color:#f92672">&amp;#34;prompt_template&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;Implement {task}&amp;#34;&lt;/span>, &lt;span style="color:#f92672">&amp;#34;depends_on&amp;#34;&lt;/span>: [&lt;span style="color:#e6db74">&amp;#34;research&amp;#34;&lt;/span>]},
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> {&lt;span style="color:#f92672">&amp;#34;name&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;review&amp;#34;&lt;/span>, &lt;span style="color:#f92672">&amp;#34;role&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;review-agent&amp;#34;&lt;/span>, &lt;span style="color:#f92672">&amp;#34;prompt_template&amp;#34;&lt;/span>: &lt;span style="color:#e6db74">&amp;#34;Review the implementation of {task}&amp;#34;&lt;/span>, &lt;span style="color:#f92672">&amp;#34;depends_on&amp;#34;&lt;/span>: [&lt;span style="color:#e6db74">&amp;#34;implement&amp;#34;&lt;/span>]}
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> ]
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>}
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Isso permite criar fluxos como pesquisa → implementação → revisão, tudo automatizado.&lt;/p>
&lt;h2 id="skills-conhecimento-sob-demanda">Skills: conhecimento sob demanda
&lt;/h2>&lt;p>Os &lt;strong>skills&lt;/strong> são recursos que têm seus metadados carregados na inicialização, mas o conteúdo completo só é carregado quando necessário. Isso é útil para ter guias e referências disponíveis sem consumir contexto desnecessariamente.&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-markdown" data-lang="markdown">&lt;span style="display:flex;">&lt;span>---
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>name: dynamodb-data-modeling
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>description: Guide for DynamoDB data modeling best practices. Use when designing or analyzing DynamoDB schema.
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span>---
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Basta colocar os arquivos em &lt;code>.kiro/skills/&lt;/code> e referenciá-los na configuração do agent com &lt;code>skill://&lt;/code>.&lt;/p>
&lt;h2 id="modelos-disponíveis">Modelos disponíveis
&lt;/h2>&lt;p>O Kiro CLI permite trocar de modelo a qualquer momento durante a conversa com &lt;code>/model&lt;/code>. O picker interativo mostra os modelos disponíveis na sua região junto com o &lt;strong>multiplicador de crédito&lt;/strong> de cada um:&lt;/p>
&lt;ul>
&lt;li>&lt;strong>Claude Sonnet&lt;/strong> (ex: claude-sonnet-4) — o modelo padrão, bom equilíbrio entre qualidade e custo (1.0x crédito)&lt;/li>
&lt;li>&lt;strong>Claude Opus&lt;/strong> — mais poderoso para raciocínio complexo, mas consome mais (3.0x crédito)&lt;/li>
&lt;li>&lt;strong>Claude Haiku&lt;/strong> — mais rápido e barato, ideal para tarefas simples (0.3x crédito)&lt;/li>
&lt;/ul>
&lt;p>Você pode definir um modelo padrão para não precisar trocar toda vez:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-bash" data-lang="bash">&lt;span style="display:flex;">&lt;span>kiro-cli settings chat.defaultModel claude-sonnet-4
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Ou iniciar uma sessão já com um modelo específico:&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-bash" data-lang="bash">&lt;span style="display:flex;">&lt;span>kiro-cli chat --model claude-sonnet-4
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>Na IDE, o modo &lt;strong>Auto&lt;/strong> roteia automaticamente para o modelo mais custo-efetivo dependendo da complexidade do prompt — tarefas simples vão para um modelo mais leve, raciocínio complexo vai para o Sonnet.&lt;/p>
&lt;h2 id="economizando-tokens-e-créditos">Economizando tokens e créditos
&lt;/h2>&lt;p>Tokens são o &amp;ldquo;combustível&amp;rdquo; do Kiro — cada mensagem, arquivo de contexto e resposta consome tokens da janela de contexto. Saber gerenciar isso faz diferença no custo e na qualidade das respostas.&lt;/p>
&lt;h3 id="monitorando-o-uso">Monitorando o uso
&lt;/h3>&lt;p>O comando &lt;code>/context&lt;/code> mostra um breakdown detalhado de como seus tokens estão sendo usados:&lt;/p>
&lt;pre tabindex="0">&lt;code>/context
&lt;/code>&lt;/pre>&lt;p>Ele exibe o percentual usado por cada componente: arquivos de contexto, definições de ferramentas, respostas do Kiro, seus prompts e arquivos de sessão. O &lt;code>/usage&lt;/code> mostra o consumo no nível da conta — quantas interações você já usou do seu plano.&lt;/p>
&lt;h3 id="compactando-o-histórico">Compactando o histórico
&lt;/h3>&lt;p>Conversas longas acumulam muito contexto. O &lt;code>/compact&lt;/code> gera um resumo da conversa e substitui as mensagens antigas, liberando espaço sem perder informação essencial:&lt;/p>
&lt;pre tabindex="0">&lt;code>/compact
&lt;/code>&lt;/pre>&lt;p>Diferente do &lt;code>/clear&lt;/code> (que apaga tudo), o &lt;code>/compact&lt;/code> preserva o contexto importante em formato resumido. Use quando o &lt;code>/context&lt;/code> mostrar que você está chegando perto do limite.&lt;/p>
&lt;h3 id="dicas-práticas-para-economizar">Dicas práticas para economizar
&lt;/h3>&lt;ul>
&lt;li>&lt;strong>Use steering files&lt;/strong> em vez de repetir instruções em todo prompt — eles são carregados uma vez e valem para toda a sessão&lt;/li>
&lt;li>&lt;strong>Skills em vez de resources&lt;/strong> — skills (&lt;code>skill://&lt;/code>) carregam só os metadados na inicialização e o conteúdo completo sob demanda, enquanto resources (&lt;code>file://&lt;/code>) carregam tudo de uma vez&lt;/li>
&lt;li>&lt;strong>Seja específico nos glob patterns&lt;/strong> — &lt;code>file://src/api/**/*.ts&lt;/code> consome menos contexto que &lt;code>file://src/**/*&lt;/code>&lt;/li>
&lt;li>&lt;strong>Use Haiku para tarefas simples&lt;/strong> — trocar para um modelo mais leve com &lt;code>/model&lt;/code> em tarefas de baixa complexidade economiza créditos (0.3x vs 1.0x)&lt;/li>
&lt;li>&lt;strong>Remova contexto desnecessário&lt;/strong> — &lt;code>/context remove&lt;/code> tira arquivos que não são mais relevantes para a tarefa atual&lt;/li>
&lt;li>&lt;strong>Comece sessões novas&lt;/strong> — &lt;code>/chat new&lt;/code> para tarefas diferentes evita carregar histórico irrelevante&lt;/li>
&lt;/ul>
&lt;h2 id="comandos-disponíveis">Comandos disponíveis
&lt;/h2>&lt;h3 id="comandos-cli-terminal">Comandos CLI (terminal)
&lt;/h3>&lt;p>Esses são os comandos que você roda direto no terminal:&lt;/p>
&lt;table>
&lt;thead>
&lt;tr>
&lt;th>Comando&lt;/th>
&lt;th>O que faz&lt;/th>
&lt;/tr>
&lt;/thead>
&lt;tbody>
&lt;tr>
&lt;td>&lt;code>kiro-cli chat&lt;/code>&lt;/td>
&lt;td>Inicia uma sessão de chat interativa&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli chat --agent rust-expert&lt;/code>&lt;/td>
&lt;td>Inicia com um agent específico&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli chat --resume&lt;/code>&lt;/td>
&lt;td>Retoma a última conversa&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli chat --no-interactive &amp;quot;query&amp;quot;&lt;/code>&lt;/td>
&lt;td>Modo headless para scripts&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli chat --trust-all-tools&lt;/code>&lt;/td>
&lt;td>Auto-aprova todas as ferramentas&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli agent list&lt;/code>&lt;/td>
&lt;td>Lista todos os agents disponíveis&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli agent create nome&lt;/code>&lt;/td>
&lt;td>Cria um novo agent&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli agent edit nome&lt;/code>&lt;/td>
&lt;td>Edita um agent no editor padrão&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli agent validate --path arquivo&lt;/code>&lt;/td>
&lt;td>Valida a configuração de um agent&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli agent set-default nome&lt;/code>&lt;/td>
&lt;td>Define o agent padrão&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli mcp add --name git --command mcp-server-git&lt;/code>&lt;/td>
&lt;td>Adiciona um MCP server&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli mcp list&lt;/code>&lt;/td>
&lt;td>Lista MCP servers configurados&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli mcp remove --name git&lt;/code>&lt;/td>
&lt;td>Remove um MCP server&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli settings list --all&lt;/code>&lt;/td>
&lt;td>Lista todas as configurações disponíveis&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli settings chat.defaultModel modelo&lt;/code>&lt;/td>
&lt;td>Define o modelo padrão&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>kiro-cli settings --delete chave&lt;/code>&lt;/td>
&lt;td>Remove uma configuração&lt;/td>
&lt;/tr>
&lt;/tbody>
&lt;/table>
&lt;h3 id="slash-commands-dentro-do-chat">Slash commands (dentro do chat)
&lt;/h3>&lt;p>Esses comandos são usados dentro de uma sessão de chat ativa:&lt;/p>
&lt;table>
&lt;thead>
&lt;tr>
&lt;th>Comando&lt;/th>
&lt;th>O que faz&lt;/th>
&lt;/tr>
&lt;/thead>
&lt;tbody>
&lt;tr>
&lt;td>&lt;code>/help&lt;/code>&lt;/td>
&lt;td>Lista todos os slash commands&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/agent [nome]&lt;/code>&lt;/td>
&lt;td>Troca de agent ou lista disponíveis&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/agent create&lt;/code>&lt;/td>
&lt;td>Cria um agent interativamente com IA&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/model [nome]&lt;/code>&lt;/td>
&lt;td>Troca de modelo LLM&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/context&lt;/code>&lt;/td>
&lt;td>Mostra uso de tokens e gerencia arquivos de contexto&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/compact&lt;/code>&lt;/td>
&lt;td>Compacta o histórico para liberar contexto&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/clear&lt;/code>&lt;/td>
&lt;td>Limpa todo o histórico (sem resumo)&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/chat save [path]&lt;/code>&lt;/td>
&lt;td>Salva a conversa atual&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/chat load [path]&lt;/code>&lt;/td>
&lt;td>Carrega uma conversa salva&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/chat new&lt;/code>&lt;/td>
&lt;td>Inicia uma nova sessão&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/knowledge&lt;/code>&lt;/td>
&lt;td>Gerencia a knowledge base&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/code init&lt;/code>&lt;/td>
&lt;td>Inicializa code intelligence com LSP&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/code overview&lt;/code>&lt;/td>
&lt;td>Gera overview da estrutura do codebase&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/code summary&lt;/code>&lt;/td>
&lt;td>Gera documentação completa do codebase&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/code status&lt;/code>&lt;/td>
&lt;td>Mostra status dos language servers&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/plan&lt;/code>&lt;/td>
&lt;td>Muda para o agent de planejamento&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/guide [pergunta]&lt;/code>&lt;/td>
&lt;td>Muda para o agent guia (ajuda sobre o Kiro)&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/tools&lt;/code>&lt;/td>
&lt;td>Lista ferramentas disponíveis e gerencia permissões&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/hooks&lt;/code>&lt;/td>
&lt;td>Mostra hooks configurados&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/mcp&lt;/code>&lt;/td>
&lt;td>Mostra status dos MCP servers&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/usage&lt;/code>&lt;/td>
&lt;td>Mostra uso de créditos e plano&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/prompts [nome]&lt;/code>&lt;/td>
&lt;td>Lista ou seleciona prompts salvos&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/paste&lt;/code>&lt;/td>
&lt;td>Cola imagem do clipboard&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/feedback&lt;/code>&lt;/td>
&lt;td>Envia feedback ou reporta problemas&lt;/td>
&lt;/tr>
&lt;tr>
&lt;td>&lt;code>/quit&lt;/code>&lt;/td>
&lt;td>Sai do chat&lt;/td>
&lt;/tr>
&lt;/tbody>
&lt;/table>
&lt;p>No TUI também estão disponíveis: &lt;code>/copy&lt;/code> (copia última resposta), &lt;code>/editor&lt;/code> (abre o $EDITOR para compor prompt), &lt;code>/spawn&lt;/code> (cria nova sessão de agent), &lt;code>/transcript&lt;/code> (abre transcrição no $PAGER) e &lt;code>/theme&lt;/code> (seleciona tema visual).&lt;/p>
&lt;h2 id="outros-destaques">Outros destaques
&lt;/h2>&lt;ul>
&lt;li>&lt;strong>Keyboard shortcuts&lt;/strong> — agents podem ter atalhos de teclado (ex: &lt;code>ctrl+shift+r&lt;/code>) para troca rápida no meio da conversa&lt;/li>
&lt;li>&lt;strong>Welcome messages&lt;/strong> — mensagens customizadas ao trocar de agent para orientar o uso&lt;/li>
&lt;li>&lt;strong>Headless mode&lt;/strong> — &lt;code>kiro-cli chat --no-interactive&lt;/code> permite usar o Kiro em scripts e automações CI/CD&lt;/li>
&lt;li>&lt;strong>Sessões por diretório&lt;/strong> — conversas são salvas por projeto, então cada repositório tem seu próprio histórico&lt;/li>
&lt;/ul>
&lt;h2 id="conclusão">Conclusão
&lt;/h2>&lt;p>O Kiro não é só mais uma ferramenta de IA para código. É um &lt;strong>ecossistema completo&lt;/strong> que ataca o problema de desenvolvimento assistido por IA em duas frentes: a &lt;strong>IDE&lt;/strong> com spec-driven development para quem quer planejamento estruturado antes de codar, e a &lt;strong>CLI&lt;/strong> para quem vive no terminal e quer um assistente que entende profundamente o contexto do projeto.&lt;/p>
&lt;p>Ambas compartilham os mesmos conceitos poderosos — agents, steering files, hooks e MCP servers — e a combinação dessas features cria um fluxo de trabalho onde a IA realmente age de forma inteligente, não apenas gera código às cegas.&lt;/p>
&lt;p>Se você trabalha com desenvolvimento e ainda não experimentou, vale muito a pena testar. A IDE está disponível em &lt;a class="link" href="https://kiro.dev" target="_blank" rel="noopener"
>kiro.dev&lt;/a> com tier gratuito, e a CLI se instala direto no terminal. A curva de aprendizado é suave — você começa com o básico e vai customizando conforme descobre o que precisa.&lt;/p></description></item></channel></rss>