Struct MySqlDialect  
pub struct MySqlDialect {}Trait Implementations§
§impl Debug for MySqlDialect
 
impl Debug for MySqlDialect
§impl Dialect for MySqlDialect
 
impl Dialect for MySqlDialect
§fn supports_create_table_select(&self) -> bool
 
fn supports_create_table_select(&self) -> bool
§fn supports_insert_set(&self) -> bool
 
fn supports_insert_set(&self) -> bool
§fn is_identifier_start(&self, ch: char) -> bool
 
fn is_identifier_start(&self, ch: char) -> bool
Determine if a character is a valid start character for an unquoted identifier
§fn is_identifier_part(&self, ch: char) -> bool
 
fn is_identifier_part(&self, ch: char) -> bool
Determine if a character is a valid unquoted identifier character
§fn is_delimited_identifier_start(&self, ch: char) -> bool
 
fn is_delimited_identifier_start(&self, ch: char) -> bool
Determine if a character starts a quoted identifier. The default
implementation, accepting “double quoted” ids is both ANSI-compliant
and appropriate for most dialects (with the notable exception of
MySQL, MS SQL, and sqlite). You can accept one of characters listed
in 
Word::matching_end_quote here§fn identifier_quote_style(&self, _identifier: &str) -> Option<char>
 
fn identifier_quote_style(&self, _identifier: &str) -> Option<char>
Return the character used to quote identifiers.
§fn supports_string_literal_backslash_escape(&self) -> bool
 
fn supports_string_literal_backslash_escape(&self) -> bool
Determine if the dialect supports escaping characters via ’' in string literals. Read more
§fn ignores_wildcard_escapes(&self) -> bool
 
fn ignores_wildcard_escapes(&self) -> bool
Determine whether the dialect strips the backslash when escaping LIKE wildcards (%, _). Read more
§fn supports_numeric_prefix(&self) -> bool
 
fn supports_numeric_prefix(&self) -> bool
Returns true if the dialect supports identifiers starting with a numeric
prefix such as tables named 
59901_user_login§fn parse_infix(
    &self,
    parser: &mut Parser<'_>,
    expr: &Expr,
    _precedence: u8,
) -> Option<Result<Expr, ParserError>>
 
