Skip to content

pixeldroid/loomtasks

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 

Repository files navigation

loom tasks

Rake tasks for working with loomlibs


overview

loomlibs are linkable LoomScript code libraries used to expand features of the Loom SDK.

If you use Rake and follow a consistent file layout across projects, these tasks can simplify the steps of setting up, building, installing, testing, demo-ing, documenting, and releasing loom libraries (*.loomlib).

The tasks install into your .loom directory, and can be loaded from there into the Rakefiles of your projects.

See more details for the list of tasks provided.

installation

requires Rake

Clone this repo.

  1. Run rake install to:
    • create a tasks folder in your Loom SDK home directory (~/.loom)
    • install the Rake tasks from this project into it.
  2. Run rake uninstall to:
    • delete the tasks folder.
    • Note: this deletes the whole folder! So be careful if you decide to put your own tasks in there.

usage

First, scaffold a new project structure:

  • rake -f ~/.loom/tasks/scaffolding.rake new:loomlib
  • rake docs:install_template

Then, enter your development cycle:

  1. Run test to see the auto-created library be built, the test harness run, and the first test fail:
    • rake test
  2. Add new code and improved tests (in lib/src/, and test/src/)
  3. Add new documentation (in docs/), and regenerate before commits back to GitHub:
    • rake docs

more details

Running rake in your project directory will execute the default task, which prints the list of available tasks and a short description of what they do:

$ rake
Foo v1.2.3 Rakefile running on Ruby 2.5.1
rake clean               # removes intermediate files to ensure a clean build
rake cli[options]        # shorthand for 'rake cli:run'
rake cli:build           # builds cli/bin/FooDemoCLI.loom for sprint34 SDK
rake cli:install[b,p]    # installs an executable copy of cli/bin/FooDemoCLI.loom on the system
rake cli:run[options]    # executes cli/bin/FooDemoCLI.loom as a commandline app, with options, if provided
rake cli:sdk[id]         # sets the provided SDK version into cli/loom.config
rake cli:uninstall[b,p]  # uninstalls the system executable 'foo'
rake clobber             # removes all generated artifacts to restore project to checkout-like state
rake docs                # builds and serves the documentation site
rake docs:build_site     # calls jekyll to [just] generate the docs site
rake docs:gen_api        # creates api docs compatible with the programming pages template
rake docs:serve_site     # calls jekyll to serve the docs site, without first building it
rake docs:watch_site     # calls jekyll to watch the docs and rebuild the site when files are changed
rake gui                 # shorthand for 'rake gui:run'
rake gui:build           # builds gui/bin/FooDemoGUI.loom for sprint34 SDK
rake gui:run             # launches gui/bin/FooDemoGUI.loom as a GUI app
rake gui:sdk[id]         # sets the provided SDK version into gui/loom.config
rake help                # shows usage and project info, optionally for a specific command
rake lib:build           # builds Foo.loomlib for sprint34 SDK
rake lib:install         # installs Foo.loomlib into sprint34 SDK
rake lib:release         # prepares sdk-specific Foo.loomlib for release, and updates version in README
rake lib:sdk[id]         # sets the provided SDK version into lib/loom.config
rake lib:show            # lists libs installed for sprint34 SDK
rake lib:uninstall       # removes Foo.loomlib from sprint34 SDK
rake lib:version[v]      # sets the library version number into lib/src/Foo.build and lib/src/Foo.ls
rake list_sdks           # lists loom sdk versions available use
rake sdk[id]             # sets the provided SDK version in the config files of lib, cli, gui, and test
rake test                # shorthand for 'rake test:run'
rake test:build          # builds test/bin/FooTest.loom against sprint34 SDK
rake test:ci             # runs test/bin/FooTest.loom for CI
rake test:run[seed]      # runs test/bin/FooTest.loom for the console
rake test:sdk[id]        # sets the provided SDK version into test/loom.config
rake version             # reports loomlib version
(using loomtasks 3.3.0)
(using lsdoc 2.1.0)

If you are looking for more detail on any of the tasks, use rake help, e.g. rake help test.

The Programming Pages theme is not packaged with loomtasks releases; it is leveraged via the remote_theme plugin for Jekyll. This is compatible with Github Pages.

The Rake tasks are defined with dependencies and modification triggers, so you can just run rake test every time you edit a source file, and the library and test app will be rebuilt as needed automatically.

conventions

