summaryrefslogtreecommitdiff
path: root/termSize_linux.go
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 /termSize_linux.go
parent2fb8dc546300f278255c0a5ee339b6a9c7e89d48 (diff)
add linux specific stty outputv0.0.13v0.0.12
Diffstat (limited to 'termSize_linux.go')
-rw-r--r--termSize_linux.go44
1 files changed, 44 insertions, 0 deletions
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
+}