NAME

Module::Build::JSAN::Installable - Build JavaScript distributions for JSAN, which can be installed locally

SYNOPSIS

In Build.PL:

use Module::Build::JSAN::Installable;

my $build = Module::Build::JSAN::Installable->new(
    module_name    => 'Foo.Bar',
    license        => 'perl',
    keywords       => [qw(Foo Bar pithyness)],
    requires     => {
        'JSAN'     => 0.10,
        'Baz.Quux' => 0.02,
    },
    build_requires => {
        'Test.Simple' => 0.20,
    },
    
    static_dir => 'assets'
);

$build->create_build_script;

To build, test and install a distribution:

% perl Build.PL
% ./Build
% ./Build test  
% ./Build install

In Components.js:

  COMPONENTS = {
      
      "kernel" : [
          "JooseX.Namespace.Depended.Manager",
          "JooseX.Namespace.Depended.Resource",
          
          "JooseX.Namespace.Depended.Materialize.Code"
      ],
      
      
      "web" : [
          "+kernel",
      
          "JooseX.Namespace.Depended.Transport.AjaxAsync",
          "JooseX.Namespace.Depended.Transport.AjaxSync",
          "JooseX.Namespace.Depended.Transport.ScriptTag",
          
          "JooseX.Namespace.Depended.Resource.URL",
          "JooseX.Namespace.Depended.Resource.URL.JS",
          "JooseX.Namespace.Depended.Resource.JS",
          "JooseX.Namespace.Depended.Resource.JS.External",
          
          //should be the last        
          "JooseX.Namespace.Depended"
      ],
  	
      
      "core" : [
          "+web"
      ],
      
      
      "serverjs" : [
          "+kernel",
          
          "JooseX.Namespace.Depended.Transport.Require",
          "JooseX.Namespace.Depended.Resource.Require",
          
          //should be the last
          "JooseX.Namespace.Depended"
      ]
  	
  } 
	

VERSION

Version 0.01

DESCRIPTION

This is a developer aid for creating JSAN distributions. JSAN is the "JavaScript Archive Network," a JavaScript library akin to CPAN. Visit http://www.openjsan.org/ for details.

This module works nearly identically to Module::Build::JSAN, so please refer to its documentation for additional details.

DIFFERENCES

1 ./Build install

This action will install current distribution in your local JSAN library. The path to the library is resolved in the following order:

- --install_base command-line argument

- environment variable JSAN_LIB

- Either the first directory in $Config{libspath}, followed with '/jsan' (probably '/usr/local/lib' on linux systems) or 'C:\JSAN' (on Windows)

As a convention, it is recommended, that you configure your local web-server that way, that /jsan will point at the /lib subdirectory of your local JSAN library. This way you can access any module from it, with URLs like: '/jsan/Test/Run.js'

1 ./Build task [--task_name=foo]

This action will build a specific concatenated version (task) of current distribution. Default task name is 'core', task name can be specified with --task_name command line option.

Information about tasks is stored in the Components.JS file in the root of distribution. See the Synposys for example of Components.JS.

After concatenation, resulting file is placed on the following path: /lib/Task/Distribution/Name/sample_task.js, considering the name of your distribution was Distribution::Name and the task name was sample_task

1 ./Build test

This action relies on not yet release JSAN::Prove module, stay tuned for further updates.

Static files handling

Under static files we'll assume any files other than javascript (*.js). Typically those are *.css files and images (*.jpg, *.gif, *.png etc).

All static files should be placed in the 'static directory'. Default name for static directory is '/static'. Alternative name can be specified with static_dir configuration parameter (see Synopsis). Static directory can be organized in any way you prefere.

Lets assume you have the following distribution structure:

/lib/Distribution/Name.js
/static/css/style1.css 
/static/img/image1.png

After building (./Build) it will be processed as:

/blib/lib/Distribution/Name.js
/blib/lib/Distribution/Name/static/css/style1.css 
/blib/lib/Distribution/Name/static/img/image1.png

During installation (./Build install) the whole 'blib' tree along with static files will be installed in your local library.

AUTHOR

Nickolay Platonov, <nplatonov at cpan.org>

BUGS

Please report any bugs or feature requests to bug-module-build-jsan-installable at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Module-Build-JSAN-Installable. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

SEE ALSO

Examples of installable JSAN distributions

http://github.com/SamuraiJack/JooseX-Namespace-Depended/tree

http://github.com/SamuraiJack/joosex-bridge-ext/tree

http://www.openjsan.org/

Home of the JavaScript Archive Network.

http://code.google.com/p/joose-js/

Joose - Moose for JavaScript

http://github.com/SamuraiJack/test.run/tree

Yet another testing platform for JavaScript

SUPPORT

You can find documentation for this module with the perldoc command.

perldoc Module::Build::JSAN::Installable

You can also look for information at:

ACKNOWLEDGEMENTS

Thanks to David Wheeler for his excelent Module::Build::JSAN, on top of which this module is built.

COPYRIGHT & LICENSE

Copyright 2009 Nickolay Platonov, all rights reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.