Struct sqruff_lib::core::parser::segments::base::SymbolSegment
source · pub struct SymbolSegment { /* private fields */ }Expand description
A segment used for matching single entities which aren’t keywords.
We rename the segment class here so that descendants of
_ProtoKeywordSegment can use the same functionality
but don't end up being labelled as a `keyword` later.Implementations§
source§impl SymbolSegment
impl SymbolSegment
pub fn create( raw: &str, position_maker: Option<PositionMarker>, args: SymbolSegmentNewArgs, ) -> ErasedSegment
Trait Implementations§
source§impl Clone for SymbolSegment
impl Clone for SymbolSegment
source§fn clone(&self) -> SymbolSegment
fn clone(&self) -> SymbolSegment
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moresource§impl Debug for SymbolSegment
impl Debug for SymbolSegment
source§impl PartialEq for SymbolSegment
impl PartialEq for SymbolSegment
source§impl Segment for SymbolSegment
impl Segment for SymbolSegment
fn new(&self, _segments: Vec<ErasedSegment>) -> ErasedSegment
fn raw(&self) -> Cow<'_, str>
fn get_type(&self) -> SyntaxKind
fn is_code(&self) -> bool
fn is_comment(&self) -> bool
fn is_whitespace(&self) -> bool
fn get_position_marker(&self) -> Option<PositionMarker>
fn set_position_marker(&mut self, position_marker: Option<PositionMarker>)
fn segments(&self) -> &[ErasedSegment]
source§fn get_raw_segments(&self) -> Vec<ErasedSegment>
fn get_raw_segments(&self) -> Vec<ErasedSegment>
Iterate raw segments, mostly for searching. Read more
fn get_uuid(&self) -> Uuid
source§fn get_source_fixes(&self) -> Vec<SourceFix>
fn get_source_fixes(&self) -> Vec<SourceFix>
Return any source fixes as list.
source§fn edit(
&self,
raw: Option<String>,
_source_fixes: Option<Vec<SourceFix>>,
) -> ErasedSegment
fn edit( &self, raw: Option<String>, _source_fixes: Option<Vec<SourceFix>>, ) -> ErasedSegment
Stub.
fn instance_types(&self) -> SyntaxSet
fn class_types(&self) -> SyntaxSet
fn copy(&self, _segments: Vec<ErasedSegment>) -> ErasedSegment
fn can_start_end_non_code(&self) -> bool
fn dialect(&self) -> DialectKind
fn type_name(&self) -> &'static str
fn get_start_loc(&self) -> (usize, usize)
fn get_end_loc(&self) -> (usize, usize)
fn to_serialised( &self, code_only: bool, show_raw: bool, include_meta: bool, ) -> TupleSerialisedSegment
fn raw_segments_with_ancestors( &self, ) -> &OnceCell<Vec<(ErasedSegment, Vec<PathStep>)>>
fn select_children( &self, start_seg: Option<&ErasedSegment>, stop_seg: Option<&ErasedSegment>, select_if: Option<fn(_: &ErasedSegment) -> bool>, loop_while: Option<fn(_: &ErasedSegment) -> bool>, ) -> Vec<ErasedSegment>
fn is_templated(&self) -> bool
fn iter_segments( &self, expanding: Option<SyntaxSet>, pass_through: bool, ) -> Vec<ErasedSegment>
fn code_indices(&self) -> Vec<usize>
fn get_parent(&self) -> Option<ErasedSegment>
fn child(&self, seg_types: SyntaxSet) -> Option<ErasedSegment>
fn children(&self, seg_types: SyntaxSet) -> Vec<ErasedSegment>
fn iter_patches(&self, templated_file: &TemplatedFile) -> Vec<FixPatch>
fn descendant_type_set(&self) -> &SyntaxSet
fn get_raw_upper(&self) -> Option<String>
fn first_non_whitespace_segment_raw_upper(&self) -> Option<String>
fn is_type(&self, type_: SyntaxKind) -> bool
fn is_meta(&self) -> bool
fn get_default_raw(&self) -> Option<&'static str>
fn set_segments(&mut self, _segments: Vec<ErasedSegment>)
fn gather_segments(&self) -> Vec<ErasedSegment>
source§fn get_matched_length(&self) -> usize
fn get_matched_length(&self) -> usize
Return the length of the segment in characters.
source§fn get_can_start_end_non_code(&self) -> bool
fn get_can_start_end_non_code(&self) -> bool
Are we able to have non-code at the start or end?
source§fn get_allow_empty(&self) -> bool
fn get_allow_empty(&self) -> bool
Can we allow it to be empty? Usually used in combination with the
can_start_end_non_code.
source§fn get_file_path(&self) -> Option<String>
fn get_file_path(&self) -> Option<String>
get_file_path returns the file path of the segment if it is a file
segment.
source§fn iter_source_fix_patches(
&self,
templated_file: &TemplatedFile,
) -> Vec<FixPatch>
fn iter_source_fix_patches( &self, templated_file: &TemplatedFile, ) -> Vec<FixPatch>
Yield any source patches as fixes now. Read more
source§fn compute_anchor_edit_info(
&self,
fixes: &Vec<LintFix>,
) -> AHashMap<Uuid, AnchorEditInfo>
fn compute_anchor_edit_info( &self, fixes: &Vec<LintFix>, ) -> AHashMap<Uuid, AnchorEditInfo>
Group and count fixes by anchor, return dictionary.
fn combined_types(&self) -> SyntaxSet
impl StructuralPartialEq for SymbolSegment
Auto Trait Implementations§
impl Freeze for SymbolSegment
impl RefUnwindSafe for SymbolSegment
impl Send for SymbolSegment
impl Sync for SymbolSegment
impl Unpin for SymbolSegment
impl UnwindSafe for SymbolSegment
Blanket Implementations§
source§impl<T> AsAnyMut for Twhere
T: Any,
impl<T> AsAnyMut for Twhere
T: Any,
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
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> CloneSegment for Twhere
T: Segment,
impl<T> CloneSegment for Twhere
T: Segment,
fn clone_box(&self) -> ErasedSegment
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit)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 more