PicoLisp

PicoLisp
Paradigm functional, procedural, object-oriented, declarative, reflective, meta
Designed by Alexander Burger
First appeared 1988
Stable release
16.6 / June 29, 2016 (2016-06-29)
Typing discipline duck, dynamic, strong
Platform POSIX
License MIT, X11
Filename extensions .l
Website picolisp.com

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

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.[1]

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[2]). 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.[3]

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.[4]

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.[5]

External links

References

  1. Burger, Alexander. "Internal structures". http://software-lab.de. External link in |website= (help)
  2. "Category:PicoLisp Rosetta Code". http://rosettacode.org. External link in |website= (help)
  3. "Even small details make a difference!".
  4. Burger, Alexander (8 May 2013). "Ersatz PicoLisp". http://software-lab.de. External link in |website= (help)
  5. "Announce: PicoLisp in Hardware".
This article is issued from Wikipedia - version of the 6/29/2016. The text is available under the Creative Commons Attribution/Share Alike but additional terms may apply for the media files.