Struct SearchQuery

Source
pub struct SearchQuery {
    pub q: String,
    pub location: Option<String>,
    pub gl: Option<String>,
    pub hl: Option<String>,
    pub page: Option<u32>,
    pub num: Option<u32>,
}
Expand description

Represents a search query with all possible parameters

This struct encapsulates all the parameters that can be sent to the Serper API for search requests, with optional fields for flexible query construction.

Fields§

§q: String

The search query string (required)

§location: Option<String>

Optional location specification

§gl: Option<String>

Optional country code (gl parameter)

§hl: Option<String>

Optional language code (hl parameter)

§page: Option<u32>

Optional page number for pagination

§num: Option<u32>

Optional number of results per page

Implementations§

Source§

impl SearchQuery

Source

pub fn new(query: String) -> Result<Self>

Creates a new search query with the specified query string

§Arguments
  • query - The search query string
§Returns

A Result containing the SearchQuery or an error if validation fails

Source

pub fn with_location(self, location: String) -> Self

Sets the location for the search query

§Arguments
  • location - The location string (e.g., “Paris, France”)
Source

pub fn with_country(self, country: String) -> Self

Sets the country code for the search query

§Arguments
  • country - The country code (e.g., “fr”, “us”)
Source

pub fn with_language(self, language: String) -> Self

Sets the language code for the search query

§Arguments
  • language - The language code (e.g., “en”, “fr”)
Source

pub fn with_page(self, page: u32) -> Self

Sets the page number for pagination

§Arguments
  • page - The page number (1-based)
Source

pub fn with_num_results(self, num: u32) -> Self

Sets the number of results per page

§Arguments
  • num - The number of results (typically 1-100)
Source

pub fn with_location_config(self, location: Location) -> Self

Applies location settings from a Location struct

§Arguments
  • location - The location configuration
Source

pub fn with_pagination(self, pagination: Pagination) -> Self

Applies pagination settings from a Pagination struct

§Arguments
  • pagination - The pagination configuration
Source

pub fn validate(&self) -> Result<()>

Validates the search query parameters

§Returns

Result indicating whether the query is valid

Source

pub fn query(&self) -> &str

Gets the query string

Source

pub fn has_location_params(&self) -> bool

Checks if the query has location parameters

Source

pub fn has_pagination_params(&self) -> bool

Checks if the query has pagination parameters

Trait Implementations§

Source§

impl Clone for SearchQuery

Source§

fn clone(&self) -> SearchQuery

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for SearchQuery

Source§

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

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

impl<'de> Deserialize<'de> for SearchQuery

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl PartialEq for SearchQuery

Source§

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

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

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 Serialize for SearchQuery

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl StructuralPartialEq for SearchQuery

Auto Trait Implementations§

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> CloneToUninit for T
where T: Clone,

Source§

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<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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

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

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

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

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

Source§

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>,

Source§

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
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

§

impl<T> ErasedDestructor for T
where T: 'static,