Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/dalehenrich/amber-skeleton

A template project for creating your own Amber-based projects.
https://github.com/dalehenrich/amber-skeleton

Last synced: 2 months ago
JSON representation

A template project for creating your own Amber-based projects.

Awesome Lists containing this project

README

        

#Amber Skeleton

**Amber Skeleton** is a template project for creating your own [Amber-based][1] projects.

## Features

### Link to Amber using `git submodule`

By using `git submodules` to link to Amber,
you no longer need to [fork and include the entire Amber source tree][2] as
part of your own project.

See [Working with submodules][3] and [Git Submodules: Adding, Using, Removing, Updating][4] for more information about using submodules.

### Easily load code from other Amber-based projects

You can use `git submodules` to link to other Amber projects and then
arrange to load the code from that project by including the following
expression in the `ready: option` of the `loadAmber()` function in your `index.html` file:

```javascript
smalltalk.AmberProjectImporter._importStPackages_prefix_(
[
'ExternalProjectPackage',
],
'/projects/externalProject/');
```

The above expression will load the code form the `/projects/externalProject/st` directory. If you want to load the development `'.js` code use the following:

```javascript
smalltalk.AmberProjectImporter._importJsPackages_prefix_(
[
'ExternalProjectPackage',
],
'/projects/externalProject/');
```

and for deployment (i.e., loading the `.deploy.js` files:

```javascript
smalltalk.AmberProjectImporter._importDeployJsPackages_prefix_(
[
'ExternalProjectPackage',
],
'/projects/externalProject/');
```

When you use **AmberProjectImporter** to import your code,
**AmberProjectExporter** will
automatically commit your code to the same directories (`js` and `st`) from which you loaded
the code.

### Share code with other Smalltalk dialects

If you install the [Cypress package][5] support (included by default)
and register your package as a **cypress** package:

```Smalltalk
AmberProjectExporter
registerPackage: 'MyPackageName'
type: 'cypress'
prefix: 'packages/'
```

You package will be stored in the [Cypress package][5] format which is
understood by a number of Smalltalk dialects ([Pharo][6], [Squeak][7], [GemStone][8],
[Amber][9], and [VW][10] as of this writing. A VAST port is in the works).

If you want to load code from another Smalltalk dialect that was saved
in [Cypress package][5] format, execute the following code in a
workspace:

```Smalltalk
CypressAmberImporter
importCypressPackages: #('ForeignPackageName')
prefix: 'path to directory containing ForiegnPackageName.package'
```

*As of this writing, I haven't done any experiments loading code from
other dialects - Amber is the first `non-Monticello` dialect I've worked
with), so I'll be interested in your results:).*

## Examples

This project is a perfect example. In particular look at the `index.html` file for examples of loading code using the **AmberProjectImporter** class.

## Installation

To start working with your own **Amber Skeleton** project:

1. [Fork the Amber Skeleton][11] project.
2. [Rename the forked project][12] to the name you want the project to
have. *Note that you might want to have a personal fork of the
Amber Skeleton project so you can customize the project for your
own needs.*
3. Clone your project to your local machine.
4. Change the commit reference for the `git submodules` (i.e., remove
and add the submodule references). It is easier
to this immediately after cloning. See [Git Submodules: Adding,
Using, Removing, Updating][4] for more information about using
submodules.
5. `init and update` the `git submodules:

```shell
git submodule init
git submodule update
```

6. Build your Amber File server. See the README in the `server/pharo` directory.

## Known Issues

Right now there is only one issue of note:

* [Slow initial load][13]

## Laurent Laffont's Amber 0.9.1 OneClick

The bulk of the work for the Amber File Server is based on the [Amber 0.9.1 OneClick][15] done
by [Laurent Laffont][14].

## Project Dependencies

**Amber projects**:

* [Amber][16]
* [amber-cypress][17]

**Pharo projects**:

* [Cypress][18]
* [Pharo][21]
* [amber-server][19]
* [Filetree][20]

[1]: https://github.com/NicolasPetton/amber
[2]: https://github.com/NicolasPetton/amber/wiki/Writing-my-first-app
[3]: http://help.github.com/submodules/
[4]: http://chrisjean.com/2009/04/20/git-submodules-adding-using-removing-and-updating/
[5]: https://github.com/CampSmalltalk/Cypress
[6]: https://github.com/dalehenrich/filetree/tree/pharo1.3
[7]: https://github.com/dalehenrich/filetree/tree/squeak4.3
[8]: https://github.com/dalehenrich/filetree/tree/gemstone2.4
[9]: https://github.com/dalehenrich/amber-skeleton
[10]: https://github.com/CampSmalltalk/STIG
[11]: https://github.com/dalehenrich/amber-skeleton/fork_select
[12]: https://github.com/blog/128-let-there-be-renaming
[13]: https://github.com/dalehenrich/amber-skeleton/issues/1
[14]: https://github.com/lolgzs
[15]: http://forum.world.st/ANN-Amber-0-9-1-OneClick-td4378569.html
[16]: https://github.com/NicolasPetton/amber
[17]: https://github.com/CampSmalltalk/amber-cypress

[18]: https://github.com/CampSmalltalk/Cypress
[19]: https://github.com/dalehenrich/amber-server
[20]: https://github.com/dalehenrich/filetree
[21]: http://www.pharo-project.org/home