Kalker (or "kalk") is a calculator program/website that supports user-defined variables, functions, derivation, and integration. It runs on Windows, macOS, Linux, Android, and in web browsers (with WebAssembly).

Crates.io npm GitHub Docs.rs Build status

Kanban | Website - Try it out here!

Features

Installation

Package managers

macOS

brew install kalker

Arch Linux

kalker in the AUR, eg. yay -S kalker

Nix/NixOS

Kalker is available through nixpkgs. The most up to date version is also available as a flake.

NetBSD

Kalker is available from the official repositories, pkgin install kalker

Binaries

Pre-compiled binaries for Linux, Windows, and macOS (64-bit) are available in the releases page.

Compiling

Minimum rust version: v1.36.0. Make sure you have diffutils gcc make and m4 installed. If you use windows: follow the instructions here (don't forget to install mingw-w64-x86_64-rust in MSYS2).

Cargo

Run cargo install kalker

Manually

  1. Go into the cli directory.
  2. Run cargo build --release
  3. Grab the binary from targets/release

Donation

Kalker is completely free and open source. If you wish to support further development of Kalker and contribute towards it one day getting published on the Google Play Store, you can do so here: PayPal

Libraries

There are currently three different libraries related to kalker.

Syntax

A more complete reference can be found on the website.

Functions

Defining: name(parameter1, parameter2, ...) = expression\ Example: $ f(x) = 2x+3 $

Using: name(argument1, argument2)\ Example: $ f(2) $

Variables

Defining: name = expression\ Example: $ x = 3 $

Using: name\ Example: $ x $

Contributing

kalk and cli (Rust)

After making changes to the kalk library (in kalk/), you can easily try them out by going to the root of the project directory, and doing cargo run. This will start kalker (cli), with the new changes. If you're using Windows, you will need to follow the instructions here, but also make sure to install mingw-w64-x86_64-rust in MSYS2.

All Rust code is expected to be formatted with `rustfmt

web (Svelte, TypeScript, Sass)

Run: 1. npm install
2. npm run dev - this will automatically re-compile the project when changes are made

mobile (Android)

Run:
1. npm install 2. npx cap sync 3. Build the project using Android Studio, or Gradle directly.