本文整理汇总了Golang中C.tcsetattr函数的典型用法代码示例。如果您正苦于以下问题:Golang tcsetattr函数的具体用法?Golang tcsetattr怎么用?Golang tcsetattr使用的例子?那么恭喜您, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了tcsetattr函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: ReadPassphrase
func ReadPassphrase() string {
stdin := C.int(os.Stdin.Fd())
C.tcgetattr(stdin, &C.AttrOld)
C.Attr = C.AttrOld
C.Attr.c_lflag = C.Attr.c_lflag&^C.ECHO | C.ECHONL
C.tcsetattr(stdin, C.TCSANOW, &C.Attr)
defer C.tcsetattr(stdin, C.TCSANOW, &C.AttrOld)
reader := bufio.NewReader(os.Stdin)
line, err := reader.ReadString('\n')
if err != nil {
return ""
}
return strings.TrimSpace(line)
}
示例2: tcset
func tcset(fd uintptr, p *Termios) syscall.Errno {
ret, err := C.tcsetattr(C.int(fd), C.TCSANOW, (*C.struct_termios)(unsafe.Pointer(p)))
if ret != 0 {
return err.(syscall.Errno)
}
return 0
}
示例3: termioInit
func (t *tScreen) termioInit() error {
var e error
var rv C.int
var newtios C.struct_termios
var fd C.int
if t.in, e = os.OpenFile("/dev/tty", os.O_RDONLY, 0); e != nil {
goto failed
}
if t.out, e = os.OpenFile("/dev/tty", os.O_WRONLY, 0); e != nil {
goto failed
}
t.tiosp = &termiosPrivate{}
fd = C.int(t.out.Fd())
if rv, e = C.tcgetattr(fd, &t.tiosp.tios); rv != 0 {
goto failed
}
t.baud = int(C.getbaud(&t.tiosp.tios))
newtios = t.tiosp.tios
newtios.c_iflag &^= C.IGNBRK | C.BRKINT | C.PARMRK |
C.ISTRIP | C.INLCR | C.IGNCR |
C.ICRNL | C.IXON
newtios.c_oflag &^= C.OPOST
newtios.c_lflag &^= C.ECHO | C.ECHONL | C.ICANON |
C.ISIG | C.IEXTEN
newtios.c_cflag &^= C.CSIZE | C.PARENB
newtios.c_cflag |= C.CS8
// We wake up at the earliest of 100 msec or when data is received.
// We need to wake up frequently to permit us to exit cleanly and
// close file descriptors on systems like Darwin, where close does
// cause a wakeup. (Probably we could reasonably increase this to
// something like 1 sec or 500 msec.)
newtios.c_cc[C.VMIN] = 0
newtios.c_cc[C.VTIME] = 1
if rv, e = C.tcsetattr(fd, C.TCSANOW|C.TCSAFLUSH, &newtios); rv != 0 {
goto failed
}
signal.Notify(t.sigwinch, syscall.SIGWINCH)
if w, h, e := t.getWinSize(); e == nil && w != 0 && h != 0 {
t.w = w
t.h = h
}
return nil
failed:
if t.in != nil {
t.in.Close()
}
if t.out != nil {
t.out.Close()
}
return e
}
示例4: Restore
func Restore(fd int, state *State) error {
ret, err := C.tcsetattr(C.int(fd), C.TCSANOW, (*C.struct_termios)(unsafe.Pointer(&state.Termios)))
if ret != 0 {
return err.(syscall.Errno)
}
return nil
}
示例5: setattr
func (bp *baseport) setattr(tio *C.struct_termios) error {
res, err := C.tcsetattr(C.int(bp.f.Fd()), C.TCSANOW, (*C.struct_termios)(unsafe.Pointer(tio)))
if res != 0 || err != nil {
return err
}
return nil
}
示例6: tcsetattr
// Sets terminal state.
//
// int tcsetattr(int fd, int optional_actions, const struct termios *termios_p);
func (tc *termios) tcsetattr(optional_actions int) error {
exitCode, errno := C.tcsetattr(C.int(tc.fd), C.int(optional_actions), tc.wrap)
if exitCode == 0 {
return nil
}
return errno
}
示例7: Setattr
// Setattr sets the parameters associated with the terminal
// from the Termios structure referenced by src. The optional_actions
// field is created by or'ing the desired tcsetattr commands.
func Setattr(fd uintptr, optional_action int, src *Termios) error {
src.i.c_iflag = src.C_iflag
src.i.c_oflag = src.C_oflag
src.i.c_cflag = src.C_cflag
src.i.c_lflag = src.C_lflag
src.i.c_cc = src.C_cc
_, rv := C.tcsetattr(C.int(fd), C.int(optional_action), &src.i)
return rv
}
示例8: stdin_read_password
func stdin_read_password() string {
stdin := C.int(os.Stdin.Fd())
C.tcgetattr(stdin, &C.T)
C.T_orig = C.T
C.T.c_lflag &^= C.ECHO
C.T.c_lflag |= C.ECHONL
C.tcsetattr(stdin, C.TCSANOW, &C.T)
var passwd string
fmt.Scanf("%s", &passwd)
C.tcsetattr(stdin, C.TCSANOW, &C.T_orig)
return passwd
}
示例9: SetAttributes
// Sets a terminal's attributes. Akin to tcsetattr().
func (t *Terminal) SetAttributes(attr *Attributes, options int) os.Error {
cattr := makeCAttributes(attr)
result := C.tcsetattr(C.int(t.Fd()), C.int(options), &cattr)
if result < 0 {
return os.NewError("Unable to set terminal attributes.")
}
return nil
}
示例10: open
func (c *Connection) open() (err error) {
c.file, err = os.OpenFile(c.Name, syscall.O_RDWR|syscall.O_NOCTTY|syscall.O_NONBLOCK, 0666)
if err != nil {
return err
}
fd, err := c.getFileDescriptor()
if err != nil {
c.file.Close()
return err
}
var st C.struct_termios
_, err = C.tcgetattr(fd, &st)
if err != nil {
c.file.Close()
return err
}
// set the baud rate of the connection
err = c.setBaudRate(c.Baud)
if err != nil {
c.file.Close()
return err
}
// No timeout set directly on termios
st.c_cc[C.VMIN] = 0
st.c_cc[C.VTIME] = 0
// Select local mode
st.c_cflag |= (C.CLOCAL | C.CREAD)
// Select raw mode
st.c_lflag &= ^C.tcflag_t(C.ICANON | C.ECHO | C.ECHOE | C.ISIG)
st.c_oflag &= ^C.tcflag_t(C.OPOST)
_, err = C.tcsetattr(fd, C.TCSANOW, &st)
if err != nil {
c.file.Close()
return err
}
r1, _, e := syscall.Syscall(syscall.SYS_FCNTL,
uintptr(c.file.Fd()),
uintptr(syscall.F_SETFL),
uintptr(0))
if e != 0 || r1 != 0 {
s := fmt.Sprint("Clearing NONBLOCK syscall error:", e, r1)
c.file.Close()
return errors.New(s)
}
return nil
}
示例11: SetFd
// SetFd configures the terminal corresponding to the file-descriptor
// fd using the attributes in the Termios structure t. Argument act
// must be one of the constants TCSANOW, TCSADRAIN, TCSAFLUSH. See
// tcsetattr(3) for more. If the system call is interrupted by a
// signal, SetFd retries it automatically.
func (t *Termios) SetFd(fd int, act int) error {
for {
r, err := C.tcsetattr(C.int(fd), C.int(act), &t.t)
if r < 0 {
if err == syscall.EINTR {
continue
}
return err
}
return nil
}
}
示例12: termioFini
func (t *tScreen) termioFini() {
signal.Stop(t.sigwinch)
<-t.indoneq
if t.out != nil {
fd := C.int(t.out.Fd())
C.tcsetattr(fd, C.TCSANOW|C.TCSAFLUSH, &t.tiosp.tios)
t.out.Close()
}
if t.in != nil {
t.in.Close()
}
}
示例13: SetInputAttr
// SetInputAttr sets VMIN and VTIME for control serial reads.
//
// In non-canonical input processing mode, input is not assembled into
// lines and input processing (erase, kill, delete, etc.) does not
// occur. Two parameters control the behavior of this mode:
// c_cc[VTIME] sets the character timer, and c_cc[VMIN] sets the
// minimum number of characters to receive before satisfying the read.
//
// If MIN > 0 and TIME = 0, MIN sets the number of characters to
//receive before the read is satisfied. As TIME is zero, the timer is
//not used.
//
// If MIN = 0 and TIME > 0, TIME serves as a timeout value. The read
//will be satisfied if a single character is read, or TIME is exceeded
//(t = TIME *0.1 s). If TIME is exceeded, no character will be
//returned.
//
// If MIN > 0 and TIME > 0, TIME serves as an inter-character
//timer. The read will be satisfied if MIN characters are received, or
//the time between two characters exceeds TIME. The timer is restarted
//every time a character is received and only becomes active after the
//first character has been received.
//
// If MIN = 0 and TIME = 0, read will be satisfied immediately. The
//number of characters currently available, or the number of
//characters requested will be returned. According to Antonino (see
//contributions), you could issue a fcntl(fd, F_SETFL, FNDELAY);
//before reading to get the same result.
//
// By modifying newtio.c_cc[VTIME] and newtio.c_cc[VMIN] all modes
//described above can be tested.
//
// -- copied from http://tldp.org/HOWTO/Serial-Programming-HOWTO/x115.html
func (port *SerialPort) SetInputAttr(minBytes int, timeout time.Duration) error {
fd := port.port.Fd()
var options C.struct_termios
if C.tcgetattr(C.int(fd), &options) < 0 {
return fmt.Errorf("tcgetattr failed")
}
options.c_cc[C.VMIN] = _Ctype_cc_t(minBytes)
options.c_cc[C.VTIME] = _Ctype_cc_t(timeout / (time.Second / 10))
if C.tcsetattr(C.int(fd), C.TCSANOW, &options) < 0 {
return fmt.Errorf("tcsetattr failed")
}
return nil
}
示例14: SerialChannels
func SerialChannels(name string, baud int, debug bool) (chan byte, chan byte, chan bool, chan bool, error) {
var err error
var serFile *os.File
var chFromSerial, chToSerial chan byte
var chDTRSerial, chQuitSerial chan bool
serFile, err = os.OpenFile(name, os.O_RDWR|syscall.O_NOCTTY|syscall.O_NONBLOCK, 0666)
if err == nil {
fd := C.int(serFile.Fd())
var st C.struct_termios
_, err = C.tcgetattr(fd, &st)
if err == nil {
if C.isatty(fd) != 1 {
err = errors.New("Not a tty")
}
}
var speed C.speed_t
if err == nil {
switch baud {
case 230400:
speed = C.B230400
case 115200:
speed = C.B115200
case 57600:
speed = C.B57600
case 19200:
speed = C.B19200
case 9600:
speed = C.B9600
default:
err = errors.New("Invalid baud rate")
}
}
if err == nil {
_, err = C.cfsetispeed(&st, speed)
if err == nil {
_, err = C.cfsetospeed(&st, speed)
}
}
if err == nil {
C.cfmakeraw(&st)
_, err = C.tcsetattr(fd, C.TCSANOW, &st)
}
if err == nil {
chFromSerial = make(chan byte, 8192)
chQuitFrom := make(chan bool)
go func() {
datain := make([]byte, 1)
for q := false; q == false; {
count, _ := serFile.Read(datain)
for i := 0; i < count; i++ {
if debug {
if datain[i] == byte(0x0D) {
fmt.Print("(\n)")
} else {
fmt.Printf("(%02X)", datain[i])
}
}
chFromSerial <- datain[i]
}
select {
case q = <-chQuitFrom:
default:
}
time.Sleep(10)
}
}()
chToSerial = make(chan byte, 8192)
chQuitTo := make(chan bool)
go func() {
dataout := make([]byte, 1)
for q := false; q == false; {
dataout[0] = <-chToSerial
if debug {
if dataout[0] == byte(0x0D) {
fmt.Print("[\n]")
} else {
fmt.Printf("[%c]", dataout[0])
}
}
scount, serr := serFile.Write(dataout)
if scount != 1 || serr != nil {
fmt.Printf("SERIAL ERROR: write error [%d][%s]\n", scount, serr)
}
}
}()
chDTRSerial = make(chan bool)
chQuitDTR := make(chan bool)
//.........这里部分代码省略.........
示例15: openPort
func openPort(name string, baud int) (rwc io.ReadWriteCloser, err error) {
f, err := os.OpenFile(name, syscall.O_RDWR|syscall.O_NOCTTY, 0666)
if err != nil {
return
}
fd := C.int(f.Fd())
if C.isatty(fd) != 1 {
f.Close()
return nil, errors.New("File is not a tty")
}
var st C.struct_termios
_, err = C.tcgetattr(fd, &st)
if err != nil {
f.Close()
return nil, err
}
var speed C.speed_t
switch baud {
case 115200:
speed = C.B115200
case 57600:
speed = C.B57600
case 38400:
speed = C.B38400
case 19200:
speed = C.B19200
case 9600:
speed = C.B9600
case 4800:
speed = C.B4800
case 2400:
speed = C.B2400
default:
f.Close()
return nil, fmt.Errorf("Unknown baud rate %v", baud)
}
_, err = C.cfsetispeed(&st, speed)
if err != nil {
f.Close()
return nil, err
}
_, err = C.cfsetospeed(&st, speed)
if err != nil {
f.Close()
return nil, err
}
// Select local mode
st.c_cflag |= (C.CLOCAL | C.CREAD)
// Select raw mode
st.c_lflag &= ^C.tcflag_t(C.ICANON | C.ECHO | C.ECHOE | C.ISIG)
st.c_oflag &= ^C.tcflag_t(C.OPOST)
_, err = C.tcsetattr(fd, C.TCSANOW, &st)
if err != nil {
f.Close()
return nil, err
}
return f, nil
}