sproutit-narwhal 0.1.106
Sign up to get free protection for your applications and to get access to all the features.
- data/DISTRIBUTION.yml +15 -0
- data/README.md +86 -0
- data/Rakefile +349 -0
- data/VERSION.yml +7 -0
- data/bin/activate +50 -0
- data/bin/activate.bash +50 -0
- data/bin/activate.cmd +3 -0
- data/bin/js +67 -0
- data/bin/json +2 -0
- data/bin/narwhal +67 -0
- data/bin/narwhal.cmd +29 -0
- data/bin/sea +45 -0
- data/bin/sea.cmd +25 -0
- data/bin/tusk +2 -0
- data/bin/tusk.cmd +5 -0
- data/catalog.json +902 -0
- data/docs/available-packages.md +32 -0
- data/docs/browser-api-plan.md +290 -0
- data/docs/browser-api.md +153 -0
- data/docs/download.md +25 -0
- data/docs/engines.md +32 -0
- data/docs/json-tool.md +121 -0
- data/docs/lib/binary.wiki +242 -0
- data/docs/lib/file.wiki +325 -0
- data/docs/lib/os/popen.md +70 -0
- data/docs/modules.md +38 -0
- data/docs/narwhal.md +487 -0
- data/docs/packages-howto.md +32 -0
- data/docs/packages.md +30 -0
- data/docs/posts/2009-07-29-hello-0.1.md +19 -0
- data/docs/quick-start.md +69 -0
- data/docs/sea.md +49 -0
- data/engines/browser/lib/binary.js +2 -0
- data/engines/browser/lib/reactor.js +21 -0
- data/engines/browser/lib/system.js +3 -0
- data/engines/default/lib/array.js +164 -0
- data/engines/default/lib/binary-engine.js +53 -0
- data/engines/default/lib/binary.js +755 -0
- data/engines/default/lib/date.js +8 -0
- data/engines/default/lib/file-engine.js +119 -0
- data/engines/default/lib/function.js +119 -0
- data/engines/default/lib/global.js +11 -0
- data/engines/default/lib/io-engine.js +26 -0
- data/engines/default/lib/json.js +488 -0
- data/engines/default/lib/object.js +69 -0
- data/engines/default/lib/os-engine.js +3 -0
- data/engines/default/lib/reactor.js +12 -0
- data/engines/default/lib/string.js +84 -0
- data/engines/default/lib/system.js +20 -0
- data/engines/default/lib/worker.js +133 -0
- data/engines/jsc/README.md +18 -0
- data/engines/jsc/bootstrap.js +53 -0
- data/engines/jsc/deps/http-parser/LICENSE +77 -0
- data/engines/jsc/deps/http-parser/README.md +145 -0
- data/engines/jsc/deps/http-parser/http_parser.c +6087 -0
- data/engines/jsc/deps/http-parser/http_parser.h +141 -0
- data/engines/jsc/deps/http-parser/http_parser.rl +500 -0
- data/engines/jsc/deps/http-parser/test.c +858 -0
- data/engines/jsc/include/binary-engine.h +11 -0
- data/engines/jsc/include/io-engine.h +23 -0
- data/engines/jsc/include/narwhal.h +427 -0
- data/engines/jsc/lib/file-engine.js +31 -0
- data/engines/jsc/lib/http.js +1 -0
- data/engines/jsc/lib/io-engine.js +202 -0
- data/engines/jsc/lib/os-engine.js +25 -0
- data/engines/jsc/lib/system.js +18 -0
- data/engines/jsc/lib/zip.js +1 -0
- data/engines/jsc/narwhal-jsc.c +273 -0
- data/engines/jsc/narwhal.c +29 -0
- data/engines/jsc/package.json +8 -0
- data/engines/jsc/src/binary-engine.cc +290 -0
- data/engines/jsc/src/file-engine.cc +405 -0
- data/engines/jsc/src/io-engine.cc +423 -0
- data/engines/jsc/src/jack/handler/jill.cc +710 -0
- data/engines/jsc/src/os-engine.cc +210 -0
- data/engines/rhino/bin/narwhal-rhino +68 -0
- data/engines/rhino/bin/narwhal-rhino.cmd +34 -0
- data/engines/rhino/bootstrap.js +119 -0
- data/engines/rhino/jars/jline.jar +0 -0
- data/engines/rhino/jars/jna.jar +0 -0
- data/engines/rhino/jars/js.jar +0 -0
- data/engines/rhino/lib/binary-engine.js +83 -0
- data/engines/rhino/lib/concurrency.js +6 -0
- data/engines/rhino/lib/event-queue.js +18 -0
- data/engines/rhino/lib/file-engine.js +216 -0
- data/engines/rhino/lib/http-client-engine.js +90 -0
- data/engines/rhino/lib/http-engine.js +10 -0
- data/engines/rhino/lib/io-engine.js +347 -0
- data/engines/rhino/lib/md5-engine.js +40 -0
- data/engines/rhino/lib/os-engine.js +150 -0
- data/engines/rhino/lib/packages-engine.js +71 -0
- data/engines/rhino/lib/sandbox-engine.js +70 -0
- data/engines/rhino/lib/system.js +38 -0
- data/engines/rhino/lib/worker-engine.js +23 -0
- data/engines/rhino/lib/zip.js +78 -0
- data/engines/rhino/package.json +4 -0
- data/engines/secure/lib/file.js +6 -0
- data/engines/secure/lib/system.js +6 -0
- data/engines/template/bin/narwhal-engine-name +32 -0
- data/engines/template/bootstrap.js +40 -0
- data/engines/template/lib/file-engine.js +118 -0
- data/engines/template/lib/system.js +17 -0
- data/examples/browser-deployment-jackconfig.js +35 -0
- data/examples/fibonacci-worker.js +35 -0
- data/examples/fibonacci.js +19 -0
- data/examples/hello +2 -0
- data/examples/narwhal +3 -0
- data/examples/not-quite-a-quine.js +1 -0
- data/extconf.rb +44 -0
- data/gem_bin/narwhal +5 -0
- data/gem_bin/sea +4 -0
- data/gem_bin/tusk +4 -0
- data/lib/args.js +849 -0
- data/lib/base16.js +16 -0
- data/lib/base64.js +120 -0
- data/lib/codec/base64.js +8 -0
- data/lib/crc32.js +60 -0
- data/lib/file-bootstrap.js +187 -0
- data/lib/file.js +659 -0
- data/lib/hash.js +28 -0
- data/lib/hashp.js +65 -0
- data/lib/html.js +16 -0
- data/lib/http-client.js +134 -0
- data/lib/http.js +17 -0
- data/lib/io.js +98 -0
- data/lib/jsmin.js +315 -0
- data/lib/jsonpath.js +89 -0
- data/lib/logger.js +55 -0
- data/lib/md4.js +146 -0
- data/lib/md5.js +164 -0
- data/lib/mime.js +166 -0
- data/lib/narwhal.js +102 -0
- data/lib/narwhal/client.js +261 -0
- data/lib/narwhal/compile.js +99 -0
- data/lib/narwhal/env.js +140 -0
- data/lib/narwhal/inline.js +106 -0
- data/lib/narwhal/json.js +324 -0
- data/lib/narwhal/json.md +178 -0
- data/lib/narwhal/repl.js +96 -0
- data/lib/narwhal/server-test.js +6 -0
- data/lib/narwhal/server.js +270 -0
- data/lib/narwhal/tusk.js +170 -0
- data/lib/narwhal/tusk/bin.js +13 -0
- data/lib/narwhal/tusk/bundle.js +0 -0
- data/lib/narwhal/tusk/catalog.js +22 -0
- data/lib/narwhal/tusk/clone.js +66 -0
- data/lib/narwhal/tusk/consolidate.js +25 -0
- data/lib/narwhal/tusk/create-catalog.js +80 -0
- data/lib/narwhal/tusk/engine.js +42 -0
- data/lib/narwhal/tusk/freeze.js +0 -0
- data/lib/narwhal/tusk/init.js +56 -0
- data/lib/narwhal/tusk/install.js +288 -0
- data/lib/narwhal/tusk/list.js +20 -0
- data/lib/narwhal/tusk/orphans.js +0 -0
- data/lib/narwhal/tusk/reheat.js +15 -0
- data/lib/narwhal/tusk/remove.js +15 -0
- data/lib/narwhal/tusk/search.js +145 -0
- data/lib/narwhal/tusk/update.js +21 -0
- data/lib/narwhal/tusk/upgrade.js +0 -0
- data/lib/os.js +33 -0
- data/lib/packages.js +423 -0
- data/lib/printf.js +169 -0
- data/lib/promise.js +352 -0
- data/lib/querystring.js +176 -0
- data/lib/ref-send.js +257 -0
- data/lib/regexp.js +12 -0
- data/lib/sandbox.js +422 -0
- data/lib/sha.js +112 -0
- data/lib/sha256.js +102 -0
- data/lib/struct.js +228 -0
- data/lib/term.js +179 -0
- data/lib/test/assert.js +95 -0
- data/lib/test/equiv.js +188 -0
- data/lib/test/jsdump.js +165 -0
- data/lib/test/runner.js +129 -0
- data/lib/unload.js +13 -0
- data/lib/uri.js +378 -0
- data/lib/url.js +5 -0
- data/lib/utf8.js +64 -0
- data/lib/util.js +985 -0
- data/lib/uuid.js +89 -0
- data/lib/xregexp.js +521 -0
- data/local.json.template +1 -0
- data/narwhal.gemspec +105 -0
- data/narwhal.js +213 -0
- data/package.json +26 -0
- data/packages/readline/engines/default/lib/readline.js +4 -0
- data/packages/readline/engines/rhino/lib/readline.js +6 -0
- data/packages/readline/package.json +5 -0
- data/sources.json +207 -0
- data/tests/all-tests.js +17 -0
- data/tests/args.js +31 -0
- data/tests/args/domain.js +215 -0
- data/tests/args/options.js +36 -0
- data/tests/args/shifting.js +92 -0
- data/tests/args/validation.js +31 -0
- data/tests/base64.js +23 -0
- data/tests/commonjs.js +3 -0
- data/tests/commonjs/all-tests.js +12 -0
- data/tests/commonjs/bytearray-encodings-tests.js +69 -0
- data/tests/commonjs/bytearray-tests.js +465 -0
- data/tests/commonjs/bytestring-encodings-tests.js +89 -0
- data/tests/commonjs/bytestring-tests.js +263 -0
- data/tests/commonjs/es5/all-tests.js +3 -0
- data/tests/commonjs/es5/bind.js +29 -0
- data/tests/commonjs/file-tests.js +315 -0
- data/tests/commonjs/file/dirname.js +31 -0
- data/tests/commonjs/file/extension.js +45 -0
- data/tests/commonjs/file/is-absolute.js +11 -0
- data/tests/commonjs/file/iterator.js +101 -0
- data/tests/commonjs/file/normal.js +27 -0
- data/tests/commonjs/file/path.js +17 -0
- data/tests/commonjs/file/relative.js +42 -0
- data/tests/commonjs/file/resolve.js +44 -0
- data/tests/commonjs/module-tests.js +9 -0
- data/tests/commonjs/modules/absolute/b.js +1 -0
- data/tests/commonjs/modules/absolute/program.js +5 -0
- data/tests/commonjs/modules/absolute/submodule/a.js +3 -0
- data/tests/commonjs/modules/absolute/test.js +9 -0
- data/tests/commonjs/modules/all-tests.js +47 -0
- data/tests/commonjs/modules/config.js +11 -0
- data/tests/commonjs/modules/cyclic/a.js +4 -0
- data/tests/commonjs/modules/cyclic/b.js +4 -0
- data/tests/commonjs/modules/cyclic/program.js +10 -0
- data/tests/commonjs/modules/cyclic/test.js +9 -0
- data/tests/commonjs/modules/determinism/program.js +3 -0
- data/tests/commonjs/modules/determinism/submodule/a.js +8 -0
- data/tests/commonjs/modules/determinism/submodule/b.js +2 -0
- data/tests/commonjs/modules/determinism/test.js +9 -0
- data/tests/commonjs/modules/exactExports/a.js +3 -0
- data/tests/commonjs/modules/exactExports/program.js +4 -0
- data/tests/commonjs/modules/exactExports/test.js +9 -0
- data/tests/commonjs/modules/hasOwnProperty/hasOwnProperty.js +0 -0
- data/tests/commonjs/modules/hasOwnProperty/program.js +3 -0
- data/tests/commonjs/modules/hasOwnProperty/test.js +9 -0
- data/tests/commonjs/modules/hasOwnProperty/toString.js +0 -0
- data/tests/commonjs/modules/method/a.js +12 -0
- data/tests/commonjs/modules/method/program.js +8 -0
- data/tests/commonjs/modules/method/test.js +9 -0
- data/tests/commonjs/modules/missing/program.js +8 -0
- data/tests/commonjs/modules/missing/test.js +9 -0
- data/tests/commonjs/modules/monkeys/a.js +1 -0
- data/tests/commonjs/modules/monkeys/program.js +4 -0
- data/tests/commonjs/modules/monkeys/test.js +9 -0
- data/tests/commonjs/modules/nested/a/b/c/d.js +3 -0
- data/tests/commonjs/modules/nested/program.js +3 -0
- data/tests/commonjs/modules/nested/test.js +9 -0
- data/tests/commonjs/modules/relative/program.js +5 -0
- data/tests/commonjs/modules/relative/submodule/a.js +1 -0
- data/tests/commonjs/modules/relative/submodule/b.js +2 -0
- data/tests/commonjs/modules/relative/test.js +9 -0
- data/tests/commonjs/modules/transitive/a.js +1 -0
- data/tests/commonjs/modules/transitive/b.js +1 -0
- data/tests/commonjs/modules/transitive/c.js +3 -0
- data/tests/commonjs/modules/transitive/program.js +3 -0
- data/tests/commonjs/modules/transitive/test.js +9 -0
- data/tests/file/all-tests.js +61 -0
- data/tests/file/fnmatch.js +102 -0
- data/tests/file/glob.js +466 -0
- data/tests/file/match.js +102 -0
- data/tests/global.js +6 -0
- data/tests/global/array.js +19 -0
- data/tests/hashes.js +94 -0
- data/tests/html.js +13 -0
- data/tests/io/stringio.js +21 -0
- data/tests/os/all-tests.js +4 -0
- data/tests/os/popen.js +41 -0
- data/tests/os/system.js +22 -0
- data/tests/printf.js +123 -0
- data/tests/query-string.js +87 -0
- data/tests/sandbox/byte-io.js +20 -0
- data/tests/sandbox/fileName.js +3 -0
- data/tests/sandbox/foo.js +0 -0
- data/tests/sandbox/reload.js +79 -0
- data/tests/string.js +35 -0
- data/tests/uri.js +41 -0
- data/tests/util/all-tests.js +79 -0
- data/tests/util/array.js +207 -0
- data/tests/util/array/is-arguments.js +29 -0
- data/tests/util/array/is-array-like.js +29 -0
- data/tests/util/case.js +9 -0
- data/tests/util/collection.js +104 -0
- data/tests/util/eq.js +57 -0
- data/tests/util/expand.js +45 -0
- data/tests/util/object.js +125 -0
- data/tests/util/operator.js +25 -0
- data/tests/util/range.js +19 -0
- data/tests/util/repr.js +26 -0
- data/tests/util/string.js +34 -0
- data/tests/util/unique.js +12 -0
- metadata +434 -0
data/lib/sha.js
ADDED
@@ -0,0 +1,112 @@
|
|
1
|
+
/*
|
2
|
+
|
3
|
+
A JavaScript implementation of the Secure Hash Algorithm, SHA-1, as defined
|
4
|
+
in FIPS PUB 180-1
|
5
|
+
Version 2.1a Copyright Paul Johnston 2000 - 2002.
|
6
|
+
Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet
|
7
|
+
Distributed under the BSD License
|
8
|
+
See http://pajhome.org.uk/crypt/md5 for details.
|
9
|
+
|
10
|
+
*/
|
11
|
+
var util = require('./util');
|
12
|
+
var struct = require('./struct');
|
13
|
+
|
14
|
+
/*** hash
|
15
|
+
*/
|
16
|
+
exports.hash = function (s, _characterSize) {
|
17
|
+
if (util.no(_characterSize)) _characterSize = struct.characterSize;
|
18
|
+
return struct.binb2bin(core_sha(struct.str2binb(s), s.length * _characterSize));
|
19
|
+
};
|
20
|
+
|
21
|
+
exports.hmac_sha = function (key, data, _characterSize) {
|
22
|
+
return struct.binb2bin(core_hmac_sha(key, data, _characterSize));
|
23
|
+
};
|
24
|
+
|
25
|
+
/* Perform a simple self-test to see if the VM is working */
|
26
|
+
exports.test = function () {
|
27
|
+
assert.eq("a9993e364706816aba3e25717850c26c9cd0d89d", exports.hash("abc").toString(16));
|
28
|
+
};
|
29
|
+
|
30
|
+
/* Calculate the SHA-1 of an array of big-endian words, and a bit length */
|
31
|
+
var core_sha = function (x, len) {
|
32
|
+
/* append padding */
|
33
|
+
x[len >> 5] |= 0x80 << (24 - len % 32);
|
34
|
+
x[((len + 64 >> 9) << 4) + 15] = len;
|
35
|
+
|
36
|
+
var w = [];
|
37
|
+
var a = 1732584193;
|
38
|
+
var b = -271733879;
|
39
|
+
var c = -1732584194;
|
40
|
+
var d = 271733878;
|
41
|
+
var e = -1009589776;
|
42
|
+
|
43
|
+
for(var i = 0; i < x.length; i += 16) {
|
44
|
+
var olda = a;
|
45
|
+
var oldb = b;
|
46
|
+
var oldc = c;
|
47
|
+
var oldd = d;
|
48
|
+
var olde = e;
|
49
|
+
|
50
|
+
for(var j = 0; j < 80; j++) {
|
51
|
+
if(j < 16) w[j] = x[i + j];
|
52
|
+
else w[j] = struct.rolU32(w[j-3] ^ w[j-8] ^ w[j-14] ^ w[j-16], 1);
|
53
|
+
var t = struct.addU32(struct.rolU32(a, 5), sha_ft(j, b, c, d), e, w[j], sha_kt(j));
|
54
|
+
e = d;
|
55
|
+
d = c;
|
56
|
+
c = struct.rolU32(b, 30);
|
57
|
+
b = a;
|
58
|
+
a = t;
|
59
|
+
}
|
60
|
+
|
61
|
+
a = struct.addU32(a, olda);
|
62
|
+
b = struct.addU32(b, oldb);
|
63
|
+
c = struct.addU32(c, oldc);
|
64
|
+
d = struct.addU32(d, oldd);
|
65
|
+
e = struct.addU32(e, olde);
|
66
|
+
}
|
67
|
+
return [a, b, c, d, e];
|
68
|
+
|
69
|
+
};
|
70
|
+
|
71
|
+
/*
|
72
|
+
* Perform the appropriate triplet combination function for the current
|
73
|
+
* iteration
|
74
|
+
*/
|
75
|
+
var sha_ft = function (t, b, c, d) {
|
76
|
+
if(t < 20) return (b & c) | ((~b) & d);
|
77
|
+
if(t < 40) return b ^ c ^ d;
|
78
|
+
if(t < 60) return (b & c) | (b & d) | (c & d);
|
79
|
+
return b ^ c ^ d;
|
80
|
+
};
|
81
|
+
|
82
|
+
/*
|
83
|
+
* Determine the appropriate additive constant for the current iteration
|
84
|
+
*/
|
85
|
+
var sha_kt = function (t) {
|
86
|
+
return (t < 20) ? 1518500249 : (t < 40) ? 1859775393 :
|
87
|
+
(t < 60) ? -1894007588 : -899497514;
|
88
|
+
};
|
89
|
+
|
90
|
+
/*
|
91
|
+
* Calculate the HMAC-SHA1 of a key and some data
|
92
|
+
*/
|
93
|
+
var core_hmac_sha = function (key, data, _characterSize) {
|
94
|
+
if (util.no(_characterSize)) _characterSize = struct.characterSize;
|
95
|
+
var bkey = struct.str2binb(key);
|
96
|
+
if(bkey.length > 16) bkey = core_sha(bkey, key.length * _characterSize);
|
97
|
+
|
98
|
+
var ipad = [], opad = [];
|
99
|
+
for(var i = 0; i < 16; i++) {
|
100
|
+
ipad[i] = bkey[i] ^ 0x36363636;
|
101
|
+
opad[i] = bkey[i] ^ 0x5C5C5C5C;
|
102
|
+
}
|
103
|
+
|
104
|
+
var hash = core_sha(ipad.concat(struct.str2binb(data)), 512 + data.length * _characterSize);
|
105
|
+
return core_sha(opad.concat(hash), 512 + 160);
|
106
|
+
};
|
107
|
+
|
108
|
+
if (module.id == require.main) {
|
109
|
+
var assert = require("./test/assert");
|
110
|
+
require("os").exit(require("test/runner").run(exports));
|
111
|
+
}
|
112
|
+
|
data/lib/sha256.js
ADDED
@@ -0,0 +1,102 @@
|
|
1
|
+
/*file chiron src/crypt/sha256.js */
|
2
|
+
|
3
|
+
var struct = require('./struct');
|
4
|
+
var util = require('./util');
|
5
|
+
|
6
|
+
/*** hash
|
7
|
+
*/
|
8
|
+
exports.hash = function (s, _characterSize) {
|
9
|
+
if (util.no(_characterSize)) _characterSize = struct.characterSize;
|
10
|
+
return struct.binb2bin(core(struct.str2binb(s, _characterSize), s.length * _characterSize));
|
11
|
+
};
|
12
|
+
|
13
|
+
var S = function (X, n) { return ( X >>> n ) | (X << (32 - n)); }
|
14
|
+
var R = function (X, n) { return ( X >>> n ); }
|
15
|
+
var Ch = function (x, y, z) { return ((x & y) ^ ((~x) & z)); }
|
16
|
+
var Maj = function (x, y, z) { return ((x & y) ^ (x & z) ^ (y & z)); }
|
17
|
+
var Sigma0256 = function (x) { return (S(x, 2) ^ S(x, 13) ^ S(x, 22)); }
|
18
|
+
var Sigma1256 = function (x) { return (S(x, 6) ^ S(x, 11) ^ S(x, 25)); }
|
19
|
+
var Gamma0256 = function (x) { return (S(x, 7) ^ S(x, 18) ^ R(x, 3)); }
|
20
|
+
var Gamma1256 = function (x) { return (S(x, 17) ^ S(x, 19) ^ R(x, 10)); }
|
21
|
+
|
22
|
+
var K = [
|
23
|
+
0x428A2F98, 0x71374491, 0xB5C0FBCF, 0xE9B5DBA5,
|
24
|
+
0x3956C25B, 0x59F111F1, 0x923F82A4, 0xAB1C5ED5,
|
25
|
+
0xD807AA98, 0x12835B01, 0x243185BE, 0x550C7DC3,
|
26
|
+
0x72BE5D74, 0x80DEB1FE, 0x9BDC06A7, 0xC19BF174,
|
27
|
+
0xE49B69C1, 0xEFBE4786, 0x0FC19DC6, 0x240CA1CC,
|
28
|
+
0x2DE92C6F, 0x4A7484AA, 0x5CB0A9DC, 0x76F988DA,
|
29
|
+
0x983E5152, 0xA831C66D, 0xB00327C8, 0xBF597FC7,
|
30
|
+
0xC6E00BF3, 0xD5A79147, 0x06CA6351, 0x14292967,
|
31
|
+
0x27B70A85, 0x2E1B2138, 0x4D2C6DFC, 0x53380D13,
|
32
|
+
0x650A7354, 0x766A0ABB, 0x81C2C92E, 0x92722C85,
|
33
|
+
0xA2BFE8A1, 0xA81A664B, 0xC24B8B70, 0xC76C51A3,
|
34
|
+
0xD192E819, 0xD6990624, 0xF40E3585, 0x106AA070,
|
35
|
+
0x19A4C116, 0x1E376C08, 0x2748774C, 0x34B0BCB5,
|
36
|
+
0x391C0CB3, 0x4ED8AA4A, 0x5B9CCA4F, 0x682E6FF3,
|
37
|
+
0x748F82EE, 0x78A5636F, 0x84C87814, 0x8CC70208,
|
38
|
+
0x90BEFFFA, 0xA4506CEB, 0xBEF9A3F7, 0xC67178F2
|
39
|
+
];
|
40
|
+
|
41
|
+
var core = function (m, l) {
|
42
|
+
var HASH = [
|
43
|
+
0x6A09E667, 0xBB67AE85, 0x3C6EF372, 0xA54FF53A,
|
44
|
+
0x510E527F, 0x9B05688C, 0x1F83D9AB, 0x5BE0CD19
|
45
|
+
];
|
46
|
+
|
47
|
+
var W = [];
|
48
|
+
var a, b, c, d, e, f, g, h, i, j;
|
49
|
+
var T1, T2;
|
50
|
+
|
51
|
+
m[l >> 5] |= 0x80 << (24 - l % 32);
|
52
|
+
m[((l + 64 >> 9) << 4) + 15] = l;
|
53
|
+
|
54
|
+
for ( i = 0; i<m.length; i+=16 ) {
|
55
|
+
a = HASH[0];
|
56
|
+
b = HASH[1];
|
57
|
+
c = HASH[2];
|
58
|
+
d = HASH[3];
|
59
|
+
e = HASH[4];
|
60
|
+
f = HASH[5];
|
61
|
+
g = HASH[6];
|
62
|
+
h = HASH[7];
|
63
|
+
|
64
|
+
for ( j = 0; j<64; j++) {
|
65
|
+
if (j < 16) W[j] = m[j + i];
|
66
|
+
else W[j] = struct.addU32(Gamma1256(W[j - 2]), W[j - 7], Gamma0256(W[j - 15]), W[j - 16]);
|
67
|
+
|
68
|
+
T1 = struct.addU32(h, Sigma1256(e), Ch(e, f, g), K[j], W[j]);
|
69
|
+
T2 = struct.addU32(Sigma0256(a), Maj(a, b, c));
|
70
|
+
|
71
|
+
h = g;
|
72
|
+
g = f;
|
73
|
+
f = e;
|
74
|
+
e = struct.addU32(d, T1);
|
75
|
+
d = c;
|
76
|
+
c = b;
|
77
|
+
b = a;
|
78
|
+
a = struct.addU32(T1, T2);
|
79
|
+
}
|
80
|
+
|
81
|
+
HASH[0] = struct.addU32(a, HASH[0]);
|
82
|
+
HASH[1] = struct.addU32(b, HASH[1]);
|
83
|
+
HASH[2] = struct.addU32(c, HASH[2]);
|
84
|
+
HASH[3] = struct.addU32(d, HASH[3]);
|
85
|
+
HASH[4] = struct.addU32(e, HASH[4]);
|
86
|
+
HASH[5] = struct.addU32(f, HASH[5]);
|
87
|
+
HASH[6] = struct.addU32(g, HASH[6]);
|
88
|
+
HASH[7] = struct.addU32(h, HASH[7]);
|
89
|
+
}
|
90
|
+
return HASH;
|
91
|
+
};
|
92
|
+
|
93
|
+
/**
|
94
|
+
|
95
|
+
References
|
96
|
+
==========
|
97
|
+
|
98
|
+
http://www.webtoolkit.info/
|
99
|
+
Secure Hash Algorithm (SHA256)
|
100
|
+
|
101
|
+
*/
|
102
|
+
|
data/lib/struct.js
ADDED
@@ -0,0 +1,228 @@
|
|
1
|
+
|
2
|
+
var util = require("util");
|
3
|
+
var binary = require("binary");
|
4
|
+
|
5
|
+
/*** alphabet16Upper
|
6
|
+
*/
|
7
|
+
exports.alphabet16Upper = "0123456789ABCDEF";
|
8
|
+
|
9
|
+
/*** alphabet16Lower
|
10
|
+
*/
|
11
|
+
exports.alphabet16Lower = "0123456789abcdef";
|
12
|
+
|
13
|
+
/*** alphabet16
|
14
|
+
``alphabet16Lower`` is the default hexadecimal alphabet.
|
15
|
+
This value can be overridden on the module
|
16
|
+
and function level.
|
17
|
+
*/
|
18
|
+
|
19
|
+
exports.alphabet16 = exports.alphabet16Lower;
|
20
|
+
|
21
|
+
/*** alphabet36
|
22
|
+
*/
|
23
|
+
exports.alphabet36 = "0123456789abcdefghijklmnopqrstuvwxyz";
|
24
|
+
|
25
|
+
/*** alphabet64
|
26
|
+
*/
|
27
|
+
exports.alphabet64 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
28
|
+
|
29
|
+
/*** padBase64
|
30
|
+
base-64 pad character. "=" for strict RFC compliance, "" for brevity
|
31
|
+
"=" by default.
|
32
|
+
This value can be overridden on the module
|
33
|
+
and function level.
|
34
|
+
*/
|
35
|
+
exports.padBase64 = "=";
|
36
|
+
|
37
|
+
/*** characterSize
|
38
|
+
bits per input character. 8 - ASCII; 16 - Unicode
|
39
|
+
This value can be overridden on the module
|
40
|
+
and function level.
|
41
|
+
*/
|
42
|
+
exports.characterSize = 8;
|
43
|
+
|
44
|
+
/*** ord
|
45
|
+
Returns the character code ordinal (offset in the ASCII or Unicode tables)
|
46
|
+
for a given single character.
|
47
|
+
|
48
|
+
- inverse: `chr`
|
49
|
+
|
50
|
+
*/
|
51
|
+
exports.ord = function (chr) {
|
52
|
+
return chr.charCodeAt();
|
53
|
+
};
|
54
|
+
|
55
|
+
/*** chr
|
56
|
+
Returns the character for a given character code ordinal (offset in the
|
57
|
+
ASCII or Unicode tables).
|
58
|
+
|
59
|
+
- inverse: `ord`
|
60
|
+
|
61
|
+
*/
|
62
|
+
exports.chr = function (ord) {
|
63
|
+
return String.fromCharCode(ord);
|
64
|
+
};
|
65
|
+
|
66
|
+
/* undocumented addU32
|
67
|
+
Add integers, wrapping at 2**32. This uses 16-bit operations internally
|
68
|
+
to work around bugs in some JavaScript interpreters.
|
69
|
+
|
70
|
+
- `variadic`
|
71
|
+
*/
|
72
|
+
exports.addU32 = function (/* ... */) {
|
73
|
+
var acc = 0;
|
74
|
+
for (var i = 0; i < arguments.length; i++) {
|
75
|
+
var x = arguments[i];
|
76
|
+
var lsw = (acc & 0xFFFF) + (x & 0xFFFF);
|
77
|
+
var msw = (acc >> 16) + (x >> 16) + (lsw >> 16);
|
78
|
+
acc = (msw << 16) | (lsw & 0xFFFF);
|
79
|
+
}
|
80
|
+
return acc;
|
81
|
+
};
|
82
|
+
|
83
|
+
/* undocumented rolU32
|
84
|
+
Bitwise rotate a 32-bit number to the left.
|
85
|
+
*/
|
86
|
+
exports.rolU32 = function (num, cnt) {
|
87
|
+
return (num << cnt) | (num >>> (32 - cnt));
|
88
|
+
};
|
89
|
+
|
90
|
+
/* undocumented str2binl
|
91
|
+
Convert a string to an array of little-endian words
|
92
|
+
If characterSize is ASCII, characters >255 have their hi-byte silently ignored.
|
93
|
+
*/
|
94
|
+
exports.str2binl = function (str, _characterSize) {
|
95
|
+
if (util.no(_characterSize))
|
96
|
+
_characterSize = exports.characterSize;
|
97
|
+
var bin = [];
|
98
|
+
var mask = (1 << _characterSize) - 1;
|
99
|
+
for (var i = 0; i < str.length * _characterSize; i += _characterSize)
|
100
|
+
bin[i>>5] |= (str.charCodeAt(i / _characterSize) & mask) << (i % 32);
|
101
|
+
return bin;
|
102
|
+
};
|
103
|
+
|
104
|
+
/* undocumented str2binb
|
105
|
+
Convert an 8-bit or 16-bit string to an array of big-endian words
|
106
|
+
In 8-bit function, characters >255 have their hi-byte silently ignored.
|
107
|
+
*/
|
108
|
+
exports.str2binb = function (str, _characterSize) {
|
109
|
+
if (util.no(_characterSize))
|
110
|
+
_characterSize = exports.characterSize;
|
111
|
+
var bin = [];
|
112
|
+
var mask = (1 << _characterSize) - 1;
|
113
|
+
for (var i = 0; i < str.length * _characterSize; i += _characterSize)
|
114
|
+
bin[i>>5] |= (
|
115
|
+
(str.charCodeAt(i / _characterSize) & mask) <<
|
116
|
+
(32 - _characterSize - i % 32)
|
117
|
+
);
|
118
|
+
return bin;
|
119
|
+
};
|
120
|
+
|
121
|
+
/* undocumented binl2str
|
122
|
+
Convert an array of little-endian words to a string
|
123
|
+
*/
|
124
|
+
exports.binl2str = function (bin, _characterSize) {
|
125
|
+
return exports.binl2bin(bin, _characterSize).decodeToString('ascii');
|
126
|
+
};
|
127
|
+
|
128
|
+
/* undocumented binl2bin
|
129
|
+
Convert an array of little-endian words to a string
|
130
|
+
*/
|
131
|
+
exports.binl2bin = function (bin, _characterSize) {
|
132
|
+
if (util.no(_characterSize))
|
133
|
+
_characterSize = exports.characterSize;
|
134
|
+
var str = [];
|
135
|
+
var mask = (1 << _characterSize) - 1;
|
136
|
+
for (var i = 0; i < bin.length * 32; i += _characterSize)
|
137
|
+
str.push((bin[i>>5] >>> (i % 32)) & mask);
|
138
|
+
return binary.ByteString(str);
|
139
|
+
};
|
140
|
+
|
141
|
+
/* undocumented binb2str
|
142
|
+
Convert an array of big-endian words to a string
|
143
|
+
*/
|
144
|
+
exports.binb2str = function (bin, _characterSize) {
|
145
|
+
return exports.binb2bin(bin, _characterSize).decodeToString('ascii');
|
146
|
+
};
|
147
|
+
|
148
|
+
/* undocumented binb2bin
|
149
|
+
Convert an array of big-endian words to a string
|
150
|
+
*/
|
151
|
+
exports.binb2bin = function (bin, _characterSize) {
|
152
|
+
if (util.no(_characterSize))
|
153
|
+
_characterSize = exports.characterSize;
|
154
|
+
var str = [];
|
155
|
+
var mask = (1 << _characterSize) - 1;
|
156
|
+
for (var i = 0; i < bin.length * 32; i += _characterSize)
|
157
|
+
str.push((bin[i>>5] >>> (32 - _characterSize - i % 32)) & mask);
|
158
|
+
return binary.ByteString(str);
|
159
|
+
};
|
160
|
+
|
161
|
+
/* undocumented binl2hex
|
162
|
+
Convert an array of little-endian words to a hex string.
|
163
|
+
*/
|
164
|
+
exports.binl2hex = function (binarray, _alphabet16) {
|
165
|
+
if (util.no(_alphabet16))
|
166
|
+
_alphabet16 = exports.alphabet16;
|
167
|
+
var str = "";
|
168
|
+
for (var i = 0; i < binarray.length * 4; i++) {
|
169
|
+
str += _alphabet16.charAt((binarray[i>>2] >> ((i % 4) * 8 + 4)) & 0xF) +
|
170
|
+
_alphabet16.charAt((binarray[i>>2] >> ((i % 4) * 8)) & 0xF);
|
171
|
+
}
|
172
|
+
return str;
|
173
|
+
};
|
174
|
+
|
175
|
+
/* undocumented binb2hex
|
176
|
+
Convert an array of big-endian words to a hex string.
|
177
|
+
*/
|
178
|
+
exports.binb2hex = function (binarray, _alphabet16) {
|
179
|
+
if (util.no(_alphabet16))
|
180
|
+
_alphabet16 = exports.alphabet16;
|
181
|
+
var str = "";
|
182
|
+
for (var i = 0; i < binarray.length * 4; i++) {
|
183
|
+
str += _alphabet16.charAt((binarray[i>>2] >> ((3 - i % 4)*8+4)) & 0xF) +
|
184
|
+
_alphabet16.charAt((binarray[i>>2] >> ((3 - i % 4) * 8)) & 0xF);
|
185
|
+
}
|
186
|
+
return str;
|
187
|
+
};
|
188
|
+
|
189
|
+
/* undocumented binl2base64
|
190
|
+
Convert an array of little-endian words to a base-64 string
|
191
|
+
*/
|
192
|
+
exports.binl2base64 = function (binarray) {
|
193
|
+
var str = "";
|
194
|
+
for (var i = 0; i < binarray.length * 4; i += 3) {
|
195
|
+
var triplet = (
|
196
|
+
(((binarray[i >> 2] >> 8 * (i % 4)) & 0xFF) << 16) |
|
197
|
+
(((binarray[i+1 >> 2] >> 8 * ((i+1)%4)) & 0xFF) << 8) |
|
198
|
+
((binarray[i+2 >> 2] >> 8 * ((i+2)%4)) & 0xFF)
|
199
|
+
);
|
200
|
+
for (var j = 0; j < 4; j++) {
|
201
|
+
if (i * 8 + j * 6 > binarray.length * 32)
|
202
|
+
str += exports.padBase64;
|
203
|
+
else str += exports.alphabet64.charAt((triplet >> 6*(3-j)) & 0x3F);
|
204
|
+
}
|
205
|
+
}
|
206
|
+
return str;
|
207
|
+
};
|
208
|
+
|
209
|
+
/* undocumented binb2base64
|
210
|
+
Convert an array of big-endian words to a base-64 string
|
211
|
+
*/
|
212
|
+
exports.binb2base64 = function (binarray) {
|
213
|
+
var str = "";
|
214
|
+
for (var i = 0; i < binarray.length * 4; i += 3) {
|
215
|
+
var triplet = (
|
216
|
+
(((binarray[i >> 2] >> 8 * (3 - i % 4)) & 0xFF) << 16) |
|
217
|
+
(((binarray[i+1 >> 2] >> 8 * (3 - (i+1)%4)) & 0xFF) << 8 ) |
|
218
|
+
((binarray[i+2 >> 2] >> 8 * (3 - (i+2)%4)) & 0xFF)
|
219
|
+
);
|
220
|
+
for (var j = 0; j < 4; j++) {
|
221
|
+
if (i * 8 + j * 6 > binarray.length * 32)
|
222
|
+
str += exports.padBase64;
|
223
|
+
else str += exports.alphabet64.charAt((triplet >> 6*(3-j)) & 0x3F);
|
224
|
+
}
|
225
|
+
}
|
226
|
+
return str;
|
227
|
+
};
|
228
|
+
|
data/lib/term.js
ADDED
@@ -0,0 +1,179 @@
|
|
1
|
+
|
2
|
+
// reference: http://ascii-table.com/ansi-escape-sequences-vt-100.php
|
3
|
+
|
4
|
+
var system = require('system');
|
5
|
+
var util = require('util');
|
6
|
+
|
7
|
+
var terms = [
|
8
|
+
'ansi',
|
9
|
+
'vt100',
|
10
|
+
'xterm',
|
11
|
+
'xtermc',
|
12
|
+
'xterm-color',
|
13
|
+
'gnome-terminal'
|
14
|
+
];
|
15
|
+
|
16
|
+
exports.Stream = function (system) {
|
17
|
+
var self = Object.create(system.stdout);
|
18
|
+
var output = system.stdout;
|
19
|
+
var errput = system.stderr;
|
20
|
+
var env = system.env || {};
|
21
|
+
var fore = "";
|
22
|
+
var back = "";
|
23
|
+
var bold = "0";
|
24
|
+
var stack = [];
|
25
|
+
var enabled = util.has(terms, env.TERM);
|
26
|
+
|
27
|
+
self.enable = function () {
|
28
|
+
enabled = true;
|
29
|
+
};
|
30
|
+
|
31
|
+
self.disable = function () {
|
32
|
+
enabled = false;
|
33
|
+
};
|
34
|
+
|
35
|
+
self.writeCode = function (code) {
|
36
|
+
if (enabled) {
|
37
|
+
output.flush();
|
38
|
+
errput.write(code).flush();
|
39
|
+
}
|
40
|
+
return self;
|
41
|
+
};
|
42
|
+
|
43
|
+
self.print = function () {
|
44
|
+
// todo recordSeparator, fieldSeparator
|
45
|
+
self.write(Array.prototype.join.call(arguments, " ") + "\n");
|
46
|
+
self.flush();
|
47
|
+
return self;
|
48
|
+
};
|
49
|
+
|
50
|
+
self.write = function (string) {
|
51
|
+
var at = 0;
|
52
|
+
self.update(bold, fore, back);
|
53
|
+
while (at < string.length) {
|
54
|
+
var pos = string.indexOf("\0", at);
|
55
|
+
if (pos == -1) {
|
56
|
+
// no additional marks, advanced to end
|
57
|
+
output.write(string.substring(at, string.length));
|
58
|
+
at = string.length;
|
59
|
+
} else {
|
60
|
+
output.write(string.substring(at, pos));
|
61
|
+
at = pos + 1;
|
62
|
+
if (string.charAt(at) == ")") {
|
63
|
+
if (!stack.length)
|
64
|
+
throw new Error("No colors on the stack at " + at);
|
65
|
+
var pair = stack.pop();
|
66
|
+
bold = pair[0];
|
67
|
+
fore = pair[1];
|
68
|
+
at = at + 1;
|
69
|
+
self.update(bold, fore, back);
|
70
|
+
} else {
|
71
|
+
var paren = string.indexOf("(", at);
|
72
|
+
stack.push([bold, fore, back]);
|
73
|
+
var command = string.substring(at, paren);
|
74
|
+
if (command == "bold") {
|
75
|
+
bold = "1";
|
76
|
+
} else if (Object.prototype.hasOwnProperty.call(exports.colors, command)) {
|
77
|
+
fore = exports.colors[command];
|
78
|
+
} else if (
|
79
|
+
/^:/.test(command) &&
|
80
|
+
Object.prototype.hasOwnProperty.call(exports.colors, command.substring(1))
|
81
|
+
) {
|
82
|
+
back = exports.colors[command.substring(1)];
|
83
|
+
} else {
|
84
|
+
throw new Error("No such command: " + command);
|
85
|
+
}
|
86
|
+
self.update(bold, fore, back);
|
87
|
+
at = paren + 1;
|
88
|
+
}
|
89
|
+
}
|
90
|
+
}
|
91
|
+
self.update("0", "", "");
|
92
|
+
return self;
|
93
|
+
};
|
94
|
+
|
95
|
+
self.update = function (bold, fore, back) {
|
96
|
+
return self.writeCode(
|
97
|
+
"\033[" + [
|
98
|
+
bold,
|
99
|
+
(fore.length ? "3" + fore : ""),
|
100
|
+
(back.length ? "4" + back : ""),
|
101
|
+
].filter(function (string) {
|
102
|
+
return string.length;
|
103
|
+
}).join(";") + "m"
|
104
|
+
);
|
105
|
+
};
|
106
|
+
|
107
|
+
self.moveTo = function (y, x) {
|
108
|
+
return self.writeCode("\033[" + y + ";" + x + "H");
|
109
|
+
};
|
110
|
+
|
111
|
+
self.moveBy = function (y, x) {
|
112
|
+
if (y == 0) {
|
113
|
+
} else if (y < 0) {
|
114
|
+
self.writeCode("\033[" + (-y) + "A");
|
115
|
+
} else {
|
116
|
+
self.writeCode("\033[" + y + "B");
|
117
|
+
}
|
118
|
+
if (x == 0) {
|
119
|
+
} else if (x > 0) {
|
120
|
+
self.writeCode("\033[" + x + "C");
|
121
|
+
} else {
|
122
|
+
self.writeCode("\033[" + (-x) + "D");
|
123
|
+
}
|
124
|
+
errput.flush();
|
125
|
+
return self;
|
126
|
+
};
|
127
|
+
|
128
|
+
self.home = function () {
|
129
|
+
return self.writeCode("\033[H");
|
130
|
+
};
|
131
|
+
|
132
|
+
self.clear = function () {
|
133
|
+
return self.writeCode("\033[2J");
|
134
|
+
};
|
135
|
+
self.clearUp = function () {
|
136
|
+
return self.writeCode("\033[1J");
|
137
|
+
};
|
138
|
+
self.cearDown = function () {
|
139
|
+
return self.writeCode("\033[J");
|
140
|
+
};
|
141
|
+
self.clearLine = function () {
|
142
|
+
return self.writeCode("\033[2K");
|
143
|
+
};
|
144
|
+
self.clearLeft = function () {
|
145
|
+
return self.writeCode("\033[1K");
|
146
|
+
};
|
147
|
+
self.clearRight = function () {
|
148
|
+
return self.writeCode("\033[K");
|
149
|
+
};
|
150
|
+
|
151
|
+
self.update(bold, fore, back);
|
152
|
+
|
153
|
+
return self;
|
154
|
+
};
|
155
|
+
|
156
|
+
exports.colors = {
|
157
|
+
"black": "0",
|
158
|
+
"red": "1",
|
159
|
+
"green": "2",
|
160
|
+
"orange": "3",
|
161
|
+
"yellow": "3",
|
162
|
+
"blue": "4",
|
163
|
+
"violet": "5",
|
164
|
+
"magenta": "5",
|
165
|
+
"purple": "5",
|
166
|
+
"cyan": "6",
|
167
|
+
"white": "7"
|
168
|
+
}
|
169
|
+
|
170
|
+
exports.stream = new exports.Stream(system);
|
171
|
+
|
172
|
+
if (module.id == require.main) {
|
173
|
+
exports.stream.print("white\0red(red\0blue(blue\0)red\0)white");
|
174
|
+
Object.keys(exports.colors).forEach(function (name) {
|
175
|
+
exports.stream.print("\0" + name + "(" + name + "\0)");
|
176
|
+
exports.stream.print("\0bold(\0" + name + "(" + name + "\0)\0)");
|
177
|
+
});
|
178
|
+
}
|
179
|
+
|