Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with
or
.
Download ZIP
Haskell IDE
Haskell Shell Other
Branch: master

Merge pull request #136 from juhp/patch-3

hamlet is deprecated by shakespeare
latest commit 38196313b7
@hamishmack hamishmack authored
Failed to load latest commit information.
bew Update bew for new version of ghcjs-dom
data Improved HLint Support and Errors Pane
doc various typos and minor text corrections
language-specs Add missing field and benchmark section to cabal.lang
linux Fix syntax
main Refactored TextEditor and still incomplete CodeMirror support. Fixes …
osx Update OS X build script
pics
po New version of the pt_BR translation file.
scripts Fixes #35
src/IDE Fix crash caused by threading issue
tests Fix thread issue that seems to break gtk events
vendor Update leksah-server submodule ref
win32 Work around for JacaScript issue on Windows
xobl Update Xobl readme
.dockerignore Vagrant file for Leksah, GHCJS and "GHC on Wine"
.gitignore Add basic cabal sandbox and GHCJS support
.gitmodules User inteface changes. Default layout is a bit more laptop screen fri…
.travis.yml Fix for GHC 7.8
Dockerfile Update Dockerfile
LICENSE preparing first beta
LICENSE.rtf Use WiX to make an MSI file for the windows binaries
Readme.md Update Readme.md
Setup.lhs Adding flags for hgettext conditional compilation support.
SetupLocale.lhs Adding flags for hgettext conditional compilation support.
leksah.cabal Merge pull request #136 from juhp/patch-3
sources.txt Switch to Gtk2Hs 0.13 and leksah-server 0.14
stack.yaml stack.yaml

Readme.md

Leksah, an Integrated Development Environment for Haskell

Build Status

Leksah aims to integrate various Haskell development tools to provide a practical and pleasant development environment. The user interface is a mix of GTK+ and WebKit based components.

Documentation can be found on leksah.org.

Installation

You can get Leksah up and running quickly on Windows and OS X using the official binaries.

Some Linux distributions include Leksah packages, but building from source on Linux is normally relatively easy.

Building From Source

Building on Linux

Install the GtkSourceView and WebKitGtk development packages for your distribution:

sudo apt-get install libgtksourceview-3.0-dev libwebkitgtk-3.0-dev

Make sure $HOME/.cabal/bin is in your PATH then:

cabal update
cabal install Cabal cabal-install
cabal install regex-tdfa-text --ghc-options=-XFlexibleContexts
cabal install alex happy
cabal install gtk2hs-buildtools
cabal install leksah
leksah

Buildling on OS X

Install MacPorts.

Make sure /opt/local/bin and $HOME/Libraries/Haskell/bin are in your PATH.

To avoid a dependency on X11 add the following to /opt/local/etc/macports/variants.conf:

-x11 +no_x11 +quartz +gtk3

Use MacPorts to install python27 and rsync (sometimes it stops to ask for these to be activated so if you do them first it might help):

sudo port install python27 rsync

Use MacPorts to install GHC and the C libraries needed by Leksah (this will take a long time):

sudo port install ghc gtk3 webkit-gtk3 gtksourceview3 gtk-osx-application-gtk3 adwaita-icon-theme

Update Cabal and cabal-install

cabal update
cabal install Cabal cabal-install

Make sure the right cabal made it into your PATH.

cabal --version

Check that the versions match the ones you just installed (if not check the symbolic links in $HOME/Libraries/Haskell/bin).

Install gtk2hs-buildtools and leksah:

cabal install regex-tdfa-text --ghc-options=-XFlexibleContexts
cabal install alex happy
cabal install gtk2hs-buildtools
cabal install leksah
leksah

Building on Windows

Install GHC.

Update MinGW if necessary. The GHC installers currently come with old versions of MinGW and you will probably need to replace it with one that comes with gcc 4.8.1. The current 64bit GHC installer seems to be happy to work with newer MinGW. It may not be possible to use the current 32bit GHC installers at all. Make sure you replace MinGW so that GHC will find the new one (just adding it to the PATH will not work). The MinGW used by GHC is typically in a location like C:\Program Files\MinGHC-7.10.1\ghc-7.10.1\mingw. Move it out of the way and put a newer one in its place.

MinGW version used to build the Leksah binaries

Install the C libraries needed by Leksah. The easiest way to do this is to install Leksah using the MSI files. They include pkg-config and all the C libraries needed.

Make sure C:\Leksah\bin and %APPDATA%\cabal\bin are in your PATH and build:

cabal update
cabal install Cabal
cabal install regex-tdfa-text --ghc-options=-XFlexibleContexts
cabal install alex happy
cabal install gtk2hs-buildtools
cabal install leksah
leksah

Building Leksah for Windows using Docker

It may seem crazy, but this is currently the best way to bootstrap Leksah for Windows from source. This is mostly because Fedora and SUSE have a much more complete set of MinGW packages than any thing else (including Windows).

Get the leksah source:

git clone https://github.com/leksah/leksah
cd leksah
git submodule update --init

Build it using the Dockerfile:

wget http://dl.fedoraproject.org/pub/fedora/linux/releases/test/22_Beta/Docker/x86_64/Fedora-Docker-Base-22_Beta-20150415.x86_64.tar.xz
docker load -i Fedora-Docker-Base-22_Beta-20150415.x86_64.tar.xz
sudo docker build -t leksah/build .

Copy the resulting msi file out of the container (version number in the file name will match the one in the leksah.cabal file):

sudo docker run --rm --volume $HOME/output:/output leksah/build cp /leksah/win32/leksah-0.15.0.1-ghc-7.10.1.msi /output
Something went wrong with that request. Please try again.