This repository contains files needed to run Lite XL in the browser. Lite XL includes a shell file that does the job pretty well, but the aim here is to improve the experience more by making it actually useful.
This repository is still a work-in-progress, so detailed instructions on how to set up everything is not available.
In general, you will need the following tools:
- Emscripten (optionally emsdk) 3.1.57 to 3.1.70. Older versions will not work.
- file_packager (Installed with Emscripten if emsdk is used)
- A HTTP Server (I use
darkhttpd
, but Python'shttp.server
and npmhttp-server
will work) - Git
- Bash (MSYS2 might work but not tested)
- Python
The specific dependencies may be mentioned in the Dockerfile.
You can find specific documentation in each subfolder.
By default, running bash scripts/gh-pages-deploy.sh
will generate DWARF debug info
if the CI
environment variable is not set.
To use the debug info, you must install the C/C++ DevTools Support (DWARF)
extension from the Chrome Web Store.
After installation, you must configure path substitution to allow your browser to find your source directory correctly.
To do this, right click on the extension icon → Options.
Click on "Add module settings", and enter lite-xl.wasm
as the module name.
Click on "Add path substitution" and enter /build-wasm32-emscripten
on the left
and your source folder (e.g. /home/user/lite-xl-playground
) on the right.
After doing this, the debug information should be usable, including stack traces, source maps and single-stepping. You may need to restart your browser (sometimes several times) for it to work properly.
You may also need to remove your previous build directory (build-wasm32-emscripten
)
to allow meson to reconfigure properly.
Original README
A lightweight text editor written in Lua, adapted from lite.
- Get Lite XL — Download for Windows, Linux and Mac OS.
- Get plugins — Add additional functionality, adapted for Lite XL.
- Get color themes — Add additional colors themes.
Please refer to our website for the user and developer documentation, including build instructions details. A quick build guide is described below.
Lite XL has support for high DPI display on Windows and Linux and, since 1.16.7 release, it supports retina displays on macOS.
Please note that Lite XL is compatible with lite for most plugins and all color themes. We provide a separate lite-xl-plugins repository for Lite XL, because in some cases some adaptations may be needed to make them work better with Lite XL. The repository with modified plugins is https://github.com/lite-xl/lite-xl-plugins.
The changes and differences between Lite XL and rxi/lite are listed in the changelog.
Lite XL is derived from lite. It is a lightweight text editor written mostly in Lua — it aims to provide something practical, pretty, small and fast easy to modify and extend, or to use without doing either.
The aim of Lite XL compared to lite is to be more user friendly, improve the quality of font rendering, and reduce CPU usage.
Additional functionality can be added through plugins which are available in the plugins repository or in the Lite XL plugins repository.
Additional color themes can be found in the colors repository. These color themes are bundled with all releases of Lite XL by default.
If you compile Lite XL yourself, it is recommended to use the script
build-packages.sh
:
bash build-packages.sh -h
The script will run Meson and create a tar compressed archive with the application or, for Windows, a zip file. Lite XL can be easily installed by unpacking the archive in any directory of your choice.
Otherwise the following is an example of basic commands if you want to customize the build:
meson setup --buildtype=release --prefix <prefix> build
meson compile -C build
DESTDIR="$(pwd)/lite-xl" meson install --skip-subprojects -C build
where <prefix>
might be one of /
, /usr
or /opt
, the default is /
.
To build a bundle application on macOS:
meson setup --buildtype=release --Dbundle=true --prefix / build
meson compile -C build
DESTDIR="$(pwd)/Lite XL.app" meson install --skip-subprojects -C build
Please note that the package is relocatable to any prefix and the option prefix affects only the place where the application is actually installed.
Head over to releases and download the version for your operating system.
The prebuilt releases supports the following OSes:
- Windows 7 and above
- Ubuntu 18.04 and above (glibc 2.27 and above)
- OS X El Capitan and above (version 10.11 and above)
Some distributions may provide custom binaries for their platforms.
Lite XL comes with installers on Windows for typical installations. Alternatively, we provide ZIP archives that you can download and extract anywhere and run directly.
To make Lite XL portable (e.g. running Lite XL from a thumb drive),
simply create a user
folder where lite-xl.exe
is located.
Lite XL will load and store all your configurations and plugins in the folder.
We provide DMG files for macOS. Simply drag the program into your Applications folder.
Important Newer versions of Lite XL are signed with a self-signed certificate, so you'll have to follow these steps when running Lite XL for the first time.
- Find Lite XL in Finder (do not open it in Launchpad).
- Control-click Lite XL, then choose
Open
from the shortcut menu.- Click
Open
in the popup menu.The correct steps may vary between macOS versions, so you should refer to the macOS User Guide.
On an older version of Lite XL, you will need to run these commands instead:
# clears attributes from the directory xattr -cr /Applications/Lite\ XL.appOtherwise, macOS will display a very misleading error saying that the application is damaged.
Unzip the file and cd
into the lite-xl
directory:
tar -xzf <file>
cd lite-xl
To run lite-xl without installing:
./lite-xl
To install lite-xl copy files over into appropriate directories:
rm -rf $HOME/.local/share/lite-xl $HOME/.local/bin/lite-xl
mkdir -p $HOME/.local/bin && cp lite-xl $HOME/.local/bin/
mkdir -p $HOME/.local/share/lite-xl && cp -r data/* $HOME/.local/share/lite-xl/
To run Lite XL from the command line, you must add it to PATH.
If $HOME/.local/bin
is not in PATH:
echo -e 'export PATH=$PATH:$HOME/.local/bin' >> $HOME/.bashrc
Alternatively on recent versions of GNOME and KDE Plasma,
you can add $HOME/.local/bin
to PATH via ~/.config/environment.d/envvars.conf
:
PATH=$HOME/.local/bin:$PATH
Note Some systems might not load
.bashrc
when logging in. This can cause problems with launching applications from the desktop / menu.
To get the icon to show up in app launcher, you need to create a desktop
entry and put it into /usr/share/applications
or ~/.local/share/applications
.
Here is an example for a desktop entry in ~/.local/share/applications/com.lite_xl.LiteXL.desktop
,
assuming Lite XL is in PATH:
[Desktop Entry]
Type=Application
Name=Lite XL
Comment=A lightweight text editor written in Lua
Exec=lite-xl %F
Icon=lite-xl
Terminal=false
StartupWMClass=lite-xl
Categories=Development;IDE;
MimeType=text/plain;inode/directory;
To get the icon to show up in app launcher immediately, run:
xdg-desktop-menu forceupdate
Alternatively, you may log out and log in again.
To uninstall Lite XL, run:
rm -f $HOME/.local/bin/lite-xl
rm -rf $HOME/.local/share/icons/hicolor/scalable/apps/lite-xl.svg \
$HOME/.local/share/applications/com.lite_xl.LiteXL.desktop \
$HOME/.local/share/metainfo/com.lite_xl.LiteXL.appdata.xml \
$HOME/.local/share/lite-xl
Any additional functionality that can be added through a plugin should be done as a plugin, after which a pull request to the Lite XL plugins repository can be made.
Pull requests to improve or modify the editor itself are welcome.
This project is free software; you can redistribute it and/or modify it under the terms of the MIT license. See LICENSE for details.
See the licenses file for details on licenses used by the required dependencies.