Struct sysctl::Ctl [] [src]

pub struct Ctl { /* fields omitted */ }

This struct represents a system control.

Methods

impl Ctl
[src]

[src]

Construct a Ctl from the name.

This is just a wrapper around Ctl::from_str.

Example

extern crate sysctl;
use sysctl::Ctl;

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

[src]

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

Example

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

[src]

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

Example

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

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

[src]

Returns a result containing the sysctl description if success, or an Error on failure.

Example

extern crate sysctl;
use sysctl::Ctl;

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

[src]

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());
}

[src]

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>());
}

[src]

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

Example

extern crate sysctl;
use sysctl::Ctl;

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

[src]

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);
}

Trait Implementations

impl Debug for Ctl
[src]

[src]

Formats the value using the given formatter. Read more

impl Clone for Ctl
[src]

[src]

Returns a copy of the value. Read more

1.0.0
[src]

Performs copy-assignment from source. Read more

impl PartialEq for Ctl
[src]

[src]

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

[src]

This method tests for !=.

impl FromStr for Ctl
[src]

The associated error which can be returned from parsing.

[src]

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

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?

[src]

Creates an iterator from a value. Read more

Auto Trait Implementations

impl Send for Ctl

impl Sync for Ctl