https://github.com/aitoroses/atscript_di_playground
This is a fork that embeds a build of di@2.0 dependency injection framework from **vojtajina** inside AtScript playground
https://github.com/aitoroses/atscript_di_playground
Last synced: 9 months ago
JSON representation
This is a fork that embeds a build of di@2.0 dependency injection framework from **vojtajina** inside AtScript playground
- Host: GitHub
- URL: https://github.com/aitoroses/atscript_di_playground
- Owner: aitoroses
- Created: 2014-11-12T14:02:11.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2014-11-12T14:03:14.000Z (over 11 years ago)
- Last Synced: 2025-03-01T08:30:39.068Z (over 1 year ago)
- Language: JavaScript
- Size: 137 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
## Fork
This is a fork that embeds a build of di@2.0 dependency injection framework from **vojtajina** inside AtScript playground
## AtScript Playground
This is an empty repo to make it easy to experiment with [AtScript].
### Initial setup
```bash
# Clone the repo...
git clone https://github.com/vojtajina/atscript-playground.git
cd atscript-playground
# Then, you need to install all the dependencies...
npm install
# If you want to be able to use global commands `karma` and `gulp`...
npm install -g karma-cli gulp
```
### The minimal example
Our example consists of two files:
* `atscript-playground/src/something.ats` defines a simple class that returns the sum of two input values
* `atscript-playground/src/main.ats` imports that class and prints a message to the console
### Running the example in the browser
To run in the browser, you need to first build the project. This creates a `build/` directory that contains the transpiled `*.js` files that are created from your AtScript project.
```bash
# Do initial build, start a webserver and re-build on every file change...
gulp build serve watch
```
Open a browser and look in the console log to see the result.
### Running the tests
The tests are in `atscript-playground/test/something_spec.ats`. Run them using Karma, like so:
```bash
karma start
```
Karma opens a browser window for running tests. To see the actual test output (and errors), look for the log in the terminal window where you issued the `karma start` command.
### What are all the pieces involved?
#### [Traceur]
Transpiles AtScript code into regular ES5 (today's JavaScript) so that it can be run in a current browser.
#### [RequireJS]
Traceur is configured to transpile AtScript modules into AMD syntax and we use RequireJS to load the code in the browser.
#### [Assert] library
When `typeAssertions: true` option is used, Traceur generates run-time type assertions such as `assert.type(x, Object)`. The assert library does the actual run-time check. Of course, you can use your own assert library.
The idea with type assertions is that you only use them during the development/testing and when deploying, you use `typeAssertions: false`.
#### [Karma]
Test runner that runs the tests in specified browsers, every time that you change a file.
#### [Gulp]
Task runner to make defining and running the tasks simpler.
[AtScript]: http://atscript.org
[Traceur]: https://github.com/google/traceur-compiler
[RequireJS]: http://requirejs.org
[Assert]: https://github.com/angular/assert
[Karma]: http://karma-runner.github.io/
[Gulp]: http://gulpjs.com