← スキル一覧に戻る

bch-development
by hiromaily
bch-developmentは、other分野における実用的なスキルです。複雑な課題への対応力を強化し、業務効率と成果の質を改善します。
⭐ 120🍴 32📅 2026年1月22日
SKILL.md
name: bch-development description: Bitcoin Cash (BCH) API implementation rules. Critical pattern for embedding Bitcoin struct and overriding BCH-specific methods. Use when working on BCH-related code in internal/infrastructure/api/btc/bch/.
BCH (Bitcoin Cash) Development Rules
🚨 CRITICAL: Override Pattern for BCH-Specific Logic
This is a non-negotiable architectural rule. BCH implementation uses struct embedding with method override pattern.
Architecture Overview
// internal/infrastructure/api/btc/bch/bitcoin_cash.go
type BitcoinCash struct {
apibtcimpl.Bitcoin // Embeds BTC implementation
}
Key Principle: BitcoinCash embeds Bitcoin, inheriting all BTC methods by default.
Rules
✅ DO: Override on BCH Side
When BCH requires different logic from BTC:
- Create a new file in
internal/infrastructure/api/btc/bch/ - Implement the method with the same name on
BitcoinCash - This "overrides" the embedded
Bitcoinmethod
❌ DON'T: Modify BTC Side for BCH
- NEVER modify
internal/infrastructure/api/btc/btc/for BCH-specific requirements - NEVER add BCH conditionals in BTC code
- NEVER add BCH-specific types or logic to the BTC package
Why This Pattern?
| Reason | Explanation |
|---|---|
| Separation of Concerns | BTC code remains pure and focused |
| Maintainability | BCH changes don't affect BTC |
| Clarity | BCH differences are explicit in BCH directory |
| Safety | BTC modifications can't accidentally break BCH |
Implementation Examples
Example 1: GetAddressInfo Override
BCH has a different response structure for getaddressinfo RPC:
// internal/infrastructure/api/btc/bch/address.go
// BCH-specific response type
type GetAddressInfoResult struct {
Address string `json:"address"`
ScriptPubKey string `json:"scriptPubKey"`
Label string `json:"label,omitempty"` // BCH uses Label (singular)
Labels []struct { // BCH has different Labels structure
Name string `json:"name"`
Purpose string `json:"purpose"`
} `json:"labels"`
// ... other BCH-specific fields
}
// Override GetAddressInfo for BCH
func (b *BitcoinCash) GetAddressInfo(addr string) (*dtobtc.AddressInfo, error) {
// BCH-specific implementation
// ...
}
Example 2: GetAccount Override
BCH requires different logic for getting account info:
// internal/infrastructure/api/btc/bch/account.go
func (b *BitcoinCash) GetAccount(addr string) (string, error) {
// BCH calls GetAddressInfo (which is also overridden)
res, err := b.GetAddressInfo(addr)
if err != nil {
return "", fmt.Errorf("fail to call btc.GetAddressInfo() in bch: %w", err)
}
// BCH-specific label extraction
if len(res.Labels) == 0 {
return "", nil
}
return res.Labels[0], nil
}
Example 3: Chain Parameters Override
BCH has different network magic numbers:
// internal/infrastructure/api/btc/bch/bitcoin_cash.go
const (
MainnetMagic wire.BitcoinNet = 0xe8f3e1e3 // BCH-specific
TestnetMagic wire.BitcoinNet = 0xf4f3e5f4 // BCH-specific
Regtestmagic wire.BitcoinNet = 0xfabfb5da // BCH-specific
)
func (b *BitcoinCash) initChainParams() {
// Override chain parameters for BCH
}
BCH vs BTC: Feature Differences
| Feature | BTC | BCH |
|---|---|---|
| SegWit | ✅ Supported | ❌ Not supported |
| Taproot | ✅ Supported | ❌ Not supported |
| Address Format | Legacy, SegWit, Taproot | Legacy, CashAddr |
| Network Magic | BTC values | BCH-specific values |
Directory Structure
internal/infrastructure/api/btc/
├── btc/ # BTC implementation (DO NOT modify for BCH)
│ ├── bitcoin.go # Bitcoin struct and methods
│ ├── account.go
│ ├── address.go
│ └── ...
├── bch/ # BCH overrides (ADD new files here)
│ ├── bitcoin_cash.go # BitcoinCash struct (embeds Bitcoin)
│ ├── account.go # Override: GetAccount
│ ├── address.go # Override: GetAddressInfo
│ └── ...
└── connection.go # Shared connection logic
Checklist for BCH Changes
When implementing BCH-specific logic:
- File created in
internal/infrastructure/api/btc/bch/(NOT inbtc/) - Method has same signature as the BTC method being overridden
- No changes made to
internal/infrastructure/api/btc/btc/ - BCH-specific types defined in BCH package (if needed)
- Error messages include "bch" for traceability
Common Mistakes
❌ WRONG: Adding BCH Logic to BTC
// internal/infrastructure/api/btc/btc/account.go
func (b *Bitcoin) GetAccount(addr string) (string, error) {
if b.coinTypeCode == domainCoin.BCH { // DON'T DO THIS!
// BCH-specific logic
}
// BTC logic
}
✅ CORRECT: Override in BCH Package
// internal/infrastructure/api/btc/bch/account.go
func (b *BitcoinCash) GetAccount(addr string) (string, error) {
// BCH-specific logic here
}
Technical Note: How Go Embedding Works
When BitcoinCash embeds Bitcoin:
- All
Bitcoinmethods are "promoted" toBitcoinCash - If
BitcoinCashdefines a method with the same name, it takes precedence - The embedded
Bitcoinmethods can still be called viab.Bitcoin.MethodName()
// Call overridden method (uses BitcoinCash.GetAddressInfo)
info, _ := bch.GetAddressInfo(addr)
// Call embedded method directly (uses Bitcoin.GetAddressInfo)
info, _ := bch.Bitcoin.GetAddressInfo(addr)
Related Files
| File | Purpose |
|---|---|
internal/infrastructure/api/btc/bch/bitcoin_cash.go | BitcoinCash struct definition |
internal/infrastructure/api/btc/btc/bitcoin.go | Bitcoin struct (embedded by BCH) |
internal/application/ports/btc/interface.go | Bitcoiner interface |
Related Documentation
スコア
総合スコア
75/100
リポジトリの品質指標に基づく評価
✓SKILL.md
SKILL.mdファイルが含まれている
+20
✓LICENSE
ライセンスが設定されている
+10
○説明文
100文字以上の説明がある
0/10
✓人気
GitHub Stars 100以上
+5
✓最近の活動
1ヶ月以内に更新
+10
✓フォーク
10回以上フォークされている
+5
✓Issue管理
オープンIssueが50未満
+5
✓言語
プログラミング言語が設定されている
+5
✓タグ
1つ以上のタグが設定されている
+5
レビュー
💬
レビュー機能は近日公開予定です



