Get terminal size two ways

This commit is contained in:
Timothy Warren 2021-03-24 13:24:40 -04:00
parent 835f550bbb
commit 0902d494c5
2 changed files with 60 additions and 21 deletions

View File

@ -1,9 +1,6 @@
package editor package editor
import ( import (
"bufio"
"os"
"timshome.page/gilo/internal/char" "timshome.page/gilo/internal/char"
"timshome.page/gilo/internal/terminal" "timshome.page/gilo/internal/terminal"
) )
@ -13,19 +10,10 @@ type Editor struct {
cols int cols int
} }
var reader = bufio.NewReader(os.Stdin)
func readKey() (rune, int) {
ch, size, err := reader.ReadRune()
if err != nil {
panic(err)
}
return ch, size
}
func drawRows() { func drawRows() {
for y :=0; y < 24; y += 1 { _, rows := terminal.Size()
for y :=0; y < rows; y += 1 {
terminal.OutLn("~") terminal.OutLn("~")
} }
} }
@ -40,7 +28,7 @@ func RefreshScreen() {
} }
func ProcessKeypress() bool { func ProcessKeypress() bool {
ch, _ := readKey() ch, _ := terminal.ReadKey()
// Clean up on exit // Clean up on exit
if ch == char.Ctrl('q') { if ch == char.Ctrl('q') {

View File

@ -1,6 +1,7 @@
package terminal package terminal
import ( import (
"bufio"
"fmt" "fmt"
"os" "os"
@ -10,6 +11,17 @@ import (
const ClearScreen = "2J" const ClearScreen = "2J"
const ResetCursor = "H" const ResetCursor = "H"
var reader = bufio.NewReader(os.Stdin)
func ReadKey() (rune, int) {
ch, size, err := reader.ReadRune()
if err != nil {
panic(err)
}
return ch, size
}
// Is this a valid interactive terminal? // Is this a valid interactive terminal?
func check() { func check() {
if !term.IsTerminal(int(os.Stdin.Fd())) { if !term.IsTerminal(int(os.Stdin.Fd())) {
@ -41,13 +53,52 @@ func ANSICode (code string) {
fmt.Printf("\x1b[%s", code) fmt.Printf("\x1b[%s", code)
} }
func Size () (width int, height int) { func sizeTrick () (rows int, cols int) {
width, height, err := term.GetSize(int(os.Stdin.Fd())) // Move cursor to location further than likely screen size
// The cursor will move to maximum available position
fmt.Print("\x1b[999C\x1b[99B")
// Ask the terminal where the cursor is
fmt.Print("\x1b[6n")
// Read stdin looking for the reported location
buffer := ""
for char, _ := ReadKey(); char != 'R'; char, _ = ReadKey() {
if char == '\x1b' || char == '[' {
continue
}
if char == 'R' || char == '\x00'{
break
}
buffer += string(char)
}
_, err := fmt.Sscanf(buffer, "%d;%d", &rows, &cols)
if err != nil { if err != nil {
panic(err)
}
return rows, cols
}
func Size () (width int, height int) {
width = 80 width = 80
height = 24 height = 24
// Try the syscall first
width, height, err := term.GetSize(int(os.Stdin.Fd()))
if err == nil {
return width, height
} }
// Figure out the size the hard way
height, width = sizeTrick()
OutLn("%d Rows, %d Cols", height, width)
return width, height return width, height
} }