SCNetworkReachability

Struct SCNetworkReachability 

Source
pub struct SCNetworkReachability { /* private fields */ }
Available on crate feature SCNetworkReachability only.
Expand description

This is the handle to a network address or name.

See also Apple’s documentation

Implementations§

Source§

impl SCNetworkReachability

Source

pub unsafe fn with_address( allocator: Option<&CFAllocator>, address: NonNull<sockaddr>, ) -> Option<CFRetained<SCNetworkReachability>>

👎Deprecated
Available on crate feature libc only.

Creates a reference to the specified network address. This reference can be used later to monitor the reachability of the target host.

Parameter address: The address of the desired host.

Returns: Returns a reference to the new immutable SCNetworkReachabilityRef.

You must release the returned value.

§Safety

address must be a valid pointer.

Source

pub unsafe fn with_address_pair( allocator: Option<&CFAllocator>, local_address: *const sockaddr, remote_address: *const sockaddr, ) -> Option<CFRetained<SCNetworkReachability>>

👎Deprecated
Available on crate feature libc only.

Creates a reference to the specified network address. This reference can be used later to monitor the reachability of the target host.

Parameter localAddress: The local address associated with a network connection. If NULL, only the remote address is of interest.

Parameter remoteAddress: The remote address associated with a network connection. If NULL, only the local address is of interest.

Returns: Returns a reference to the new immutable SCNetworkReachabilityRef.

You must release the returned value.

§Safety
  • local_address must be a valid pointer or null.
  • remote_address must be a valid pointer or null.
Source

pub unsafe fn with_name( allocator: Option<&CFAllocator>, nodename: NonNull<c_char>, ) -> Option<CFRetained<SCNetworkReachability>>

👎Deprecated

Creates a reference to the specified network host or node name. This reference can be used later to monitor the reachability of the target host.

Parameter nodename: The node name of the desired host. This name would be the same as that passed to the gethostbyname(3) or getaddrinfo(3) functions.

Returns: Returns a reference to the new immutable SCNetworkReachabilityRef.

You must release the returned value.

§Safety

nodename must be a valid pointer.

Source§

impl SCNetworkReachability

Source

pub unsafe fn flags(&self, flags: NonNull<SCNetworkReachabilityFlags>) -> bool

👎Deprecated

Determines if the given target is reachable using the current network configuration.

Parameter target: The network reference associated with the address or name to be checked for reachability.

Parameter flags: A pointer to memory that will be filled with the SCNetworkReachabilityFlags detailing the reachability of the specified target.

Returns: Returns TRUE if the network connection flags are valid; FALSE if the status could not be determined.

§Safety

flags must be a valid pointer.

Source

pub unsafe fn set_callback( &self, callout: SCNetworkReachabilityCallBack, context: *mut SCNetworkReachabilityContext, ) -> bool

👎Deprecated

Assigns a client to a target, which receives callbacks when the reachability of the target changes.

Parameter target: The network reference associated with the address or name to be checked for reachability.

Parameter callout: The function to be called when the reachability of the target changes. If NULL, the current client for the target is removed.

Parameter context: The SCNetworkReachabilityContext associated with the callout. The value may be NULL.

Returns: Returns TRUE if the notification client was successfully set.

§Safety
  • callout must be implemented correctly.
  • context must be a valid pointer or null.
Source

pub fn schedule_with_run_loop( &self, run_loop: &CFRunLoop, run_loop_mode: &CFString, ) -> bool

👎Deprecated

Schedules the given target with the given run loop and mode.

Parameter target: The address or name that is set up for asynchronous notifications. Must be non-NULL.

Parameter runLoop: A reference to a run loop on which the target should be scheduled. Must be non-NULL.

Parameter runLoopMode: The mode on which to schedule the target. Must be non-NULL.

Returns: Returns TRUE if the target is scheduled successfully; FALSE otherwise.

Source

pub fn unschedule_from_run_loop( &self, run_loop: &CFRunLoop, run_loop_mode: &CFString, ) -> bool

👎Deprecated

Unschedules the given target from the given run loop and mode.

