hstr/INSTALLATION.md

393 lines
8.3 KiB
Markdown
Raw Normal View History

# Installation
Install:
* [Ubuntu](#ubuntu)
* [Fedora](#fedorarhelcentos)
* [Gentoo](#gentoo)
* [CentOS](#fedorarhelcentos)
* [openSUSE](#opensuse)
* [RHEL](#fedorarhelcentos)
* [Debian](#debianmint)
* [Mint](#debianmint)
* [Arch Linux](#arch-linux)
* [Scientific Linux](#fedorarhelcentos)
* [macOS](#macos)
Build:
* [build on any Linux distro](#build-on-any-linux-distro)
* [build snap](#snap)
* [build on Ubuntu](#build-on-ubuntu)
* [build on Debian](#build-on-debian)
* [build on Fedora](#build-on-fedora)
2018-08-12 05:34:45 +08:00
* [build on Windows Subsystem for Linux (WSL)](#build-on-wsl)
* [build on Cygwin](#build-on-cygwin)
Tarball:
* [build and install tarball](#build-and-install-tarball)
# Install
Install HSTR using a package.
## Ubuntu
Install `hh` on Ubuntu using one-liner:
2016-10-11 14:51:18 +08:00
```bash
sudo add-apt-repository ppa:ultradvorka/ppa && sudo apt-get update && sudo apt-get install hh && hh --show-configuration >> ~/.bashrc
```
2016-10-11 14:51:18 +08:00
... or step by step:
```bash
sudo add-apt-repository ppa:ultradvorka/ppa
sudo apt-get update
sudo apt-get install hh
```
Optionally [configure](CONFIGURATION.md) `hh` and check its [man page](README.md#documentation).
## Fedora/RHEL/Centos
2016-02-17 23:31:52 +08:00
Install `hh` on Fedora, RHEL or CentOS:
```bash
sudo dnf install hstr -y
```
... or:
```bash
sudo yum install hstr -y
```
2016-02-17 23:31:52 +08:00
Optionally [configure](CONFIGURATION.md) `hh` and check its [man page](README.md#documentation).
---
If you want to make sure you have the latest version, then download `.rpm` archive from
[GitHub releases](https://github.com/dvorka/hstr/releases) and install it:
```bash
sudo dnf install ./hstr-<major>.<minor>.<revision>-2.x86_64.rpm -y
```
## Debian/Mint
Install `hh` from PPA. Add [my PPA](http://www.mindforger.com/debian),
trust [GPG key](http://www.mindforger.com/gpgpubkey.txt) and install `hh`:
```bash
# add PPA to APT sources:
sudo echo -e "\ndeb http://www.mindforger.com/debian stretch main" >> /etc/apt/sources.list
# import PPA's GPG key
wget -qO - http://www.mindforger.com/gpgpubkey.txt | sudo apt-key add -
# update sources
sudo apt update
# install MindForger
sudo apt install hstr
```
2015-01-13 22:24:08 +08:00
Optionally [configure](CONFIGURATION.md) `hh` and check its [man page](README.md#documentation).
---
2018-08-12 02:18:00 +08:00
Alternatively you can download and install `.deb` archive from [GitHub releases](https://github.com/dvorka/hstr/releases)
2018-05-23 16:49:40 +08:00
section of the project:
2018-05-23 16:49:40 +08:00
```bash
dpkg -i hstr_-<major>.<minor>.<revision>_1-amd64.deb
```
## openSUSE
To install `hh` on openSUSE Leap 42.1 run the following commands as root:
```bash
zypper addrepo http://download.opensuse.org/repositories/home:tuw-e184/openSUSE_Leap_42.1/home:tuw-e184.repo
zypper refresh
zypper install hstr
```
2015-01-13 22:24:08 +08:00
Optionally [configure](CONFIGURATION.md) `hh` and check its [man page](README.md#documentation).
## Gentoo
To install `hh` run (HSTR has been added to [Portage](https://bugs.gentoo.org/show_bug.cgi?id=527122)):
2018-08-01 05:23:20 +08:00
```bash
emerge app-shells/hstr
```
Optionally [configure](CONFIGURATION.md) `hh` and check its [man page](README.md#documentation).
## Arch Linux
Download latest distribution from [GitHub releases](https://github.com/dvorka/hstr/releases).
Use [PKGBUILD](https://wiki.archlinux.org/index.php/PKGBUILD) in the root of the distribution to build package using `makepkg`.
2015-02-06 14:18:52 +08:00
https://aur.archlinux.org/packages/hstr-git/
Install `hh`.
2015-01-13 22:24:08 +08:00
Optionally [configure](CONFIGURATION.md) `hh` and check its [man page](README.md#documentation).
## macOS
You can either install `hh` from [Homebrew](http://brew.sh/):
```bash
brew install hh
```
or from the source code as described further in this section. First install MacPorts:
http://www.macports.org
2015-01-13 22:24:08 +08:00
And then install readline and ncurses:
2018-08-01 05:23:20 +08:00
```bash
2015-01-13 22:24:08 +08:00
port install readline
port install ncurses
```
2015-04-12 09:30:40 +08:00
Build and install (if using Homebrew):
```bash
autoreconf -fvi
./configure CFLAGS=-I$(brew --prefix)/opt/readline/include LDFLAGS=-L$(brew --prefix)/opt/readline/lib
make
```
2017-02-03 05:01:40 +08:00
Alternative if using MacPorts ([macports.com](https://www.macports.org/ports.php?by=name&substr=hstr)/[GitHub](https://github.com/macports/macports-ports/blob/master/shells/hstr/Portfile)):
2015-04-12 09:30:40 +08:00
```bash
autoreconf -fvi
./configure CFLAGS=-I/opt/local/include/ LDFLAGS=-L/opt/local/lib
make
```
2015-01-13 22:24:08 +08:00
Optionally [configure](CONFIGURATION.md) `hh` and check its [man page](README.md#documentation).
# Build
Build HSTR from source code.
2018-08-12 05:11:35 +08:00
## Build on any Linux distro
Clone Git repository:
2017-06-05 12:49:15 +08:00
```bash
git clone https://github.com/dvorka/hstr.git
```
2017-06-05 12:49:15 +08:00
Create build files using:
2017-06-05 12:49:15 +08:00
```bash
cd ./build/tarball && ./tarball-automake.sh && cd ../..
2017-06-05 12:49:15 +08:00
```
Build and install `hh` using:
2017-06-05 12:49:15 +08:00
```bash
./configure && make && make install
```
Run HSTR:
2017-06-05 12:49:15 +08:00
```bash
hh
2017-06-05 12:49:15 +08:00
```
2017-06-05 12:49:15 +08:00
Optionally [configure](CONFIGURATION.md) `hh` and check its [man page](README.md#documentation).
## Build snap
To build [snap](https://snapcraft.io/) for 'hh' first clone Git repository:
```bash
git clone https://github.com/dvorka/hstr.git
```
Make sure that you can build HSTR from source code
as described in a "Build on ..." section for your
distribution.
Install [snapcraft](https://snapcraft.io/) and build
snap by running snapcraft in the root of Git repository:
```
$ ls ./snap
snapcraft.yaml
$ snapcraft
...
```
Find `hh_0+git..._amd64.snap` in the current directory.
## Build on Ubuntu
To build `hh` on Ubuntu clone Git repository:
```bash
git clone https://github.com/dvorka/hstr.git
```
Install dependencies:
2017-06-05 12:49:15 +08:00
```bash
2018-08-12 05:11:35 +08:00
sudo apt install automake gcc make libncursesw5-dev libreadline-dev
```
Create build files using:
```bash
cd ./build/tarball && ./tarball-automake.sh && cd ../..
```
Build and install `hh` using:
```bash
./configure && make && make install
```
Run HSTR:
```bash
hh
```
Optionally [configure](CONFIGURATION.md) `hh` and check its [man page](README.md#documentation).
## Build on Debian
To build `hh` on Ubuntu clone Git repository:
```bash
git clone https://github.com/dvorka/hstr.git
```
Install dependencies:
```bash
sudo apt install autotools gcc make libncursesw5-dev libreadline-dev
```
Create build files using:
```bash
cd ./build/tarball && ./tarball-automake.sh && cd ../..
```
Build and install `hh` using:
```bash
./configure && make && make install
```
Run HSTR:
```bash
hh
```
Optionally [configure](CONFIGURATION.md) `hh` and check its [man page](README.md#documentation).
## Build on Fedora
To build `hh` on Ubuntu clone Git repository:
2017-06-05 12:49:15 +08:00
```bash
git clone https://github.com/dvorka/hstr.git
```
Install dependencies:
```bash
sudo dnf install autotools ncurses-devel readline-devel
```
Create build files using:
```bash
cd ./build/tarball && ./tarball-automake.sh && cd ../..
```
Build and install `hh` using:
```bash
./configure && make && make install
```
Run HSTR:
```bash
hh
```
Optionally [configure](CONFIGURATION.md) `hh` and check its [man page](README.md#documentation).
## Build on WSL
2018-08-12 05:32:03 +08:00
To build `hstr` on [Windows Subsystem for Linux (WSL)](https://msdn.microsoft.com/en-us/commandline/wsl/about) clone Git repository:
```bash
git clone https://github.com/dvorka/hstr.git
```
2018-08-12 05:05:59 +08:00
Install dependencies:
```bash
2018-08-12 05:11:35 +08:00
sudo apt install automake gcc make libncursesw5-dev libreadline-dev
2018-08-12 05:05:59 +08:00
```
Create build files using:
```bash
cd ./build/tarball && ./tarball-automake.sh && cd ../..
```
2018-08-12 05:32:03 +08:00
Build and install `hstr` using:
```bash
./configure && make && make install
```
2018-08-12 05:32:03 +08:00
It's **important** to finish installation by configuration of `hstr` binding
2018-08-12 05:34:45 +08:00
which ensures propagation of chosen command to the prompt:
2018-08-12 05:32:03 +08:00
```bash
hstr --show-configuration >> ~/.bashrc
. ~/.bashrc
```
Make sure to **run** `hstr` using <kbd>Ctrl</kbd><kbd>r</kbd> - otherwise commands will not appear in prompt.
2018-08-12 05:32:03 +08:00
Optionally [configure](CONFIGURATION.md) `hh` and check its [man page](README.md#documentation).
2018-08-12 05:32:03 +08:00
## Build on Cygwin
To build `hh` on [Cygwin](https://www.cygwin.com) clone Git repository:
```bash
git clone https://github.com/dvorka/hstr.git
```
Create build files using:
```bash
cd ./build/tarball && ./tarball-automake.sh && cd ../..
```
Build and install `hh` using:
```bash
./configure && make && make install
```
Optionally [configure](CONFIGURATION.md) `hh` and check its [man page](README.md#documentation).
# Tarball
Download and install HSTR tarball.
## Build and Install Tarball
2018-08-12 02:18:00 +08:00
Download latest tarball from [GitHub releases](https://github.com/dvorka/hstr/releases) section.
Expand the archive and install `hh` using:
```bash
./configure && make && make install
```
Optionally [configure](CONFIGURATION.md) `hh` and check its [man page](README.md#documentation).