[][src]Struct sysctl::Ctl

pub struct Ctl {
    pub oid: Vec<c_int>,
}

This struct represents a system control.

Fields

Methods

impl Ctl
[src]

Construct a Ctl from the name.

This is just a wrapper around Ctl::from_str.

Returns a result containing the struct Ctl on success or a SysctlError on failure.

Example

extern crate sysctl;
use sysctl::Ctl;

let ctl = Ctl::new("kern.osrelease");

If the sysctl does not exist, Err(SysctlError::NotFound) is returned.

extern crate sysctl;
use sysctl::{Ctl, SysctlError};

let ctl = Ctl::new("this.sysctl.does.not.exist");
match ctl {
    Err(SysctlError::NotFound(_)) => (),
    Err(_) => panic!("Wrong error type returned"),
    Ok(_) => panic!("Nonexistent sysctl seems to exist"),
}

Returns a result containing the sysctl name on success, or a SysctlError on failure.

Example

let ctl = Ctl::new("kern.osrelease").expect("could not get sysctl");
assert_eq!(ctl.name().expect("could not get name"), "kern.osrelease");

Returns a result containing the sysctl value type on success, or a Sysctl Error on failure.

Example

let ctl = Ctl::new("kern.osrelease")
    .expect("Could not get kern.osrelease sysctl");
let value_type = ctl.value_type()
        .expect("Could not get kern.osrelease value type");
assert_eq!(value_type, CtlType::String);

Returns a result containing the sysctl value on success, or a SysctlError on failure.

Example

extern crate sysctl;
extern crate libc;

fn main() {
    let osrevision = sysctl::Ctl::new("kern.osrevision")
        .expect("could not get kern.osrevisio sysctl");
    println!("Value: {:?}", osrevision.value());
}

A generic method that takes returns a result containing the sysctl value if success, or a SysctlError on failure.

May only be called for sysctls of type Opaque or Struct.

Example

extern crate sysctl;
extern crate libc;

use libc::c_int;

#[derive(Debug)]
#[repr(C)]
struct ClockInfo {
    hz: c_int, /* clock frequency */
    tick: c_int, /* micro-seconds per hz tick */
    spare: c_int,
    stathz: c_int, /* statistics clock frequency */
    profhz: c_int, /* profiling clock frequency */
}

fn main() {
    let clockrate = sysctl::Ctl::new("kern.clockrate")
        .expect("could not get clockrate sysctl");
    println!("{:?}", clockrate.value_as::<ClockInfo>());
}

Sets the value of a sysctl. Fetches and returns the new value if successful, or returns a SysctlError on failure.

Example

This example is not tested
extern crate sysctl;
use sysctl::Ctl;

fn main() {
    let usbdebug = Ctl::new("hw.usb.debug")
        .expect("could not get hw.usb.debug control");
    let set = usbdebug.set_value(sysctl::CtlValue::Int(1));
    println!("hw.usb.debug: -> {:?}", set);
}

Get the flags for a sysctl.

Returns a Result containing the flags on success, or a SysctlError on failure.

Example

extern crate sysctl;
use sysctl::{Ctl, CtlFlags};

fn main() {
    let osrev = Ctl::new("kern.osrevision")
        .expect("could not get control");

    let readable = osrev.flags()
        .expect("could not get flags")
        .contains(CtlFlags::RD);

    assert!(readable);
}

Returns a Result containing the control metadata for a sysctl.

Returns a Result containing the CtlInfo struct on success, or a SysctlError on failure.

Example

extern crate sysctl;
use sysctl::{Ctl, CtlInfo};

fn main() {
    let osrev = Ctl::new("kern.osrevision")
        .expect("could not get control");

    let info = osrev.info()
        .expect("could not get info");

    // kern.osrevision is not a structure.
    assert_eq!(info.struct_type(), None);
}

Trait Implementations

impl PartialEq<Ctl> for Ctl
[src]

This method tests for self and other values to be equal, and is used by ==. Read more

This method tests for !=.

impl IntoIterator for Ctl
[src]

Ctl implements the IntoIterator trait to allow for easy iteration over nodes.

Example

extern crate sysctl;
use sysctl::Ctl;

let kern = Ctl::new("kern");
for ctl in kern {
    let name = ctl.name().expect("could not get name");
    println!("{}", name);
}

The type of the elements being iterated over.

Which kind of iterator are we turning this into?

Creates an iterator from a value. Read more

impl Clone for Ctl
[src]

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

impl Debug for Ctl
[src]

Formats the value using the given formatter. Read more

impl FromStr for Ctl
[src]

The associated error which can be returned from parsing.

Parses a string s to return a value of this type. Read more

Auto Trait Implementations

impl Send for Ctl

impl Sync for Ctl

Blanket Implementations

impl<T> ToOwned for T where
    T: Clone
[src]

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

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

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

impl<T> From for T
[src]

Performs the conversion.

impl<I> IntoIterator for I where
    I: Iterator
[src]

The type of the elements being iterated over.

Which kind of iterator are we turning this into?

Creates an iterator from a value. Read more

impl<T, U> Into for T where
    U: From<T>, 
[src]

Performs the conversion.

impl<T, U> TryFrom for T where
    T: From<U>, 
[src]

🔬 This is a nightly-only experimental API. (try_from)

The type returned in the event of a conversion error.

🔬 This is a nightly-only experimental API. (try_from)

Performs the conversion.

impl<T> Borrow for T where
    T: ?Sized
[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut for T where
    T: ?Sized
[src]

Mutably borrows from an owned value. Read more

impl<T, U> TryInto for T where
    U: TryFrom<T>, 
[src]

🔬 This is a nightly-only experimental API. (try_from)

The type returned in the event of a conversion error.

🔬 This is a nightly-only experimental API. (try_from)

Performs the conversion.

impl<T> Any for T where
    T: 'static + ?Sized
[src]

🔬 This is a nightly-only experimental API. (get_type_id)

this method will likely be replaced by an associated static

Gets the TypeId of self. Read more