mirror of
https://github.com/affaan-m/everything-claude-code.git
synced 2026-05-19 07:13:07 +08:00
Translate everything-claude-code repository to Japanese including: - 17 root documentation files - 60 agent documentation files - 80 command documentation files - 99 rule files across 18 language directories (common, angular, arkts, cpp, csharp, dart, fsharp, golang, java, kotlin, perl, php, python, ruby, rust, swift, typescript, web) - 199 skill documentation files Total: 455 files translated to Japanese with: - Consistent terminology glossary applied throughout - YAML field names preserved in English (name, description, etc.) - Code blocks and examples untouched (comments translated) - Markdown structure and relative links preserved - Professional translation maintaining technical accuracy This translation expands ECC accessibility to Japanese-speaking developers and teams. Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
3.5 KiB
3.5 KiB
paths
| paths | ||
|---|---|---|
|
F# コーディングスタイル
このファイルは common/coding-style.md を F# 固有のコンテンツで拡張します。
標準
- 標準的な F# の規約に従い、正確性のために型システムを活用する
- デフォルトでイミュータビリティを優先する。パフォーマンス上の理由がある場合のみ
mutableを使用する - モジュールを焦点を絞り、凝集性を保つ
型とモデル
- ドメインモデリングにはクラス階層よりも判別共用体を優先する
- 名前付きフィールドを持つデータにはレコードを使用する
- プリミティブ型に対する型安全なラッパーには単一ケース共用体を使用する
- 相互運用またはミュータブルなステートが必要でない限り、クラスの使用を避ける
type EmailAddress = EmailAddress of string
type OrderStatus =
| Pending
| Confirmed of confirmedAt: DateTimeOffset
| Shipped of trackingNumber: string
| Cancelled of reason: string
type Order =
{ Id: Guid
CustomerId: string
Status: OrderStatus
Items: OrderItem list }
イミュータビリティ
- レコードはデフォルトでイミュータブル。更新には
with式を使用する - ミュータブルなコレクションよりも
list、map、setを優先する - ドメインロジックで
refセルとミュータブルフィールドを避ける
let rename (profile: UserProfile) newName =
{ profile with Name = newName }
関数スタイル
- 大きなメソッドよりも小さく合成可能な関数を優先する
- パイプ演算子
|>を使用して読みやすいデータパイプラインを構築する - if/else チェーンよりもパターンマッチングを優先する
- null の代わりに
Optionを使用する。失敗する可能性のある操作にはResultを使用する
let processOrder order =
order
|> validateItems
|> Result.bind calculateTotal
|> Result.map applyDiscount
|> Result.mapError OrderError
非同期とエラーハンドリング
- .NET の非同期 API との相互運用には
task { }を使用する - F# ネイティブの非同期ワークフローには
async { }を使用する - パブリック非同期 API を通じて
CancellationTokenを伝播する - 予期されるエラーには例外ではなく
ResultとRailway指向プログラミングを優先する
let loadOrderAsync (orderId: Guid) (ct: CancellationToken) =
task {
let! order = repository.FindAsync(orderId, ct)
return
order
|> Option.defaultWith (fun () ->
failwith $"Order {orderId} was not found.")
}
フォーマット
- 自動フォーマットには
fantomasを使用する - 意味のある空白を優先する。不要な括弧を避ける
- 未使用の
open宣言を削除する
open 宣言の順序
open 文を4つのセクションに空行で区切ってグループ化し、各セクション内は辞書順で並べる:
System.*Microsoft.*- サードパーティの名前空間
- ファーストパーティ / プロジェクトの名前空間
open System
open System.Collections.Generic
open System.Threading.Tasks
open Microsoft.AspNetCore.Http
open Microsoft.Extensions.Logging
open FsCheck.Xunit
open Swensen.Unquote
open MyApp.Domain
open MyApp.Infrastructure