summaryrefslogtreecommitdiff
path: root/node_modules/utile/README.md
diff options
context:
space:
mode:
authorMinteck <contact@minteck.org>2021-12-21 16:50:49 +0100
committerMinteck <contact@minteck.org>2021-12-21 16:50:49 +0100
commit20204baf1807825af4798ad03bfb329e4da05bc5 (patch)
tree1568515fa1e4592206ed5d2327b39e6b443cbd03 /node_modules/utile/README.md
downloadbingoloto-remote-20204baf1807825af4798ad03bfb329e4da05bc5.tar.gz
bingoloto-remote-20204baf1807825af4798ad03bfb329e4da05bc5.tar.bz2
bingoloto-remote-20204baf1807825af4798ad03bfb329e4da05bc5.zip
Commit
Diffstat (limited to 'node_modules/utile/README.md')
-rw-r--r--node_modules/utile/README.md87
1 files changed, 87 insertions, 0 deletions
diff --git a/node_modules/utile/README.md b/node_modules/utile/README.md
new file mode 100644
index 0000000..58dfde4
--- /dev/null
+++ b/node_modules/utile/README.md
@@ -0,0 +1,87 @@
+# utile [![Build Status](https://secure.travis-ci.org/flatiron/utile.png)](http://travis-ci.org/flatiron/utile)
+
+A drop-in replacement for `util` with some additional advantageous functions
+
+## Motivation
+Javascript is definitely a "batteries not included language" when compared to languages like Ruby or Python. Node.js has a simple utility library which exposes some basic (but important) functionality:
+
+```
+$ node
+> var util = require('util');
+> util.
+(...)
+
+util.debug util.error util.exec util.inherits util.inspect
+util.log util.p util.print util.pump util.puts
+```
+
+When one considers their own utility library, why ever bother requiring `util` again? That is the approach taken by this module. To compare:
+
+```
+$ node
+> var utile = require('./lib')
+> utile.
+(...)
+
+utile.async utile.capitalize utile.clone utile.cpr utile.createPath utile.debug
+utile.each utile.error utile.exec utile.file utile.filter utile.find
+utile.inherits utile.log utile.mixin utile.mkdirp utile.p utile.path
+utile.print utile.pump utile.puts utile.randomString utile.requireDir uile.requireDirLazy
+utile.rimraf
+```
+
+As you can see all of the original methods from `util` are there, but there are several new methods specific to `utile`. A note about implementation: _no node.js native modules are modified by utile, it simply copies those methods._
+
+## Methods
+The `utile` modules exposes some simple utility methods:
+
+* `.each(obj, iterator)`: Iterate over the keys of an object.
+* `.mixin(target [source0, source1, ...])`: Copies enumerable properties from `source0 ... sourceN` onto `target` and returns the resulting object.
+* `.clone(obj)`: Shallow clones the specified object.
+* `.capitalize(str)`: Capitalizes the specified `str`.
+* `.randomString(length)`: randomString returns a pseudo-random ASCII string (subset) the return value is a string of length ⌈bits/6⌉ of characters from the base64 alphabet.
+* `.filter(obj, test)`: return an object with the properties that `test` returns true on.
+* `.args(arguments)`: Converts function arguments into actual array with special `callback`, `cb`, `array`, and `last` properties. Also supports *optional* argument contracts. See [the example](https://github.com/flatiron/utile/blob/master/examples/utile-args.js) for more details.
+* `.requireDir(directory)`: Requires all files and directories from `directory`, returning an object with keys being filenames (without trailing `.js`) and respective values being return values of `require(filename)`.
+* `.requireDirLazy(directory)`: Lazily requires all files and directories from `directory`, returning an object with keys being filenames (without trailing `.js`) and respective values (getters) being return values of `require(filename)`.
+* `.format([string] text, [array] formats, [array] replacements)`: Replace `formats` in `text` with `replacements`. This will fall back to the original `util.format` command if it is called improperly.
+
+## Packaged Dependencies
+In addition to the methods that are built-in, utile includes a number of commonly used dependencies to reduce the number of includes in your package.json. These modules _are not eagerly loaded to be respectful of startup time,_ but instead are lazy-loaded getters on the `utile` object
+
+* `.async`: [Async utilities for node and the browser][0]
+* `.inflect`: [Customizable inflections for node.js][6]
+* `.mkdirp`: [Recursively mkdir, like mkdir -p, but in node.js][1]
+* `.rimraf`: [A rm -rf util for nodejs][2]
+* `.cpr`: [Asynchronous recursive file copying with Node.js][3]
+
+## Installation
+
+### Installing npm (node package manager)
+```
+ curl http://npmjs.org/install.sh | sh
+```
+
+### Installing utile
+```
+ [sudo] npm install utile
+```
+
+## Tests
+All tests are written with [vows][4] and should be run with [npm][5]:
+
+``` bash
+ $ npm test
+```
+
+#### Author: [Charlie Robbins](http://github.com/indexzero)
+#### Contributors: [Dominic Tarr](http://github.com/dominictarr), [Marak Squires](https://github.com/marak)
+#### License: MIT
+
+[0]: https://github.com/caolan/async
+[1]: https://github.com/substack/node-mkdirp
+[2]: https://github.com/isaacs/rimraf
+[3]: https://github.com/avianflu/ncp
+[4]: https://vowsjs.org
+[5]: https://npmjs.org
+[6]: https://github.com/pksunkara/inflect