lazygit/vendor/github.com/jesseduffield/gocui
Stefan Haller f0b49eba71 Press enter in main view of files/commitFiles to enter staging/patch-building
This was already possible, but only when a file was selected, and it woudln't
always land on the right line when a pager was used. Now it's also possible to
do this for directories, and it jumps to the right line.

At the moment this is a hack that relies on delta's hyperlinks, so it only works
on lines that have hyperlinks (added and context).

The implementation is very hacky for other reasons too (e.g. the addition of the
weirdly named ClickedViewRealLineIdx to OnFocusOpts).
2025-04-29 11:37:53 +02:00
..
.gitignore switch to Go modules 2019-09-01 21:24:03 +10:00
attribute.go Bump gocui 2024-01-10 09:39:25 +01:00
AUTHORS use dep 2018-08-06 00:38:38 +10:00
CHANGES_tcell.md use tcell via porting over code from awesome-gocui 2021-04-06 19:34:32 +10:00
CODE_OF_CONDUCT.md use tcell via porting over code from awesome-gocui 2021-04-06 19:34:32 +10:00
CONTRIBUTING.md use tcell via porting over code from awesome-gocui 2021-04-06 19:34:32 +10:00
doc.go use tcell via porting over code from awesome-gocui 2021-04-06 19:34:32 +10:00
edit.go Bump gocui 2023-08-02 11:35:36 +02:00
escape.go Bump gocui 2024-08-24 10:35:59 +02:00
gui.go [gocui] Add PreviousX/PreviousY to ViewMouseBindingOpts 2025-04-29 11:37:53 +02:00
gui_others.go Bump gocui 2024-04-18 10:10:30 +02:00
gui_windows.go Bump gocui 2024-04-18 10:10:30 +02:00
keybinding.go Bump gocui 2024-04-18 10:10:30 +02:00
LICENSE use dep 2018-08-06 00:38:38 +10:00
loader.go fix commit amend 2021-04-10 11:54:38 +10:00
README.md use tcell via porting over code from awesome-gocui 2021-04-06 19:34:32 +10:00
scrollbar.go Use slimmer scrollbars 2024-01-30 08:44:03 +11:00
task.go Use an interface for tasks instead of a concrete struct 2023-07-10 17:12:21 +10:00
task_manager.go Use an interface for tasks instead of a concrete struct 2023-07-10 17:12:21 +10:00
tcell_driver.go Bump gocui 2025-02-10 13:40:22 +01:00
text_area.go Bump gocui 2024-08-24 10:21:25 +02:00
view.go Press enter in main view of files/commitFiles to enter staging/patch-building 2025-04-29 11:37:53 +02:00

GOCUI - Go Console User Interface

CircleCI CodeCov Go Report Card GolangCI GoDoc GitHub tag (latest SemVer)

Minimalist Go package aimed at creating Console User Interfaces. A community fork based on the amazing work of jroimartin

Features

  • Minimalist API.
  • Views (the "windows" in the GUI) implement the interface io.ReadWriter.
  • Support for overlapping views.
  • The GUI can be modified at runtime (concurrent-safe).
  • Global and view-level keybindings.
  • Mouse support.
  • Colored text.
  • Customizable editing mode.
  • Easy to build reusable widgets, complex layouts...

About fork

This fork has many improvements over the original work from jroimartin.

  • Written ontop of TCell
  • Better wide character support
  • Support for 1 Line height views
  • Better support for running in docker container
  • Customize frame colors
  • Improved code comments and quality
  • Many small improvements
  • Change Visibility of views

For information about this org see: awesome-gocui/about.

Installation

Execute:

$ go get github.com/awesome-gocui/gocui

Documentation

Execute:

$ go doc github.com/awesome-gocui/gocui

Or visit godoc.org to read it online.

Example

See the _example folder for more examples

package main

import (
	"fmt"
	"log"

	"github.com/awesome-gocui/gocui"
)

func main() {
	g, err := gocui.NewGui(gocui.OutputNormal, true)
	if err != nil {
		log.Panicln(err)
	}
	defer g.Close()

	g.SetManagerFunc(layout)

	if err := g.SetKeybinding("", gocui.KeyCtrlC, gocui.ModNone, quit); err != nil {
		log.Panicln(err)
	}

	if err := g.MainLoop(); err != nil && !gocui.IsQuit(err) {
		log.Panicln(err)
	}
}

func layout(g *gocui.Gui) error {
	maxX, maxY := g.Size()
	if v, err := g.SetView("hello", maxX/2-7, maxY/2, maxX/2+7, maxY/2+2, 0); err != nil {
		if !gocui.IsUnknownView(err) {
			return err
		}

		if _, err := g.SetCurrentView("hello"); err != nil {
			return err
		}

		fmt.Fprintln(v, "Hello world!")
	}

	return nil
}

func quit(g *gocui.Gui, v *gocui.View) error {
	return gocui.ErrQuit
}

Screenshots

r2cui

_examples/demo.go

_examples/dynamic.go

Projects using gocui

  • komanda-cli: IRC Client For Developers.
  • vuls: Agentless vulnerability scanner for Linux/FreeBSD.
  • wuzz: Interactive cli tool for HTTP inspection.
  • httplab: Interactive web server.
  • domainr: Tool that checks the availability of domains based on keywords.
  • gotime: Time tracker for projects and tasks.
  • claws: Interactive command line client for testing websockets.
  • terminews: Terminal based RSS reader.
  • diagram: Tool to convert ascii arts into hand drawn diagrams.
  • pody: CLI app to manage Pods in a Kubernetes cluster.
  • kubexp: Kubernetes client.
  • kcli: Tool for inspecting kafka topics/partitions/messages.
  • fac: git merge conflict resolver
  • jsonui: Interactive JSON explorer for your terminal.
  • cointop: Interactive terminal based UI application for tracking cryptocurrencies.
  • lazygit: simple terminal UI for git commands.
  • lazydocker: The lazier way to manage everything docker.

Note: if your project is not listed here, let us know! :)