Struct sqruff_lib::core::parser::segments::base::CodeSegment
source · pub struct CodeSegment {
pub code_type: &'static str,
/* private fields */
}
Fields§
§code_type: &'static str
Implementations§
source§impl CodeSegment
impl CodeSegment
pub fn create( raw: &str, position_maker: &PositionMarker, args: CodeSegmentNewArgs ) -> ErasedSegment
Trait Implementations§
source§impl Clone for CodeSegment
impl Clone for CodeSegment
source§fn clone(&self) -> CodeSegment
fn clone(&self) -> CodeSegment
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 CodeSegment
impl Debug for CodeSegment
source§impl Hash for CodeSegment
impl Hash for CodeSegment
source§impl PartialEq for CodeSegment
impl PartialEq for CodeSegment
source§fn eq(&self, other: &CodeSegment) -> bool
fn eq(&self, other: &CodeSegment) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.source§impl Segment for CodeSegment
impl Segment for CodeSegment
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
Create a new segment, with exactly the same position but different content.
Returns:
A copy of this object with new contents.
Used mostly by fixes.
NOTE: This *doesn't* copy the uuid. The edited segment is a new
segment.
From RawSegment implementation
fn new(&self, _segments: Vec<ErasedSegment>) -> ErasedSegment
fn raw(&self) -> Cow<'_, str>
fn get_type(&self) -> &'static str
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) -> Option<Uuid>
fn class_types(&self) -> AHashSet<&'static str>
fn reference(&self) -> Node<ObjectReferenceSegment>
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 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<&[&str]>, pass_through: bool ) -> Vec<ErasedSegment>
fn recursive_crawl_all(&self, reverse: bool) -> Vec<ErasedSegment>
fn recursive_crawl( &self, seg_types: &[&str], recurse_into: bool, no_recursive_seg_type: Option<&str>, allow_self: bool ) -> Vec<ErasedSegment>
fn code_indices(&self) -> Vec<usize>
fn get_parent(&self) -> Option<ErasedSegment>
fn child(&self, seg_types: &[&str]) -> Option<ErasedSegment>
fn children(&self, seg_types: &[&str]) -> Vec<ErasedSegment>
fn iter_patches(&self, templated_file: &TemplatedFile) -> Vec<FixPatch>
fn descendant_type_set(&self) -> AHashSet<&'static str>
fn match_grammar(&self) -> Option<Arc<dyn Matchable>>
fn get_raw_upper(&self) -> Option<String>
fn first_non_whitespace_segment_raw_upper(&self) -> Option<String>
fn is_type(&self, type_: &str) -> bool
fn is_meta(&self) -> bool
fn get_default_raw(&self) -> Option<&'static str>
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 get_source_fixes(&self) -> Vec<SourceFix>
fn get_source_fixes(&self) -> Vec<SourceFix>
Return any source fixes as list.
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 instance_types(&self) -> AHashSet<&'static str>
fn combined_types(&self) -> AHashSet<&'static str>
fn apply_fixes( &self, dialect: &Dialect, fixes: AHashMap<Uuid, AnchorEditInfo> ) -> (ErasedSegment, Vec<ErasedSegment>, Vec<ErasedSegment>, bool)
impl StructuralPartialEq for CodeSegment
Auto Trait Implementations§
impl Freeze for CodeSegment
impl RefUnwindSafe for CodeSegment
impl Send for CodeSegment
impl Sync for CodeSegment
impl Unpin for CodeSegment
impl UnwindSafe for CodeSegment
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
source§impl<T> CloneSegment for Twhere
T: Segment,
impl<T> CloneSegment for Twhere
T: Segment,
fn clone_box(&self) -> ErasedSegment
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