Rahul Sharma (Editor)

PicoLisp

Updated on
Edit
Like
Comment
Share on FacebookTweet on TwitterShare on LinkedInShare on Reddit
Designed by
  
Alexander Burger

Typing discipline
  
duck, dynamic, strong

First appeared
  
1988

Platform
  
POSIX

Paradigm
  
functional, procedural, object-oriented, declarative, reflective, meta

Stable release
  
16.12 / December 8, 2016; 3 months ago (2016-12-08)

PicoLisp is an open source Lisp dialect. It runs on Linux and other POSIX-compliant systems.

Contents

Features

Its most prominent features are simplicity and minimalism. It is built on top of a single internal data type (cell), without giving up flexibility and expressive power. On the language level the programmer can use three different data types (numbers, symbols and lists) being represented by cells and differentiated by bits at the end of the cell.

Because the only non-atomic data type is the linked list, many interoperable functions exist that concentrate on list processing. As a result, PicoLisp programs are often more succinct - and at the same time faster - than those of other interpreted languages (see examples from Rosetta Code). Functions are free from the restrictions that would be imposed by a compiler, and can so accept arbitrary types and numbers of arguments. Macros are needed only in rare cases and are implemented using the quote function. PicoLisp breaks a tradition by dropping the lambda function seen in many other Lisps, like Common Lisp and Emacs Lisp. This is caused by the fact that the quote function is changed to return all its arguments unevaluated, not only the car of the first. This results in a more readable syntax, less run-time and no necessity to have a lambda function.

A special feature is the intrinsic CRUD functionality. Persistent symbols are first-class objects, they are loaded from database files automatically when accessed, and written back when modified. Applications are written using a class hierarchy of entities and relations. Additional features include: Prolog engine and database queries, distributed databases, inlining of C language functions and native C function calls, child process management, interprocess communication, browser GUI, and internationalization.

History

Originally developed on the Apple Macintosh in the 1980s, and used in commercial application development since then. It was soon ported to MS-DOS and SCO Unix, and used mainly on Linux since 1993. Database functionality was added in the mid-1990s.

While the first versions were written in a mix of C and assembly language, a first rewrite from scratch was done in 1999 completely in C. That version was released 2002 under the GNU GPL license, and changed to a MIT/X11 license in 2010.

In 2009 the 64-bit version was released, another rewrite, this time written in a generic assembler which in turn is implemented in PicoLisp. This version adds support for coroutines.

A Java version called "Ersatz Picolisp" was released in December 2010.

In September 2014, Burger announced the PilMCU project on the PicoLisp development listserv, an effort with George Orais to implement PicoLisp directly in hardware in a spirit reminiscent of Lisp Machines.

References

PicoLisp Wikipedia