Parameter target: The address or name that is set up for asynchronous notifications. Must be non-NULL.

Parameter runLoop: A reference to a run loop from which the target should be unscheduled. Must be non-NULL.

Parameter runLoopMode: The mode on which to unschedule the target. Must be non-NULL.

Returns: Returns TRUE if the target is unscheduled successfully; FALSE otherwise.

Source

pub unsafe fn set_dispatch_queue(&self, queue: Option<&DispatchQueue>) -> bool

👎Deprecated
Available on crate feature dispatch2 only.

Schedule or unschedule callbacks for the given target on the given dispatch queue.

Parameter target: The address or name that is set up for asynchronous notifications. Must be non-NULL.

Parameter queue: A libdispatch queue to run the callback on. Pass NULL to unschedule callbacks.

Returns: Returns TRUE if the target is scheduled or unscheduled successfully; FALSE otherwise.

§Safety

queue possibly has additional threading requirements.

Methods from Deref<Target = CFType>§

Source

pub fn downcast_ref<T>(&self) -> Option<&T>
where T: ConcreteType,

Attempt to downcast the type to that of type T.

This is the reference-variant. Use CFRetained::downcast if you want to convert a retained type. See also ConcreteType for more details on which types support being converted to.

Source

pub fn retain_count(&self) -> usize

Get the reference count of the object.

This function may be useful for debugging. You normally do not use this function otherwise.

Beware that some things (like CFNumbers, small CFStrings etc.) may not have a normal retain count for optimization purposes, and can return usize::MAX in that case.

Trait Implementations§

Source§

impl AsRef<AnyObject> for SCNetworkReachability

Source§

fn as_ref(&self) -> &AnyObject

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<CFType> for SCNetworkReachability

Source§

fn as_ref(&self) -> &CFType

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<SCNetworkReachability> for SCNetworkReachability

Source§

fn as_ref(&self) -> &Self

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl Borrow<AnyObject> for SCNetworkReachability

Source§

fn borrow(&self) -> &AnyObject

Immutably borrows from an owned value. Read more
Source§

impl Borrow<CFType> for SCNetworkReachability

Source§

fn borrow(&self) -> &CFType

Immutably borrows from an owned value. Read more
Source§

impl ConcreteType for SCNetworkReachability

Source§

fn type_id() -> CFTypeID

Returns the type identifier of all SCNetworkReachability instances.

Source§

impl Debug for SCNetworkReachability

Source§

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

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

impl Deref for SCNetworkReachability

Source§

type Target = CFType

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl Hash for SCNetworkReachability

Source§

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

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

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 Message for SCNetworkReachability

Source§

fn retain(&self) -> Retained<Self>
where Self: Sized,

Increment the reference count of the receiver. Read more
Source§

impl PartialEq for SCNetworkReachability

Source§

fn eq(&self, other: &Self) -> 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 RefEncode for SCNetworkReachability

Source§

const ENCODING_REF: Encoding

The Objective-C type-encoding for a reference of this type. Read more
Source§

impl Type for SCNetworkReachability

Source§

fn retain(&self) -> CFRetained<Self>
where Self: Sized,

Increment the reference count of the receiver. Read more
Source§

fn as_concrete_TypeRef(&self) -> &Self

👎Deprecated: this is redundant
Helper for easier transition from the core-foundation crate.
Source§

unsafe fn wrap_under_get_rule(ptr: *const Self) -> CFRetained<Self>
where Self: Sized,

👎Deprecated: use CFRetained::retain
Helper for easier transition from the core-foundation crate. Read more
Source§

fn as_CFTypeRef(&self) -> &CFType
where Self: AsRef<CFType>,

👎Deprecated: this is redundant (CF types deref to CFType)
Helper for easier transition from the core-foundation crate.
Source§

unsafe fn wrap_under_create_rule(ptr: *const Self) -> CFRetained<Self>
where Self: Sized,

👎Deprecated: use CFRetained::from_raw
Helper for easier transition from the core-foundation crate. Read more
Source§

impl Eq for SCNetworkReachability

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
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.
Source§

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