surtur
b0eaf5e49e
All checks were successful
continuous-integration/drone/push Build is passing
also got rid of the redundant ctr variable as we only need the one that is part of G_state.
30 lines
691 B
C++
30 lines
691 B
C++
#ifndef FORTUNA_GENERATOR_H
|
|
#define FORTUNA_GENERATOR_H
|
|
|
|
#include <string>
|
|
#include <cstring>
|
|
#include <tuple>
|
|
|
|
namespace fortuna {
|
|
namespace generator {
|
|
|
|
struct G_state;
|
|
|
|
/* initializes generator */
|
|
G_state *initialize_generator();
|
|
|
|
auto do_crypto(int64_t k, unsigned __int128 ctr) -> std::string;
|
|
|
|
auto reseed(G_state G, const std::string& s) -> G_state;
|
|
|
|
auto do_sha(int64_t key_with_seed) -> int64_t;
|
|
|
|
auto generate_blocks(G_state G, int k_blocks) -> std::tuple<std::string, G_state>;
|
|
|
|
/* returns output of 0 <= n <= 2^20 bytes */
|
|
auto generate_random_data(G_state G, int n) -> std::tuple<std::string, G_state>;
|
|
|
|
} //namespace generator
|
|
} //namespace fortuna
|
|
#endif//FORTUNA_GENERATOR_H
|