diff options
| author | Benedict <benedict@0xb8000.de> | 2016-03-19 13:44:55 +0100 |
|---|---|---|
| committer | Benedict <benedict@0xb8000.de> | 2017-02-21 13:00:24 +0100 |
| commit | 4a9770b8ba9d86db12779f5ae00366bce60a42ad (patch) | |
| tree | 760dee07368fa25141e2467d21128486f5e5e7f8 /task2.c | |
| parent | 236d0ee8acedc2535a4a973acd99a708b530a053 (diff) | |
completed task6 nearly completly
just a few characters are still wrong in the key.
freqencies analysis has to be made more comprehensive
Diffstat (limited to 'task2.c')
| -rw-r--r-- | task2.c | 15 |
1 files changed, 8 insertions, 7 deletions
@@ -6,16 +6,17 @@ int main(int argc, char**argv) if (argc != 3) return 1; - - char *xor_string_tmp = malloc(strlen(argv[1])); - char *result = malloc(strlen(argv[1])); - char *str1 = malloc(strlen(argv[1])); - char *str2 = malloc(strlen(argv[2])); + int length_arg_1 = strlen(argv[1]); + int length_arg_2 = strlen(argv[2]); + char *xor_string_tmp = malloc(length_arg_1+1); + char *result = malloc(length_arg_1*2+1); + char *str1 = malloc(length_arg_1+1); + char *str2 = malloc(length_arg_2+1); decode_hex_string(argv[1], str1); decode_hex_string(argv[2], str2); - xor_string(str1, str2, xor_string_tmp, strlen(argv[2]), strlen(argv[1])); - hex_binary_to_string(xor_string_tmp, result, strlen(argv[1])); + xor_string(str1, str2, xor_string_tmp, length_arg_2, length_arg_1); + hex_binary_to_string(xor_string_tmp, result, (length_arg_1/2)); printf("%s\n", result); free(xor_string_tmp); |
