The Battle for Wesnoth  1.19.5+dev
Classes | Typedefs | Enumerations | Functions | Variables
lg Namespace Reference

Classes

class  redirect_output_setter
 Helper class to redirect the output of the logger in a certain scope. More...
 
class  log_domain
 
class  log_in_progress
 
class  logger
 
class  scope_logger
 

Typedefs

typedef std::map< std::string, severitydomain_map
 
typedef std::pair< const std::string, severitylogd
 

Enumerations

enum class  severity {
  LG_NONE =-1 , LG_ERROR =0 , LG_WARN =1 , LG_INFO =2 ,
  LG_DEBUG =3
}
 

Functions

std::ostringstream & operator<< (std::ostringstream &oss, const lg::severity severity)
 
bool is_not_log_file (const std::string &filename)
 Use the defined prefix and suffix to determine if a filename is a log file. More...
 
void rotate_logs (const std::string &log_dir)
 Check how many log files exist and delete the oldest when there's too many. More...
 
std::string unique_log_filename ()
 Generate a unique file name using the current timestamp and a randomly generated number. More...
 
void check_log_dir_writable ()
 Checks that a dummy file can be written to and deleted from the logs directory. More...
 
void move_log_file ()
 Move the log file to another directory. More...
 
void set_log_to_file ()
 Do the initial redirection to a log file if the logs directory is writable. More...
 
utils::optional< bool > log_dir_writable ()
 Returns the result set by check_log_dir_writable(). More...
 
std::string get_log_file_path ()
 
void timestamps (bool t)
 
void precise_timestamps (bool pt)
 
loggererr ()
 
loggerwarn ()
 
loggerinfo ()
 
loggerdebug ()
 
log_domaingeneral ()
 
bool set_log_domain_severity (const std::string &name, severity severity)
 
bool set_log_domain_severity (const std::string &name, const logger &lg)
 
bool get_log_domain_severity (const std::string &name, severity &severity)
 
std::string list_log_domains (const std::string &filter)
 
void set_strict_severity (severity severity)
 
void set_strict_severity (const logger &lg)
 
bool broke_strict ()
 
std::string format_timespan (const std::chrono::seconds &span)
 TODO: we also have utils::format_timespan, which does something very similar... More...
 
void set_log_sanitize (bool sanitize)
 toggle log sanitization More...
 
std::string sanitize_log (const std::string &logstr)
 
std::stringstream & log_to_chat ()
 Use this to show WML errors in the ingame chat. More...
 
void do_console_redirect ()
 Allocates a console if needed and redirects output to CONOUT. More...
 
bool using_own_console ()
 Returns true if a console was allocated by the Wesnoth process. More...
 

Variables

static domain_mapdomains
 
static severity strict_level_ = severity::LG_NONE
 
static log_domain dom ("general")
 
static bool strict_threw_ = false
 
const std::string log_file_prefix = "wesnoth-"
 
const std::string log_file_suffix = ".log"
 
const std::string out_log_file_suffix = ".out" + log_file_suffix
 
const unsigned max_logs = 8
 

Typedef Documentation

◆ domain_map

typedef std::map<std::string, severity> lg::domain_map

Definition at line 301 of file log.cpp.

◆ logd

typedef std::pair<const std::string, severity> lg::logd

Definition at line 123 of file log.hpp.

Enumeration Type Documentation

◆ severity

enum lg::severity
strong
Enumerator
LG_NONE 
LG_ERROR 
LG_WARN 
LG_INFO 
LG_DEBUG 

Definition at line 82 of file log.hpp.

Function Documentation

◆ broke_strict()

bool lg::broke_strict ( )

◆ check_log_dir_writable()

void lg::check_log_dir_writable ( )

Checks that a dummy file can be written to and deleted from the logs directory.

Definition at line 146 of file log.cpp.

References filesystem::delete_file(), filesystem::file_exists(), filesystem::file_size(), filesystem::get_logs_dir(), is_log_dir_writable_, filesystem::make_directory(), and filesystem::write_file().

Referenced by move_log_file(), and set_log_to_file().

◆ debug()

logger & lg::debug ( )

◆ do_console_redirect()

void lg::do_console_redirect ( )

Allocates a console if needed and redirects output to CONOUT.

Definition at line 134 of file log_windows.cpp.

Referenced by process_command_args().

◆ err()

logger & lg::err ( )

◆ format_timespan()

std::string lg::format_timespan ( const std::chrono::seconds &  span)

TODO: we also have utils::format_timespan, which does something very similar...

Definition at line 404 of file log.cpp.

