Struct regorust::Output

source ·
pub struct Output { /* private fields */ }
Expand description

Interface for the Rego output.

Outputs can either be examined as strings, or inspected using Rego Nodes. It is also possible to extract bindings for specific variables.

§Examples

match result.to_str() {
  Ok(output_str) => {
    println!("{}", output_str);
  }
  Err(err_str) => {
    println!("error: {}", err_str);
  }
}
let x = result.binding("x").expect("cannot get x");
println!("x = {}", x.json().unwrap());

Implementations§

source§

impl Output

source

pub fn ok(&self) -> bool

Returns whether the output is ok.

The output of a successful query will always be a Node. However, if there was an error that arose with the Rego engine, then this Node will be of kind NodeKind::ErrorSeq and contain one or more errors. This method gives a quick way, without inspecting the result node, of finding whether it is ok.

source

pub fn to_str(&self) -> Result<&str, &str>

Returns the output as a JSON-encoded string.

If the result of Self::ok() is false, the result will be an string containing error information.

source

pub fn to_node(&self) -> Result<Node, Node>

Returns the output node.

The value of the Result enum will reflect the output of Self::ok().

source

pub fn binding_at_index( &self, index: regoSize, name: &str, ) -> Result<Node, Node>

Attempts to return the binding for the given variable name.

If the output is not OK or the variable is not bound, then this will return an Result::Err with the output node. Otherwise it will return the bound value for the variable.

source

pub fn binding(&self, name: &str) -> Result<Node, Node>

Attempts to return the binding for the given variable name.

If the output is not OK or the variable is not bound, then this will return an Result::Err with the output node. Otherwise it will return the bound value for the variable.

source

pub fn expressions_at_index(&self, index: regoSize) -> Result<Node, Node>

Attempts to return the expressions at a given result index.

source

pub fn expressions(&self) -> Result<Node, Node>

Attempts to return the expressions at a given result index.

source

pub fn size(&self) -> regoSize

Returns the number of results in the output.

Trait Implementations§

source§

impl Debug for Output

source§

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

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

impl Display for Output

source§

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

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

impl Drop for Output

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl PartialEq for Output

source§

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

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

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

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.

Auto Trait Implementations§

§

impl Freeze for Output

§

impl RefUnwindSafe for Output

§

impl !Send for Output

§

impl !Sync for Output

§

impl Unpin for Output

§

impl UnwindSafe for Output

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

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

source§

fn into(self) -> U

Calls U::from(self).

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

source§

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

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

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

§

type Error = Infallible

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

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

Performs the conversion.
source§

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.
source§

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

Performs the conversion.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more