MySQL 8.4.2
Source Code Documentation
|
The trace of one statement. More...
Public Member Functions | |
Opt_trace_stmt (Opt_trace_context *ctx_arg) | |
Constructor, starts a trace for information_schema and dbug. More... | |
void | end () |
Ends a trace; destruction may not be possible immediately as we may have to keep the trace in case the user later reads it from I_S. More... | |
bool | has_ended () const |
void | set_allowed_mem_size (size_t size) |
Sets the quantity of allowed memory for this trace. More... | |
void | set_query (const char *query, size_t length, const CHARSET_INFO *charset) |
bool | open_struct (const char *key, Opt_trace_struct *ots, bool wants_disable_I_S, char opening_bracket) |
When creating an Opt_trace_struct: adds a key and the opening bracket to the trace buffer, updates current_struct. More... | |
void | close_struct (const char *saved_key, bool has_disabled_I_S, char closing_bracket) |
When closing an Opt_trace_struct: More... | |
void | separator () |
Put optional comma, newline and indentation. More... | |
void | next_line () |
Put newline and indentation. More... | |
void | add (const char *key, const char *val, size_t val_length, bool quotes, bool escape) |
Adds a key/value pair to the trace buffer. More... | |
void | fill_info (Opt_trace_info *info) const |
Fills user-level information. More... | |
size_t | alloced_length () const |
void | assert_current_struct (const Opt_trace_struct *s) const |
void | missing_privilege () |
bool | support_I_S () const |
void | disable_I_S () |
Temporarily disables I_S output for this statement. More... | |
void | restore_I_S () |
Restores I_S support to what it was before the previous call to disable_I_S(). More... | |
const char * | make_unknown_key () |
Generate a dummy unique key, and return pointer to it. More... | |
Private Attributes | |
bool | ended |
Whether end() has been called on this instance. More... | |
int | I_S_disabled |
0 <=> this trace should be in information_schema. More... | |
bool | missing_priv |
whether user lacks privilege to see this trace More... | |
Opt_trace_context * | ctx |
context More... | |
Opt_trace_struct * | current_struct |
current open structure More... | |
Prealloced_array< Opt_trace_struct *, 16 > | stack_of_current_structs |
Same logic as Opt_trace_context::stack_of_current_stmts. More... | |
Buffer | trace_buffer |
Where the trace is accumulated. More... | |
Buffer | query_buffer |
Where the original query is put. More... | |
uint | unknown_key_count |
Counter which serves to have unique autogenerated keys, needed if we autogenerate more than one key in a single object. More... | |
char | unknown_key [24] |
Space for last autogenerated key. More... | |
The trace of one statement.
For example, executing a stored procedure containing 3 sub-statements will produce 4 traces (one for the CALL statement, one for each sub-statement), so 4 Opt_trace_stmt linked together into Opt_trace_context's lists.
Opt_trace_stmt::Opt_trace_stmt | ( | Opt_trace_context * | ctx_arg | ) |
Constructor, starts a trace for information_schema and dbug.
ctx_arg | context |
void Opt_trace_stmt::add | ( | const char * | key, |
const char * | val, | ||
size_t | val_length, | ||
bool | quotes, | ||
bool | escape | ||
) |
Adds a key/value pair to the trace buffer.
key | key or NULL |
val | representation of value as string |
val_length | length of value |
quotes | should value be delimited with '"' (false when the value is the representation of a number, boolean or null) |
escape | does value need escaping (has special characters) |
|
inline |
|
inline |
void Opt_trace_stmt::close_struct | ( | const char * | saved_key, |
bool | has_disabled_I_S, | ||
char | closing_bracket | ||
) |
When closing an Opt_trace_struct:
saved_key | key or NULL |
has_disabled_I_S | whether structure had disabled I_S output |
closing_bracket | closing bracket to use |
|
inline |
Temporarily disables I_S output for this statement.
void Opt_trace_stmt::end | ( | void | ) |
Ends a trace; destruction may not be possible immediately as we may have to keep the trace in case the user later reads it from I_S.
void Opt_trace_stmt::fill_info | ( | Opt_trace_info * | info | ) | const |
Fills user-level information.
|
inline |
end()
has been called on this instance. const char * Opt_trace_stmt::make_unknown_key | ( | ) |
Generate a dummy unique key, and return pointer to it.
The pointed data has the lifetime of Opt_trace_stmt, and is overwritten by the next call to this function.
void Opt_trace_stmt::missing_privilege | ( | ) |
void Opt_trace_stmt::next_line | ( | ) |
Put newline and indentation.
bool Opt_trace_stmt::open_struct | ( | const char * | key, |
Opt_trace_struct * | ots, | ||
bool | wants_disable_I_S, | ||
char | opening_bracket | ||
) |
When creating an Opt_trace_struct: adds a key and the opening bracket to the trace buffer, updates current_struct.
key | key or NULL |
ots | structure being created |
wants_disable_I_S | whether structure wants to disable I_S output |
opening_bracket | opening bracket to use |
false | ok |
true | error, Opt_trace_struct must set itself to dummy; trace may have been written to, will likely be invalid JSON. |
|
inline |
Restores I_S support to what it was before the previous call to disable_I_S().
void Opt_trace_stmt::separator | ( | ) |
Put optional comma, newline and indentation.
void Opt_trace_stmt::set_allowed_mem_size | ( | size_t | size | ) |
Sets the quantity of allowed memory for this trace.
void Opt_trace_stmt::set_query | ( | const char * | query, |
size_t | length, | ||
const CHARSET_INFO * | charset | ||
) |
|
inline |
|
private |
context
|
private |
current open structure
|
private |
Whether end()
has been called on this instance.
|
private |
0 <=> this trace should be in information_schema.
In the life of an Opt_trace_stmt, support for I_S may be temporarily disabled. Once disabled, it must stay disabled until re-enabled at the same stack frame. This: Opt_trace_object1 // disables I_S Opt_trace_object2 // re-enables I_S is impossible (the top object wins). So it is sufficient, to keep track of the current state, to have a counter incremented each time we get a request to disable I_S.
|
private |
whether user lacks privilege to see this trace
|
private |
Where the original query is put.
|
private |
Same logic as Opt_trace_context::stack_of_current_stmts.
|
private |
Where the trace is accumulated.
|
private |
Space for last autogenerated key.
|
private |
Counter which serves to have unique autogenerated keys, needed if we autogenerate more than one key in a single object.