From 764f1033b72ea174470a40c49ae2a519be047d46 Mon Sep 17 00:00:00 2001 From: Trevor Berrange Sanchez Date: Mon, 10 Jun 2024 20:59:16 +0200 Subject: [PATCH] Pass around []const T instead of ArrayList & also add better toString methods to SocketAddr --- src/accountsdb/download.zig | 22 +++++++++++++--------- src/cmd/cmd.zig | 4 ++-- src/net/net.zig | 14 ++++++++++++-- 3 files changed, 27 insertions(+), 13 deletions(-) diff --git a/src/accountsdb/download.zig b/src/accountsdb/download.zig index eb368d666..47733a200 100644 --- a/src/accountsdb/download.zig +++ b/src/accountsdb/download.zig @@ -39,15 +39,19 @@ const PeerSearchResult = struct { pub fn findPeersToDownloadFromAssumeCapacity( allocator: std.mem.Allocator, table: *const GossipTable, - contact_infos: []ContactInfo, + contact_infos: []const ContactInfo, my_shred_version: usize, my_pubkey: Pubkey, - blacklist: []Pubkey, - trusted_validators: ?std.ArrayList(Pubkey), + blacklist: []const Pubkey, + trusted_validators: ?[]const Pubkey, + /// `.capacity` must be >= `contact_infos.len`. + /// The arraylist is first cleared, and then the outputs + /// are appended to it. valid_peers: *std.ArrayList(PeerSnapshotHash), ) !PeerSearchResult { // clear the list valid_peers.clearRetainingCapacity(); + std.debug.assert(valid_peers.capacity >= contact_infos.len); const TrustedMapType = std.AutoHashMap( SlotAndHash, // full snapshot hash @@ -62,7 +66,7 @@ pub fn findPeersToDownloadFromAssumeCapacity( // populate with the hashes of trusted validators var trusted_count: usize = 0; // SAFE: the perf is safe because maybe_ is non null only if trusted_validators is non-null - for (trusted_validators.?.items) |trusted_validator| { + for (trusted_validators.?) |trusted_validator| { const gossip_data = table.get(.{ .SnapshotHashes = trusted_validator }) orelse continue; const trusted_hashes = gossip_data.value.data.SnapshotHashes; trusted_count += 1; @@ -154,7 +158,7 @@ pub fn downloadSnapshotsFromGossip( allocator: std.mem.Allocator, logger: Logger, // if null, then we trust any peer for snapshot download - maybe_trusted_validators: ?std.ArrayList(Pubkey), + maybe_trusted_validators: ?[]const Pubkey, gossip_service: *GossipService, output_dir: []const u8, min_mb_per_sec: usize, @@ -209,8 +213,8 @@ pub fn downloadSnapshotsFromGossip( defer allocator.free(snapshot_filename); const rpc_socket = peer.contact_info.getSocket(socket_tag.RPC).?; - const r = rpc_socket.toString(); - const rpc_url = r[0][0..r[1]]; + const rpc_url_bounded = rpc_socket.toStringBounded(); + const rpc_url = rpc_url_bounded.constSlice(); const snapshot_url = try std.fmt.allocPrintZ(allocator, "http://{s}/{s}", .{ rpc_url, @@ -520,7 +524,7 @@ test "accounts_db.download: test remove untrusted peers" { my_shred_version, my_pubkey, &.{}, - trusted_validators, + trusted_validators.items, &valid_peers, ); try std.testing.expectEqual(valid_peers.items.len, 10); @@ -535,7 +539,7 @@ test "accounts_db.download: test remove untrusted peers" { my_shred_version, my_pubkey, &.{}, - trusted_validators, + trusted_validators.items, &valid_peers, ); try std.testing.expectEqual(valid_peers.items.len, 8); diff --git a/src/cmd/cmd.zig b/src/cmd/cmd.zig index a41633aa4..b008ac579 100644 --- a/src/cmd/cmd.zig +++ b/src/cmd/cmd.zig @@ -722,7 +722,7 @@ fn downloadSnapshot() !void { try downloadSnapshotsFromGossip( gpa_allocator, logger, - trusted_validators, + if (trusted_validators) |trusted| trusted.items else null, &gossip_service, snapshot_dir_str, @intCast(min_mb_per_sec), @@ -795,7 +795,7 @@ fn getOrDownloadSnapshots( try downloadSnapshotsFromGossip( allocator, logger, - trusted_validators, + if (trusted_validators) |trusted| trusted.items else null, gossip_service orelse return error.SnapshotsNotFoundAndNoGossipService, snapshot_dir_str, @intCast(min_mb_per_sec), diff --git a/src/net/net.zig b/src/net/net.zig index 2106aa195..a4e6f9ae6 100644 --- a/src/net/net.zig +++ b/src/net/net.zig @@ -240,9 +240,19 @@ pub const SocketAddr = union(enum(u8)) { /// - integer: length of the string within the array pub fn toString(self: Self) struct { [53]u8, usize } { var buf: [53]u8 = undefined; - var stream = std.io.fixedBufferStream(&buf); + const len = self.toStringBuf(&buf); + return .{ buf, len }; + } + + pub fn toStringBounded(self: Self) std.BoundedArray(u8, 53) { + var buf: [53]u8 = undefined; + return std.BoundedArray(u8, 53).fromSlice(buf[0..self.toStringBuf(&buf)]) catch unreachable; + } + + pub fn toStringBuf(self: Self, buf: *[53]u8) std.math.IntFittingRange(0, 53) { + var stream = std.io.fixedBufferStream(buf); self.toAddress().format("", .{}, stream.writer()) catch unreachable; - return .{ buf, stream.pos }; + return @intCast(stream.pos); } pub fn isUnspecified(self: *const Self) bool {