summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeff Carr <[email protected]>2025-09-26 18:53:21 -0500
committerJeff Carr <[email protected]>2025-09-26 19:04:48 -0500
commitecfdb58a48931389c5f27f465bf7478428cb385d (patch)
treeab46ed23c419db2667fbb867111ba44bb00a1313
parent2fb8dc546300f278255c0a5ee339b6a9c7e89d48 (diff)
add linux specific stty outputv0.0.13v0.0.12
-rw-r--r--tablePB.go1
-rw-r--r--termSize.go19
-rw-r--r--termSize_darwin.go27
-rw-r--r--termSize_linux.go44
-rw-r--r--termSize_windows.go27
5 files changed, 101 insertions, 17 deletions
diff --git a/tablePB.go b/tablePB.go
index c30baf6..8946175 100644
--- a/tablePB.go
+++ b/tablePB.go
@@ -30,6 +30,7 @@ func PrintTable(pb *guipb.Table) {
var args []string
var sizes []int
+ log.Info("INFO: table len=", len(pb.AnyCols))
// first print the table header
for _, col := range pb.AnyCols {
args = append(args, col.Header.Name)
diff --git a/termSize.go b/termSize.go
index 85594e0..8595c5e 100644
--- a/termSize.go
+++ b/termSize.go
@@ -1,12 +1,10 @@
package cobol
import (
- "os"
"strings"
"unicode"
"go.wit.com/log"
- "golang.org/x/term"
)
var WIDTH int = 120
@@ -16,22 +14,9 @@ var TERMSIZE int = 80
// If the output is not an interactive terminal (e.g., it's being piped to a file
// or another command), it returns a default width and false.
func getTerminalWidth() (int, bool) {
- // term.IsTerminal checks if the given file descriptor is connected to a terminal.
- // We use os.Stdout.Fd() to check the standard output.
- if term.IsTerminal(int(os.Stdout.Fd())) {
- var err error
- // term.GetSize returns the dimensions of the given terminal.
- WIDTH, _, err = term.GetSize(int(os.Stdout.Fd()))
- if err != nil {
- // If we can't get the size for some reason, fall back to the default.
- log.Printf("could not get terminal size: %v", err)
- return WIDTH, false
- }
- return WIDTH, true
- }
+ newWidth, ok := osTerminalWidth()
- // If it's not a terminal, return the default width.
- return WIDTH, false
+ return newWidth, ok
}
// like the perl Chomp but with the terminal width
diff --git a/termSize_darwin.go b/termSize_darwin.go
new file mode 100644
index 0000000..0702792
--- /dev/null
+++ b/termSize_darwin.go
@@ -0,0 +1,27 @@
+package cobol
+
+import (
+ "os"
+
+ "go.wit.com/log"
+ "golang.org/x/term"
+)
+
+func osTerminalWidth() (int, bool) {
+ // term.IsTerminal checks if the given file descriptor is connected to a terminal.
+ // We use os.Stdout.Fd() to check the standard output.
+ if term.IsTerminal(int(os.Stdout.Fd())) {
+ var err error
+ // term.GetSize returns the dimensions of the given terminal.
+ WIDTH, _, err = term.GetSize(int(os.Stdout.Fd()))
+ if err != nil {
+ // If we can't get the size for some reason, fall back to the default.
+ log.Printf("could not get terminal size: %v", err)
+ return WIDTH, false
+ }
+ return WIDTH, true
+ }
+
+ // If it's not a terminal, return the default width.
+ return WIDTH, false
+}
diff --git a/termSize_linux.go b/termSize_linux.go
new file mode 100644
index 0000000..34201ac
--- /dev/null
+++ b/termSize_linux.go
@@ -0,0 +1,44 @@
+package cobol
+
+import (
+ "os"
+
+ "go.wit.com/log"
+ "golang.org/x/term"
+)
+
+func osTerminalWidth() (int, bool) {
+ w, _, err := ttyGetSize()
+ if err == nil {
+ return w, true
+ }
+
+ // term.IsTerminal checks if the given file descriptor is connected to a terminal.
+ // We use os.Stdout.Fd() to check the standard output.
+ if term.IsTerminal(int(os.Stdout.Fd())) {
+ var err error
+ // term.GetSize returns the dimensions of the given terminal.
+ WIDTH, _, err = term.GetSize(int(os.Stdout.Fd()))
+ if err != nil {
+ // If we can't get the size for some reason, fall back to the default.
+ log.Printf("could not get terminal size: %v", err)
+ return WIDTH, false
+ }
+ return WIDTH, true
+ }
+
+ // If it's not a terminal, return the default width.
+ return WIDTH, false
+}
+
+func ttyGetSize() (int, int, error) {
+ tty, err := os.Open("/dev/tty")
+ if err != nil {
+ return 0, 0, err
+ }
+ w, h, err := term.GetSize(int(tty.Fd()))
+ if err != nil {
+ log.Info("linux.osTerminalWidth tty.Fd() err", w, h, err)
+ }
+ return w, h, err
+}
diff --git a/termSize_windows.go b/termSize_windows.go
new file mode 100644
index 0000000..0702792
--- /dev/null
+++ b/termSize_windows.go
@@ -0,0 +1,27 @@
+package cobol
+
+import (
+ "os"
+
+ "go.wit.com/log"
+ "golang.org/x/term"
+)
+
+func osTerminalWidth() (int, bool) {
+ // term.IsTerminal checks if the given file descriptor is connected to a terminal.
+ // We use os.Stdout.Fd() to check the standard output.
+ if term.IsTerminal(int(os.Stdout.Fd())) {
+ var err error
+ // term.GetSize returns the dimensions of the given terminal.
+ WIDTH, _, err = term.GetSize(int(os.Stdout.Fd()))
+ if err != nil {
+ // If we can't get the size for some reason, fall back to the default.
+ log.Printf("could not get terminal size: %v", err)
+ return WIDTH, false
+ }
+ return WIDTH, true
+ }
+
+ // If it's not a terminal, return the default width.
+ return WIDTH, false
+}