SOURCE CODE: UizeSite.Build.FileBuilders.ModuleSourceCodePages (view docs)

/*______________
|       ______  |   U I Z E    J A V A S C R I P T    F R A M E W O R K
|     /      /  |   ---------------------------------------------------
|    /    O /   |    MODULE : UizeSite.Build.FileBuilders.ModuleSourceCodePages Package
|   /    / /    |
|  /    / /  /| |    ONLINE : http://uize.com
| /____/ /__/_| | COPYRIGHT : (c)2012-2016 UIZE
|          /___ |   LICENSE : Available under MIT License or GNU General Public License
|_______________|             http://uize.com/license.html
*/

/* Module Meta Data
  type: Package
  importance: 5
  codeCompleteness: 100
  docCompleteness: 100
*/

/*?
  Introduction
    The =UizeSite.Build.FileBuilders.ModuleSourceCodePages= module defines a file builder for the module source code pages of the UIZE Web site.

    *DEVELOPERS:* `Chris van Rensburg`

    Functions defined in the file builder are called as instance methods on an instance of a subclass of the =Uize.Services.FileBuilderAdapter= class, so the functions can access instance methods implemented in this class.
*/

Uize.module ({
  name:'UizeSite.Build.FileBuilders.ModuleSourceCodePages',
  required:[
    'Uize.Url',
    'UizeSite.Build.Util'
  ],
  builder:function () {
    'use strict';

    var
      _modulesSourceCodePagesPath = '/reference/source-code/',
      _jsExtension = '.js',
      _jsJstExtension = '.js.jst',
      _cssSourceExtension = '.csst'
    ;

    return Uize.package ({
      description:'Module source code pages',
      urlMatcher:function (_urlParts) {
        return (
          _urlParts.fileType == 'html' &&
          _urlParts.folderPath == this.builtUrl (_modulesSourceCodePagesPath)
        );
      },
      builderInputs:function (_urlParts) {
        var
          m = this,
          _moduleUrl = m.getModuleUrl (_urlParts.fileName,false),
          _sourcePathSansExtension = m.sourceUrl (_moduleUrl)
        ;
        return {
          sourceCode:
            m.fileExists ({path:_sourcePathSansExtension + _jsJstExtension})
              ? _sourcePathSansExtension + _jsJstExtension
              : m.fileExists ({path:_sourcePathSansExtension + _cssSourceExtension})
                ? _sourcePathSansExtension + _cssSourceExtension
                : m.tempUrl (_moduleUrl) + _jsExtension
          ,
          sourceCodeTemplate:this.memoryUrl (_modulesSourceCodePagesPath + '~SOURCE-CODE-TEMPLATE.html.jst')
        };
      },
      builder:function (_inputs,_urlParts) {
        var
          _sourceCode = _inputs.sourceCode,
          _params = this.params
        ;
        return this.readFile ({path:_inputs.sourceCodeTemplate}) ({
          moduleName:_urlParts.fileName,
          body:this.readFile ({path:_sourceCode})
        });
      }
    });
  }
});