- Rename data/cards/ to data/raw/ for scraped data - Add data/definitions/ as authoritative card data source - Add convert_cards.py script to transform raw -> definitions - Generate 378 card definitions (344 Pokemon, 24 Trainers, 10 Energy) - Add CardService for loading and querying card definitions - In-memory indexes for fast lookups by type, set, pokemon_type - search() with multiple filter criteria - get_all_cards() for GameEngine integration - Add SetInfo model for set metadata - Update Attack model with damage_display field for variable damage - Update CardDefinition with image_path, illustrator, flavor_text - Add 45 tests (21 converter + 24 CardService) - Update scraper output path to data/raw/ Card data is JSON-authoritative (no database) to support offline fork goal.
28 lines
529 B
JSON
28 lines
529 B
JSON
{
|
|
"id": "a1-029-petilil",
|
|
"name": "Petilil",
|
|
"card_type": "pokemon",
|
|
"hp": 60,
|
|
"pokemon_type": "grass",
|
|
"stage": "basic",
|
|
"variant": "normal",
|
|
"retreat_cost": 1,
|
|
"set_id": "a1",
|
|
"rarity": "common",
|
|
"attacks": [
|
|
{
|
|
"name": "Blot",
|
|
"cost": [
|
|
"grass"
|
|
],
|
|
"damage": 10,
|
|
"damage_display": "10",
|
|
"effect_description": "Heal 10 damage from this Pok\u00e9mon."
|
|
}
|
|
],
|
|
"weakness": {
|
|
"energy_type": "fire",
|
|
"value": 20
|
|
},
|
|
"illustrator": "Naoyo Kimura"
|
|
} |