JSPM

file-register

0.0.3
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 285
  • Score
    100M100P100Q87538F
  • License MIT

(Node.js) The way we organize code: break into files and folders and map to an object.

Package Exports

  • file-register

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 (file-register) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

File Register

(Node.js) The way we organize code: break into files and folders and map to an object.

Originally part of Carcass.

How to use

See test/example/index.js and test/example.mocha.js for more details.

For example say you have a group of files and directories looks like this:

example/
    index.js
    lib/
        utils.js
        models/
            User.js
            ...
        views/
            index.js
            ...
        ...

Quick usage

It exports a class, and you can get an instance:

var Register = require('file-register');
var example = new Register();

Assuming the code is in example/index.js:

var path = require('path');
example.register(path.resolve(__dirname, 'lib'));

Now you have everything in lib mapped to the example object.

example.should.have.property('utils');
example.should.have.property('models');
example.should.have.property('views');

For files, the key is the filename without the extension, and the value is what you can get with require(file) (i.e. whatever the file exports).

example.should.have.property('utils').with.type('object');
example.utils.should.have.property('lorem').with.type('function');

For directories, if require() can handle it (i.e. there's an index.js or package.json etc.), we use require().

example.should.have.property('views').with.type('string');

Otherwise the directory is mapped recursively.

example.should.have.property('models').with.type('object');
example.models.should.have.property('User').with.type('function');

Using the proto

TODO

API change from carcass.proto.register

TODO