cryptopals-zig/set1/challenge2_fixed_xor/src/main.zig

51 lines
1.6 KiB
Zig

const std = @import("std");
fn readHex(allocator: std.mem.Allocator, max_size: usize) ![]u8 {
const stdin = std.io.bufferedReader(std.io.getStdIn().reader()).reader();
var inputbuffer = std.ArrayList(u8).init(allocator);
defer inputbuffer.deinit();
var resultbuffer = std.ArrayList(u8).init(allocator);
defer resultbuffer.deinit();
while (true) {
try stdin.readUntilDelimiterArrayList(&inputbuffer, '\n', max_size * 2);
try resultbuffer.resize(inputbuffer.items.len / 2);
_ = std.fmt.hexToBytes(resultbuffer.items, inputbuffer.items) catch {
std.log.err("not a valid hexadecimal", .{});
continue;
};
return resultbuffer.toOwnedSlice();
}
}
pub fn main() anyerror!void {
var gpa = std.heap.GeneralPurposeAllocator(.{}){};
defer _ = gpa.deinit();
const allocator = gpa.allocator();
const stdout = std.io.getStdOut().writer();
while (true) {
const input1 = try readHex(allocator, 4096);
defer allocator.free(input1);
const input2 = try readHex(allocator, 4096);
defer allocator.free(input2);
if (input1.len != input2.len) {
std.log.err("not the same length", .{});
continue;
}
var output = try std.ArrayList(u8).initCapacity(allocator, input1.len);
defer output.deinit();
var i: usize = 0;
while (i < input1.len) : (i += 1) {
try output.append(input1[i] ^ input2[i]);
}
try stdout.print("{}\n", .{std.fmt.fmtSliceHexLower(output.items)});
}
}