References chrono::deconstruct_duration(), and utils::join().

Referenced by wesnothd::banned::get_human_time_span(), and wesnothd::player_status().

◆ general()

log_domain & lg::general ( )

◆ get_log_domain_severity()

bool lg::get_log_domain_severity ( const std::string &  name,
severity severity 
)

Definition at line 371 of file log.cpp.

References domains.

Referenced by gui2::dialogs::log_settings::pre_show(), and game_config::set_debug().

◆ get_log_file_path()

std::string lg::get_log_file_path ( )

Definition at line 285 of file log.cpp.

References log_file_suffix, and output_file_path_.

Referenced by move_log_file().

◆ info()

logger & lg::info ( )

Definition at line 319 of file log.cpp.

References LG_INFO.

Referenced by ad_hoc_addon_fetch_session(), game_events::event_handlers::add_event_handler(), server_base::async_send_error(), server_base::async_send_warning(), BOOST_AUTO_TEST_CASE(), events::chat_handler::change_logging(), campaignd::command_line::command_line(), commandline_options::commandline_options(), addons_client::connect(), deprecated_message(), gui2::addon_list::describe_status(), addon_info::description_translated(), gui2::dialogs::server_info::display(), addon_info::display_title_translated(), game_config::dist_channel_id(), addons_client::do_resolve_addon_dependencies(), gui2::dialogs::editor_edit_side::editor_edit_side(), ai::default_recruitment::recruitment::execute(), gui2::dialogs::mp_lobby::game_filter_init(), help::generate_terrain_sections(), get_addon_install_info(), theme::get_basic_theme_info(), ai::default_recruitment::recruitment::get_cheapest_unit_cost_for_leader(), texture::get_info(), gui2::get_mp_tooltip(), gui2::dialogs::addon_manager::get_status_filter_visibility(), wesnothd::server::handle_player_in_game(), campaignd::server::handle_read_from_fifo(), game_lua_kernel::impl_get_terrain_info(), addons_client::install_addon(), intf_log(), game_config_manager::load_game_config_with_loadscreen(), main(), ng::depcheck::manager::manager(), gui2::dialogs::addon_manager::on_addon_select(), gui2::dialogs::addon_manager::on_selected_version_change(), gui2::dialogs::mp_connect::on_server_add(), gui2::dialogs::mp_lobby::open_match_history(), gui2::dialogs::mp_lobby::open_profile_url(), help::unit_topic_generator::operator()(), gui2::dialogs::outro::outro(), spirit_po::catalog_metadata::parse_header(), commandline_options::parse_log_strictness(), gui2::dialogs::mp_create_game::pre_show(), gui2::dialogs::mp_lobby::process_network_data(), playmp_controller::process_oos(), game_events::wml_event_pump::put_wml_message(), run_campaignd(), gui2::addon_list::select_addon(), unit_type_data::set_config(), gui2::dialogs::log_settings::set_logger(), editor::map_context::set_side_setup(), editor::terrain_palette::setup_item(), gui2::dialogs::mp_create_game::sync_with_depcheck(), addon_info::translated_info(), unit_moves(), gui2::lobby_player_list_helper::update(), gui2::dialogs::mp_lobby::user_dialog_callback(), and sdl::window::window().

◆ is_not_log_file()

bool lg::is_not_log_file ( const std::string &  filename)

Use the defined prefix and suffix to determine if a filename is a log file.

Returns
true if it's a log file, false otherwise

Definition at line 96 of file log.cpp.

References log_file_prefix, and log_file_suffix.

Referenced by rotate_logs().

◆ list_log_domains()

std::string lg::list_log_domains ( const std::string &  filter)

Definition at line 380 of file log.cpp.

References domains.

Referenced by gui2::dialogs::log_settings::log_settings(), process_command_args(), and run_campaignd().

◆ log_dir_writable()

utils::optional< bool > lg::log_dir_writable ( )

Returns the result set by check_log_dir_writable().

Will not be set if called before log redirection is done.

Returns
true if the log directory is writable, false otherwise.

Definition at line 280 of file log.cpp.

References is_log_dir_writable_.

Referenced by do_gameloop().

◆ log_to_chat()

std::stringstream & lg::log_to_chat ( )

◆ move_log_file()

void lg::move_log_file ( )

Move the log file to another directory.

Used if a custom userdata directory is given as a command line option to move it to the new location.

Definition at line 178 of file log.cpp.

