forked from mirror/Archipelago
* Init
* remove submodule
* Init
* Update docs
* Fix tests
* Update to use apcivvi
* Update Readme and codeowners
* Minor changes
* Remove .value from options (except starting hint)
* Minor updates
* remove unnecessary property
* Cleanup Rules and Region
* Fix output file generation
* Implement feedback
* Remove 'AP' tag and fix issue with format strings and using same quotes
* Update worlds/civ_6/__init__.py
Co-authored-by: Scipio Wright <scipiowright@gmail.com>
* Minor docs changes
* minor updates
* Small rework of create items
* Minor updates
* Remove unused variable
* Move client to Launcher Components with rest of similar clients
* Revert "Move client to Launcher Components with rest of similar clients"
This reverts commit f9fd5df9fd.
* modify component
* Fix generation issues
* Fix tests
* Minor change
* Add improvement and test case
* Minor options changes
* .
* Preliminary Review
* Fix failing test due to slot data serialization
* Format json
* Remove exclude missable boosts
* Update options (update goody hut text, make research multiplier a range)
* Update docs punctuation and slot data init
* Move priority/excluded locations into options
* Implement docs PR feedback
* PR Feedback for options
* PR feedback misc
* Update location classification and fix client type
* Fix typings
* Update research cost multiplier
* Remove unnecessary location priority code
* Remove extrenous use of items()
* WIP PR Feedback
* WIP PR Feedback
* Add victory event
* Add option set for death link effect
* PR improvements
* Update post fill hint to support items with multiple classifications
* remove unnecessary len
* Move location exclusion logic
* Update test to use set instead of accidental dict
* Update docs around progressive eras and boost locations
* Update docs for options to be more readable
* Fix issue with filler items and prehints
* Update filler_data to be static
* Update links in docs
* Minor updates and PR feedback
* Update boosts data
* Update era required items
* Update existing techs
* Update existing techs
* move boost data class
* Update reward data
* Update prereq data
* Update new items and progressive districts
* Remove unused code
* Make filler item name func more efficient
* Update death link text
* Move Civ6 to the end of readme
* Fix bug with hidden locations and location.name
* Partial PR Feedback Implementation
* Format changes
* Minor review feedback
* Modify access rules to use list created in generate_early
* Modify boost rules to precalculate requirements
* Remove option checks from access rules
* Fix issue with pre initialized dicts
* Add inno setup for civ6 client
* Update inno_setup.iss
---------
Co-authored-by: Scipio Wright <scipiowright@gmail.com>
Co-authored-by: Exempt-Medic <60412657+Exempt-Medic@users.noreply.github.com>
Co-authored-by: Exempt-Medic <ExemptMedic@Gmail.com>
Co-authored-by: NewSoupVi <57900059+NewSoupVi@users.noreply.github.com>
36 lines
1.5 KiB
Python
36 lines
1.5 KiB
Python
from typing import Dict, List, Optional
|
|
|
|
from .Data import get_progressive_districts_data
|
|
|
|
_flat_progressive_districts: Optional[Dict[str, str]] = {}
|
|
|
|
|
|
def get_flat_progressive_districts() -> Dict[str, str]:
|
|
"""Returns a dictionary of all items that are associated with a progressive item.
|
|
Key is the item name ("TECH_WRITING") and the value is the associated progressive
|
|
item ("PROGRESSIVE_CAMPUS")"""
|
|
if _flat_progressive_districts:
|
|
return _flat_progressive_districts
|
|
|
|
progressive_districts = get_progressive_districts_data()
|
|
flat_progressive_districts: Dict[str, str] = {}
|
|
for key, value in progressive_districts.items():
|
|
for item in value:
|
|
flat_progressive_districts[item] = key
|
|
return flat_progressive_districts
|
|
|
|
|
|
def convert_items_to_progressive_items(items: List[str]):
|
|
"""converts a list of items to instead be their associated progressive item if
|
|
they have one. ["TECH_MINING", "TECH_WRITING"] -> ["TECH_MINING", "PROGRESSIVE_CAMPUS]
|
|
"""
|
|
flat_progressive_districts = get_flat_progressive_districts()
|
|
return [flat_progressive_districts.get(item, item) for item in items]
|
|
|
|
|
|
def convert_item_to_progressive_item(item: str):
|
|
"""converts an items to instead be its associated progressive item if
|
|
it has one. "TECH_WRITING" -> "PROGRESSIVE_CAMPUS"""
|
|
flat_progressive_districts = get_flat_progressive_districts()
|
|
return flat_progressive_districts.get(item, item)
|