/* See LICENSE file for copyright and license details. */ #include "common.h" static void process(struct algorithm *algorithm, struct global_data *global) { size_t r; r = algorithm->hasher.process(&algorithm->hasher, &global->buffer->buf[algorithm->offset], global->buffer->length - algorithm->offset); algorithm->offset += r; } static void finalise(struct algorithm *algorithm, struct global_data *global) { if (algorithm->hasher.finalise_const(&algorithm->hasher, &global->buffer->buf[algorithm->offset], global->buffer->length - algorithm->offset, 0)) abort(); format_result(algorithm, global->file, global->format); } int calculate(const char *file, struct barrier_group *group, struct global_data *global) { int fd, is_new_fd, r, ret = -1; const char *fname; global->nalgorithms = inithashers(global->algorithms, global->nalgorithms); if (!global->nalgorithms) return 0; fd = openfile(file, &is_new_fd, &fname); if (fd < 0) return -1; global->buffer->length = 0; while (!(r = feedbuffer(fd, global->buffer, fname))) { barriersend(group, global, &process); shiftbuffer(global->algorithms, global->nalgorithms, global->buffer); } if (r < 0) goto fail; barriersend(group, global, &finalise); ret = 0; fail: destroyhashers(global->algorithms, global->nalgorithms); if (is_new_fd) close(fd); return ret; }