Skip to content

Commit

Permalink
Squashed commit of the following:
Browse files Browse the repository at this point in the history
commit a750143
Author: usagi-flow <[email protected]>
Date:   Wed May 15 20:56:11 2024 +0200

    doc(evil): add a notice regarding the branch being rebased

commit 88e3b5f
Author: usagi-flow <[email protected]>
Date:   Wed May 15 20:56:11 2024 +0200

    doc(evil): add a screenshot

commit 1227eeb
Author: usagi-flow <[email protected]>
Date:   Wed May 15 20:56:11 2024 +0200

    doc(evil): fix links in README.md

commit 5ca6c2c
Author: usagi-flow <[email protected]>
Date:   Wed May 15 20:56:11 2024 +0200

    doc(evil): Update README.md
  • Loading branch information
usagi-flow committed May 18, 2024
1 parent 2301430 commit 28f8027
Show file tree
Hide file tree
Showing 2 changed files with 47 additions and 40 deletions.
87 changes: 47 additions & 40 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,64 +1,71 @@
<div align="center">

<h1>
<picture>
<source media="(prefers-color-scheme: dark)" srcset="logo_dark.svg">
<source media="(prefers-color-scheme: light)" srcset="logo_light.svg">
<img alt="Helix" height="128" src="logo_light.svg">
</picture>
</h1>

[![Build status](https://github.com/helix-editor/helix/actions/workflows/build.yml/badge.svg)](https://github.com/helix-editor/helix/actions)
[![GitHub Release](https://img.shields.io/github/v/release/helix-editor/helix)](https://github.com/helix-editor/helix/releases/latest)
[![Documentation](https://shields.io/badge/-documentation-452859)](https://docs.helix-editor.com/)
[![GitHub contributors](https://img.shields.io/github/contributors/helix-editor/helix)](https://github.com/helix-editor/helix/graphs/contributors)
[![Matrix Space](https://img.shields.io/matrix/helix-community:matrix.org)](https://matrix.to/#/#helix-community:matrix.org)
<h1>evil-helix</h1>

</div>
A soft fork of [Helix](https://helix-editor.com) which introduces Vim keybindings and more.

[![Build status](https://img.shields.io/github/actions/workflow/status/usagi-flow/helix/evil-build.yml?style=for-the-badge&logo=github)](https://github.com/usagi-flow/helix/actions/workflows/evil-build.yml)

![Screenshot](./screenshot.png)

A [Kakoune](https://github.com/mawww/kakoune) / [Neovim](https://github.com/neovim/neovim) inspired editor, written in Rust.
<hr />

</div>

> [!IMPORTANT]
> This project is a work-in-progress, but should be stable enough for daily usage.
The editing model is very heavily based on Kakoune; during development I found
myself agreeing with most of Kakoune's design decisions.
## Installation

For more information, see the [website](https://helix-editor.com) or
[documentation](https://docs.helix-editor.com/).
[Download a package](https://github.com/usagi-flow/evil-helix/releases) and extract it in `/opt`. Additionally, it's recommended to symlink it in `/usr/local/bin`:

All shortcuts/keymaps can be found [in the documentation on the website](https://docs.helix-editor.com/keymap.html).
```sh
cd /opt
sudo curl -Lo helix.tar.gz https://github.com/usagi-flow/evil-helix/releases/download/release-<VERSION>/helix-<ARCH>-<OS>.tar.gz
sudo tar -xf helix.tar.gz
cd /usr/local/bin
sudo ln -sv /opt/helix/hx .
```

[Troubleshooting](https://github.com/helix-editor/helix/wiki/Troubleshooting)
Builds are not in package repositories yet.

# Features
## Project philosophy

- Vim-like modal editing
- Multiple selections
- Built-in language server support
- Smart, incremental syntax highlighting and code editing via tree-sitter
### Configurable features instead of plugins

It's a terminal-based editor first, but I'd like to explore a custom renderer
(similar to Emacs) in wgpu or skulpin.
This fork seeks to implement functionality as part of the editor, and make it configurable.
The added functionality includes a Vim look-and-feel, but also other features.

Note: Only certain languages have indentation definitions at the moment. Check
`runtime/queries/<lang>/` for `indents.scm`.
In contrast, the upstream project, Helix, mostly limits its scope to its current core functionality, and defers further functionality to the future Scheme-based plugin system.

# Installation
Compared to plugins, implementing features as part of the editor greatly improves performance, and avoids the risk of plugin compatibility issues.

[Installation documentation](https://docs.helix-editor.com/install.html).
### Sensible defaults

[![Packaging status](https://repology.org/badge/vertical-allrepos/helix.svg)](https://repology.org/project/helix/versions)
In addition, sensible defaults are crucial:
The editor must offer a wide range of tools for your job, but it must do what you expect an editor to do.

# Contributing
### Avoid Scheme/Lisp

Contributing guidelines can be found [here](./docs/CONTRIBUTING.md).
Scheme/Lisp should not be forced onto the user.
It's error-prone and harder to read by humans, compared to Rust/TOML/Lua/...

# Getting help
If upstream Helix moves to a [Scheme-based configuration](https://github.com/helix-editor/helix/issues/10389),
this project will seek to keep a user-friendly alternative.

Your question might already be answered on the [FAQ](https://github.com/helix-editor/helix/wiki/FAQ).
## Project goals

Discuss the project on the community [Matrix Space](https://matrix.to/#/#helix-community:matrix.org) (make sure to join `#helix-editor:matrix.org` if you're on a client that doesn't support Matrix Spaces yet).
- Introduce more Vim keybindings
- Implement common/crucial features as part of the editor:
- File tree (cf. [upstream PR](https://github.com/helix-editor/helix/pull/5768))
- Light/dark mode support
- Modeline support (cf. [upstream PR](https://github.com/helix-editor/helix/pull/7788))
- Maintain compatibility with upstream
- Isolate features to minimize conflicts with upstream changes
- Contribute features to upstream where possible
- Ensure (through CI) that rebasing is always possible
- Find a name for this project

# Credits
## Development

Thanks to [@jakenvac](https://github.com/jakenvac) for designing the logo!
Keep in mind the `main` branch is regularly being rebased onto the upstream `master` branch.
Binary file modified screenshot.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit 28f8027

Please sign in to comment.