Skip to content
/ uiua Public
forked from uiua-lang/uiua

A stack-based array programming language

License

Notifications You must be signed in to change notification settings

MJJoyce/uiua

 
 

Repository files navigation

Uiua

Uiua (pronounced "wee-wuh") is a stack-based array programming language.

Documentation, examples, and an online interpreter can be found at uiua.org.

You can also check out the Discord server.

You can support Uiua's development via GitHub Sponsors.

Installation

You can try the language without installing anything on the website.

If you want to install the interpreter locally there are 2 options:

  • If you are on Windows, you can simply download the latest release.

  • If you are not on Windows, you will need to install via Cargo. This requires Rust to be installed.

    You can install with:

    cargo install uiua
    

    To enable audio output, enable the audio feature:

    cargo install uiua --features audio
    

    If you want audio on Linux, you may need to install some dependencies first:

    apt install libasound2-dev libudev-dev pkg-config
    

Language Server

The interpreter has a built-in language server that implements the Language Server Protocol.

A language client extension is available for VSCode here.

The language client requires that the interpreter is installed locally and available on your PATH.

Formatter Configuration

You can configure Uiua's formatter by creating a file called .fmt.ua in the directory from which you run the interpreter. This configuration file is also a Uiua program.

Configuration options are specified by binding values to specific names.

Example with default values:

TrailingNewline ← 1
CommentSpaceAfterHash ← 1
MultilineIndent ← 2
CompactMultilineMode ← "auto"
AlignComments ← 1

The following configuration options are available:

TrailingNewline

Type: boolean

Default: 1

Whether to add a trailing newline to a file.

CommentSpaceAfterHash

Type: boolean

Default: 1

Whether to insert a space after a # in a comment if there is not one already.

MultilineIndent

Type: natural number

Default: 2

The number of spaces to indent each line of a multiline expression.

CompactMultilineMode

Type: one of "always", "never", or "auto"

Default: "auto"

How to format multiline expressions.

  • "always": Always format multiline expressions in compact mode.
  • "never": Never format multiline expressions in compact mode.
  • "auto": Format multiline expressions in compact mode if they exceed MultilineCompactThreshold.

MultilineCompactThreshold

Type: natural number

Default: 10

The maximum a columns a multiline expression can start on before it stops being formatted in compact mode.

Only used if CompactMultilineMode is "auto".

AlignComments

Type: boolean

Default: 1

Whether to align consecutive end-of-line comments.

About

A stack-based array programming language

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 98.1%
  • CSS 1.3%
  • Other 0.6%