VariableDefinition

Struct VariableDefinition 

Source
pub struct VariableDefinition(/* private fields */);
Expand description

An AST node for $ast

Implementations§

Source§

impl VariableDefinition

Source

pub fn name(&self) -> Option<String>

Get the name of the variable definition

Source

pub fn is_export(&self) -> bool

Check if this variable definition is exported

Source

pub fn assignment_operator(&self) -> Option<String>

Get the assignment operator/flavor used in this variable definition

Returns the operator as a string: “=”, “:=”, “::=”, “:::=”, “+=”, “?=”, or “!=”

§Example
use makefile_lossless::Makefile;
let makefile: Makefile = "VAR := value\n".parse().unwrap();
let var = makefile.variable_definitions().next().unwrap();
assert_eq!(var.assignment_operator(), Some(":=".to_string()));
Source

pub fn raw_value(&self) -> Option<String>

Get the raw value of the variable definition

Source

pub fn parent(&self) -> Option<MakefileItem>

Get the parent item of this variable definition, if any

Returns Some(MakefileItem) if this variable has a parent that is a MakefileItem (e.g., a Conditional), or None if the parent is the root Makefile node.

§Example
use makefile_lossless::Makefile;

let makefile: Makefile = r#"ifdef DEBUG
VAR = value
endif
"#.parse().unwrap();
let cond = makefile.conditionals().next().unwrap();
let var = cond.if_items().next().unwrap();
// Variable's parent is the conditional
assert!(matches!(var, makefile_lossless::MakefileItem::Variable(_)));
Source

pub fn remove(&mut self)

Remove this variable definition from its parent makefile

This will also remove any preceding comments and up to 1 empty line before the variable.

§Example
use makefile_lossless::Makefile;
let mut makefile: Makefile = "VAR = value\n".parse().unwrap();
let mut var = makefile.variable_definitions().next().unwrap();
var.remove();
assert_eq!(makefile.variable_definitions().count(), 0);
Source

pub fn set_assignment_operator(&mut self, op: &str)

Change the assignment operator of this variable definition while preserving everything else (export prefix, variable name, value, whitespace, etc.)

§Arguments
  • op - The new operator: “=”, “:=”, “::=”, “:::=”, “+=”, “?=”, or “!=”
§Example
use makefile_lossless::Makefile;
let mut makefile: Makefile = "VAR := value\n".parse().unwrap();
let mut var = makefile.variable_definitions().next().unwrap();
var.set_assignment_operator("?=");
assert_eq!(var.assignment_operator(), Some("?=".to_string()));
assert!(makefile.code().contains("VAR ?= value"));
Source

pub fn set_value(&mut self, new_value: &str)

Update the value of this variable definition while preserving the rest (export prefix, operator, whitespace, etc.)

§Example
use makefile_lossless::Makefile;
let mut makefile: Makefile = "export VAR := old_value\n".parse().unwrap();
let mut var = makefile.variable_definitions().next().unwrap();
var.set_value("new_value");
assert_eq!(var.raw_value(), Some("new_value".to_string()));
assert!(makefile.code().contains("export VAR := new_value"));
Source§

impl VariableDefinition

Source

pub fn line(&self) -> usize

Get the line number (0-indexed) where this node starts.

Source

pub fn column(&self) -> usize

Get the column number (0-indexed, in bytes) where this node starts.

Source

pub fn line_col(&self) -> (usize, usize)

Get both line and column (0-indexed) where this node starts. Returns (line, column) where column is measured in bytes from the start of the line.

Trait Implementations§

Source§

impl AstNode for VariableDefinition

Source§

type Language = Lang

Source§

fn can_cast(kind: SyntaxKind) -> bool

Source§

fn cast(syntax: SyntaxNode<Lang>) -> Option<Self>

Source§

fn syntax(&self) -> &SyntaxNode<Lang>

Source§

fn clone_for_update(&self) -> Self
where Self: Sized,

Source§

fn clone_subtree(&self) -> Self
where Self: Sized,

Source§

impl Clone for VariableDefinition

Source§

fn clone(&self) -> VariableDefinition

Returns a duplicate of the value. Read more
1.0.0§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Display for VariableDefinition

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl Hash for VariableDefinition

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for VariableDefinition

Source§

fn eq(&self, other: &VariableDefinition) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for VariableDefinition

Source§

impl StructuralPartialEq for VariableDefinition

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> CloneToUninit for T
where T: Clone,

§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, U> Into<U> for T
where U: From<T>,

§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
§

impl<T> ToString for T
where T: Display + ?Sized,

§

fn to_string(&self) -> String

Converts the given value to a String. Read more
§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.