aboutsummaryrefslogtreecommitdiff
path: root/codegen/migrate.py
diff options
context:
space:
mode:
authormat <github@matdoes.dev>2022-05-25 00:30:47 -0500
committermat <github@matdoes.dev>2022-05-25 00:30:47 -0500
commitdc5a9149a588f727f14f7d6d89908ba8fe87b642 (patch)
treec54d6c9e735c4d24631ad9c11141158680957ccc /codegen/migrate.py
parent479c05474704a5a2f68b79468d2cde05c0ceec62 (diff)
downloadazalea-drasl-dc5a9149a588f727f14f7d6d89908ba8fe87b642.tar.xz
Fix migrate
Diffstat (limited to 'codegen/migrate.py')
-rw-r--r--codegen/migrate.py17
1 files changed, 10 insertions, 7 deletions
diff --git a/codegen/migrate.py b/codegen/migrate.py
index 6928cea1..7cd46058 100644
--- a/codegen/migrate.py
+++ b/codegen/migrate.py
@@ -1,4 +1,4 @@
-from codegen.lib.utils import PacketIdentifier, group_packets
+from lib.utils import PacketIdentifier, group_packets
import lib.code.utils
import lib.code.version
import lib.code.packet
@@ -24,19 +24,19 @@ for packet in old_packet_list:
assert packet['class'].endswith('.class')
packet_name = old_mappings.get_class(packet['class'][:-6])
old_packets[PacketIdentifier(
- packet['id'], packet['direction'], packet['state'])] = packet_name
+ packet['id'], packet['direction'].lower(), packet['state'].lower())] = packet_name
for packet in new_packet_list:
assert packet['class'].endswith('.class')
packet_name = new_mappings.get_class(packet['class'][:-6])
new_packets[PacketIdentifier(
- packet['id'], packet['direction'], packet['state'])] = packet_name
-
+ packet['id'], packet['direction'].lower(), packet['state'].lower())] = packet_name
# find removed packets
removed_packets: list[PacketIdentifier] = []
for packet in old_packets:
- if packet not in new_packets:
+ if packet not in new_packets or new_packets[packet] != old_packets[packet]:
removed_packets.append(packet)
+ print('Removed packet:', packet)
for (direction, state), packets in group_packets(removed_packets).items():
lib.code.packet.remove_packet_ids(packets, direction, state)
@@ -48,6 +48,8 @@ for old_packet, old_packet_name in old_packets.items():
for new_packet, new_packet_name in new_packets.items():
if old_packet == new_packet and old_packet.packet_id != new_packet.packet_id:
changed_packets[old_packet] = new_packet.packet_id
+ print('Changed packet id:', old_packet, '->',
+ new_packet, f'({new_packet_name})')
for (direction, state), packets in group_packets(list(changed_packets.keys())).items():
lib.code.packet.remove_packet_ids(packets, direction, state)
@@ -57,11 +59,12 @@ print()
# find added packets
added_packets: list[PacketIdentifier] = []
for packet in new_packets:
- if packet not in old_packets:
+ if packet not in old_packets and new_packets[packet] == old_packets[packet]:
added_packets.append(packet)
+ print('Added packet:', packet)
for packet in added_packets:
lib.code.packet.generate_packet(
- new_burger_data, new_mappings, packet.packet_id, packet.direction, packet.state)
+ new_burger_data[0]['packets']['packet'], new_mappings, packet.packet_id, packet.direction, packet.state)
lib.code.utils.fmt()
print('Done!')