You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

180 lines
6.9 KiB

Duktape
=======
[![Build Status](https://travis-ci.org/svaarala/duktape.svg?branch=master)](https://travis-ci.org/svaarala/duktape)
11 years ago
Introduction
------------
[Duktape](http://duktape.org/) is an **embeddable Javascript** engine,
with a focus on **portability** and **compact** footprint.
Duktape is easy to integrate into a C/C++ project: add `duktape.c`,
`duktape.h`, and `duk_config.h` to your build, and use the Duktape API
to call Ecmascript functions from C code and vice versa.
Main features:
* Embeddable, portable, compact
* Ecmascript E5/E5.1 compliant, with some semantics updated from ES6+
* Partial support for Ecmascript 2015 (E6) and Ecmascript 2016 (E7),
[Post-ES5 feature status](http://wiki.duktape.org/PostEs5Features.html)
* Khronos/ES6 TypedArray and Node.js Buffer bindings
* WHATWG Encoding API living standard
* Built-in debugger
* Built-in regular expression engine
* Built-in Unicode support
* Minimal platform dependencies
* Combined reference counting and mark-and-sweep garbage collection with finalization
* Custom features like co-routines
* Property virtualization using a subset of Ecmascript E6 Proxy object
* Bytecode dump/load for caching compiled functions
* Distributable includes an optional logging framework, CommonJS-based module
loading implementations, etc
* Liberal license
See [duktape.org](http://duktape.org/) for packaged end-user downloads
and documentation. The end user downloads are also available from the
[duktape-releases](https://github.com/svaarala/duktape-releases) repo
as both binaries and in unpacked form as git tags. Snapshot builds from
master are available in [duktape.org/snapshots](http://duktape.org/snapshots).
11 years ago
Have fun!
Support
-------
* Duktape Wiki: [wiki.duktape.org](http://wiki.duktape.org)
* User community Q&A: Stack Overflow [duktape](http://stackoverflow.com/questions/tagged/duktape) tag
* Bugs and feature requests: [GitHub issues](https://github.com/svaarala/duktape/issues)
* General discussion: IRC `#duktape` on `chat.freenode.net` ([webchat](https://webchat.freenode.net))
11 years ago
About this repository
---------------------
This repository is **intended for Duktape developers only**, and contains
Duktape internals: test cases, internal documentation, sources for the
duktape.org web site, etc.
Getting started: end user
-------------------------
When embedding Duktape in your application you should use the packaged source
distributables available from [duktape.org/download.html](http://duktape.org/download.html).
See [duktape.org/guide.html#gettingstarted](http://duktape.org/guide.html#gettingstarted)
for the basics.
11 years ago
Automatically generated bleeding edge snapshots from master are available at
[duktape.org/snapshots](http://duktape.org/snapshots).
11 years ago
The distributable `src/` directory contains a `duk_config.h` configuration
header and amalgamated sources for Duktape default configuration. Use
`python tools/configure.py` to create header and sources for customized
configuration options, see http://wiki.duktape.org/Configuring.html. For
example, to enable fastint support (example for Linux):
$ tar xvfJ duktape-2.0.0.tar.xz
$ cd duktape-2.0.0
$ rm -rf src-custom
$ python tools/configure.py \
--source-directory src-input \
--output-directory src-custom \
--config-metadata config \
-DDUK_USE_FASTINT
# src-custom/ will now contain: duktape.c, duktape.h, duk_config.h.
You can also clone this repository, make modifications, and build a source
distributable on Linux, OSX, and Windows using `python util/dist.py`.
Getting started: modifying and rebuilding the distributable
-----------------------------------------------------------
If you intend to change Duktape internals and want to rebuild the source
distributable in Linux, OSX, or Windows:
# Linux; can often install from packages or using 'pip'
$ sudo apt-get install python python-yaml
$ python util/dist.py
# OSX
# Install Python 2.7.x
$ pip install PyYAML
$ python util/dist.py
# Windows
; Install Python 2.7.x from python.org, and add it to PATH
> pip install PyYAML
> python util\dist.py
11 years ago
The source distributable directory will be in `dist/`.
11 years ago
For platform specific notes see http://wiki.duktape.org/DevelopmentSetup.html.
Getting started: other development (Linux only)
-----------------------------------------------
11 years ago
Other development stuff, such as building the website and running test cases,
is based on a `Makefile` **intended for Linux only**. See detailed
instructions in http://wiki.duktape.org/DevelopmentSetup.html.
Branch policy
-------------
* The `master` branch is used for active development. While pull requests
are tested before merging, master may be broken from time to time. When
development on a new major release starts, master will also get API
incompatible changes without warning. For these reasons **you should
generally not depend on the master branch** for building your project; use
a release tag or a release maintenance branch instead.
* Pull requests and their related branches are frequently rebased so you
should not fork off them. Pull requests may be open for a while for
testing and discussion.
* Release tags like `v1.4.1` are used for releases and match the released
distributables. These are stable once the release is complete.
* Maintenance branches are used for backporting fixes and features for
maintenance releases. Documentation changes go to master for maintenance
releases too. For example, `v1.5-maintenance` was created for the 1.5.0
release and is used for 1.5.x maintenance releases.
* A maintenance branch is also created for a major release when master moves
on to active development of the next major release. For example,
`v1-maintenance` was created when 1.5.0 was released (last planned 1.x
release) and development of 2.0.0 (with API incompatible changes) started
on master. The 1.6.0 and 1.7.0 releases were made from `v1-maintenance`
for example.
Versioning
----------
Duktape uses [Semantic Versioning](http://semver.org/).
Because Duktape tracks the latest Ecmascript specification versions,
compliance fixes are made in minor versions even when they are technically
not backwards compatible. See
[Versioning](http://duktape.org/guide.html#versioning) for details.
Reporting bugs
--------------
See [CONTRIBUTING.md](https://github.com/svaarala/duktape/blob/master/CONTRIBUTING.md).
Security critical Github issues (for example anything leading to a segfault)
are tagged `security`.
11 years ago
Contributing
------------
11 years ago
See [CONTRIBUTING.md](https://github.com/svaarala/duktape/blob/master/CONTRIBUTING.md).
11 years ago
Copyright and license
---------------------
11 years ago
See [AUTHORS.rst](https://github.com/svaarala/duktape/blob/master/AUTHORS.rst)
11 years ago
and [LICENSE.txt](https://github.com/svaarala/duktape/blob/master/LICENSE.txt).
[Duktape Wiki](https://github.com/svaarala/duktape-wiki/) is part of Duktape
documentation and under the same copyright and license.