pub struct PostgreSqlDialect {}Expand description
A Dialect for PostgreSQL
Trait Implementations§
Source§impl Debug for PostgreSqlDialect
 
impl Debug for PostgreSqlDialect
Source§impl Dialect for PostgreSqlDialect
 
impl Dialect for PostgreSqlDialect
Source§fn is_custom_operator_part(&self, ch: char) -> bool
 
fn is_custom_operator_part(&self, ch: char) -> bool
Source§fn supports_explain_with_utility_options(&self) -> bool
 
fn supports_explain_with_utility_options(&self) -> bool
Source§fn supports_listen_notify(&self) -> bool
 
fn supports_listen_notify(&self) -> bool
Source§fn supports_factorial_operator(&self) -> bool
 
fn supports_factorial_operator(&self) -> bool
Source§fn supports_comment_on(&self) -> bool
 
fn supports_comment_on(&self) -> bool
Source§fn supports_load_extension(&self) -> bool
 
fn supports_load_extension(&self) -> bool
Source§fn supports_named_fn_args_with_colon_operator(&self) -> bool
 
fn supports_named_fn_args_with_colon_operator(&self) -> bool
See https://www.postgresql.org/docs/current/functions-json.html
Required to support the colon in:
SELECT json_object('a': 'b')Source§fn supports_named_fn_args_with_expr_name(&self) -> bool
 
fn supports_named_fn_args_with_expr_name(&self) -> bool
See https://www.postgresql.org/docs/current/functions-json.html
Required to support the label in:
SELECT json_object('label': 'value')Source§fn supports_empty_projections(&self) -> bool
 
fn supports_empty_projections(&self) -> bool
Return true if the dialect supports empty projections in SELECT statements
Example
SELECT from table_nameSource§fn supports_array_typedef_with_brackets(&self) -> bool
 
fn supports_array_typedef_with_brackets(&self) -> bool
Source§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.
Source§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 hereSource§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
Source§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
Source§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 moreSource§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
Source§fn supports_filter_during_aggregation(&self) -> bool
 
fn supports_filter_during_aggregation(&self) -> bool
Does the dialect support 
FILTER (WHERE expr) for aggregate queries?Source§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.Source§fn prec_value(&self, prec: Precedence) -> u8
 
fn prec_value(&self, prec: Precedence) -> u8
Decide the lexical Precedence of operators. Read more
Source§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.Source§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.Source§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)Source§fn supports_nested_comments(&self) -> bool
 
fn supports_nested_comments(&self) -> bool
Returns true if the dialect supports nested comments
e.g. 
/* /* nested */ */Source§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
Source§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_000Source§fn supports_geometric_types(&self) -> bool
 
fn supports_geometric_types(&self) -> bool
Returns true if the dialect supports geometric types. Read more
Source§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 moreSource§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 moreSource§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
Source§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 moreSource§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
Source§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
Source§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
Source§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. ANSISource§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.Source§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
Source§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.Source§fn supports_connect_by(&self) -> bool
 
fn supports_connect_by(&self) -> bool
Returns true if the dialect supports CONNECT BY.
Source§fn supports_execute_immediate(&self) -> bool
 
fn supports_execute_immediate(&self) -> bool
Returns true if the dialect supports 
EXECUTE IMMEDIATE statements.Source§fn supports_match_recognize(&self) -> bool
 
fn supports_match_recognize(&self) -> bool
Returns true if the dialect supports the MATCH_RECOGNIZE operation.
Source§fn supports_in_empty_list(&self) -> bool
 
fn supports_in_empty_list(&self) -> bool
Returns true if the dialect supports 
(NOT) IN () expressionsSource§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] statementsSource§fn supports_end_transaction_modifier(&self) -> bool
 
fn supports_end_transaction_modifier(&self) -> bool
Returns true if the dialect supports 
END {TRY | CATCH} statementsSource§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').Source§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').Source§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').Source§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_loginSource§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
Source§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}.Source§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}.Source§fn supports_lambda_functions(&self) -> bool
 