References check_log_dir_writable(), get_log_file_path(), filesystem::get_logs_dir(), is_log_dir_writable_, log_file_suffix, logs_dir_, out_log_file_suffix, output_file_path_, and unique_log_filename().

Referenced by filesystem::setup_user_data_dir().

◆ operator<<()

std::ostringstream & lg::operator<< ( std::ostringstream &  oss,
const lg::severity  severity 
)

Definition at line 90 of file log.cpp.

◆ precise_timestamps()

void lg::precise_timestamps ( bool  pt)

◆ rotate_logs()

void lg::rotate_logs ( const std::string &  log_dir)

Check how many log files exist and delete the oldest when there's too many.

Definition at line 102 of file log.cpp.

References filesystem::delete_file(), utils::erase_if(), ERR_LS, filesystem::get_files_in_dir(), is_not_log_file(), LOG_LS, max_logs, output_file_path_, and game_config::path.

Referenced by set_log_to_file().

◆ sanitize_log()

std::string lg::sanitize_log ( const std::string &  logstr)

Definition at line 432 of file log.cpp.

References log_sanitization.

Referenced by lg::log_in_progress::operator|().

◆ set_log_domain_severity() [1/2]

bool lg::set_log_domain_severity ( const std::string &  name,
const logger lg 
)

Definition at line 367 of file log.cpp.

References set_log_domain_severity().

◆ set_log_domain_severity() [2/2]

bool lg::set_log_domain_severity ( const std::string &  name,
severity  severity 
)

◆ set_log_sanitize()

void lg::set_log_sanitize ( bool  sanitize)

toggle log sanitization

Definition at line 428 of file log.cpp.

References log_sanitization.

Referenced by process_command_args().

◆ set_log_to_file()

void lg::set_log_to_file ( )

Do the initial redirection to a log file if the logs directory is writable.

Also performs log rotation to delete old logs. NOTE: This runs before command line arguments are processed. Therefore the log file is initially written under the default userdata directory

Definition at line 234 of file log.cpp.

References check_log_dir_writable(), filesystem::get_logs_dir(), is_log_dir_writable_, log_file_suffix, logs_dir_, out_log_file_suffix, output_file_path_, rotate_logs(), and unique_log_filename().

Referenced by process_command_args().

◆ set_strict_severity() [1/2]

void lg::set_strict_severity ( const logger lg)

Definition at line 394 of file log.cpp.

References set_strict_severity().

◆ set_strict_severity() [2/2]

void lg::set_strict_severity ( severity  severity)

◆ timestamps()

void lg::timestamps ( bool  t)

Definition at line 304 of file log.cpp.

References t, and timestamp.

Referenced by BOOST_AUTO_TEST_CASE(), main(), and run_campaignd().

◆ unique_log_filename()

std::string lg::unique_log_filename ( )

Generate a unique file name using the current timestamp and a randomly generated number.

Returns
A unique file name to use for the current log file.

Definition at line 133 of file log.cpp.

References randomness::mt_rng::get_next_random(), and log_file_prefix.

Referenced by move_log_file(), and set_log_to_file().

◆ using_own_console()

bool lg::using_own_console ( )

Returns true if a console was allocated by the Wesnoth process.

Returns false if no native console or if it was attached from a parent process.

Definition at line 141 of file log_windows.cpp.

Referenced by main().

◆ warn()

logger & lg::warn ( )

Variable Documentation

◆ dom

log_domain lg::dom("general") ( "general"  )
static

Referenced by general().

◆ domains

domain_map* lg::domains
static

◆ log_file_prefix

const std::string lg::log_file_prefix = "wesnoth-"

Definition at line 68 of file log.hpp.

Referenced by is_not_log_file(), and unique_log_filename().

◆ log_file_suffix

const std::string lg::log_file_suffix = ".log"

Definition at line 69 of file log.hpp.

Referenced by get_log_file_path(), is_not_log_file(), move_log_file(), and set_log_to_file().

◆ max_logs

const unsigned lg::max_logs = 8

Definition at line 76 of file log.hpp.

Referenced by rotate_logs().

◆ out_log_file_suffix

const std::string lg::out_log_file_suffix = ".out" + log_file_suffix

Definition at line 71 of file log.hpp.

Referenced by move_log_file(), and set_log_to_file().

◆ strict_level_

severity lg::strict_level_ = severity::LG_NONE
static

Definition at line 303 of file log.cpp.

Referenced by lg::logger::operator()(), and set_strict_severity().

◆ strict_threw_

bool lg::strict_threw_ = false
static

Definition at line 398 of file log.cpp.

Referenced by broke_strict(), and lg::logger::operator()().