fn parse_infix( &self, parser: &mut Parser<'_>, expr: &Expr, _precedence: u8, ) -> Option<Result<Expr, ParserError>>
Dialect-specific infix parser override Read more
§fn parse_statement(
    &self,
    parser: &mut Parser<'_>,
) -> Option<Result<Statement, ParserError>>
 
fn parse_statement( &self, parser: &mut Parser<'_>, ) -> Option<Result<Statement, ParserError>>
Dialect-specific statement parser override Read more
§fn require_interval_qualifier(&self) -> bool
 
fn require_interval_qualifier(&self) -> bool
Whether 
INTERVAL expressions require units (called “qualifiers” in the ANSI SQL spec) to be specified,
e.g. INTERVAL 1 DAY vs INTERVAL 1. Read more§fn supports_limit_comma(&self) -> bool
 
fn supports_limit_comma(&self) -> bool
Does the dialect support parsing 
LIMIT 1, 2 as LIMIT 2 OFFSET 1?§fn supports_user_host_grantee(&self) -> bool
 
fn supports_user_host_grantee(&self) -> bool
Does the dialect support MySQL-style 
'user'@'host' grantee syntax?§fn is_table_factor_alias(
    &self,
    explicit: bool,
    kw: &Keyword,
    _parser: &mut Parser<'_>,
) -> bool
 
fn is_table_factor_alias( &self, explicit: bool, kw: &Keyword, _parser: &mut Parser<'_>, ) -> bool
Returns true if the specified keyword should be parsed as a table factor alias.
When explicit is true, the keyword is preceded by an 
AS word. Parser is provided
to enable looking ahead if needed.§fn supports_table_hints(&self) -> bool
 
fn supports_table_hints(&self) -> bool
Returns true if the dialect supports the table hints in the 
FROM clause.§fn requires_single_line_comment_whitespace(&self) -> bool
 
fn requires_single_line_comment_whitespace(&self) -> bool
Returns true if this dialect requires a whitespace character after 
-- to start a single line comment. Read more§fn supports_match_against(&self) -> bool
 
fn supports_match_against(&self) -> bool
Does the dialect support the 
MATCH() AGAINST() syntax?§fn supports_set_names(&self) -> bool
 
fn supports_set_names(&self) -> bool
Returns true if the dialect supports 
SET NAMES <charset_name> [COLLATE <collation_name>]. Read more§fn supports_comma_separated_set_assignments(&self) -> bool
 
fn supports_comma_separated_set_assignments(&self) -> bool
Returns true if the dialect supports multiple 
SET statements
in a single statement. Read more§fn is_nested_delimited_identifier_start(&self, _ch: char) -> bool
 
fn is_nested_delimited_identifier_start(&self, _ch: char) -> bool
Determine if a character starts a potential nested quoted identifier.
Example: RedShift supports the following quote styles to all mean the same thing: Read more
§fn peek_nested_delimited_identifier_quotes(
    &self,
    _chars: Peekable<Chars<'_>>,
) -> Option<(char, Option<char>)>
 
fn peek_nested_delimited_identifier_quotes( &self, _chars: Peekable<Chars<'_>>, ) -> Option<(char, Option<char>)>
Only applicable whenever 
Self::is_nested_delimited_identifier_start returns true
If the next sequence of tokens potentially represent a nested identifier, then this method
returns a tuple containing the outer quote style, and if present, the inner (nested) quote style. Read more§fn is_custom_operator_part(&self, _ch: char) -> bool
 
fn is_custom_operator_part(&self, _ch: char) -> bool
Most dialects do not have custom operators. Override this method to provide custom operators.
§fn supports_unicode_string_literal(&self) -> bool
 
fn supports_unicode_string_literal(&self) -> bool
Determine if the dialect supports string literals with 
U& prefix.
This is used to specify Unicode code points in string literals.
For example, in PostgreSQL, the following is a valid string literal: Read more§fn supports_filter_during_aggregation(&self) -> bool
 
fn supports_filter_during_aggregation(&self) -> bool
Does the dialect support 
FILTER (WHERE expr) for aggregate queries?§fn supports_window_clause_named_window_reference(&self) -> bool
 
fn supports_window_clause_named_window_reference(&self) -> bool
Returns true if the dialect supports referencing another named window
within a window clause declaration. Read more
§fn supports_within_after_array_aggregation(&self) -> bool
 
fn supports_within_after_array_aggregation(&self) -> bool
Returns true if the dialect supports 
ARRAY_AGG() [WITHIN GROUP (ORDER BY)] expressions.
Otherwise, the dialect should expect an ORDER BY without the WITHIN GROUP clause, e.g. ANSI§fn supports_group_by_expr(&self) -> bool
 
fn supports_group_by_expr(&self) -> bool
Returns true if the dialects supports 
group sets, roll up, or cube expressions.§fn supports_group_by_with_modifier(&self) -> bool
 
fn supports_group_by_with_modifier(&self) -> bool
Returns true if the dialects supports 
GROUP BY modifiers prefixed by a WITH keyword.
Example: GROUP BY value WITH ROLLUP.§fn supports_left_associative_joins_without_parens(&self) -> bool
 
fn supports_left_associative_joins_without_parens(&self) -> bool
Indicates whether the dialect supports left-associative join parsing
by default when parentheses are omitted in nested joins. Read more
§fn supports_outer_join_operator(&self) -> bool
 
fn supports_outer_join_operator(&self) -> bool
Returns true if the dialect supports the 
(+) syntax for OUTER JOIN.§fn supports_connect_by(&self) -> bool
 
fn supports_connect_by(&self) -> bool
Returns true if the dialect supports CONNECT BY.
§fn supports_execute_immediate(&self) -> bool
 
fn supports_execute_immediate(&self) -> bool
Returns true if the dialect supports 
EXECUTE IMMEDIATE statements.§fn supports_match_recognize(&self) -> bool
 
fn supports_match_recognize(&self) -> bool
Returns true if the dialect supports the MATCH_RECOGNIZE operation.
§fn supports_in_empty_list(&self) -> bool
 
fn supports_in_empty_list(&self) -> bool
Returns true if the dialect supports 
(NOT) IN () expressions§fn supports_start_transaction_modifier(&self) -> bool
 
fn supports_start_transaction_modifier(&self) -> bool
Returns true if the dialect supports 
BEGIN {DEFERRED | IMMEDIATE | EXCLUSIVE | TRY | CATCH} [TRANSACTION] statements§fn supports_end_transaction_modifier(&self) -> bool
 
fn supports_end_transaction_modifier(&self) -> bool
Returns true if the dialect supports 
END {TRY | CATCH} statements§fn supports_named_fn_args_with_eq_operator(&self) -> bool
 
fn supports_named_fn_args_with_eq_operator(&self) -> bool
Returns true if the dialect supports named arguments of the form 
FUN(a = '1', b = '2').§fn supports_named_fn_args_with_colon_operator(&self) -> bool
 
fn supports_named_fn_args_with_colon_operator(&self) -> bool
Returns true if the dialect supports named arguments of the form 
FUN(a : '1', b : '2').§fn supports_named_fn_args_with_assignment_operator(&self) -> bool
 
fn supports_named_fn_args_with_assignment_operator(&self) -> bool
Returns true if the dialect supports named arguments of the form 
FUN(a := '1', b := '2').§fn supports_named_fn_args_with_rarrow_operator(&self) -> bool
 
fn supports_named_fn_args_with_rarrow_operator(&self) -> bool
Returns true if the dialect supports named arguments of the form 
FUN(a => '1', b => '2').§fn supports_named_fn_args_with_expr_name(&self) -> bool
 
fn supports_named_fn_args_with_expr_name(&self) -> bool
Returns true if dialect supports argument name as arbitrary expression.
e.g. 
FUN(LOWER('a'):'1',  b:'2')
Such function arguments are represented in the AST by the FunctionArg::ExprNamed variant,
otherwise use the FunctionArg::Named variant (compatible reason).§fn supports_numeric_literal_underscores(&self) -> bool
 
fn supports_numeric_literal_underscores(&self) -> bool
Returns true if the dialect supports numbers containing underscores, e.g. 
10_000_000§fn supports_window_function_null_treatment_arg(&self) -> bool
 
fn supports_window_function_null_treatment_arg(&self) -> bool
Returns true if the dialects supports specifying null treatment
as part of a window function’s parameter list as opposed
to after the parameter list. Read more
§fn supports_dictionary_syntax(&self) -> bool
 
fn supports_dictionary_syntax(&self) -> bool
Returns true if the dialect supports defining structs or objects using a
syntax like 
{'x': 1, 'y': 2, 'z': 3}.§fn support_map_literal_syntax(&self) -> bool
 
fn support_map_literal_syntax(&self) -> bool
Returns true if the dialect supports defining object using the
syntax like 
Map {1: 10, 2: 20}.§fn supports_lambda_functions(&self) -> bool
 
fn supports_lambda_functions(&self) -> bool
Returns true if the dialect supports lambda functions, for example: Read more
§fn supports_parenthesized_set_variables(&self) -> bool
 
fn supports_parenthesized_set_variables(&self) -> bool
Returns true if the dialect supports multiple variable assignment
using parentheses in a 
SET variable declaration. Read more§fn supports_select_wildcard_except(&self) -> bool
 
fn supports_select_wildcard_except(&self) -> bool
Returns true if the dialect supports an 
EXCEPT clause following a
wildcard in a select list. Read more§fn convert_type_before_value(&self) -> bool
 
fn convert_type_before_value(&self) -> bool
Returns true if the dialect has a CONVERT function which accepts a type first
and an expression second, e.g. 
CONVERT(varchar, 1)§fn supports_triple_quoted_string(&self) -> bool
 
fn supports_triple_quoted_string(&self) -> bool
Returns true if the dialect supports triple quoted string
e.g. 
"""abc"""§fn parse_prefix(
    &self,
    _parser: &mut Parser<'_>,
) -> Option<Result<Expr, ParserError>>
 
fn parse_prefix( &self, _parser: &mut Parser<'_>, ) -> Option<Result<Expr, ParserError>>
Dialect-specific prefix parser override
§fn supports_trailing_commas(&self) -> bool
 
fn supports_trailing_commas(&self) -> bool
Does the dialect support trailing commas around the query?
§fn supports_projection_trailing_commas(&self) -> bool
 
fn supports_projection_trailing_commas(&self) -> bool
Does the dialect support trailing commas in the projection list?
§fn supports_from_trailing_commas(&self) -> bool
 
fn supports_from_trailing_commas(&self) -> bool
Returns true if the dialect supports trailing commas in the 
FROM clause of a SELECT statement.
Example: SELECT 1 FROM T, U, LIMIT 1§fn supports_column_definition_trailing_commas(&self) -> bool
 
fn supports_column_definition_trailing_commas(&self) -> bool
Returns true if the dialect supports trailing commas in the
column definitions list of a 
CREATE statement.
Example: CREATE TABLE T (x INT, y TEXT,)§fn supports_object_name_double_dot_notation(&self) -> bool
 
fn supports_object_name_double_dot_notation(&self) -> bool
Returns true if the dialect supports double dot notation for object names Read more
§fn supports_struct_literal(&self) -> bool
 
fn supports_struct_literal(&self) -> bool
Return true if the dialect supports the STRUCT literal Read more
§fn supports_empty_projections(&self) -> bool
 
fn supports_empty_projections(&self) -> bool
Return true if the dialect supports empty projections in SELECT statements Read more
§fn supports_select_expr_star(&self) -> bool
 
fn supports_select_expr_star(&self) -> bool
Return true if the dialect supports wildcard expansion on
arbitrary expressions in projections. Read more
§fn supports_from_first_select(&self) -> bool
 
fn supports_from_first_select(&self) -> bool
Return true if the dialect supports “FROM-first” selects. Read more
§fn supports_pipe_operator(&self) -> bool
 
fn supports_pipe_operator(&self) -> bool
Return true if the dialect supports pipe operator. Read more
§fn supports_select_wildcard_exclude(&self) -> bool
 
fn supports_select_wildcard_exclude(&self) -> bool
Returns true if the dialect supports an exclude option
following a wildcard in the projection section. For example:
SELECT * EXCLUDE col1 FROM tbl. Read more§fn supports_select_exclude(&self) -> bool
 
fn supports_select_exclude(&self) -> bool
Returns true if the dialect supports an exclude option
as the last item in the projection section, not necessarily
after a wildcard. For example:
SELECT *, c1, c2 EXCLUDE c3 FROM tbl Read more§fn supports_create_table_multi_schema_info_sources(&self) -> bool
 
fn supports_create_table_multi_schema_info_sources(&self) -> bool
Returne true if the dialect supports specifying multiple options
in a 
CREATE TABLE statement for the structure of the new table. For example:
CREATE TABLE t (a INT, b INT) AS SELECT 1 AS b, 2 AS a§fn get_next_precedence(
    &self,
    _parser: &Parser<'_>,
) -> Option<Result<u8, ParserError>>
 
fn get_next_precedence( &self, _parser: &Parser<'_>, ) -> Option<Result<u8, ParserError>>
Dialect-specific precedence override Read more
§fn get_next_precedence_default(
    &self,
    parser: &Parser<'_>,
) -> Result<u8, ParserError>
 
fn get_next_precedence_default( &self, parser: &Parser<'_>, ) -> Result<u8, ParserError>
Get the precedence of the next token, looking at the full token stream. Read more
§fn parse_column_option(
    &self,
    _parser: &mut Parser<'_>,
) -> Result<Option<Result<Option<ColumnOption>, ParserError>>, ParserError>
 
fn parse_column_option( &self, _parser: &mut Parser<'_>, ) -> Result<Option<Result<Option<ColumnOption>, ParserError>>, ParserError>
Dialect-specific column option parser override Read more
§fn prec_value(&self, prec: Precedence) -> u8
 
fn prec_value(&self, prec: Precedence) -> u8
Decide the lexical Precedence of operators. Read more
§fn prec_unknown(&self) -> u8
 
fn prec_unknown(&self) -> u8
Returns the precedence when the precedence is otherwise unknown
§fn describe_requires_table_keyword(&self) -> bool
 
fn describe_requires_table_keyword(&self) -> bool
§fn allow_extract_custom(&self) -> bool
 
fn allow_extract_custom(&self) -> bool
Returns true if this dialect allows the 
EXTRACT function to words other than [Keyword].§fn allow_extract_single_quotes(&self) -> bool
 
fn allow_extract_single_quotes(&self) -> bool
Returns true if this dialect allows the 
EXTRACT function to use single quotes in the part being extracted.§fn supports_dollar_placeholder(&self) -> bool
 
fn supports_dollar_placeholder(&self) -> bool
Returns true if this dialect allows dollar placeholders
e.g. 
SELECT $var (SQLite)§fn supports_create_index_with_clause(&self) -> bool
 
fn supports_create_index_with_clause(&self) -> bool
Does the dialect support with clause in create index statement?
e.g. 
CREATE INDEX idx ON t WITH (key = value, key2)fn supports_explain_with_utility_options(&self) -> bool
fn supports_asc_desc_in_column_definition(&self) -> bool
§fn supports_factorial_operator(&self) -> bool
 
fn supports_factorial_operator(&self) -> bool
Returns true if the dialect supports 
a! expressions§fn supports_nested_comments(&self) -> bool
 
fn supports_nested_comments(&self) -> bool
Returns true if the dialect supports nested comments
e.g. 
/* /* nested */ */§fn supports_eq_alias_assignment(&self) -> bool
 
fn supports_eq_alias_assignment(&self) -> bool
Returns true if this dialect supports treating the equals operator 
= within a SelectItem
as an alias assignment operator, rather than a boolean expression.
For example: the following statements are equivalent for such a dialect: Read more§fn supports_try_convert(&self) -> bool
 
fn supports_try_convert(&self) -> bool
Returns true if this dialect supports the 
TRY_CONVERT function§fn supports_bang_not_operator(&self) -> bool
 
fn supports_bang_not_operator(&self) -> bool
Returns true if the dialect supports 
!a syntax for boolean NOT expressions.§fn supports_listen_notify(&self) -> bool
 
fn supports_listen_notify(&self) -> bool
Returns true if the dialect supports the 
LISTEN, UNLISTEN and NOTIFY statements§fn supports_load_data(&self) -> bool
 
fn supports_load_data(&self) -> bool
Returns true if the dialect supports the 
LOAD DATA statement§fn supports_load_extension(&self) -> bool
 
fn supports_load_extension(&self) -> bool
Returns true if the dialect supports the 
LOAD extension statement§fn supports_top_before_distinct(&self) -> bool
 
fn supports_top_before_distinct(&self) -> bool
Returns true if this dialect expects the 
TOP option
before the ALL/DISTINCT options in a SELECT statement.§fn supports_boolean_literals(&self) -> bool
 
fn supports_boolean_literals(&self) -> bool
Returns true if the dialect supports boolean literals (
true and false).
For example, in MSSQL these are treated as identifiers rather than boolean literals.§fn supports_show_like_before_in(&self) -> bool
 
fn supports_show_like_before_in(&self) -> bool
Returns true if this dialect supports the 
LIKE 'pattern' option in
a SHOW statement before the IN option§fn supports_comment_on(&self) -> bool
 
fn supports_comment_on(&self) -> bool
Returns true if this dialect supports the 
COMMENT statement§fn supports_partiql(&self) -> bool
 
fn supports_partiql(&self) -> bool
Returns true if the dialect supports PartiQL for querying semi-structured data
https://partiql.org/index.html
§fn is_reserved_for_identifier(&self, kw: Keyword) -> bool
 
fn is_reserved_for_identifier(&self, kw: Keyword) -> bool
Returns true if the specified keyword is reserved and cannot be
used as an identifier without special handling like quoting.
§fn get_reserved_keywords_for_table_factor(&self) -> &[Keyword]
 
fn get_reserved_keywords_for_table_factor(&self) -> &[Keyword]
Returns reserved keywords when looking to parse a 
TableFactor.
See Self::supports_from_trailing_commas§fn get_reserved_keywords_for_select_item_operator(&self) -> &[Keyword]
 
fn get_reserved_keywords_for_select_item_operator(&self) -> &[Keyword]
Returns reserved keywords that may prefix a select item expression
e.g. 
SELECT CONNECT_BY_ROOT name FROM Tbl2 (Snowflake)§fn get_reserved_grantees_types(&self) -> &[GranteesType]
 
fn get_reserved_grantees_types(&self) -> &[GranteesType]
Returns grantee types that should be treated as identifiers
§fn supports_table_sample_before_alias(&self) -> bool
 
fn supports_table_sample_before_alias(&self) -> bool
Returns true if this dialect supports the 
TABLESAMPLE option
before the table alias option. For example: Read more§fn supports_insert_table_function(&self) -> bool
 
fn supports_insert_table_function(&self) -> bool
Does the dialect support table function in insertion?
§fn supports_insert_format(&self) -> bool
 
fn supports_insert_format(&self) -> bool
Does the dialect support insert formats, e.g. 
INSERT INTO ... FORMAT <format>§fn supports_set_stmt_without_operator(&self) -> bool
 
fn supports_set_stmt_without_operator(&self) -> bool
Returns true if this dialect supports 
SET statements without an explicit
assignment operator such as =. For example: SET SHOWPLAN_XML ON.§fn is_column_alias(&self, kw: &Keyword, _parser: &mut Parser<'_>) -> bool
 
fn is_column_alias(&self, kw: &Keyword, _parser: &mut Parser<'_>) -> bool
Returns true if the specified keyword should be parsed as a column identifier.
See [keywords::RESERVED_FOR_COLUMN_ALIAS]
§fn is_select_item_alias(
    &self,
    explicit: bool,
    kw: &Keyword,
    parser: &mut Parser<'_>,
) -> bool
 
fn is_select_item_alias( &self, explicit: bool, kw: &Keyword, parser: &mut Parser<'_>, ) -> bool
Returns true if the specified keyword should be parsed as a select item alias.
When explicit is true, the keyword is preceded by an 
AS word. Parser is provided
to enable looking ahead if needed.§fn is_table_alias(&self, kw: &Keyword, _parser: &mut Parser<'_>) -> bool
 
fn is_table_alias(&self, kw: &Keyword, _parser: &mut Parser<'_>) -> bool
Returns true if the specified keyword should be parsed as a table identifier.
See [keywords::RESERVED_FOR_TABLE_ALIAS]
§fn supports_timestamp_versioning(&self) -> bool
 
fn supports_timestamp_versioning(&self) -> bool
Returns true if this dialect supports querying historical table data
by specifying which version of the data to query.
§fn supports_string_escape_constant(&self) -> bool
 
fn supports_string_escape_constant(&self) -> bool
Returns true if this dialect supports the E’…’ syntax for string literals Read more
§fn supports_array_typedef_with_brackets(&self) -> bool
 
fn supports_array_typedef_with_brackets(&self) -> bool
Returns true if the dialect supports array type definition with brackets with
an optional size. For example:
CREATE TABLE my_table (arr1 INT[], arr2 INT[3])
SELECT x::INT[]§fn supports_geometric_types(&self) -> bool
 
fn supports_geometric_types(&self) -> bool
Returns true if the dialect supports geometric types. Read more
§fn supports_order_by_all(&self) -> bool
 
fn supports_order_by_all(&self) -> bool
Returns true if the dialect supports 
ORDER BY ALL.
ALL which means all columns of the SELECT clause. Read morefn supports_space_separated_column_options(&self) -> bool
§fn supports_alter_column_type_using(&self) -> bool
 
fn supports_alter_column_type_using(&self) -> bool
Returns true if the dialect supports the 
USING clause in an ALTER COLUMN statement.
Example: Read more§fn supports_comma_separated_drop_column_list(&self) -> bool
 
fn supports_comma_separated_drop_column_list(&self) -> bool
Returns true if the dialect supports 
ALTER TABLE tbl DROP COLUMN c1, ..., cn§fn is_identifier_generating_function_name(
    &self,
    _ident: &Ident,
    _name_parts: &[ObjectNamePart],
) -> bool
 
fn is_identifier_generating_function_name( &self, _ident: &Ident, _name_parts: &[ObjectNamePart], ) -> bool
Returns true if the dialect considers the specified ident as a function
that returns an identifier. Typically used to generate identifiers
programmatically. Read more
Auto Trait Implementations§
impl Freeze for MySqlDialect
impl RefUnwindSafe for MySqlDialect
impl Send for MySqlDialect
impl Sync for MySqlDialect
impl Unpin for MySqlDialect
impl UnwindSafe for MySqlDialect
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> Conv for T
 
impl<T> Conv for T
§impl<T, V> Convert<T> for Vwhere
    V: Into<T>,
 
impl<T, V> Convert<T> for Vwhere
    V: Into<T>,
fn convert(value: Self) -> T
fn convert_box(value: Box<Self>) -> Box<T>
fn convert_vec(value: Vec<Self>) -> Vec<T>
fn convert_vec_box(value: Vec<Box<Self>>) -> Vec<Box<T>>
fn convert_matrix(value: Vec<Vec<Self>>) -> Vec<Vec<T>>
fn convert_option(value: Option<Self>) -> Option<T>
fn convert_option_box(value: Option<Box<Self>>) -> Option<Box<T>>
fn convert_option_vec(value: Option<Vec<Self>>) -> Option<Vec<T>>
§impl<T> FmtForward for T
 
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
    Self: Binary,
 
fn fmt_binary(self) -> FmtBinary<Self>where
    Self: Binary,
Causes 
self to use its Binary implementation when Debug-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
    Self: Display,
 
fn fmt_display(self) -> FmtDisplay<Self>where
    Self: Display,
Causes 
self to use its Display implementation when
Debug-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
    Self: LowerExp,
 
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
    Self: LowerExp,
Causes 
self to use its LowerExp implementation when
Debug-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
    Self: LowerHex,
 
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
    Self: LowerHex,
Causes 
self to use its LowerHex implementation when
Debug-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
    Self: Octal,
 
fn fmt_octal(self) -> FmtOctal<Self>where
    Self: Octal,
Causes 
self to use its Octal implementation when Debug-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
    Self: Pointer,
 
fn fmt_pointer(self) -> FmtPointer<Self>where
    Self: Pointer,
Causes 
self to use its Pointer implementation when
Debug-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
    Self: UpperExp,
 
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
    Self: UpperExp,
Causes 
self to use its UpperExp implementation when
Debug-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
    Self: UpperHex,
 
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
    Self: UpperHex,
Causes 
self to use its UpperHex implementation when
Debug-formatted.§fn fmt_list(self) -> FmtList<Self>where
    &'a Self: for<'a> IntoIterator,
 
fn fmt_list(self) -> FmtList<Self>where
    &'a Self: for<'a> IntoIterator,
Formats each item in a sequence. Read more
§impl<T> FutureExt for T
 
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
 
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
 
fn with_current_context(self) -> WithContext<Self>
§impl<T> Instrument for T
 
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
 
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
 
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts 
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
 
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts 
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<T> IntoRequest<T> for T
 
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
 
fn into_request(self) -> Request<T>
Wrap the input message 
T in a tonic::Request§impl<L> LayerExt<L> for L
 
impl<L> LayerExt<L> for L
§fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
    L: Layer<S>,
 
fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
    L: Layer<S>,
Applies the layer to a service and wraps it in [
Layered].§impl<T> Pipe for Twhere
    T: ?Sized,
 
impl<T> Pipe for Twhere
    T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
    Self: Sized,
 
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
    Self: Sized,
Pipes by value. This is generally the method you want to use. Read more
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
    R: 'a,
 
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
    R: 'a,
Borrows 
self and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
    R: 'a,
 
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
    R: 'a,
Mutably borrows 
self and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
 
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
    &'a mut self,
    func: impl FnOnce(&'a mut B) -> R,
) -> R
 
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
 
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
Borrows 
self, then passes self.as_ref() into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
 
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
Mutably borrows 
self, then passes self.as_mut() into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
 
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
Borrows 
self, then passes self.deref() into the pipe function.§impl<T> Pointable for T
 
impl<T> Pointable for T
§impl<T> PolicyExt for Twhere
    T: ?Sized,
 
impl<T> PolicyExt for Twhere
    T: ?Sized,
§impl<T> ServiceExt for T
 
impl<T> ServiceExt for T
§fn propagate_header(self, header: HeaderName) -> PropagateHeader<Self>where
    Self: Sized,
 
fn propagate_header(self, header: HeaderName) -> PropagateHeader<Self>where
    Self: Sized,
Propagate a header from the request to the response. Read more
§fn add_extension<T>(self, value: T) -> AddExtension<Self, T>where
    Self: Sized,
 
fn add_extension<T>(self, value: T) -> AddExtension<Self, T>where
    Self: Sized,
Add some shareable value to request extensions. Read more
§fn map_request_body<F>(self, f: F) -> MapRequestBody<Self, F>where
    Self: Sized,
 
fn map_request_body<F>(self, f: F) -> MapRequestBody<Self, F>where
    Self: Sized,
Apply a transformation to the request body. Read more
§fn map_response_body<F>(self, f: F) -> MapResponseBody<Self, F>where
    Self: Sized,
 
fn map_response_body<F>(self, f: F) -> MapResponseBody<Self, F>where
    Self: Sized,
Apply a transformation to the response body. Read more
§fn compression(self) -> Compression<Self>where
    Self: Sized,
 
fn compression(self) -> Compression<Self>where
    Self: Sized,
Compresses response bodies. Read more
§fn decompression(self) -> Decompression<Self>where
    Self: Sized,
 
fn decompression(self) -> Decompression<Self>where
    Self: Sized,
Decompress response bodies. Read more
§fn trace_for_http(self) -> Trace<Self, SharedClassifier<ServerErrorsAsFailures>>where
    Self: Sized,
 
fn trace_for_http(self) -> Trace<Self, SharedClassifier<ServerErrorsAsFailures>>where
    Self: Sized,
High level tracing that classifies responses using HTTP status codes. Read more
§fn trace_for_grpc(self) -> Trace<Self, SharedClassifier<GrpcErrorsAsFailures>>where
    Self: Sized,
 
fn trace_for_grpc(self) -> Trace<Self, SharedClassifier<GrpcErrorsAsFailures>>where
    Self: Sized,
High level tracing that classifies responses using gRPC headers. Read more
§fn follow_redirects(self) -> FollowRedirect<Self>where
    Self: Sized,
 
fn follow_redirects(self) -> FollowRedirect<Self>where
    Self: Sized,
§fn sensitive_headers(
    self,
    headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveRequestHeaders<SetSensitiveResponseHeaders<Self>>where
    Self: Sized,
 
fn sensitive_headers(
    self,
    headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveRequestHeaders<SetSensitiveResponseHeaders<Self>>where
    Self: Sized,
§fn sensitive_request_headers(
    self,
    headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveRequestHeaders<Self>where
    Self: Sized,
 
fn sensitive_request_headers(
    self,
    headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveRequestHeaders<Self>where
    Self: Sized,
§fn sensitive_response_headers(
    self,
    headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveResponseHeaders<Self>where
    Self: Sized,
 
fn sensitive_response_headers(
    self,
    headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveResponseHeaders<Self>where
    Self: Sized,
§fn override_request_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetRequestHeader<Self, M>where
    Self: Sized,
 
fn override_request_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetRequestHeader<Self, M>where
    Self: Sized,
Insert a header into the request. Read more
§fn append_request_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetRequestHeader<Self, M>where
    Self: Sized,
 
fn append_request_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetRequestHeader<Self, M>where
    Self: Sized,
Append a header into the request. Read more
§fn insert_request_header_if_not_present<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetRequestHeader<Self, M>where
    Self: Sized,
 
fn insert_request_header_if_not_present<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetRequestHeader<Self, M>where
    Self: Sized,
Insert a header into the request, if the header is not already present. Read more
§fn override_response_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetResponseHeader<Self, M>where
    Self: Sized,
 
fn override_response_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetResponseHeader<Self, M>where
    Self: Sized,
Insert a header into the response. Read more
§fn append_response_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetResponseHeader<Self, M>where
    Self: Sized,
 
fn append_response_header<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetResponseHeader<Self, M>where
    Self: Sized,
Append a header into the response. Read more
§fn insert_response_header_if_not_present<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetResponseHeader<Self, M>where
    Self: Sized,
 
fn insert_response_header_if_not_present<M>(
    self,
    header_name: HeaderName,
    make: M,
) -> SetResponseHeader<Self, M>where
    Self: Sized,
Insert a header into the response, if the header is not already present. Read more
§fn set_request_id<M>(
    self,
    header_name: HeaderName,
    make_request_id: M,
) -> SetRequestId<Self, M>where
    Self: Sized,
    M: MakeRequestId,
 
fn set_request_id<M>(
    self,
    header_name: HeaderName,
    make_request_id: M,
) -> SetRequestId<Self, M>where
    Self: Sized,
    M: MakeRequestId,
Add request id header and extension. Read more
§fn set_x_request_id<M>(self, make_request_id: M) -> SetRequestId<Self, M>where
    Self: Sized,
    M: MakeRequestId,
 
fn set_x_request_id<M>(self, make_request_id: M) -> SetRequestId<Self, M>where
    Self: Sized,
    M: MakeRequestId,
Add request id header and extension, using 
x-request-id as the header name. Read more§fn propagate_request_id(
    self,
    header_name: HeaderName,
) -> PropagateRequestId<Self>where
    Self: Sized,
 
fn propagate_request_id(
    self,
    header_name: HeaderName,
) -> PropagateRequestId<Self>where
    Self: Sized,
Propgate request ids from requests to responses. Read more
§fn propagate_x_request_id(self) -> PropagateRequestId<Self>where
    Self: Sized,
 
fn propagate_x_request_id(self) -> PropagateRequestId<Self>where
    Self: Sized,
Propgate request ids from requests to responses, using 
x-request-id as the header name. Read more§fn catch_panic(self) -> CatchPanic<Self, DefaultResponseForPanic>where
    Self: Sized,
 
fn catch_panic(self) -> CatchPanic<Self, DefaultResponseForPanic>where
    Self: Sized,
Catch panics and convert them into 
500 Internal Server responses. Read more§fn request_body_limit(self, limit: usize) -> RequestBodyLimit<Self>where
    Self: Sized,
 
fn request_body_limit(self, limit: usize) -> RequestBodyLimit<Self>where
    Self: Sized,
Intercept requests with over-sized payloads and convert them into
413 Payload Too Large responses. Read more§fn trim_trailing_slash(self) -> NormalizePath<Self>where
    Self: Sized,
 
fn trim_trailing_slash(self) -> NormalizePath<Self>where
    Self: Sized,
Remove trailing slashes from paths. Read more
§fn append_trailing_slash(self) -> NormalizePath<Self>where
    Self: Sized,
 
fn append_trailing_slash(self) -> NormalizePath<Self>where
    Self: Sized,
Append trailing slash to paths. Read more
§impl<T> Tap for T
 
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
 
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Immutable access to the 
Borrow<B> of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
 
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
Mutable access to the 
BorrowMut<B> of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
 
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
Immutable access to the 
AsRef<R> view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
 
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
Mutable access to the 
AsMut<R> view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
 
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Immutable access to the 
Deref::Target of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
 
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Mutable access to the 
Deref::Target of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
 
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
Calls 
.tap() only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
 
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
Calls 
.tap_mut() only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
 
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
Calls 
.tap_borrow() only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
 
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
Calls 
.tap_borrow_mut() only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
 
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
Calls 
.tap_ref() only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
 
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
Calls 
.tap_ref_mut() only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
 
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
Calls 
.tap_deref() only in debug builds, and is erased in release
builds.