fn supports_lambda_functions(&self) -> bool
Returns true if the dialect supports lambda functions, for example: Read more
Source§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 moreSource§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 moreSource§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 moreSource§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)Source§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"""Source§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
Source§fn supports_trailing_commas(&self) -> bool
 
fn supports_trailing_commas(&self) -> bool
Does the dialect support trailing commas around the query?
Source§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?Source§fn supports_projection_trailing_commas(&self) -> bool
 
fn supports_projection_trailing_commas(&self) -> bool
Does the dialect support trailing commas in the projection list?
Source§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 1Source§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,)Source§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
Source§fn supports_struct_literal(&self) -> bool
 
fn supports_struct_literal(&self) -> bool
Return true if the dialect supports the STRUCT literal Read more
Source§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
Source§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
Source§fn supports_pipe_operator(&self) -> bool
 
fn supports_pipe_operator(&self) -> bool
Return true if the dialect supports pipe operator. Read more
Source§fn supports_user_host_grantee(&self) -> bool
 
fn supports_user_host_grantee(&self) -> bool
Does the dialect support MySQL-style 
'user'@'host' grantee syntax?Source§fn supports_match_against(&self) -> bool
 
fn supports_match_against(&self) -> bool
Does the dialect support the 
MATCH() AGAINST() syntax?Source§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 moreSource§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 moreSource§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 aSource§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
Source§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
Source§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
Source§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
Source§fn prec_unknown(&self) -> u8
 
fn prec_unknown(&self) -> u8
Returns the precedence when the precedence is otherwise unknown
Source§fn describe_requires_table_keyword(&self) -> bool
 
fn describe_requires_table_keyword(&self) -> bool
Source§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)Source§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 morefn supports_asc_desc_in_column_definition(&self) -> bool
Source§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 moreSource§fn supports_try_convert(&self) -> bool
 
fn supports_try_convert(&self) -> bool
Returns true if this dialect supports the 
TRY_CONVERT functionSource§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.Source§fn supports_load_data(&self) -> bool
 
fn supports_load_data(&self) -> bool
Returns true if the dialect supports the 
LOAD DATA statementSource§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.Source§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.Source§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 optionSource§fn supports_create_table_select(&self) -> bool
 
fn supports_create_table_select(&self) -> bool
Returns true if the dialect supports the 
CREATE TABLE SELECT statementSource§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
Source§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.
Source§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_commasSource§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)Source§fn get_reserved_grantees_types(&self) -> &[GranteesType]
 
fn get_reserved_grantees_types(&self) -> &[GranteesType]
Returns grantee types that should be treated as identifiers
Source§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 moreSource§fn supports_insert_set(&self) -> bool
 
fn supports_insert_set(&self) -> bool
Returns true if this dialect supports the 
INSERT INTO ... SET col1 = 1, ... syntax. Read moreSource§fn supports_insert_table_function(&self) -> bool
 
fn supports_insert_table_function(&self) -> bool
Does the dialect support table function in insertion?
Source§fn supports_insert_format(&self) -> bool
 
fn supports_insert_format(&self) -> bool
Does the dialect support insert formats, e.g. 
INSERT INTO ... FORMAT <format>Source§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.Source§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
Source§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.Source§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
Source§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.Source§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.
Source§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.Source§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 moreSource§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
Source§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, ..., cnSource§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 PostgreSqlDialect
impl RefUnwindSafe for PostgreSqlDialect
impl Send for PostgreSqlDialect
impl Sync for PostgreSqlDialect
impl Unpin for PostgreSqlDialect
impl UnwindSafe for PostgreSqlDialect
Blanket Implementations§
Source§impl<T> AlignerFor<1> for T
 
impl<T> AlignerFor<1> for T
Source§impl<T> AlignerFor<1024> for T
 
impl<T> AlignerFor<1024> for T
Source§type Aligner = AlignTo1024<T>
 
type Aligner = AlignTo1024<T>
The 
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<128> for T
 
impl<T> AlignerFor<128> for T
Source§type Aligner = AlignTo128<T>
 
type Aligner = AlignTo128<T>
The 
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<16> for T
 
impl<T> AlignerFor<16> for T
Source§impl<T> AlignerFor<16384> for T
 
impl<T> AlignerFor<16384> for T
Source§type Aligner = AlignTo16384<T>
 
type Aligner = AlignTo16384<T>
The 
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<2> for T
 
impl<T> AlignerFor<2> for T
Source§impl<T> AlignerFor<2048> for T
 
impl<T> AlignerFor<2048> for T
Source§type Aligner = AlignTo2048<T>
 
type Aligner = AlignTo2048<T>
The 
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<256> for T
 
impl<T> AlignerFor<256> for T
Source§type Aligner = AlignTo256<T>
 
type Aligner = AlignTo256<T>
The 
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<32> for T
 
impl<T> AlignerFor<32> for T
Source§impl<T> AlignerFor<32768> for T
 
impl<T> AlignerFor<32768> for T
Source§type Aligner = AlignTo32768<T>
 
type Aligner = AlignTo32768<T>
The 
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<4> for T
 
impl<T> AlignerFor<4> for T
Source§impl<T> AlignerFor<4096> for T
 
impl<T> AlignerFor<4096> for T
Source§type Aligner = AlignTo4096<T>
 
type Aligner = AlignTo4096<T>
The 
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<512> for T
 
impl<T> AlignerFor<512> for T
Source§type Aligner = AlignTo512<T>
 
type Aligner = AlignTo512<T>
The 
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<64> for T
 
impl<T> AlignerFor<64> for T
Source§impl<T> AlignerFor<8> for T
 
impl<T> AlignerFor<8> for T
Source§impl<T> AlignerFor<8192> for T
 
impl<T> AlignerFor<8192> for T
Source§type Aligner = AlignTo8192<T>
 
type Aligner = AlignTo8192<T>
The 
AlignTo* type which aligns Self to ALIGNMENT.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
Source§impl<T, W> HasTypeWitness<W> for Twhere
    W: MakeTypeWitness<Arg = T>,
    T: ?Sized,
 
impl<T, W> HasTypeWitness<W> for Twhere
    W: MakeTypeWitness<Arg = T>,
    T: ?Sized,
Source§impl<T> Identity for Twhere
    T: ?Sized,
 
impl<T> Identity for Twhere
    T: ?Sized,
Source§impl<T> Instrument for T
 
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
Source§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 moreSource§impl<T> PolicyExt for Twhere
    T: ?Sized,
 
impl<T> PolicyExt for Twhere
    T: ?Sized,
Source§impl<S> ROExtAcc for S
 
impl<S> ROExtAcc for S
Source§fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F
 
fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F
Gets a reference to a field, determined by 
offset. Read moreSource§fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F
 
fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F
Gets a muatble reference to a field, determined by 
offset. Read moreSource§fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F
 
fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F
Gets a const pointer to a field,
the field is determined by 
offset. Read moreSource§fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F
 
fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F
Gets a mutable pointer to a field, determined by 
offset. Read moreSource§impl<S> ROExtOps<Aligned> for S
 
impl<S> ROExtOps<Aligned> for S
Source§fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F
 
fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F
Replaces a field (determined by 
offset) with value,
returning the previous value of the field. Read moreSource§fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> Fwhere
    F: Copy,
 
fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> Fwhere
    F: Copy,
Source§impl<S> ROExtOps<Unaligned> for S
 
impl<S> ROExtOps<Unaligned> for S
Source§fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F
 
fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F
Replaces a field (determined by 
offset) with value,
returning the previous value of the field. Read moreSource§fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> Fwhere
    F: Copy,
 
fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> Fwhere
    F: Copy,
Source§impl<T> SelfOps for Twhere
    T: ?Sized,
 
impl<T> SelfOps for Twhere
    T: ?Sized,
Source§fn piped<F, U>(self, f: F) -> U
 
fn piped<F, U>(self, f: F) -> U
Emulates the pipeline operator, allowing method syntax in more places. Read more
Source§fn piped_ref<'a, F, U>(&'a self, f: F) -> Uwhere
    F: FnOnce(&'a Self) -> U,
 
fn piped_ref<'a, F, U>(&'a self, f: F) -> Uwhere
    F: FnOnce(&'a Self) -> U,
The same as 
piped except that the function takes &Self
Useful for functions that take &Self instead of Self. Read moreSource§fn piped_mut<'a, F, U>(&'a mut self, f: F) -> Uwhere
    F: FnOnce(&'a mut Self) -> U,
 
fn piped_mut<'a, F, U>(&'a mut self, f: F) -> Uwhere
    F: FnOnce(&'a mut Self) -> U,
The same as 
piped, except that the function takes &mut Self.
Useful for functions that take &mut Self instead of Self.Source§fn mutated<F>(self, f: F) -> Self
 
fn mutated<F>(self, f: F) -> Self
Mutates self using a closure taking self by mutable reference,
passing it along the method chain. Read more
Source§fn observe<F>(self, f: F) -> Self
 
fn observe<F>(self, f: F) -> Self
Observes the value of self, passing it along unmodified.
Useful in long method chains. Read more
Source§fn as_ref_<T>(&self) -> &T
 
fn as_ref_<T>(&self) -> &T
Performs a reference to reference conversion with 
AsRef,
using the turbofish .as_ref_::<_>() syntax. Read moreSource§impl<This> TransmuteElement for Thiswhere
    This: ?Sized,
 
impl<This> TransmuteElement for Thiswhere
    This: ?Sized,
Source§unsafe fn transmute_element<T>(self) -> Self::TransmutedPtrwhere
    Self: CanTransmuteElement<T>,
 
unsafe fn transmute_element<T>(self) -> Self::TransmutedPtrwhere
    Self: CanTransmuteElement<T>,
Transmutes the element type of this pointer.. Read more
Source§impl<T> TypeIdentity for Twhere
    T: ?Sized,
 
impl<T> TypeIdentity for Twhere
    T: ?Sized,
Source§fn as_type_mut(&mut self) -> &mut Self::Type
 
fn as_type_mut(&mut self) -> &mut Self::Type
Converts a mutable reference back to the original type.
Source§fn into_type_box(self: Box<Self>) -> Box<Self::Type>
 
fn into_type_box(self: Box<Self>) -> Box<Self::Type>
Converts a box back to the original type.
Source§fn into_type_arc(this: Arc<Self>) -> Arc<Self::Type>
 
fn into_type_arc(this: Arc<Self>) -> Arc<Self::Type>
Converts an Arc back to the original type. Read more
Source§fn into_type_rc(this: Rc<Self>) -> Rc<Self::Type>
 
fn into_type_rc(this: Rc<Self>) -> Rc<Self::Type>
Converts an Rc back to the original type. Read more
Source§fn from_type_ref(this: &Self::Type) -> &Self
 
fn from_type_ref(this: &Self::Type) -> &Self
Converts a reference back to the original type.
Source§fn from_type_mut(this: &mut Self::Type) -> &mut Self
 
fn from_type_mut(this: &mut Self::Type) -> &mut Self
Converts a mutable reference back to the original type.
Source§fn from_type_box(this: Box<Self::Type>) -> Box<Self>
 
fn from_type_box(this: Box<Self::Type>) -> Box<Self>
Converts a box back to the original type.