Installation

How to install and update Lume

As Lume is run by Deno, read the Deno installation instructions if you don't have it installed yet.

Setup Lume

To setup Lume in your project folder, run the following command:

deno run -Ar https://deno.land/x/lume/init.ts

This command creates the following files:

  • _config.ts or _config.js: The Lume configuration file, where you can customize the site build.
  • deno.json: The Deno's configuration file. It includes the import map and some tasks to run Lume. You can also configure other features of Deno like TypeScript, formatter, linter, etc.

Here is an example of these two configuration files:

import lume from "lume/mod.ts";

const site = lume();

export default site;

Now you can use Deno's tasks to run Lume in any environment. The command deno task lume runs Lume and you can add additional arguments. For example deno task lume -s runs Lume, open a local web server and start watching the changes.

The tasks build (to build the website) and serve (to build and start a local server) are just shortcuts to the main lume task with additional arguments.

Run deno task lume -h to see the instructions.

Setup Lume CLI on your computer

Lume uses Deno task to work, you need to type always deno task lume [...args], which is a bit verbose. To avoid typing deno task all the time, you can install the Lume CLI script with:

deno install --allow-run --name lume --force --reload https://deno.land/x/lume_cli/mod.ts

This creates the lume command:

  • lume init will run the command deno run -Ar https://deno.land/x/lume/init.ts to initialize Lume in the current directory.
  • lume upgrade-cli will upgrade the Lume CLI script to the latest version.
  • Any other command will be delegated to deno task lume [...args]. For example, lume -s will run deno task lume -s.

Update Lume

The task deno task lume upgrade (or lume upgrade on Lume CLI) upgrades the Lume version used in your project folder to the latest version.

Use the argument --dev to ugrade to the latest development version (the last commit in the Github repository). It's useful to test new features of Lume not yet released.

Vendoring

If you want to download all remote dependencies of Deno in a local folder, you can use the DENO_DIR environment variable. For example, edit the lume task to define this variable:

{
  "importMap": "import_map.json",
  "tasks": {
    "lume": "DENO_DIR=_vendor echo \"import 'lume/cli.ts'\" | deno run --unstable -A -",
    "build": "deno task lume",
    "serve": "deno task lume -s"
  }
}

Now, when you run any Lume task, all Deno dependencies will be downloaded into the _vendor folder.

Visual Studio Code configuration

If you use Visual Studio Code, it's highly recommended to install the Deno extension.

There are other extensions that you may want to install, depending on the template engine you want to use. For example Nunjucks, Liquid, Eta, postcss, etc.

WebStorm configuration

There's a Deno plugin for WebStorm that you can install if you use this IDE.