Package Exports
- ember-cli/lib/cli
- ember-cli/lib/commands/build
- ember-cli/lib/commands/init
- ember-cli/lib/ext/promise
- ember-cli/lib/ui
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (ember-cli) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
ember-cli
a ember commandline utility.
Warning
Although potentially exciting, this is still really a WIP, use at your own risk.
Why?
The https://github.com/stefanpenner/ember-app-kit project has proved to be quite useful, we have learned lots, and it allowed us to iterate quickly while building real ambitious applications.
While it's initial incarnation is useful, it has several meta problems:
- It is not "simple" and appears daunting.
- Because of inline configuration, the api surface area is massive
- #2 does not allow users to express the "what" just the "how", this prevents EAK from doing more of the heavy lifting itself.
- [#2 #3] makes it quite tedious to upgrade
Rational for #3
If we want to upgrade or swap in a faster build pipeline it would be a major pain currently. But with #3, in theory it should be minimal pain.
Guidelines
- convention over configuration. (look to rails)- we should provide internal configuration/implementation to satisfy the 'what' with the how.
 
- simple > easy
- the current contents of tasks/* should reside in the ember executables library
- the pipeline-related Broccoli configuration should also reside in the above mentioned library.
Usage
Install
This is an npm package and can be used locally by installing it globally
npm install -gCurrent Commands
ember build <env-name>
ember server
ember init [app-name] [--dry-run] [--skip-npm-install]Ideas
- excutable (this project)
ember
ember init  <app-name>
ember build <env-name> [default: development] [optional: target path]
ember server
  --autotest   [default: false]
  --port       [default: 8000]
  --subscribe  [default:release, optional: (beta|canary)] 
                 # on "start" of an app, it will prompt the user if the channel they
                 # subscribe to has an update.
                 # if an update occured. they are asked [yes, no] to try the update (using bower)
                 #   (what about other libs? ember-data or components or..)
  --env        [default: development] # allow previewing the various build envs.
  --app        [default: .]
ember generate [...]
ember generate scaffold [...] # for resources
    
ember addon # reserved for future use.- folder structure: (very similar to what we currently have)
app/*            # like EAK today
tasks/           # custom user tasks
vendor/          # mostly for bower, some non-bower stuff will reside.
tests/           # tests test config and test helpers.
tmp/*            # created on demand, but scratch pad for EAK.
Broccolifile.js  # should contain a mechanism for default ember tasks to be loaded
                 # should be the place for users to define custom broccoli related things.
package.json
bower.json
.gitignore
.travis
.jshintrc- configurationserver.js # for adding additional connect middleware (like a proxy to the backend) Broccolifile # default tasks will exist in "ember" tasks/ # custom user tasks 
- detect .js, .coffee, .styl, .scss, .sass
and use the appropriate filter, or throw with useful error.
e.g: 
new Error("tried compiling: app.coffee but CoffesScript is Missing, to install please: npm install coffee-script --save-dev")
     ````
- tasks consider extracting them into broccoli-ember