Aucune description

Laurent Laffont 5f10b714eb fix JSObjectProxy>>doesNotUnderstand: that failed if access an attribute that returns empty string il y a 13 ans
bin 38991a46c0 fixed previous commit il y a 13 ans
css cd7a1e1308 Removed JQuery binding! Now Canvas calls JQuery directly. Everything seems to be working fine, but I may have broken a few things in the IDE il y a 13 ans
examples 6cdb154a47 Fixed presentation example il y a 13 ans
ide d3cf306cca Ripped out ide.html from homepage, feel free to clean it or delete it Nicolas. il y a 13 ans
images 9884f8d8af New welcome page il y a 13 ans
js 5f10b714eb fix JSObjectProxy>>doesNotUnderstand: that failed if access an attribute that returns empty string il y a 13 ans
server 05613c2535 More amberification and a recompile of FileServer.st. il y a 13 ans
st 5f10b714eb fix JSObjectProxy>>doesNotUnderstand: that failed if access an attribute that returns empty string il y a 13 ans
.gitignore 9ba4c5cb98 sync with amber/master + ignore .svn dirs il y a 13 ans
CHANGELOG 82a21206f7 changelog file il y a 13 ans
LICENSE 1af622cf99 Starting renaming jtalk to amber il y a 13 ans
README.md 4880fd28ca More renaming il y a 13 ans
index.html 04d9eb3956 link to the getting started page on the wiki il y a 13 ans

README.md

Amber

By Nicolas Petton petton.nicolas@gmail.com

Amber is an implementation of the Smalltalk language that runs on top of the JavaScript runtime. It is designed to make client-side development faster and easier.

Overview

Amber is written in itself, including the parser and compiler. Amber compiles into efficient JavaScript, mapping one-to-one with the equivalent JavaScript. There is no interpretation at runtime.

Some highlights:

  • Amber features an IDE with a Class browser, Workspace, Transcript, a ReferencesBrowser supporting senders/implementors and class references, basic Inspector and even a beginning of a Debugger and a unit TestRunner.
  • Pharo Smalltalk is considered as the reference implementation.
  • Amber includes a canvas to generate HTML, like Seaside
  • Amber can use Javascript libraries and the current IDE is built on jQuery
  • You can inline Javascript code and there are many ways to interact between Amber and Javascript

How to commit changes from the web-based IDE

The Amber class browser is able to commit changes to disk. The "commit category" button will send a PUT request with the JS code of all classes in the selected class category in a file named js/CATEGORY.js and also send the corresponding .st files to the st directory.

The easiest way to enable committing is probably to use the nodejs server or to setup a webdav with Apache.

To start the local server:

./bin/server

then go to http://localhost:4000

The following steps explain how to setup a webdav for Amber with Debian, but the setup on OSX and other Linux distros should be similar.

Install Apache and enable the dav module

apt-get install apache2
a2enmod dav
a2enmod dav_fs

Create a password for the webdav

htpasswd -c /etc/apache2/htpasswd-webdav USERNAME

Setup the webdav for Amber

Add the following lines to the default vhost (in /etc/apache2/sites-available/default):

Alias /amber/ "/path/to/amber/"
    <Directory "/path/to/amber/">
        Options Indexes MultiViews FollowSymLinks
    DirectoryIndex index.html
    AllowOverride None
        Order allow,deny
    allow from all

    Dav on

    AuthType Basic
        AuthName "amber"
        AuthUserFile /etc/apache2/htpasswd-webdav
    <LimitExcept GET OPTIONS>
            Require valid-user
    </LimitExcept>

    </Directory>

Make sure the group www-data has required rights to modify files in the webdav directory.

Restart Apache

/etc/init.d/apache2 restart

License

Amber is released under the MIT license. All contributions made for inclusion are considered to be under MIT.

More infos

More on the project page