fix double free
This commit is contained in:
parent
55283f4376
commit
6abec1ca62
|
@ -43,8 +43,8 @@ pub fn main() anyerror!void {
|
|||
const stdin = std.io.bufferedReader(std.io.getStdIn().reader()).reader();
|
||||
const stdout = std.io.getStdOut().writer();
|
||||
|
||||
var bestplaintext = try allocator.alloc(u8, 0);
|
||||
defer allocator.free(bestplaintext);
|
||||
var bestplaintext = std.ArrayList(u8).init(allocator);
|
||||
defer bestplaintext.deinit();
|
||||
var bestscore: u32 = 0;
|
||||
|
||||
while (true) {
|
||||
|
@ -58,9 +58,8 @@ pub fn main() anyerror!void {
|
|||
decrypt(plaintext, ciphertext, key);
|
||||
const s = score(plaintext);
|
||||
if (s > bestscore) {
|
||||
allocator.free(bestplaintext);
|
||||
bestplaintext = try allocator.alloc(u8, plaintext.len);
|
||||
std.mem.copy(u8, bestplaintext, plaintext);
|
||||
try bestplaintext.resize(plaintext.len);
|
||||
std.mem.copy(u8, bestplaintext.items, plaintext);
|
||||
bestscore = s;
|
||||
}
|
||||
key +%= 1;
|
||||
|
@ -70,5 +69,5 @@ pub fn main() anyerror!void {
|
|||
}
|
||||
}
|
||||
|
||||
try stdout.print("{s}\n", .{bestplaintext});
|
||||
try stdout.print("{s}\n", .{bestplaintext.items});
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue