annotate foosdk/sdk/foobar2000/SDK/console.cpp @ 1:20d02a178406 default tip

*: check in everything else yay
author Paper <paper@tflc.us>
date Mon, 05 Jan 2026 02:15:46 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
1 #include "foobar2000-sdk-pch.h"
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
2 #include "console_manager.h"
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
3 #include "console.h"
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
4 #include "metadb_handle.h"
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
5 #include "event_logger.h"
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
6
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
7 void console::info(const char * p_message) {print(p_message);}
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
8 void console::error(const char * p_message) {complain("Error", p_message);}
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
9 void console::warning(const char * p_message) {complain("Warning", p_message);}
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
10
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
11 void console::info_location(const playable_location & src) {print_location(src);}
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
12 void console::info_location(const metadb_handle_ptr & src) {print_location(src);}
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
13
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
14 void console::print_location(const metadb_handle_ptr & src)
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
15 {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
16 print_location(src->get_location());
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
17 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
18
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
19 void console::print_location(const playable_location & src)
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
20 {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
21 FB2K_console_formatter() << src;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
22 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
23
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
24 void console::complain(const char * what, const char * msg) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
25 FB2K_console_formatter() << what << ": " << msg;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
26 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
27 void console::complain(const char * what, std::exception const & e) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
28 complain(what, e.what());
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
29 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
30
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
31 void console::print(const char* p_message)
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
32 {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
33 if (core_api::are_services_available()) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
34 for (auto p : console_receiver::enumerate()) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
35 p->print(p_message, SIZE_MAX);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
36 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
37 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
38 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
39
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
40 void console::printf(const char* p_format,...)
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
41 {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
42 va_list list;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
43 va_start(list,p_format);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
44 printfv(p_format,list);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
45 va_end(list);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
46 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
47
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
48 void console::printfv(const char* p_format,va_list p_arglist)
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
49 {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
50 pfc::string8_fastalloc temp;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
51 uPrintfV(temp,p_format,p_arglist);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
52 print(temp);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
53 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
54
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
55
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
56
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
57 namespace {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
58
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
59 class event_logger_recorder_impl : public event_logger_recorder {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
60 public:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
61 void playback( event_logger::ptr playTo ) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
62 for(auto i = m_entries.first(); i.is_valid(); ++i ) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
63 playTo->log_entry( i->line.get_ptr(), i->severity );
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
64 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
65 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
66
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
67 void log_entry( const char * line, unsigned severity ) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
68 auto rec = m_entries.insert_last();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
69 rec->line = line;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
70 rec->severity = severity;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
71 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
72 private:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
73
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
74 struct entry_t {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
75 pfc::string_simple line;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
76 unsigned severity;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
77 };
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
78 pfc::chain_list_v2_t< entry_t > m_entries;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
79 };
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
80
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
81 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
82
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
83 event_logger_recorder::ptr event_logger_recorder::create() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
84 return new service_impl_t<event_logger_recorder_impl>();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
85 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
86
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
87
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
88
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
89
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
90 namespace console {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
91 void addNotify(fb2k::console_notify* n) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
92 static_api_ptr_t<fb2k::console_manager>()->addNotify(n);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
93 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
94 void removeNotify(fb2k::console_notify* n) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
95 static_api_ptr_t<fb2k::console_manager>()->removeNotify(n);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
96 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
97 fb2k::arrayRef getLines() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
98 return static_api_ptr_t<fb2k::console_manager>()->getLines();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
99 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
100 void clearBacklog() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
101 static_api_ptr_t<fb2k::console_manager>()->clearBacklog();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
102 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
103
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
104 bool isVerbose() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
105 return static_api_ptr_t<fb2k::console_manager>()->isVerbose();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
106 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
107 }