Bir takım yazma
Bir takım, atl install ile kurulabilen, yeniden kullanılabilir bir AI ajanı, becerisi ve kuralı paketidir. Bu sayfa, boş bir dizinden kataloglanmış bir takıma kadar her şeyi adım adım anlatır.
Bir takım nedir (ve ne değildir)?
Bir takım, yalnızca bir team.json dosyası ve birkaç Markdown içeren bir Git deposudur. atl install <handle>/<team> çalıştırdığında CLI, handle'ı GitHub tabanlı katalog (catalog) ile eşleştirir, depoyu geçici bir HTTPS tarball'ı olarak indirir ve takımın agents/, skills/, rules/ içeriğini hedef .claude/ dizinine kopyalar. Hepsi bu — eklenti sistemi yok, JavaScript çalışma zamanı yok, özel ikili yok. Her şey metin dosyaları ve kopyalardır.
Bir takımın içinde şunlar olabilir:
- Tek bir ajan (Claude'un izleyeceği yönergeleri içeren tek bir Markdown dosyası)
- Bir ya da daha çok beceri (Claude'un çağırabileceği eğik çizgili komutlar)
- Kurallar (her oturumda yüklenen, davranışı biçimlendiren yönergeler)
- Yukarıdakilerin herhangi bir bileşimi
Bir takım, kataloglandığında kurulabilir hâle gelir: herkese açık GitHub deposunu atl-team konusuyla etiketle ya da repodan atl publish çalıştır; oluşturulan dizin (index) bunu alır. Artık herkes atl install <handle>/<team> ile kurabilir — handle, reponun GitHub sahibidir. Kayıt defteri deposu ve gönderim PR'ı yoktur.
Tam adım adım anlatım
Sıfırdan küçük gerçek bir takım kuralım. Bir my-team deposu oluşturacaksın, bir ajan ekleyeceksin ve onu yayımlamaya hazır hâle getireceksin.
Adım 1 — Takım deposunu oluştur
mkdir ~/projects/my-team
cd ~/projects/my-team
git init -b mainKlasör adının takımın katalog adıyla aynı olması gerekmez — o aşağıdaki team.json dosyasında belirlenir.
Adım 2 — team.json yaz
Bu, takımın manifesto dosyasıdır. En küçük geçerli hâli:
{
"schemaVersion": 1,
"name": "my-team",
"version": "0.1.0",
"description": "Opinionated setup for Next.js + Tailwind projects.",
"author": { "name": "Your Name", "url": "https://github.com/you" },
"license": "MIT",
"keywords": ["nextjs", "tailwind", "typescript"],
"agents": [
{ "name": "web-agent", "description": "Reviews and builds Next.js pages." }
],
"skills": [],
"rules": []
}Tüm alanlar için: team.json.
Dikkat edilecek tuzaklar:
name, takımın kısa adıdır. Bir kez belirlendiğinde değiştirme — kullanıcılar buna göre başvuracak. Kebab-case olmalıdır (küçük harfler, rakamlar, tireler).version, SemVer biçimindedir (major.minor.patch). Değişiklik yayımladığında artır —atl updatebu alana bakarak çekim yapıp yapmayacağına karar verir.authorbir nesnedir, dize değildir. En azından{ "name": "Your Name" }."author": "You"gibi düz dize ayrıştırma hatasına neden olur.agents, üst bilgi dizisidir, ajan içeriği değildir. Asıl ajan Markdown'ıagents/<name>/agent.mdaltında yaşar (bkz. Adım 3).
Adım 3 — Ajanını ekle
team.json dosyasının bildirdiği her ajan, agents/ altında çocuklar deseniyle bir dizine ihtiyaç duyar:
my-team/
├── team.json
└── agents/
└── web-agent/
├── agent.md ← kısa: kimlik, kapsam, ilkeler (<300 satır)
└── children/ ← isteğe bağlı: derinlemesine konular
├── routing.md
├── data-fetching.md
└── testing.mdagent.md, giriş noktasıdır — Claude her çağrıda onu okur. Kısa tut. Ayrıntılı desenleri children/*.md dosyalarına koy; ajanın ## Knowledge Base bölümü onlara bağlantı verir ve Claude gerektiğinde okur.
En küçük agent.md:
---
name: web-agent
description: "Reviews and builds Next.js pages."
---
# Web Agent
## Identity
I build and review Next.js pages for this project.
## Area of Responsibility (Positive List)
I ONLY touch:
- `app/` — Next.js App Router pages + layouts + routes
- `components/` — shared UI primitives
- `lib/` — data-fetching + utility functions
I do NOT touch:
- `api/` — that's the backend's concern
- Build config (`next.config.js`, `tsconfig.json`) without explicit approval
## Core Principles
1. Server components by default; client components only when interactive.
2. Co-locate styles with their component; no global CSS.
3. Loading UI for every async boundary.İşte çalışan bir ajan. Ajan büyüdükçe children/ dizinine daha fazla ayrıntı ekle.
Derinlemesine
Çocuklar deseni, core/rules/agent-structure.md kuralında anlatılır; özeti Children + learnings sayfasındadır. Ana fikir: agent.md kısa kalır, konuya özgü ayrıntı her konu bir dosyada olmak üzere children/*.md dosyalarına gider.
Adım 4 — Commit at
Çalışmanı commit'le — atl kurulumları commit'lenmiş ref üzerinden yapar, çalışma ağacından değil:
git add .
git commit -m "feat: initial team"Adım 5 — Başkalarının kurabilmesi için yayımla
atl install handle'ları katalog üzerinden çözer, dolayısıyla bir takımın handle ile kurulabilmesi için önce kataloglanması gerekir. Repoyu herkese açık bir GitHub deposuna push'la ve atl-team konusuyla etiketle:
# Hesabın ya da org'un altında herkese açık bir GitHub deposuna push'la:
gh repo create you/my-team --public --source=. --push
# Katalogun dizine alması için etiketle:
gh repo edit you/my-team --add-topic atl-teamDizin herkese açık atl-team etiketli depolardan yeniden oluşturulur; kısa süre içinde takımın you/my-team olarak keşfedilebilir olur.
Adım 6 — Kur
mkdir /tmp/demo-app && cd /tmp/demo-app
atl install you/my-team
# → atl: installed you/my-team@0.1.0 at project scope
atl list
# project:
# you/my-team@0.1.0
ls -la .claude/agents/
# → web-agent.mdÇıktı buna uyuyorsa takımın kurulmuştur. Ajan artık /tmp/demo-app/ içinde Claude tarafından kullanılabilir.
Takım, yayıncısının bildirdiği kapsamda (scope) kurulur (varsayılan project — bkz. team.json içindeki scope alanı). Her kurulum için --global ya da --project ile geçersiz kılabilirsin.
Adım 7 — Yinele
~/projects/my-team/ altındaki dosyaları düzenle, team.json içindeki version alanını artır, sonra commit'le ve push'la. Katalog yeni sürüme göre yeniden dizinlenir ve takımı kurulu olan her proje atl update ile alır:
cd ~/projects/my-team
vim agents/web-agent/agent.md # ya da herhangi bir düzenleme
# team.json içindeki "version" alanını artır, sonra:
git commit -am "tweak web-agent guidance"
git push
cd /tmp/demo-app
atl update
# → atl yayımlanmış sürümü yeniden çeker, değiştirilmemiş kopyaları yenileratl update, yerel olarak değiştirmediğin kopyaları yeniler; kendi düzenlemelerine dokunmaz.
Adım 8 — (İsteğe bağlı) Beceri ve kural ekle
Beceriler eğik çizgili komutlardır. Her biri bir frontmatter ile birlikte skills/<skill-name>/skill.md dosyasına yazılır:
---
name: lint-page
description: "/lint-page <path> — run the project's lint config against a Next.js page file."
argument-hint: "<path-to-page>"
---
# /lint-page Skill
## Purpose
Lint a single Next.js page file using the project's ESLint + Prettier.
## Flow
1. Validate the path exists and matches `app/**/*.tsx` or `pages/**/*.tsx`.
2. Run `npm run lint -- --file <path>`.
3. Parse the output; if violations exist, print them with file:line:column citations.
4. Offer to auto-fix where safe.team.json dosyasında bildir:
"skills": [
{ "name": "lint-page", "description": "/lint-page <path> — run lint against a page file." }
]Kurallar, Claude'un davranışını biçimlendiren, her oturumda yüklenen Markdown dosyalarıdır. rules/<rule-name>.md konumuna koy:
# React 19 defaults
- Server components unless interactivity is needed
- Never use `"use client"` at the top of a shared lib
- `useActionState` replaces manual form-state boilerplateBildir:
"rules": [
{ "name": "react-19-defaults", "description": "Default to server components; avoid client boundary creep." }
]Herhangi bir değişiklikten sonra — ajan, beceri ya da kural — sürümü artır, commit at, push'la; ardından atl update ile değişikliği al.
Adım 9 — Sonraki adımlar
- İskele becerisi ekle. Takımın yeni proje açma amacındaysa bir
/create-new-projectbecerisi ekle. Bkz. İskele belirtimi. - Başka bir takıma bağımlı ol. Takımın başka birinin takımı üzerine inşa ediliyorsa
team.jsoniçindekidependenciesaltında bildir —atl install, bağımlılığı seninki ile birlikte indirir. - Doğrulanmış rozet kazan. AgentTeamLand maintainer'larınca incelenen takımlar (ve
agentteamland/*altındaki her şey)atl searchçıktısında[verified]rozeti gösterir. Rozetin olmaması yalnızca takımın kendi kendine yayımlandığı anlamına gelir.
Takım düzeni başvurusu
my-team/
├── team.json ← manifesto (zorunlu)
├── README.md ← takım belgeleri (kuvvetle önerilir)
├── LICENSE ← genellikle MIT
│
├── agents/ ← ajan başına bir dizin
│ ├── web-agent/
│ │ ├── agent.md ← kısa: kimlik + kapsam + ilkeler + Knowledge Base dizini
│ │ └── children/ ← isteğe bağlı: derinlemesine konular
│ │ ├── routing.md
│ │ ├── data-fetching.md
│ │ └── testing.md
│ └── api-agent/
│ ├── agent.md
│ └── children/ ...
│
├── skills/ ← beceri başına bir dizin
│ ├── lint-page/
│ │ └── skill.md ← frontmatter (name, description, argument-hint) + gövde
│ └── run-e2e/
│ └── skill.md
│
└── rules/ ← kural başına bir .md (düz, dizin değil)
├── react-19-defaults.md
└── file-naming.mdteam.json tarafından listelenen agents/, skills/ ve rules/ altındaki her dosya, kullanıcı kurulum yaptığında onun .claude/ dizinine bir kopya olarak gelir. Listelenmeyen dosyalar yok sayılır.
Kurulum arka planda nasıl çalışır?
atl install you/my-team çalıştırıldığında:
- Çöz. Handle, GitHub tabanlı katalogda aranır (herkese açık
atl-teametiketli depolardan üretilen dizin). Birinci parti takım, monorepo'nun bir alt yoluna; üçüncü parti takım kendi bağımsız deposuna çözülür. - İndir. Takım, geçici bir dizine ref-sabitli HTTPS tarball'ı olarak indirilir —
gitikili dosyası gerekmez. Geçici dizin kurulumdan sonra silinir. - Doğrula.
atl,team.jsondosyasını ayrıştırır, birnamealanı olduğunu kontrol eder ve bildirilen her ajan/beceri/kuralın diskte gerçekten var olduğunu doğrular. Eksik olan varsa burada hata verir. - Yaz. Ajanlar, beceriler ve kurallar kapsamın
.claude/dizinine kopyalanır — global kurulum için~/.claude, proje kurulumu için<proje>/.claude. - Kaydet.
<katman>/.atl/installed/<handle>__<name>.jsonkonumundaki takıma özgü manifesto, kaynak ref ve dosya başına SHA-256 değerlerini kaydeder;atl update'in otomatik yenileme veatl doctor'ın bütünlük denetimi bu verilere dayanır.
Kalıcı klonlama önbelleği yoktur, ayrı bir ATL varlık deposu da yoktur. Takım varlıkları .claude/ altında yaşar; ATL'nin kendi durum verisi (katalog önbelleği, öğrenme kuyruğu, pin'ler, kurulum manifestoları) ~/.atl ve <proje>/.atl altında yaşar.
Sık karşılaşılan tuzaklar
Error: agent source missing: .../agents/foo/agent.md → team.json dosyan agents: [{"name": "foo"}] olarak listeliyor ama dosya sisteminde agents/foo.md (düz) var; çocuklar deseni agents/foo/agent.md bekler. Bildirilen varlıkları disktekiyle eşleştir.
Error: parse team.json: json: cannot unmarshal string into Go struct field TeamManifest.author → author bir nesne olmalı, dize değil. "author": "You" yerine "author": { "name": "You" } yaz.
Takımı düzenledim ve atl update çalıştırdım ama etki yok → Commit attın mı, sürümü artırdın mı, push'ladın mı? atl update, yayımlanmış sürümü çeker; commit'lenmemiş veya push'lanmamış düzenlemeler akmaz. Commit at + sürümü artır + push'la, sonra atl update.
atl install "team not found" diyor → Handle henüz katalogda yok. Depo herkese açık olmalı ve atl-team konusuyla etiketlenmiş olmalı (ya da atl publish çalıştırılmış olmalı). Neyin dizinde olduğunu atl search ile doğrula.
Bir takımı temiz biçimde silmek istiyorum → atl remove you/my-team çalıştırmak, takımın manifest kayıtlı dosyalarını kapsamdan kaldırır (varsayılan olarak project; global katman için --global) ve artık boş olan dizinleri temizler.
Sıkça sorulan sorular
Kullanmak için takımı bir yere push'lamak zorunda mıyım? Evet. atl install, handle'ları GitHub tabanlı katalog üzerinden çözer; dolayısıyla takımın atl-team etiketli herkese açık bir deposu olması (ya da atl publish çalıştırılmış olması) gerekir.
Tek bir projede birden çok takım yan yana yaşayabilir mi? Evet — istediğin kadar kur. Her takımın öğeleri paylaşılan .claude/ dizinine kopyalanır. İki takım aynı adda bir öğe bildirirse en son kurulan kazanır ve atl tek satırlık bir uyarı yazdırır.
atl hangi Markdown biçimini kullanır? İsteğe bağlı YAML frontmatter ile düz Markdown. Claude Code'un ajan ve beceri biçimi yerel olarak desteklenir.
Becerileri takımdan bağımsız sürümleyebilir miyim? Bugün hayır. Sürümleme takım düzeyindedir; team.json içindeki version alanı üzerinden yapılır.
Boyut sınırları var mı? Sert sınır yoktur. Pratikte takım depoları 10 MB'ın altındadır. Büyük ikili dosyalar eklerseniz README'de belirtin ki kullanıcılar ne indirdiklerini bilsin.
Ayrıca bkz.
- team.json alan başvurusu
- İskele belirtimi —
/create-new-projectbecerileri ekleme atl install— tam CLI başvurusuatl publish— takımının biriken kazanımlarını upstream'e taşı- Children + learnings — ajan/beceri bilgi tabanı deseni