Source

pure-lang / pure /

Filename Size Date modified Message
..
config
debian
etc
examples
lib
test
texmacs
34.3 KB
7.5 KB
3.1 KB
212.4 KB
49.2 KB
21.1 KB
68.9 KB
8.2 KB
2.4 KB
9.8 KB
14.8 KB
10.2 KB
24.6 KB
56.2 KB
2.0 KB
1.3 KB
541.4 KB
57.8 KB
116.3 KB
1.1 KB
21.7 KB
7.9 KB
25.9 KB
2.3 KB
34.5 KB
1.6 KB
6.5 KB
29.8 KB
1.3 KB
587.3 KB
1.8 KB
20.2 KB
776 B
2.1 KB
470.5 KB
76.7 KB
35.2 KB
16.0 KB
12.4 KB
37.9 KB
4.5 KB
53.3 KB
PURE - The Pure programming language.
==== = ==============================

Pure is a functional programming language based on term rewriting. It has a
modern syntax featuring curried function applications, lexical closures and
equational definitions with pattern matching, and thus is somewhat similar to
languages of the Haskell and ML variety. But Pure is also a very dynamic
language, and is more like Lisp in this respect. The interpreter has an LLVM
backend to do JIT compilation, hence programs run blazingly fast and
interfacing to C modules is easy.

WHERE TO GET IT
----- -- --- --

You can find tarballs, binary packages and the source repository at
http://purelang.bitbucket.org.

COPYING
-------

Unless explicitly stated otherwise, this software is Copyright (c) 2008-2013
by Albert Graef. Please see the source for the copyright and license notes
pertaining to individual source files.

Pure comes with a fairly liberal license which lets you distribute your own
Pure programs and extensions under a license of your choice and permits
linking of commercial applications against the Pure runtime and the Pure
standard library without requiring special permission. Moreover, the Pure
interpreter (the 'pure' main program), the Pure runtime library ('libpure')
and the Pure standard library (the Pure scripts in the 'lib' folder) are
distributed as free software, and you are welcome to modify and redistribute
them under the appropriate license terms, as detailed below.

(The above explanations are not legal advice. Please read the full text of the
licenses and consult qualified professional counsel for an interpretation of
the license terms as they apply to you.)

The *Pure interpreter* is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by the Free
Software Foundation, either version 3 of the License, or (at your option) any
later version.

The *Pure runtime library* and the *Pure standard library* are also free
software: you can redistribute them and/or modify them under the terms of the
GNU *Lesser* General Public License as published by the Free Software
Foundation, either version 3 of the License, or (at your option) any later
version.

Pure is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
A PARTICULAR PURPOSE.

Please see the accompanying COPYING and COPYING.LESSER files for the precise
license terms. Online copies of the GPL and LGPL are also available at
http://www.gnu.org/licenses/.

LINKING WITH GPLV2 SOFTWARE
------- ---- ----- --------

In addition to the above license conditions we also grant the special
permission to link code distributed under GPLv2 *only* (that is, version 2 of
the GNU General Public License without the "or later" clause) with the Pure
runtime library and the Pure standard library.

This is a temporary measure to enable interoperability with software which,
for whatever reason, is still distributed under the GPLv2 only (such as
Gnumeric), and may be revoked in future Pure releases when all relevant
software has migrated to GPLv3-compatible licenses.

NON-COPYLEFTED MATERIALS
-------------- ---------

The distribution also contains some non-copylefted sources which can be used
in both open source and commercial applications, usually under the terms of
the new (a.k.a. 3-clause) BSD license:

- pure_norl.cc is a version of the interpreter main program without readline
  support, which can be used as a starting point for alternate interpreter
  frontends.

- The sample programs in the examples subdirectory. (Please see the COPYING
  files in examples and its subdirectories for details.)

Please also check the corresponding source files for additional licensing
information and pertaining copyrights.

LLVM LICENSE
---- -------

