Skip to content
A statically typed lisp, without a GC, for real-time applications.
Haskell C Emacs Lisp Other
Branch: master
Clone or download
Type Name Latest commit message Commit time
Failed to load latest commit information.
app Bump to version 0.3.0. Jul 4, 2019
bench multiple fixes: Feb 15, 2019
core Merge branch 'string-join-ref' of in… Sep 17, 2019
docs Merge branch 'string-join-ref' of in… Sep 17, 2019
emacs Improved emacs mode. Mar 8, 2018
examples More functional event handler in SDLApp. Sep 13, 2019
headerparse headerparse: fix for comments after decl May 29, 2019
img Remove two unused images. Mar 14, 2018
out dirs: readded keep dir Dec 12, 2017
resources MP3 works! Mar 23, 2018
src Merge pull request #550 from jacereda/typos Sep 11, 2019
test-for-errors compiler: catch double definitions; fixes #320 May 20, 2019
test Regression test for nested lambdas (issue 342) Sep 18, 2019
.gitignore compiler: use library directory and enforce @ Jul 17, 2018
.travis.yml Travis: Switching to older infrastructure to work around… May 20, 2018
CarpHask.cabal Bump to version 0.3.0. Jul 4, 2019
LICENSE new license Aug 23, 2016
LUA_LICENSE lau license: fix referenced file Jan 14, 2019 Add myself to contributors Sep 7, 2019
Setup.hs REPLACE WITH HASKELL VERSION Jun 26, 2017 A script for running all benchmarks. Feb 6, 2018 loc: add headerparse Oct 4, 2018 Ensure intermediate directory if not exists. Feb 19, 2018 Fix script Sep 17, 2019
stack.yaml Even more fixes Mar 5, 2019


Join the chat at


WARNING! This is a research project and a lot of information here might become outdated and misleading without any explanation. Don't use it for anything important just yet!

Version 0.3.0 of the language is out!


Carp is a small programming language designed to work well for interactive and performance sensitive use cases like games, sound synthesis and visualizations.

The key features of Carp are the following:

  • Automatic and deterministic memory management (no garbage collector or VM)
  • Inferred static types for great speed and reliability
  • Ownership tracking enables a functional programming style while still using mutation of cache-friendly data structures under the hood
  • No hidden performance penalties – allocation and copying are explicit
  • Straightforward integration with existing C code

Learn more

The Carp REPL has built-in documentation, run (help) to access it!

A Very Small Example

(load-and-use SDL)

(defn tick [state]
  (+ state 10))

(defn draw [app rend state]
  (bg rend &(rgb (/ @state 2) (/ @state 3) (/ @state 4))))

(defn main []
  (let [app (SDLApp.create "The Minimalistic Color Generator" 400 300)
        state 0]
    ( &app SDLApp.quit-on-esc tick draw state)))

To build this example, save it to a file called 'example.carp' and load it with (load "example.carp"), then execute (build) to build an executable, and (run) to start. The external dependencies are SDL2 and pkg-config.

Language Designer & Lead Developer

Erik Svedäng (@e_svedang)

Core Contributor

Veit Heller (@hellerve)


  • Markus Gustavsson
  • Fyodor Shchukin
  • Anes Lihovac
  • Chris Hall
  • Tom Smeding
  • Dan Connolly
  • Reini Urban
  • Jonas Granquist
  • Joel Kaasinen (@opqdonut)
  • Eric Shimizu Karbstein (@GrayJack)
  • Jorge Acereda (@jacereda)

Are you missing from the contributors list? Please send a pull request!


Copyright 2016 - 2019 Erik Svedäng

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

The regular expression implementation as found in src/carp_regex.h are Copyright (C) 1994-2017, PUC-Rio under the terms of the MIT license. Details can be found in the License file LUA_LICENSE.

You can’t perform that action at this time.