2011-09-13 17:50:18 +03:00
|
|
|
#ifndef _misc__hpp__included__
|
|
|
|
#define _misc__hpp__included__
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
2011-11-06 14:41:41 +02:00
|
|
|
#include <stdexcept>
|
2012-10-13 12:48:37 +03:00
|
|
|
#include "library/string.hpp"
|
2011-09-13 17:50:18 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get random hexes
|
|
|
|
*
|
|
|
|
* Get string of random hex characters of specified length.
|
|
|
|
*
|
|
|
|
* \param length The number of hex characters to return.
|
|
|
|
* \return The random hexadecimal string.
|
|
|
|
* \throws std::bad_alloc Not enough memory.
|
|
|
|
*/
|
|
|
|
std::string get_random_hexstring(size_t length) throw(std::bad_alloc);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set random seed
|
|
|
|
*
|
|
|
|
* This function sets the random seed to use.
|
|
|
|
*
|
|
|
|
* \param seed The value to use as seed.
|
|
|
|
* \throw std::bad_alloc Not enough memory.
|
|
|
|
*/
|
|
|
|
void set_random_seed(const std::string& seed) throw(std::bad_alloc);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Set random seed to (hopefully) unique value
|
|
|
|
*
|
|
|
|
* This function sets the random seed to value that should only be used once. Note, the value is not necressarily
|
|
|
|
* crypto-secure, even if it is unique.
|
|
|
|
*
|
|
|
|
* \throw std::bad_alloc Not enough memory.
|
|
|
|
*/
|
|
|
|
void set_random_seed() throw(std::bad_alloc);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Load a ROM.
|
2011-09-15 22:56:33 +03:00
|
|
|
*
|
2011-09-13 17:50:18 +03:00
|
|
|
* Given commandline arguments, load a ROM.
|
2011-09-15 22:56:33 +03:00
|
|
|
*
|
2011-09-13 17:50:18 +03:00
|
|
|
* \param cmdline The command line.
|
|
|
|
* \return The loaded ROM set.
|
|
|
|
* \throws std::bad_alloc Not enough memory.
|
|
|
|
* \throws std::runtime_error Can't load the ROMset.
|
|
|
|
*/
|
2011-09-17 01:05:41 +03:00
|
|
|
struct loaded_rom load_rom_from_commandline(std::vector<std::string> cmdline) throw(std::bad_alloc,
|
2011-09-13 17:50:18 +03:00
|
|
|
std::runtime_error);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Dump listing of regions to graphics system messages.
|
2011-09-15 22:56:33 +03:00
|
|
|
*
|
2011-09-13 17:50:18 +03:00
|
|
|
* \throws std::bad_alloc Not enough memory.
|
|
|
|
*/
|
2011-09-17 01:05:41 +03:00
|
|
|
void dump_region_map() throw(std::bad_alloc);
|
2011-09-13 17:50:18 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Fatal error.
|
2011-09-15 22:56:33 +03:00
|
|
|
*
|
2011-09-17 01:05:41 +03:00
|
|
|
* Fatal error.
|
2011-09-13 17:50:18 +03:00
|
|
|
*/
|
2011-09-17 01:05:41 +03:00
|
|
|
void fatal_error() throw();
|
2011-09-13 17:50:18 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Get path to config directory.
|
2011-09-15 22:56:33 +03:00
|
|
|
*
|
2011-09-13 17:50:18 +03:00
|
|
|
* \return The config directory path.
|
|
|
|
* \throw std::bad_alloc Not enough memory.
|
|
|
|
*/
|
2011-09-17 01:05:41 +03:00
|
|
|
std::string get_config_path() throw(std::bad_alloc);
|
2011-09-13 17:50:18 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Panic on OOM.
|
|
|
|
*/
|
2011-09-17 01:05:41 +03:00
|
|
|
void OOM_panic();
|
2011-09-13 17:50:18 +03:00
|
|
|
|
2011-09-17 09:55:35 +03:00
|
|
|
/**
|
|
|
|
* messages -> window::out().
|
|
|
|
*/
|
|
|
|
std::ostream& _messages();
|
|
|
|
#define messages _messages()
|
|
|
|
|
2011-09-13 17:50:18 +03:00
|
|
|
|
2011-10-20 17:42:29 +03:00
|
|
|
uint32_t gcd(uint32_t a, uint32_t b) throw();
|
|
|
|
|
2011-09-17 01:05:41 +03:00
|
|
|
void create_lsnesrc();
|
2011-09-13 17:50:18 +03:00
|
|
|
|
2012-01-06 17:28:01 +02:00
|
|
|
/**
|
|
|
|
* Return hexadecimal representation of address
|
|
|
|
*/
|
|
|
|
std::string format_address(void* addr);
|
|
|
|
|
2012-01-11 01:21:13 +02:00
|
|
|
/**
|
|
|
|
* Get state of running global ctors flag.
|
|
|
|
*/
|
|
|
|
bool in_global_ctors();
|
|
|
|
/**
|
|
|
|
* Clear the global ctors flag.
|
|
|
|
*/
|
|
|
|
void reached_main();
|
|
|
|
|
2011-09-13 17:50:18 +03:00
|
|
|
#endif
|