Gemini CLI vs OpenCodeUpdated 2026-03-16

SUMMARY

Gemini CLI (CLI) uses markdown configuration while OpenCode (CLI) uses markdown. They differ on 1 of 11 compared features. Both tools provide AI-assisted development but take different approaches to project configuration.

FEATURE COMPARISON

FeatureGemini CLIOpenCode
Config formatmarkdownmarkdown
Hierarchy support
Global config
Project config
Subdirectory scoping
File inclusion / imports
Ignore file
IDE integrationCLICLI
Schema / structureFree-form (Markdown)Free-form (Markdown)
Git committed
EncodingUTF-8UTF-8

FILE MAPPING

PurposeGemini CLIOpenCode
Project instructionsGEMINI.mdAGENTS.md
Settings / configuration.gemini/settings.jsonopencode.json
Project instructions.gemini/styleguide.mdCLAUDE.md

SIDE-BY-SIDE CODE SAMPLES

Gemini CLI
GEMINI.md
markdown
# Project Context

## Stack
- Node.js 22 with TypeScript 5.x
- Express.js for the API server
- Prisma ORM with PostgreSQL
- React 19 with Vite for the frontend

## Architecture
- Monorepo with pnpm workspaces
- packages/api — Express REST API
- packages/web — React SPA
- packages/shared — Shared types and utilities

## Commands
- pnpm dev — Start all services
- pnpm test — Run vitest across all packages
- pnpm lint — ESLint + Prettier check
- pnpm db:migrate — Run Prisma migrations

## Conventions
- Use barrel exports (index.ts) for public APIs
- Error responses use RFC 7807 Problem Details format
- All API endpoints require authentication except /health

OpenCode
AGENTS.md
markdown
# Project Instructions

## Overview
This is a TypeScript monorepo using pnpm workspaces.

## Code Style
- Use strict TypeScript with no implicit any
- Prefer functional components with hooks
- All exports should be named (no default exports)

## Architecture
- /packages/core — shared business logic
- /packages/ui — React component library
- /apps/web — Next.js frontend

## Build & Test
Run tests with: pnpm test
Build all packages: pnpm build
All PRs must have >80% coverage on changed files.

## Conventions
- Use conventional commits (feat:, fix:, chore:)
- Prefer composition over inheritance
- See @docs/api-guidelines.md for API design patterns

KEY DIFFERENCES

1. Subdirectory scoping

Gemini CLI: Not supported. OpenCode: Supported.

WHICH SHOULD I USE?

Recommendation

Choose based on your IDE/CLI preference. If you use Gemini CLI, configure GEMINI.md. If you use OpenCode, configure AGENTS.md. Many projects include config files for multiple tools so each team member can use their preferred editor.

PORTABILITY TIP

sync-instructions.sh
bash
# Maintain a single source of truth:
cp AI-INSTRUCTIONS.md CLAUDE.md
cp AI-INSTRUCTIONS.md .cursorrules
cp AI-INSTRUCTIONS.md AGENTS.md

SEE ALSO

agentconfig.ing2026-03-16COMPARE(1)