Pure uses LLVM (http://llvm.org) as its compiler backend. LLVM is under
Copyright (c) 2003-2011 by the University of Illinois at Urbana-Champaign,
and is licensed under a 3-clause BSD-style license, please read COPYING.LLVM
included in the distribution for the exact licensing terms. You can also find
the LLVM license at http://llvm.org.

INSTALLATION
------------

Please see the INSTALL file for detailed instructions. On most Unix-like
systems, './configure --enable-release && make && sudo make install' should do
the trick. This requires GNU make and g++. For other setups, you'll probably
have to fiddle with the Makefile and the sources. You'll also need LLVM for
the compiler backend. LLVM 2.5 or later is required with recent Pure versions.
For your convenience, instructions for installing LLVM are also included in
the INSTALL file.

After installing the interpreter, you should also install the online
documentation to make the 'help' command work in the interpreter. If you have
a working internet connection and the 'wget' program, this can be done with
the command 'sudo make install-docs'. Again, please check the INSTALL file for
details.

USING PURE
----- ----

To start the Pure interpreter, just type 'pure' at the command prompt. You'll
be greeted with a sign-on message, after which the interpreter leaves you at
its prompt and you can start typing definitions and expressions to be
evaluated. Use the 'quit' command to exit the interpreter (on most systems you
can also just type EOF a.k.a. Ctrl-D at the beginning of the interpreter's
command line). For instance:

Pure 0.47 (x86_64-unknown-linux-gnu) Copyright (c) 2008-2011 by Albert Graef
(Type 'help' for help, 'help copying' for license information.)
Loaded prelude from /usr/local/lib/pure/prelude.pure.

> fact n = if n>0 then n*fact (n-1) else 1;
> map fact (1..10);
[1,2,6,24,120,720,5040,40320,362880,3628800]
> quit

Of course, you can also put your definitions into a script and run that script
from the command line:

$ pure -x factorial.pure

Add the -i option to force interactive mode when executing a script, and -q to
suppress the sign-on message:

$ pure -i -q -x factorial.pure
> 

Or you can compile your script to a native executable:

$ pure -c factorial.pure -o factorial
$ ./factorial

Pure scripts are just ordinary text files, which can be created with any text
editor. The distribution contains some language definition files and
programming modes to provide syntax highlighting in various popular text
editors, such as Emacs, Gedit, Kate and Vim. The Emacs mode also lets you run
the Pure interpreter in an Emacs buffer, this is probably the most convenient
interface to the interpreter if you're friends with Emacs. Syntax files for
Andre Simon's highlight program and the Pygments highlighter are also
included, these let you pretty-print Pure source in various output formats
such as HTML and LaTeX. You can find all this stuff in the etc subdirectory in
the source distribution, installation instructions are included in the syntax
files.

Online documentation is available in the form of a (brief) Unix manual page
and an extensive manual in html format which contains detailed information on
the Pure language, the interpreter, the standard library and all available
addon modules and libraries. You can invoke the manpage with 'man pure' after
installation, and the online manual by using the 'help' command inside the
interpreter. The former needs the 'man' program, the latter a html browser,
w3m by default. See the INSTALL file or the manpage for details. Or just point
your browser at the following URL to read the manual on the web:

http://puredocs.bitbucket.org/

Some example programs can be found in the examples subdir in the sources; in
particular, have a look at the hello.pure program which will quickly give you
an idea how Pure programs look like. You can also browse the scripts in the
lib directory, in particular prelude.pure and the modules included there,
which contain the "built-in" definitions readily available when you start up
the Pure interpreter.

Further documentation including a wiki is available at:
http://purelang.bitbucket.org

You're also invited to join the Pure mailing list at:
http://groups.google.com/group/pure-lang

Enjoy! :)


Albert Graef
Dept. of Computer Music
Johannes Gutenberg University of Mainz
Germany

<Dr.Graef at t-online.de>
http://purelang.bitbucket.org
http://groups.google.com/group/pure-lang
Tip: Filter by directory path e.g. /media app.js to search for public/media/app.js.
Tip: Use camelCasing e.g. ProjME to search for ProjectModifiedEvent.java.
Tip: Filter by extension type e.g. /repo .js to search for all .js files in the /repo directory.
Tip: Separate your search with spaces e.g. /ssh pom.xml to search for src/ssh/pom.xml.
Tip: Use ↑ and ↓ arrow keys to navigate and return to view the file.
Tip: You can also navigate files with Ctrl+j (next) and Ctrl+k (previous) and view the file with Ctrl+o.
Tip: You can also navigate files with Alt+j (next) and Alt+k (previous) and view the file with Alt+o.