diff options
Diffstat (limited to 'codegen')
| -rw-r--r-- | codegen/genblocks.py | 14 | ||||
| -rw-r--r-- | codegen/genregistries.py | 16 | ||||
| -rw-r--r-- | codegen/lib/code/registry.py | 32 | ||||
| -rw-r--r-- | codegen/lib/extract.py | 6 | ||||
| -rw-r--r-- | codegen/lib/utils.py | 3 | ||||
| -rw-r--r-- | codegen/migrate.py | 17 |
6 files changed, 76 insertions, 12 deletions
diff --git a/codegen/genblocks.py b/codegen/genblocks.py index 174d2e16..fe5eddd1 100644 --- a/codegen/genblocks.py +++ b/codegen/genblocks.py @@ -8,18 +8,8 @@ import lib.utils version_id = lib.code.version.get_version_id() - lib.extract.get_generator_mod_data(version_id, 'blockCollisionShapes') -# lib.download.get_burger() -# lib.download.get_client_jar(version_id) - -# print('Generating data with burger') -# os.system( -# f'cd {lib.utils.get_dir_location("downloads/Burger")} && python munch.py ../client-{version_id}.jar --output ../burger-{version_id}.json --toppings blockstates' -# ) -# print('Ok') - mappings = lib.download.get_mappings_for_version(version_id) block_states_burger = lib.extract.get_block_states_burger(version_id) ordered_blocks = lib.extract.get_ordered_blocks_burger(version_id) @@ -27,3 +17,7 @@ block_states_report = lib.extract.get_block_states_report(version_id) lib.code.blocks.generate_blocks( block_states_burger, block_states_report, ordered_blocks, mappings) + +lib.code.utils.fmt() + +print('Done!') diff --git a/codegen/genregistries.py b/codegen/genregistries.py new file mode 100644 index 00000000..43591d59 --- /dev/null +++ b/codegen/genregistries.py @@ -0,0 +1,16 @@ +import lib.code.registry +import lib.code.version +import lib.code.packet +import lib.code.utils +import lib.download +import lib.extract +import lib.utils + +version_id = lib.code.version.get_version_id() +registries = lib.extract.get_registries_report(version_id) + +lib.code.registry.generate_registries(registries) + +lib.code.utils.fmt() + +print('Done!') diff --git a/codegen/lib/code/registry.py b/codegen/lib/code/registry.py new file mode 100644 index 00000000..fbe9e5af --- /dev/null +++ b/codegen/lib/code/registry.py @@ -0,0 +1,32 @@ +from typing import Optional +from lib.utils import to_snake_case, upper_first_letter, get_dir_location, to_camel_case +from ..mappings import Mappings +import re + +REGISTRIES_DIR = get_dir_location('../azalea-registry/src/lib.rs') + + +def generate_registries(registries: dict): + code = [] + + code.append('use registry_macros::registry;') + code.append('') + + for registry_name, registry in registries.items(): + # registry!(Block, { + # Air => "minecraft:air", + # Stone => "minecraft:stone" + # }); + registry_struct_name = to_camel_case(registry_name.split(':')[1]) + code.append(f'registry!({registry_struct_name}, {{') + registry_entries = sorted( + registry['entries'].items(), key=lambda x: x[1]['protocol_id']) + for variant_name, _variant in registry_entries: + variant_struct_name = to_camel_case( + variant_name.split(':')[1]) + code.append(f'\t{variant_struct_name} => "{variant_name}",') + code.append('});') + code.append('') + + with open(REGISTRIES_DIR, 'w') as f: + f.write('\n'.join(code)) diff --git a/codegen/lib/extract.py b/codegen/lib/extract.py index 070aba14..75e4908b 100644 --- a/codegen/lib/extract.py +++ b/codegen/lib/extract.py @@ -24,6 +24,12 @@ def get_block_states_report(version_id: str): return json.load(f) +def get_registries_report(version_id: str): + generate_data_from_server_jar(version_id) + with open(get_dir_location(f'downloads/generated-{version_id}/reports/registries.json'), 'r') as f: + return json.load(f) + + def get_block_states_burger(version_id: str): burger_data = get_burger_data_for_version(version_id) return burger_data[0]['blocks']['block'] diff --git a/codegen/lib/utils.py b/codegen/lib/utils.py index c3d293c0..efabbb38 100644 --- a/codegen/lib/utils.py +++ b/codegen/lib/utils.py @@ -10,7 +10,8 @@ def to_snake_case(name: str): def to_camel_case(name: str): - s = re.sub('_([a-z])', lambda m: m.group(1).upper(), name) + s = re.sub('[_ ](\w)', lambda m: m.group(1).upper(), + name.replace('.', '_').replace('/', '_')) s = upper_first_letter(s) # if the first character is a number, we need to add an underscore # maybe we could convert it to the number name (like 2 would become "two")? diff --git a/codegen/migrate.py b/codegen/migrate.py index 2dacc208..50bdb354 100644 --- a/codegen/migrate.py +++ b/codegen/migrate.py @@ -1,8 +1,9 @@ from lib.code.packet import fix_state from lib.utils import PacketIdentifier, group_packets -import lib.code.utils import lib.code.version +import lib.code.blocks import lib.code.packet +import lib.code.utils import lib.download import lib.extract import sys @@ -102,6 +103,20 @@ lib.code.version.set_protocol_version( new_burger_data[0]['version']['protocol']) lib.code.version.set_version_id(new_version_id) +print('Updated protocol!') + + +old_ordered_blocks = lib.extract.get_ordered_blocks_burger(old_version_id) +new_ordered_blocks = lib.extract.get_ordered_blocks_burger(new_version_id) +if old_ordered_blocks != new_ordered_blocks: + print('Blocks changed, updating...') + block_states_burger = lib.extract.get_block_states_burger(new_version_id) + block_states_report = lib.extract.get_block_states_report(new_version_id) + + lib.code.blocks.generate_blocks( + block_states_burger, block_states_report, old_ordered_blocks, new_mappings) + + lib.code.utils.fmt() print('Done!') |
