Pico (programming language)
This article has multiple issues. Please help improve it or discuss these issues on the talk page. (Learn how and when to remove these messages)
|
| Pico | |
|---|---|
| Paradigms | Reflective, procedural |
| Family | Lisp |
| Designed by | Theo D'Hondt Wolfgang De Meuter |
| Developer | Vrije Universiteit Brussel |
| First appeared | 1995 |
| Stable release | 2.0
/ 2007 |
| Implementation language | Scheme |
| Platform | IA-32, x86-64 |
| OS | Mac OS 9, macOS; Linux–BSD, Windows |
| Website | pico |
| Influenced by | |
| Scheme, Smalltalk | |
Pico is a programming language developed at the Software Languages Lab at Vrije Universiteit Brussel, intended to be simple, powerful, extensible, and easy to read.[1] The language was created to introduce the essentials of programming to non-computer science students.
Pico can be seen as an effort to generate a palatable and enjoyable language for people who do not want to study hard for the elegance and power of a language. They have done it by adapting Scheme's semantics.
While designing Pico, the Software Languages Lab was inspired by the Abelson and Sussman's book "Structure and Interpretation of Computer Programs". Furthermore, they were influenced by the teaching of programming at high school or academic level.
Pico should be interpreted as 'small', the idea was to create a small language for educational purposes.
Language elements
[edit | edit source]De Meuter, Gonzalez, and D'Hondt describe the Pico syntax as being "two-tiered."[1] The first layer consists of simple rules for writing small programs in a functional programming style.
Comments
[edit | edit source]Comments are surrounded by backquotes ("`").
Variables
[edit | edit source]Variables are dynamically typed; Pico uses static scope.
var: value
Functions
[edit | edit source]Functions, like everything in Pico, are first-class objects, meaning they can be assigned to variables and passed to and returned from functions. Also, there are no anonymous functions in Pico; functions must have a name.[1] For example, a function, func, with two parameters, param1 and param2, can be defined as:
func(param1, param2): ...
Functions can be called with the following syntax:
func(arg1, arg2)
Operators
[edit | edit source]Operators can be used as prefix or infix in Pico:
+(5, 2) 5 + 2
Data types
[edit | edit source]Pico has the following types: string, integer, real and tables.
It does not have a native char type, so users should resort to size 1 strings.
Tables are compound data structures that may contain any of the regular data types.
Boolean types are represented by functions (as in lambda calculus).
Control structures
[edit | edit source]Conditional evaluation
[edit | edit source]Only the usual if statement is included
if(condition, then, else)
Code snippets
[edit | edit source]display('Hello World', eoln)
max(a, b): if(a < b, b, a)
`http://www.paulgraham.com/accgen.html`
foo(n): fun(i): n := n+i
Implementations
[edit | edit source]Mac OS, Mac OS X
[edit | edit source]Windows
[edit | edit source]- WinPico This version is buggy
- WinPico stable
Linux
[edit | edit source]Cross-platform
[edit | edit source]References
[edit | edit source]External links
[edit | edit source]- Lua error in Module:Official_website at line 94: attempt to index field 'wikibase' (a nil value).