Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/SmiteshP/nvim-gps

Simple statusline component that shows what scope you are working inside
https://github.com/SmiteshP/nvim-gps

lua neovim neovim-plugin nvim nvim-plugin nvim-treesitter treesitter

Last synced: 13 days ago
JSON representation

Simple statusline component that shows what scope you are working inside

Awesome Lists containing this project

README

        

# ⚠️ Deprecated! Use [nvim-navic](https://github.com/SmiteshP/nvim-navic) instead of this plugin

nvim-navic is an improved version of nvim-gps (a version 2.0!). It accompishes the same task as this plugin, but uses LSP instead of Treesitter. It also adds ability to have coloured icons!

# 🛰️ nvim-gps

Take this handy dandy gps with you on your coding adventures and always know where you are!

## 🤔 What is nvim-gps?

nvim-gps is a simple status line component that shows context of the current cursor position in file. It is similar to the statusline function provided by [nvim-treesitter](https://github.com/nvim-treesitter/nvim-treesitter/blob/af96150a2d34a05b7265ee3c42425315bcd62e39/doc/nvim-treesitter.txt#L414), but smarter. Using custom treesitter queries for each language, nvim-gps is able to show exact name of containing class, struct, function, method, etc. along with some fancy symbols!

![example](https://user-images.githubusercontent.com/43147494/130349444-fa7176a3-d068-4309-87ec-bcf6f0204261.png)

Here is a barebones example how it looks in a statusline

![nvim-gps-barebone-demo](https://user-images.githubusercontent.com/43147494/130415000-6ae9c965-d631-41b2-b1f0-40ad4840a192.gif)

Here is a example of how it can look in a fully configured statusline

![nvim-gps-demo](https://user-images.githubusercontent.com/43147494/130349453-d3e1fd61-348e-439c-b013-3433fd284323.gif)

## ✅ Supported Languages

* Bash (and Zsh)
* C
* C++
* C#
* Fennel
* Go
* Haskell
* Html
* Java
* Javascript (and jsx)
* JSON
* LaTeX
* Lua
* Norg
* Nix
* Ocaml
* Php
* Python
* Ruby
* Rust
* TOML
* Typescript (and tsx)
* Verilog
* YAML
* YANG
* Zig

## ⚡️ Requirements

* Neovim >= 0.5.0
* [nvim-treesitter](https://github.com/nvim-treesitter/nvim-treesitter)

## 📦 Installation

Install the plugin with your preferred package manager:

### [packer](https://github.com/wbthomason/packer.nvim)

```lua
-- Lua
use {
"SmiteshP/nvim-gps",
requires = "nvim-treesitter/nvim-treesitter"
}
```

### [vim-plug](https://github.com/junegunn/vim-plug)

```vim
" Vimscript
Plug "nvim-treesitter/nvim-treesitter"
Plug "SmiteshP/nvim-gps"
```

## ⚙️ Configuration

nvim-gps provides a `setup` function that takes in a table with configuration options.
The default configuration assumes that you are using a nerd font.

> Note: `setup` function needs to be called once for nvim-gps to work.

```lua
-- Lua

-- Default config
require("nvim-gps").setup()
```

```lua
-- Lua

-- Customized config
require("nvim-gps").setup({

disable_icons = false, -- Setting it to true will disable all icons

icons = {
["class-name"] = ' ', -- Classes and class-like objects
["function-name"] = ' ', -- Functions
["method-name"] = ' ', -- Methods (functions inside class-like objects)
["container-name"] = '⛶ ', -- Containers (example: lua tables)
["tag-name"] = '炙' -- Tags (example: html tags)
},

-- Add custom configuration per language or
-- Disable the plugin for a language
-- Any language not disabled here is enabled by default
languages = {
-- Some languages have custom icons
["json"] = {
icons = {
["array-name"] = ' ',
["object-name"] = ' ',
["null-name"] = '[] ',
["boolean-name"] = 'ﰰﰴ ',
["number-name"] = '# ',
["string-name"] = ' '
}
},
["latex"] = {
icons = {
["title-name"] = "# ",
["label-name"] = " ",
},
},
["norg"] = {
icons = {
["title-name"] = " ",
},
},
["toml"] = {
icons = {
["table-name"] = ' ',
["array-name"] = ' ',
["boolean-name"] = 'ﰰﰴ ',
["date-name"] = ' ',
["date-time-name"] = ' ',
["float-name"] = ' ',
["inline-table-name"] = ' ',
["integer-name"] = '# ',
["string-name"] = ' ',
["time-name"] = ' '
}
},
["verilog"] = {
icons = {
["module-name"] = ' '
}
},
["yaml"] = {
icons = {
["mapping-name"] = ' ',
["sequence-name"] = ' ',
["null-name"] = '[] ',
["boolean-name"] = 'ﰰﰴ ',
["integer-name"] = '# ',
["float-name"] = ' ',
["string-name"] = ' '
}
},
["yang"] = {
icons = {
["module-name"] = " ",
["augment-path"] = " ",
["container-name"] = " ",
["grouping-name"] = " ",
["typedef-name"] = " ",
["identity-name"] = " ",
["list-name"] = "﬘ ",
["leaf-list-name"] = " ",
["leaf-name"] = " ",
["action-name"] = " ",
}
},

-- Disable for particular languages
-- ["bash"] = false, -- disables nvim-gps for bash
-- ["go"] = false, -- disables nvim-gps for golang

-- Override default setting for particular languages
-- ["ruby"] = {
-- separator = '|', -- Overrides default separator with '|'
-- icons = {
-- -- Default icons not specified in the lang config
-- -- will fallback to the default value
-- -- "container-name" will fallback to default because it's not set
-- ["function-name"] = '', -- to ensure empty values, set an empty string
-- ["tag-name"] = ''
-- ["class-name"] = '::',
-- ["method-name"] = '#',
-- }
--}
},

separator = ' > ',

-- limit for amount of context shown
-- 0 means no limit
depth = 0,

-- indicator used when context hits depth limit
depth_limit_indicator = ".."
})
```

## 🚀 Usage

nvim-gps doesn't modify your statusline by itself, instead you are provided with two functions and it is left up to you to incorporate them into your statusline.

```lua
-- Lua
local gps = require("nvim-gps")

gps.is_available() -- Returns boolean value indicating whether a output can be provided
gps.get_location() -- Returns a string with context information (or nil if not available)

-- example output: "mystruct > sum"
```

You can also pass optional arguments to get_location function to override options given in setup function:

```lua
opts = {
disable_icons = false,
separator = ' > ',
depth = 0,
depth_limit_indicator = ".."
}

gps.get_location(opts)
```

These two functions should satisfy the needs of most users, however if you want the raw intermediate data for custom usage you can use the following function:

```lua
gps.get_data() -- Returns a table of intermediate representation of data (which is used by get_location)
-- Table of tables that contain 'text', 'type' and 'icon' for each context
```

An example output of get_data function:

```lua
{
{
text = "mystruct",
type = "class-name",
icon = " "
},
{
text = "sum",
type = "method-name",
icon = " "
}
}
```

## Examples of Integrating with Other Plugins

### [feline](https://github.com/famiu/feline.nvim)

An example feline setup

```lua
-- Lua
local gps = require("nvim-gps")

table.insert(components.active[1], {
provider = function()
return gps.get_location()
end,
enabled = function()
return gps.is_available()
end
})
```

### [galaxyline](https://github.com/glepnir/galaxyline.nvim)

An example galaxyline setup

```lua
-- Lua
local gps = require("nvim-gps")

require('galaxyline').section.left[1]= {
nvimGPS = {
provider = function()
return gps.get_location()
end,
condition = function()
return gps.is_available()
end
}
}
```

### [lualine](https://github.com/hoob3rt/lualine.nvim)

An example lualine setup

```lua
-- Lua
local gps = require("nvim-gps")

require("lualine").setup({
sections = {
lualine_c = {
{ gps.get_location, cond = gps.is_available },
}
}
})
```

### vimscript

example setup using native vim way

```vim
" vimscript
func! NvimGps() abort
return luaeval("require'nvim-gps'.is_available()") ?
\ luaeval("require'nvim-gps'.get_location()") : ''
endf

set statusline+=%{NvimGps()}
```

### [windline](https://github.com/windwp/windline.nvim)

example windline setup

```lua
-- Lua
local gps = require("nvim-gps")

comps.gps = {
function()
if gps.is_available() then
return gps.get_location()
end
return ''
end,
{"white", "black"}
}
```

## 🔥 Contributions

Is your favorite language not supported? Or did you find something not being captured by the nvim-gps? Please consider opening a issue, or even better make a PR and solve the issue!! 😄

Please read the CONTRIBUTING.md to understand how the treesitter queries work and how you can add/enhance the queries for your favorite programming languages!