10 releases
Uses old Rust 2015
0.2.2 | Jun 25, 2017 |
---|---|
0.2.1 | Nov 9, 2016 |
0.2.0 | Sep 5, 2016 |
0.1.6 | Nov 14, 2015 |
0.1.3 | Jul 19, 2015 |
#9 in #pseudo-terminal
563 downloads per month
Used in 10 crates
(9 directly)
21KB
400 lines
PTY
The pty
crate provides pty::fork()
. That makes a parent process fork with new pseudo-terminal (PTY).
This crate depends on followings:
libc
library- POSIX environment
Usage
Add this to your Cargo.toml
:
[dependencies]
pty = "0.2"
and this to your crate root:
extern crate pty;
pty::fork()
This function returns pty::Child
. It represents the child process and its PTY.
For example, the following code spawns tty(1)
command by pty::fork()
and outputs the result of the command.
extern crate pty;
extern crate libc;
use std::ffi::CString;
use std::io::Read;
use std::ptr;
use pty::fork::*;
fn main() {
let fork = Fork::from_ptmx().unwrap();
if let Some(mut master) = fork.is_parent().ok() {
// Read output via PTY master
let mut output = String::new();
match master.read_to_string(&mut output) {
Ok(_nread) => println!("child tty is: {}", output.trim()),
Err(e) => panic!("read error: {}", e),
}
}
else {
// Child process just exec `tty`
Command::new("tty").status().expect("could not execute tty");
}
}
When run this, we get new PTY in the child process.
$ tty
/dev/pts/5
$ cargo run
Running `target/debug/example`
child tty is: /dev/pts/8
Documentation
API documentation for latest version: http://hibariya.github.io/pty-rs/pty/index.html
Contributing
- Fork it ( https://github.com/hibariya/pty-rs/fork )
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
License
Copyright (c) 2015 Hika Hibariya
Distributed under the MIT License.
Dependencies
~110KB