The loomlib rake tasks make the following assumptions about the layout of a project.

If there are portions of the scaffold that you are not interested in using (i.e. cli, gui), just delete those folders, and the corresponding rake tasks will not be loaded.

directory structure

foo-loomlib $
├─cli/
├─docs/
├─Gemfile
├─gui/
├─lib/
├─Rakefile
└─test/
  • library source is under lib/
  • source for a CLI demo is under cli/; the CLI demo app will consume the library and illustrate its use from the command line
  • documentation source is under docs/; lsdoc is the supported API doc generation tool
  • the project uses a Gemfile for building and serving documentation locally with Jekyll and the Github Pages gem
  • source for a GUI demo is under gui/; the GUI demo app will consume the library and illustrate its use via a graphical user interface
  • the project uses a Rakefile for building, testing, and preparing releases
  • library test source is under test/; spec-ls is the supported testing framework

documentation

Support for docs tasks comes from loomlib_doc.rake. Use of lsdoc is assumed.

docs/ contains configuration and source files to be converted into documentation. The documentation is not packaged with the loomlib; it is generated into a site from docs/ directory by GitHub pages. Note that this requires an option be set for the source code repository (see Publishing from a docs/ folder).

└─docs
  ├─_api/
  ├─_config.yml
  ├─_data/
  ├─_includes/
  ├─_layouts/
  ├─examples/
  ├─guides/
  └─index.md
  • project level configuration for jekyll and the site theme is defined in docs/_config.yml
  • the documentation home page is written in markdown as docs/index.md
  • (optional) example pages are written under docs/examples/; they will have their own tab in the generated docs site
  • (optional) guide pages are written under docs/guides/; they will have their own tab in the generated docs site
  • lsdoc provides some files under docs/_data/, docs/_includes/, and docs/_layouts/ to facilitate documentation generation. Use of Programming Pages is assumed

demos

Support for CLI demo tasks comes from loomlib_cli.rake.

cli/ contains a command line demonstration app.

└─cli
  ├─bin
  │ └─Main.loom
  ├─loom.config
  └─src
    ├─FooDemoCLI.ls
    └─FooDemoCLI.build
  • the cli demo application is built into, and executed from cli/bin/
  • the cli demo has its own loom config file at cli/loom.config
  • the cli demo has its own loom build file at cli/src/FooDemoCLI.build
  • the cli demo source code is under cli/src/

Support for GUI demo tasks comes from loomlib_gui.rake.

gui/ contains a functional graphical demonstration app.

└─gui
  ├─assets/
  ├─bin
  │ └─Main.loom
  ├─loom.config
  └─src
    ├─FooDemoGUI.ls
    └─FooDemoGUI.build
  • the gui demo assets are under gui/assets/
  • the gui demo application is built into, and run from gui/bin/
  • the gui demo has its own loom config file at gui/loom.config
  • the gui demo has its own loom build file at gui/src/FooDemoGUI.build
  • the gui demo source code is under gui/src/

lib

Support for library tasks comes from loomlib_lib.rake.

lib/ contains the library code, which will be packaged into a .loomlib file for installation into a Loom SDK.

└─lib
  ├─build
  │ └─Foo.loomlib
  ├─loom.config
  └─src
    ├─Foo.build
    └─com
      └─bar
        └─Foo.ls
  • the loomlib is built into lib/build/
  • the library has its own loom config file at lib/loom.config
  • the library has its own loom build file at lib/src/Foo.build
  • library source code is under lib/src/
version

Some file under lib/ contains the following line (where 1.2.3 is the version of your library):

public static const version:String = '1.2.3';

This provides runtime access to the library version, and is also used in the name of the loomlib built for release (compatible with a corresponding GitHub release).

test

Support for test tasks comes from loomlib_test.rake. Use of spec-ls is assumed.

test/ contains unit tests of the library code. The tests are not packaged with the loomlib; they are run from a separate test runner app.

└─test
  ├─bin
  │ └─Main.loom
  ├─loom.config
  └─src
    ├─app
    │ └─FooTest.ls
    ├─spec
    │ └─FooSpec.ls
    └─FooTest.build
  • the test application is built into, and run from test/bin/
  • the tests have their own loom config file at test/loom.config
  • the tests have their own loom build file at test/src/FooTest.build
  • the test application source code is under test/src/app/
  • the specification source code is under test/src/spec/

contributing

Pull requests are welcome!