mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-01 00:31:21 +00:00
222bb666e9
``` ➜ erigon-lib git:(fieldalign) ✗ fieldalignment -fix ./... /Users/estensen/Developer/erigon-lib/commitment/bin_patricia_hashed.go:81:16: struct of size 1065120 could be 1065112 /Users/estensen/Developer/erigon-lib/commitment/bin_patricia_hashed.go:1063:14: struct of size 1032 could be 1024 /Users/estensen/Developer/erigon-lib/commitment/hex_patricia_hashed.go:62:24: struct of size 952776 could be 952768 /Users/estensen/Developer/erigon-lib/commitment/hex_patricia_hashed.go:98:12: struct of size 1832 could be 1824 /Users/estensen/Developer/erigon-lib/commitment/hex_patricia_hashed.go:113:12: struct with 208 pointer bytes could be 152 /Users/estensen/Developer/erigon-lib/commitment/hex_patricia_hashed.go:143:11: struct of size 464 could be 456 /Users/estensen/Developer/erigon-lib/gointerfaces/types/types.pb.go:24:11: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/types/types.pb.go:79:11: struct of size 56 could be 48 /Users/estensen/Developer/erigon-lib/gointerfaces/types/types.pb.go:134:11: struct with 56 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/gointerfaces/types/types.pb.go:189:11: struct with 56 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/gointerfaces/types/types.pb.go:244:12: struct with 56 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/gointerfaces/types/types.pb.go:299:12: struct with 56 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/gointerfaces/types/types.pb.go:355:19: struct of size 56 could be 48 /Users/estensen/Developer/erigon-lib/gointerfaces/types/types.pb.go:418:23: struct with 168 pointer bytes could be 128 /Users/estensen/Developer/erigon-lib/gointerfaces/types/types.pb.go:571:20: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/types/types.pb.go:626:20: struct with 136 pointer bytes could be 128 /Users/estensen/Developer/erigon-lib/gointerfaces/types/types.pb.go:721:15: struct of size 168 could be 160 /Users/estensen/Developer/erigon-lib/etl/buffers.go:75:21: struct with 88 pointer bytes could be 64 /Users/estensen/Developer/erigon-lib/etl/buffers.go:182:27: struct with 56 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/etl/buffers.go:274:32: struct with 56 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/etl/collector.go:41:16: struct with 72 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/etl/etl.go:66:20: struct with 96 pointer bytes could be 64 /Users/estensen/Developer/erigon-lib/etl/heap.go:25:15: struct with 40 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/patricia/patricia.go:29:11: struct with 40 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/patricia/patricia.go:347:12: struct with 32 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/patricia/patricia.go:367:18: struct with 48 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/patricia/patricia.go:377:19: struct with 168 pointer bytes could be 144 /Users/estensen/Developer/erigon-lib/compress/compress.go:52:17: struct with 176 pointer bytes could be 136 /Users/estensen/Developer/erigon-lib/compress/compress.go:241:24: struct with 48 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/compress/compress.go:327:14: struct with 40 pointer bytes could be 8 /Users/estensen/Developer/erigon-lib/compress/compress.go:353:18: struct with 48 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/compress/compress.go:450:19: struct with 48 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/compress/compress.go:670:21: struct with 48 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/compress/compress.go:734:23: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/compress/decompress.go:31:15: struct with 32 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/compress/decompress.go:39:19: struct with 40 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/compress/decompress.go:117:15: struct with 64 pointer bytes could be 56 /Users/estensen/Developer/erigon-lib/compress/decompress.go:125:19: struct with 96 pointer bytes could be 80 /Users/estensen/Developer/erigon-lib/compress/decompress.go:386:13: struct with 64 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/compress/parallel_compress.go:208:22: struct with 16 pointer bytes could be 8 /Users/estensen/Developer/erigon-lib/recsplit/golomb_rice.go:32:17: struct with 16 pointer bytes could be 8 /Users/estensen/Developer/erigon-lib/recsplit/index.go:35:12: struct of size 432 could be 424 /Users/estensen/Developer/erigon-lib/recsplit/index_reader.go:26:18: struct with 48 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/recsplit/recsplit.go:64:15: struct of size 704 could be 680 /Users/estensen/Developer/erigon-lib/recsplit/recsplit.go:111:19: struct of size 104 could be 96 /Users/estensen/Developer/erigon-lib/aggregator/aggregator.go:171:17: struct of size 640 could be 632 /Users/estensen/Developer/erigon-lib/aggregator/aggregator.go:198:17: struct with 168 pointer bytes could be 144 /Users/estensen/Developer/erigon-lib/aggregator/aggregator.go:389:14: struct with 584 pointer bytes could be 568 /Users/estensen/Developer/erigon-lib/aggregator/aggregator.go:921:21: struct with 72 pointer bytes could be 56 /Users/estensen/Developer/erigon-lib/aggregator/aggregator.go:1195:22: struct with 2432 pointer bytes could be 2416 /Users/estensen/Developer/erigon-lib/aggregator/aggregator.go:2123:13: struct with 2448 pointer bytes could be 2416 /Users/estensen/Developer/erigon-lib/aggregator/aggregator.go:2634:17: struct with 96 pointer bytes could be 64 /Users/estensen/Developer/erigon-lib/aggregator/history.go:39:14: struct with 96 pointer bytes could be 88 /Users/estensen/Developer/erigon-lib/bptree/binary_file.go:33:17: struct with 40 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/bptree/node.go:79:13: struct of size 88 could be 80 /Users/estensen/Developer/erigon-lib/chain/chain_config.go:28:13: struct with 136 pointer bytes could be 120 /Users/estensen/Developer/erigon-lib/common/background/progress.go:26:18: struct with 40 pointer bytes could be 8 /Users/estensen/Developer/erigon-lib/gointerfaces/downloader/downloader.pb.go:25:19: struct with 64 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/downloader/downloader.pb.go:80:22: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/downloader/downloader.pb.go:127:20: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/downloader/downloader.pb.go:165:19: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/downloader/downloader.pb.go:203:17: struct of size 104 could be 96 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:135:23: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:173:21: struct with 48 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:220:24: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:258:22: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:305:26: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:343:24: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:390:30: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:437:26: struct of size 72 could be 64 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:500:30: struct with 64 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:563:28: struct with 64 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:626:37: struct with 56 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:681:35: struct with 48 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:736:29: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:774:27: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:821:27: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:859:25: struct with 48 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:906:23: struct of size 48 could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:953:21: struct of size 72 could be 64 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:1008:24: struct of size 104 could be 88 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:1079:25: struct of size 144 could be 136 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:1190:19: struct with 56 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:1245:17: struct with 72 pointer bytes could be 64 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:1300:23: struct with 48 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:1347:21: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:1394:23: struct of size 48 could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:1441:21: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:1488:17: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/ethbackend.pb.go:1535:24: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/kv.pb.go:220:13: struct of size 120 could be 112 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/kv.pb.go:299:11: struct of size 104 could be 96 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/kv.pb.go:370:20: struct with 56 pointer bytes could be 48 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/kv.pb.go:425:20: struct of size 136 could be 128 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/kv.pb.go:513:23: struct with 56 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/kv.pb.go:585:18: struct of size 112 could be 104 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/kv.pb.go:664:25: struct of size 48 could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/kv.pb.go:719:23: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/remote/kv.pb.go:757:21: struct with 72 pointer bytes could be 64 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:300:26: struct of size 72 could be 64 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:355:35: struct with 48 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:410:29: struct with 56 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:465:38: struct with 48 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:520:16: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:567:26: struct of size 56 could be 48 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:622:26: struct with 48 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:677:21: struct of size 80 could be 72 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:740:12: struct with 56 pointer bytes could be 48 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:795:17: struct with 72 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:874:21: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:912:21: struct of size 48 could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:959:22: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:1006:17: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:1053:23: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:1091:21: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:1138:22: struct with 48 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:1185:20: struct with 48 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:1232:24: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/sentry/sentry.pb.go:1270:16: struct of size 56 could be 48 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:25:28: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:63:26: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:110:26: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:148:24: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:195:27: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:233:25: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:280:21: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:318:19: struct with 96 pointer bytes could be 80 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:389:24: struct with 96 pointer bytes could be 88 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:452:22: struct of size 48 could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:499:28: struct with 56 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:554:26: struct of size 48 could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:601:22: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:639:20: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:686:20: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/mining.pb.go:724:18: struct of size 48 could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:132:15: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:179:17: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:226:15: struct with 72 pointer bytes could be 64 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:281:26: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:328:24: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:375:19: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:413:17: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:460:17: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:498:15: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:545:19: struct with 48 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:592:20: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:630:18: struct of size 56 could be 48 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:693:19: struct with 48 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:740:17: struct of size 56 could be 48 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:795:18: struct of size 80 could be 72 /Users/estensen/Developer/erigon-lib/gointerfaces/txpool/txpool.pb.go:858:22: struct of size 80 could be 72 /Users/estensen/Developer/erigon-lib/direct/sentry_client.go:171:25: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/kv/mdbx/kv_mdbx.go:50:15: struct with 104 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/kv/mdbx/kv_mdbx.go:355:13: struct with 160 pointer bytes could be 152 /Users/estensen/Developer/erigon-lib/kv/memdb/memory_mutation_cursor.go:39:27: struct with 200 pointer bytes could be 184 /Users/estensen/Developer/erigon-lib/kv/remotedb/kv_remote.go:22:17: struct with 72 pointer bytes could be 48 /Users/estensen/Developer/erigon-lib/kv/remotedb/kv_remote.go:38:15: struct with 80 pointer bytes could be 64 /Users/estensen/Developer/erigon-lib/kv/remotedbserver/server.go:314:24: struct with 40 pointer bytes could be 8 /Users/estensen/Developer/erigon-lib/state/aggregator.go:44:17: struct with 192 pointer bytes could be 128 /Users/estensen/Developer/erigon-lib/state/aggregator.go:422:13: struct of size 384 could be 360 /Users/estensen/Developer/erigon-lib/state/aggregator.go:455:26: struct with 424 pointer bytes could be 368 /Users/estensen/Developer/erigon-lib/state/aggregator.go:853:22: struct with 24 pointer bytes could be 8 /Users/estensen/Developer/erigon-lib/state/aggregator22.go:37:19: struct with 176 pointer bytes could be 136 /Users/estensen/Developer/erigon-lib/state/aggregator22.go:643:15: struct of size 240 could be 216 /Users/estensen/Developer/erigon-lib/state/aggregator22.go:674:28: struct with 272 pointer bytes could be 224 /Users/estensen/Developer/erigon-lib/state/aggregator22.go:1126:26: struct with 104 pointer bytes could be 88 /Users/estensen/Developer/erigon-lib/state/aggregator22.go:1156:23: struct with 24 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/state/domain.go:52:16: struct with 32 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/state/domain.go:89:13: struct with 120 pointer bytes could be 48 /Users/estensen/Developer/erigon-lib/state/domain.go:399:17: struct with 96 pointer bytes could be 64 /Users/estensen/Developer/erigon-lib/state/domain.go:443:14: struct with 32 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/state/domain.go:594:16: struct with 72 pointer bytes could be 48 /Users/estensen/Developer/erigon-lib/state/history.go:48:14: struct with 72 pointer bytes could be 48 /Users/estensen/Developer/erigon-lib/state/history.go:435:20: struct with 48 pointer bytes could be 32 /Users/estensen/Developer/erigon-lib/state/history.go:529:23: struct with 40 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/state/history.go:1150:23: struct of size 344 could be 336 /Users/estensen/Developer/erigon-lib/state/inverted_index.go:46:20: struct with 128 pointer bytes could be 88 /Users/estensen/Developer/erigon-lib/state/inverted_index.go:389:23: struct with 136 pointer bytes could be 88 /Users/estensen/Developer/erigon-lib/state/inverted_index.go:541:24: struct with 184 pointer bytes could be 152 /Users/estensen/Developer/erigon-lib/state/merge.go:69:19: struct of size 72 could be 56 /Users/estensen/Developer/erigon-lib/state/merge.go:143:20: struct of size 48 could be 40 /Users/estensen/Developer/erigon-lib/state/read_indices.go:29:18: struct with 64 pointer bytes could be 48 /Users/estensen/Developer/erigon-lib/state/read_indices.go:211:14: struct of size 72 could be 56 /Users/estensen/Developer/erigon-lib/state/read_indices.go:233:27: struct with 72 pointer bytes could be 56 /Users/estensen/Developer/erigon-lib/state/state_recon.go:61:16: struct with 56 pointer bytes could be 16 /Users/estensen/Developer/erigon-lib/state/state_recon.go:112:19: struct with 136 pointer bytes could be 112 /Users/estensen/Developer/erigon-lib/state/state_recon.go:190:22: struct with 128 pointer bytes could be 112 /Users/estensen/Developer/erigon-lib/types/testdata.go:81:26: struct with 40 pointer bytes could be 8 /Users/estensen/Developer/erigon-lib/types/txn.go:46:21: struct with 400 pointer bytes could be 40 /Users/estensen/Developer/erigon-lib/types/txn.go:82:13: struct with 200 pointer bytes could be 8 /Users/estensen/Developer/erigon-lib/types/txn.go:691:18: struct with 32 pointer bytes could be 8 /Users/estensen/Developer/erigon-lib/txpool/fetch.go:43:12: struct with 136 pointer bytes could be 112 /Users/estensen/Developer/erigon-lib/txpool/pool.go:69:13: struct with 104 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/txpool/pool.go:221:13: struct of size 104 could be 96 /Users/estensen/Developer/erigon-lib/txpool/pool.go:291:13: struct with 336 pointer bytes could be 288 /Users/estensen/Developer/erigon-lib/txpool/pool.go:1789:29: struct with 32 pointer bytes could be 8 /Users/estensen/Developer/erigon-lib/txpool/pool.go:1819:19: struct with 32 pointer bytes could be 24 /Users/estensen/Developer/erigon-lib/txpool/pool.go:1994:18: struct of size 64 could be 56 /Users/estensen/Developer/erigon-lib/txpool/pool.go:2102:14: struct of size 64 could be 56 /Users/estensen/Developer/erigon-lib/txpool/send.go:37:11: struct with 64 pointer bytes could be 48 /Users/estensen/Developer/erigon-lib/txpool/test_util.go:31:17: struct with 72 pointer bytes could be 40 ```
423 lines
11 KiB
Go
423 lines
11 KiB
Go
package commitment
|
|
|
|
import (
|
|
"encoding/binary"
|
|
"encoding/hex"
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/holiman/uint256"
|
|
"golang.org/x/crypto/sha3"
|
|
"golang.org/x/exp/slices"
|
|
|
|
"github.com/ledgerwatch/erigon-lib/common"
|
|
"github.com/ledgerwatch/erigon-lib/common/length"
|
|
)
|
|
|
|
// In memory commitment and state to use with the tests
|
|
type MockState struct {
|
|
t *testing.T
|
|
sm map[string][]byte // backbone of the state
|
|
cm map[string]BranchData // backbone of the commitments
|
|
numBuf [binary.MaxVarintLen64]byte
|
|
}
|
|
|
|
func NewMockState(t *testing.T) *MockState {
|
|
t.Helper()
|
|
return &MockState{
|
|
t: t,
|
|
sm: make(map[string][]byte),
|
|
cm: make(map[string]BranchData),
|
|
}
|
|
}
|
|
|
|
func (ms MockState) branchFn(prefix []byte) ([]byte, error) {
|
|
if exBytes, ok := ms.cm[string(prefix)]; ok {
|
|
return exBytes[2:], nil // Skip touchMap, but keep afterMap
|
|
}
|
|
return nil, nil
|
|
}
|
|
|
|
func (ms MockState) accountFn(plainKey []byte, cell *Cell) error {
|
|
exBytes, ok := ms.sm[string(plainKey[:])]
|
|
if !ok {
|
|
ms.t.Logf("accountFn not found key [%x]", plainKey)
|
|
cell.Delete = true
|
|
return nil
|
|
}
|
|
var ex Update
|
|
pos, err := ex.Decode(exBytes, 0)
|
|
if err != nil {
|
|
ms.t.Fatalf("accountFn decode existing [%x], bytes: [%x]: %v", plainKey, exBytes, err)
|
|
return nil
|
|
}
|
|
if pos != len(exBytes) {
|
|
ms.t.Fatalf("accountFn key [%x] leftover bytes in [%x], comsumed %x", plainKey, exBytes, pos)
|
|
return nil
|
|
}
|
|
if ex.Flags&STORAGE_UPDATE != 0 {
|
|
ms.t.Logf("accountFn reading storage item for key [%x]", plainKey)
|
|
return fmt.Errorf("storage read by accountFn")
|
|
}
|
|
if ex.Flags&DELETE_UPDATE != 0 {
|
|
ms.t.Fatalf("accountFn reading deleted account for key [%x]", plainKey)
|
|
return nil
|
|
}
|
|
if ex.Flags&BALANCE_UPDATE != 0 {
|
|
cell.Balance.Set(&ex.Balance)
|
|
} else {
|
|
cell.Balance.Clear()
|
|
}
|
|
if ex.Flags&NONCE_UPDATE != 0 {
|
|
cell.Nonce = ex.Nonce
|
|
} else {
|
|
cell.Nonce = 0
|
|
}
|
|
if ex.Flags&CODE_UPDATE != 0 {
|
|
copy(cell.CodeHash[:], ex.CodeHashOrStorage[:])
|
|
} else {
|
|
copy(cell.CodeHash[:], EmptyCodeHash)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (ms MockState) storageFn(plainKey []byte, cell *Cell) error {
|
|
exBytes, ok := ms.sm[string(plainKey[:])]
|
|
if !ok {
|
|
ms.t.Logf("storageFn not found key [%x]", plainKey)
|
|
cell.Delete = true
|
|
return nil
|
|
}
|
|
var ex Update
|
|
pos, err := ex.Decode(exBytes, 0)
|
|
if err != nil {
|
|
ms.t.Fatalf("storageFn decode existing [%x], bytes: [%x]: %v", plainKey, exBytes, err)
|
|
return nil
|
|
}
|
|
if pos != len(exBytes) {
|
|
ms.t.Fatalf("storageFn key [%x] leftover bytes in [%x], comsumed %x", plainKey, exBytes, pos)
|
|
return nil
|
|
}
|
|
if ex.Flags&BALANCE_UPDATE != 0 {
|
|
ms.t.Logf("storageFn reading balance for key [%x]", plainKey)
|
|
return nil
|
|
}
|
|
if ex.Flags&NONCE_UPDATE != 0 {
|
|
ms.t.Fatalf("storageFn reading nonce for key [%x]", plainKey)
|
|
return nil
|
|
}
|
|
if ex.Flags&CODE_UPDATE != 0 {
|
|
ms.t.Fatalf("storageFn reading codeHash for key [%x]", plainKey)
|
|
return nil
|
|
}
|
|
if ex.Flags&DELETE_UPDATE != 0 {
|
|
ms.t.Fatalf("storageFn reading deleted item for key [%x]", plainKey)
|
|
return nil
|
|
}
|
|
if ex.Flags&STORAGE_UPDATE != 0 {
|
|
copy(cell.Storage[:], ex.CodeHashOrStorage[:])
|
|
cell.StorageLen = len(ex.CodeHashOrStorage)
|
|
} else {
|
|
cell.StorageLen = 0
|
|
cell.Storage = [length.Hash]byte{}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (ms *MockState) applyPlainUpdates(plainKeys [][]byte, updates []Update) error {
|
|
for i, key := range plainKeys {
|
|
update := updates[i]
|
|
if update.Flags&DELETE_UPDATE != 0 {
|
|
delete(ms.sm, string(key))
|
|
} else {
|
|
if exBytes, ok := ms.sm[string(key)]; ok {
|
|
var ex Update
|
|
pos, err := ex.Decode(exBytes, 0)
|
|
if err != nil {
|
|
return fmt.Errorf("applyPlainUpdates decode existing [%x], bytes: [%x]: %w", key, exBytes, err)
|
|
}
|
|
if pos != len(exBytes) {
|
|
return fmt.Errorf("applyPlainUpdates key [%x] leftover bytes in [%x], comsumed %x", key, exBytes, pos)
|
|
}
|
|
if update.Flags&BALANCE_UPDATE != 0 {
|
|
ex.Flags |= BALANCE_UPDATE
|
|
ex.Balance.Set(&update.Balance)
|
|
}
|
|
if update.Flags&NONCE_UPDATE != 0 {
|
|
ex.Flags |= NONCE_UPDATE
|
|
ex.Nonce = update.Nonce
|
|
}
|
|
if update.Flags&CODE_UPDATE != 0 {
|
|
ex.Flags |= CODE_UPDATE
|
|
copy(ex.CodeHashOrStorage[:], update.CodeHashOrStorage[:])
|
|
}
|
|
if update.Flags&STORAGE_UPDATE != 0 {
|
|
ex.Flags |= STORAGE_UPDATE
|
|
copy(ex.CodeHashOrStorage[:], update.CodeHashOrStorage[:])
|
|
}
|
|
ms.sm[string(key)] = ex.Encode(nil, ms.numBuf[:])
|
|
} else {
|
|
ms.sm[string(key)] = update.Encode(nil, ms.numBuf[:])
|
|
}
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (ms *MockState) applyBranchNodeUpdates(updates map[string]BranchData) {
|
|
for key, update := range updates {
|
|
if pre, ok := ms.cm[key]; ok {
|
|
// Merge
|
|
merged, err := pre.MergeHexBranches(update, nil)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
ms.cm[key] = merged
|
|
} else {
|
|
ms.cm[key] = update
|
|
}
|
|
}
|
|
}
|
|
|
|
func decodeHex(in string) []byte {
|
|
payload, err := hex.DecodeString(in)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
return payload
|
|
}
|
|
|
|
// UpdateBuilder collects updates to the state
|
|
// and provides them in properly sorted form
|
|
type UpdateBuilder struct {
|
|
balances map[string]*uint256.Int
|
|
nonces map[string]uint64
|
|
codeHashes map[string][length.Hash]byte
|
|
storages map[string]map[string][]byte
|
|
deletes map[string]struct{}
|
|
deletes2 map[string]map[string]struct{}
|
|
keyset map[string]struct{}
|
|
keyset2 map[string]map[string]struct{}
|
|
}
|
|
|
|
func NewUpdateBuilder() *UpdateBuilder {
|
|
return &UpdateBuilder{
|
|
balances: make(map[string]*uint256.Int),
|
|
nonces: make(map[string]uint64),
|
|
codeHashes: make(map[string][length.Hash]byte),
|
|
storages: make(map[string]map[string][]byte),
|
|
deletes: make(map[string]struct{}),
|
|
deletes2: make(map[string]map[string]struct{}),
|
|
keyset: make(map[string]struct{}),
|
|
keyset2: make(map[string]map[string]struct{}),
|
|
}
|
|
}
|
|
|
|
func (ub *UpdateBuilder) Balance(addr string, balance uint64) *UpdateBuilder {
|
|
sk := string(decodeHex(addr))
|
|
delete(ub.deletes, sk)
|
|
ub.balances[sk] = uint256.NewInt(balance)
|
|
ub.keyset[sk] = struct{}{}
|
|
return ub
|
|
}
|
|
|
|
func (ub *UpdateBuilder) Nonce(addr string, nonce uint64) *UpdateBuilder {
|
|
sk := string(decodeHex(addr))
|
|
delete(ub.deletes, sk)
|
|
ub.nonces[sk] = nonce
|
|
ub.keyset[sk] = struct{}{}
|
|
return ub
|
|
}
|
|
|
|
func (ub *UpdateBuilder) CodeHash(addr string, hash string) *UpdateBuilder {
|
|
sk := string(decodeHex(addr))
|
|
delete(ub.deletes, sk)
|
|
hcode, err := hex.DecodeString(hash)
|
|
if err != nil {
|
|
panic(fmt.Errorf("invalid code hash provided: %w", err))
|
|
}
|
|
if len(hcode) != length.Hash {
|
|
panic(fmt.Errorf("code hash should be %d bytes long, got %d", length.Hash, len(hcode)))
|
|
}
|
|
|
|
dst := [length.Hash]byte{}
|
|
copy(dst[:32], hcode)
|
|
|
|
ub.codeHashes[sk] = dst
|
|
ub.keyset[sk] = struct{}{}
|
|
return ub
|
|
}
|
|
|
|
func (ub *UpdateBuilder) Storage(addr string, loc string, value string) *UpdateBuilder {
|
|
sk1 := string(decodeHex(addr))
|
|
sk2 := string(decodeHex(loc))
|
|
v := decodeHex(value)
|
|
if d, ok := ub.deletes2[sk1]; ok {
|
|
delete(d, sk2)
|
|
if len(d) == 0 {
|
|
delete(ub.deletes2, sk1)
|
|
}
|
|
}
|
|
if k, ok := ub.keyset2[sk1]; ok {
|
|
k[sk2] = struct{}{}
|
|
} else {
|
|
ub.keyset2[sk1] = make(map[string]struct{})
|
|
ub.keyset2[sk1][sk2] = struct{}{}
|
|
}
|
|
if s, ok := ub.storages[sk1]; ok {
|
|
s[sk2] = v
|
|
} else {
|
|
ub.storages[sk1] = make(map[string][]byte)
|
|
ub.storages[sk1][sk2] = v
|
|
}
|
|
return ub
|
|
}
|
|
|
|
func (ub *UpdateBuilder) IncrementBalance(addr string, balance []byte) *UpdateBuilder {
|
|
sk := string(decodeHex(addr))
|
|
delete(ub.deletes, sk)
|
|
increment := uint256.NewInt(0)
|
|
increment.SetBytes(balance)
|
|
if old, ok := ub.balances[sk]; ok {
|
|
balance := uint256.NewInt(0)
|
|
balance.Add(old, increment)
|
|
ub.balances[sk] = balance
|
|
} else {
|
|
ub.balances[sk] = increment
|
|
}
|
|
ub.keyset[sk] = struct{}{}
|
|
return ub
|
|
}
|
|
|
|
func (ub *UpdateBuilder) Delete(addr string) *UpdateBuilder {
|
|
sk := string(decodeHex(addr))
|
|
delete(ub.balances, sk)
|
|
delete(ub.nonces, sk)
|
|
delete(ub.codeHashes, sk)
|
|
delete(ub.storages, sk)
|
|
ub.deletes[sk] = struct{}{}
|
|
ub.keyset[sk] = struct{}{}
|
|
return ub
|
|
}
|
|
|
|
func (ub *UpdateBuilder) DeleteStorage(addr string, loc string) *UpdateBuilder {
|
|
sk1 := string(decodeHex(addr))
|
|
sk2 := string(decodeHex(loc))
|
|
if s, ok := ub.storages[sk1]; ok {
|
|
delete(s, sk2)
|
|
if len(s) == 0 {
|
|
delete(ub.storages, sk1)
|
|
}
|
|
}
|
|
if k, ok := ub.keyset2[sk1]; ok {
|
|
k[sk2] = struct{}{}
|
|
} else {
|
|
ub.keyset2[sk1] = make(map[string]struct{})
|
|
ub.keyset2[sk1][sk2] = struct{}{}
|
|
}
|
|
if d, ok := ub.deletes2[sk1]; ok {
|
|
d[sk2] = struct{}{}
|
|
} else {
|
|
ub.deletes2[sk1] = make(map[string]struct{})
|
|
ub.deletes2[sk1][sk2] = struct{}{}
|
|
}
|
|
return ub
|
|
}
|
|
|
|
// Build returns three slices (in the order sorted by the hashed keys)
|
|
// 1. Plain keys
|
|
// 2. Corresponding hashed keys
|
|
// 3. Corresponding updates
|
|
func (ub *UpdateBuilder) Build() (plainKeys, hashedKeys [][]byte, updates []Update) {
|
|
hashed := make([]string, 0, len(ub.keyset)+len(ub.keyset2))
|
|
preimages := make(map[string][]byte)
|
|
preimages2 := make(map[string][]byte)
|
|
keccak := sha3.NewLegacyKeccak256()
|
|
for key := range ub.keyset {
|
|
keccak.Reset()
|
|
keccak.Write([]byte(key))
|
|
h := keccak.Sum(nil)
|
|
hashedKey := make([]byte, len(h)*2)
|
|
for i, c := range h {
|
|
hashedKey[i*2] = (c >> 4) & 0xf
|
|
hashedKey[i*2+1] = c & 0xf
|
|
}
|
|
hashed = append(hashed, string(hashedKey))
|
|
preimages[string(hashedKey)] = []byte(key)
|
|
}
|
|
hashedKey := make([]byte, 128)
|
|
for sk1, k := range ub.keyset2 {
|
|
keccak.Reset()
|
|
keccak.Write([]byte(sk1))
|
|
h := keccak.Sum(nil)
|
|
for i, c := range h {
|
|
hashedKey[i*2] = (c >> 4) & 0xf
|
|
hashedKey[i*2+1] = c & 0xf
|
|
}
|
|
for sk2 := range k {
|
|
keccak.Reset()
|
|
keccak.Write([]byte(sk2))
|
|
h2 := keccak.Sum(nil)
|
|
for i, c := range h2 {
|
|
hashedKey[64+i*2] = (c >> 4) & 0xf
|
|
hashedKey[64+i*2+1] = c & 0xf
|
|
}
|
|
hs := string(common.Copy(hashedKey))
|
|
hashed = append(hashed, hs)
|
|
preimages[hs] = []byte(sk1)
|
|
preimages2[hs] = []byte(sk2)
|
|
}
|
|
|
|
}
|
|
slices.Sort(hashed)
|
|
plainKeys = make([][]byte, len(hashed))
|
|
hashedKeys = make([][]byte, len(hashed))
|
|
updates = make([]Update, len(hashed))
|
|
for i, hashedKey := range hashed {
|
|
hashedKeys[i] = []byte(hashedKey)
|
|
key := preimages[hashedKey]
|
|
key2 := preimages2[hashedKey]
|
|
plainKey := make([]byte, len(key)+len(key2))
|
|
copy(plainKey[:], key)
|
|
if key2 != nil {
|
|
copy(plainKey[len(key):], key2)
|
|
}
|
|
plainKeys[i] = plainKey
|
|
u := &updates[i]
|
|
if key2 == nil {
|
|
if balance, ok := ub.balances[string(key)]; ok {
|
|
u.Flags |= BALANCE_UPDATE
|
|
u.Balance.Set(balance)
|
|
}
|
|
if nonce, ok := ub.nonces[string(key)]; ok {
|
|
u.Flags |= NONCE_UPDATE
|
|
u.Nonce = nonce
|
|
}
|
|
if codeHash, ok := ub.codeHashes[string(key)]; ok {
|
|
u.Flags |= CODE_UPDATE
|
|
copy(u.CodeHashOrStorage[:], codeHash[:])
|
|
}
|
|
if _, del := ub.deletes[string(key)]; del {
|
|
u.Flags = DELETE_UPDATE
|
|
continue
|
|
}
|
|
} else {
|
|
if dm, ok1 := ub.deletes2[string(key)]; ok1 {
|
|
if _, ok2 := dm[string(key2)]; ok2 {
|
|
u.Flags = DELETE_UPDATE
|
|
continue
|
|
}
|
|
}
|
|
if sm, ok1 := ub.storages[string(key)]; ok1 {
|
|
if storage, ok2 := sm[string(key2)]; ok2 {
|
|
u.Flags |= STORAGE_UPDATE
|
|
u.CodeHashOrStorage = [length.Hash]byte{}
|
|
u.ValLength = len(storage)
|
|
copy(u.CodeHashOrStorage[:], storage)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return
|
|
}
|